我对Docker很陌生,并用它来进入我的第一个真实项目。我们有一个使用Codeigniter和PostgreSQL的php应用程序,效果很好。现在我试图将它停靠,我用pdo_pgsql驱动程序遇到了一些麻烦。
我在网上找到一些帮助来安装pdo_pgsql驱动程序,但是这是php-5x的所有过时解决方案。我似乎工作,因为我检查了phpinfo页面,我的php.ini正确加载,并说pdo_pgsql和pgsql驱动程序都安装和活动????
以下是错误:
奇怪的是,当我第一次点击页面时,我只收到第一个错误。然后,如果我刷新页面,则会出现第二个错误。
当我登录容器并cd
到它所说文件不存在的目录时,我可以清楚地看到pdo.so
,pdo_pgsql.so
和pgsql.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:以上所有内容都是匿名的,为了便于阅读而精简
答案 0 :(得分:1)
哦,当我想通了。所以我上面所做的一切都有效。 Docker缓存的方式发生了一些奇怪的事情。我猜我没有正确更新图像。我只是删除了所有容器和图像,然后重建并运行它,它只是神奇地工作。在此过程中,某些目录和文件也存在一些权限问题。
希望上面的剪辑可以帮助某人,没有很多关于docker php-apache图片的文档和pdo_pgsql。