
我是新來的,這是我的第一個問題,所以請告訴我我的表達方式是否有問題。
所以問題是:我正在建立一個 LAMP 堆疊,其中包含 3 個獨立的容器,分別用於 nginx、maiadb 和 wordpress。
整個 nginx 和 php-fpm 似乎運作良好,因為我可以訪問網站的索引並處理 php 頁面。 Mdb 建立 wordpress 資料庫並建立一個具有所有權限的「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,以確保 db 確實在監聽來自每個IP。
我認為問題來自 wp-config.php ,但正如我在 docker-compose 環境中所理解的,你可以用他的名字而不是 ip 來引用每個容器,而且我不知道如何從 wordpress 檢索 mariadb 的 IP - php。
請幫幫我,提前感謝所有讀過這篇文章的人! ^^