Docker PHP与pdo_pgsql安装问题

时间:2017-12-02 00:42:39

标签: php postgresql codeigniter docker

我对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:以上所有内容都是匿名的,为了便于阅读而精简

1 个答案:

答案 0 :(得分:1)

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

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