繁体   English   中英

Docker PHP与pdo_pgsql安装问题

[英]Docker PHP with pdo_pgsql install issue

我是Docker的新手,用它来进入我的第一个真正的项目。 我们有一个使用Codeigniter和PostgreSQL的php应用程序,效果很好。 现在我正在尝试将它停靠,我遇到了一些pdo_pgsql驱动程序的麻烦。

我在网上找到一些帮助来安装pdo_pgsql驱动程序,但是这是php-5x的所有过时解决方案。 我似乎工作,因为我检查了phpinfo页面,我的php.ini正确加载,并说pdo_pgsql和pgsql驱动程序都安装和活动????

这是错误:

奇怪的是,当我第一次点击页面时,我只得到第一个错误。 然后,如果我刷新页面,则会出现第二个错误。

当我登录容器并cd到它所说文件不存在的目录时,我可以清楚地看到pdo.sopdo_pgsql.sopgsql.so

遇到了错误

您已在config / database.php文件中指定了无效的数据库连接组(dockerize)。

遇到PHP错误

严重性:核心警告

消息:PHP启动:无法加载动态库'/ usr / local / lib / php / extensions / no-debug-non-zts-20160303 / pgsql' - / usr / local / lib / php / extensions / no-debug- non-zts-20160303 / pgsql:无法打开共享对象文件:没有这样的文件或目录

文件名:未知

这是Dockerfile

# Dockerfile
FROM php:7.1.12-apache

MAINTAINER Me <me@myself.com>

COPY deploy/config/php.ini /usr/local/etc/php/
COPY target/myapp.tar.gz /var/www/html

RUN apt-get update

# Install Postgre PDO
RUN apt-get install -y libpq-dev \
    && docker-php-ext-configure pgsql -with-pgsql=/usr/local/pgsql \
    && docker-php-ext-install pdo pdo_pgsql pgsql

RUN tar -xzf /var/www/html/myapp.tar.gz \
    && cd /var/www/html \
    && rm -f myapp.tar.gz \
    && OLD_URL='http://localhost:8080' \
    && NEW_URL='http://dockerhost:8080' \
    && sed -i -e "s#$OLD_URL#$NEW_URL#" "/var/www/html/application/config/config.php"

EXPOSE 80
EXPOSE 443

这是我docker-compose.yml

version: "3"
services:
  app:
    image: me/myapp:v1
    build: .
    ports:
      - "8080:80"
      - "8043:443"
  postgres:
    image: postgres:9.6.6
    ports:
      - "5432:5432"

这是我的Codeigniter database.php

这尝试连接到另一个容器中的Postgres,该容器应该由docker-compose提供,并使用上面的yml。 我读了一些地方说我只是使用postgres作为连接的主机,因为docker-compose.yml文件有一个名为postgres的服务。 这对我来说听起来有点可疑,这看起来不错吗?

$active_group = "dockerize";
$query_builder = TRUE;
$db['dockerize'] = array(
        'dsn'       => 'pgsql:host=postgres;port=5432;dbname=mydb;user=postgres;password=postgres',
        'hostname' => 'postgres',
        'username' => 'postgres',
        'password' => 'postgres',
        'database' => 'mydb',
        'dbdriver' => 'pdo',
        'dbprefix' => '',
        'pconnect' => FALSE,
        'db_debug' => (ENVIRONMENT !== 'production'),
        'cache_on' => FALSE,
        'cachedir' => '',
        'char_set' => 'utf8',
        'dbcollat' => 'utf8_general_ci',
        'swap_pre' => '',
        'encrypt'  => FALSE,
        'compress' => FALSE,
        'stricton' => FALSE,
        'failover' => array(),
        'save_queries' => TRUE
);

fyi:以上所有内容都是匿名的,并且为了便于阅读而精简

哦,当我想通了。 所以我上面所做的一切都有效。 Docker缓存的方式发生了一些奇怪的事情。 我猜我没有正确更新图像。 我只是删除了所有容器和图像,然后重建并运行它,它只是神奇地工作。 在此过程中,某些目录和文件也存在一些权限问题。

希望上面的剪辑可以帮助某人,没有很多关于docker php-apache图片的文档与pdo_pgsql。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM