gpt4 book ai didi

php - 如何使用 Docker 连接 php-apache 和 MySQL?

转载 作者:行者123 更新时间:2023-11-29 09:27:13 26 4
gpt4 key购买 nike

我在实时服务器上有一个 Wordpress 站点,我想使用 Docker 在本地创建一个 LAMP 堆栈来测试。

我拉取了 php:7.0-apachemysql:5.7 的镜像,与 live 上的版本相同。

我创建了一个 MySQL 容器:

docker run -d --name achi-mysql -e MYSQL_ROOT_PASSWORD=123456 mysql:5.7

我创建了一个 php 和 apache 容器并将其与 MySQL 链接:

docker run -d --name achi-php-apache --link achi-mysql:mysql -p 8080:80 -v /home/achi/workspace/web/wordpress-template/:/var/www/html php:7.0-apache

我在 localhost:8080 上收到以下错误:

fatal error :未捕获错误:调用/var/www/html/wp-includes/wp-db.php:1564 [...] 中未定义的函数 mysql_connect()

我是否以错误的方式链接了这两个容器?<​​/p>

最佳答案

您的问题不在于容器之间的连接。问题是您的 PHP/Apache 容器不支持 mysqli (或 PDO MySQL )。 WordPress 无法找到其他功能来连接 MySQL 数据库或您的 MySQL 容器。相反,WordPress 默认使用 deprecated and removed (since PHP 7.0) mysql_ function。您至少需要在 PHP 容器上安装 mysqli(如下所述)。

我还建议使用 docker-compose 文件通过一个命令安装和运行所有容器。

要创建您想要的容器,您可以使用以下 docker-compose.yml file :

version: "3"

services:
achi-php-apache:
build:
context: ./
container_name: achi-php-apache
ports:
- "8080:80"
volumes:
- /home/achi/workspace/web/wordpress-template:/var/www/html:rw
depends_on:
- achi-mysql
networks:
- wp-net
achi-mysql:
image: mysql:5.7
container_name: achi-mysql
ports:
- "3306:3306"
environment:
MYSQL_ROOT_PASSWORD: 123456
MYSQL_DATABASE: wp-dbname
volumes:
- wp-mysql-data:/var/lib/mysql
networks:
- wp-net

networks:
wp-net:
driver: bridge

volumes:
wp-mysql-data:

您需要将以下 Dockerfile 放在与 docker-compose.yml 文件相同的目录中:

FROM php:7.0-apache

RUN docker-php-ext-install -j$(nproc) mysqli

Dockerfile 安装缺少的 mysqli 扩展,以便 WordPress 可以使用它。

您也可以使用 PDO MySQL 代替 mysqli 。在这种情况下,您可以使用以下 Dockerfile:

FROM php:7.0-apache

RUN docker-php-ext-install -j$(nproc) pdo
RUN docker-php-ext-install -j$(nproc) pdo_mysql

现在你可以在docker-compose up文件所在的文件夹中执行命令docker-compose.yml。创建容器并运行后,您应该能够访问 WordPress 站点 ( <ip-or-hostname>:8080 )。

wp-config.php 文件中,您需要使用以下常量:

define('DB_NAME', 'wp-dbname');
define('DB_USER', 'root');
define('DB_PASSWORD', '123456');
define('DB_HOST', 'achi-mysql');

您还可以使用 official WordPress image 安装 WordPress。在这种情况下,您可以使用以下 docker-compose.yml 文件:

version: "3"

services:
achi-php-apache:
image: wordpress:4.9.4-php7.0-apache
container_name: achi-php-apache
ports:
- "8080:80"
environment:
WORDPRESS_DB_HOST: achi-mysql
WORDPRESS_DB_USER: root
WORDPRESS_DB_PASSWORD: 123456
WORDPRESS_DB_NAME: wp-dbname
volumes:
- /home/achi/workspace/web/wordpress-template:/var/www/html:rw
depends_on:
- achi-mysql
networks:
- wp-net
achi-mysql:
image: mysql:5.7
container_name: achi-mysql
ports:
- "3306:3306"
environment:
MYSQL_ROOT_PASSWORD: 123456
MYSQL_DATABASE: wp-dbname
volumes:
- wp-mysql-data:/var/lib/mysql
networks:
- wp-net

networks:
wp-net:
driver: bridge

volumes:
wp-mysql-data:

关于php - 如何使用 Docker 连接 php-apache 和 MySQL?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49254178/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com