我是新来的,这是我的第一个问题,如果我的表达方式有什么问题,请告诉我。
问题是这样的:我正在构建一个 LAMP 堆栈,其中包含 3 个独立的容器,分别用于 nginx、maiadb 和 wordpress。
整个 nginx 和 php-fpm 似乎运行良好,因为我可以访问站点的索引并处理 php 页面。Mdb 构建 wordpress db 并创建一个对其具有所有权限的“wordpress@wordpress-php”用户。
当我访问网站进行安装时,它开始出错,我被卡住了:“建立数据库连接时出错”
这是我的 wp-config.php,我将其复制到容器内的 wordpress 目录中:
<?php
4 define( 'DB_NAME', 'wordpress' );
7 define( 'DB_USER', 'wordpress' );
10 define( 'DB_PASSWORD', 'wordpress' );
15 define( 'DB_HOST', 'mariadb' );
16 define( 'DB_CHARSET', 'utf8' );
17
19 define( 'DB_COLLATE', '' );
20 define('AUTHOR', 'yotillar');
21
22 // Authentication unique keys and salts.
23 define( 'AUTH_KEY', 'key' );
24 define( 'SECURE_AUTH_KEY', 'key' );
25 define( 'LOGGED_IN_KEY', 'key' );
26 define( 'NONCE_KEY', 'key' );
27 define( 'AUTH_SALT', 'salt' );
28 define( 'SECURE_AUTH_SALT', 'salt' );
29 define( 'LOGGED_IN_SALT', 'salt' );
30 define( 'NONCE_SALT', 'salt' );
31
38 $table_prefix = 'wp_';
51 define( 'WP_DEBUG', true );
52 define( 'WP_DEBUG_LOG', true );
53 define( 'WP_DEBUG_DISPLAY', false );
59 if ( ! defined( 'ABSPATH' ) ) {
60 »···define( 'ABSPATH', __DIR__ . '/' );
61 }
64 require_once ABSPATH . 'wp-settings.php';
65 ?>
这是我的docker-compose.yaml:
version: "3.5"
2
3 networks:
4 front-network:
5 driver: bridge
6 attachable: false
7 back-network:
8 driver: bridge
9 attachable: false
10
11 volumes:
12 mdb-data:
13 wordpress:
14
15 services:
16
17 nginx:
18 depends_on:
19 - wordpress-php
20 build: "./services/nginx"
21 image: nginx:mytag
22 volumes:
23 - wordpress:/var/www/myserver/wordpress:rw
24 - "../logs/nginx_logs:/var/log/nginx:rw"
25 restart: on-failure
26 ports:
27 - "80:80"
28 - "443:443"
29 expose:
30 - 9000
31 networks:
32 - front-network
33
34
35 wordpress-php:
36 depends_on:
37 - mariadb
38 build: "./services/wordpress"
39 image: wordpress-php:mytag
40 volumes:
41 - wordpress:/var/www/myserver/wordpress:rw
42 - "../logs/php7.3-fpm.log:/var/log/php7.3-fpm.log:rw"
43 restart: on-failure
44 environment:
45 - WORDPRESS_DB_HOST=mariadb:3306
46 - WORDPRESS_DB_NAME=wordpress
45 - WORDPRESS_DB_USER=wordpress
48 - WORDPRESS_DB_PASSWORD=wordpress
50 expose:
51 - 3306
52 - 9000
53 networks:
54 - front-network
55 - back-network
56
57
58 mariadb:
59 build: "./services/mariadb"
60 image: mariadb:mytag
61 volumes:
62 - mdb-data:/var/lib/mysql:rw
63 - "../logs/mariadb_logs/error.log:/var/log/mysql/error.log"
64 restart: on-failure
65 environment:
66 - MYSQL_DATABASE=wordpress
67 - MYSQL_USER=wordpress
68 - MYSQL_USER_PASSWORD=wordpress
69 - MYSQL_ROOT_PASSWORD=root
70 expose:
71 - 3306
72 networks:
73 - back-network
74
我在 ./etc/mysql/mariadb.conf.d/50-se rver.cnf 和 ./etc/mysql/my.cnf 中将 mariadb 的绑定地址设置为 0.0.0.0,以确保数据库确实在监听每个 ip。
我认为问题出在 wp-config.php ,但据我所知,在 docker-compose 环境中,您可以使用其名称而不是 ip 来引用每个容器,并且我不知道如何从 wordpress-php 检索 mariadb 的 IP。
请帮助我,提前感谢读到这里的所有人!^^