![MaxScale が Galera Cluster に接続しない](https://rvso.com/image/789292/MaxScale%20%E3%81%8C%20Galera%20Cluster%20%E3%81%AB%E6%8E%A5%E7%B6%9A%E3%81%97%E3%81%AA%E3%81%84.png)
私は分散 HA クラウド システムに取り組んでおり、Galera Cluster
に 3 つの独立したサーバーがありますDocker Swarm
。 は期待どおりに動作します。
Galera
ブートストラップのため、メンバーには 3 つの別々のサービスがあります(単純なレプリカでは解決できません)。このため、クラスターを使用するには、レプリケートされたロード バランサー/プロキシが必要です (Swarm
接続文字列で使用される 3 つのレプリカを持つ 1 つのサービス)。
デザインは次のようになります。
サービスをセットアップしようとしましたMaxScale
が、maxctrl list servers
コマンド (実行中のコンテナ内) には次のように表示されます:
Error: Could not connect to MaxScale
システムを起動するために使用したコマンド:
docker-compose up --remove-orphans --force-recreate
Galera Cluster
をテストMaxScale
するための最小限のセットアップを作成しましたlocalhost
(テスト用の単一ノード構造のみ。実際の製品には 3 つのマネージャー ノードと 3 つの DB ノードがあります)。問題を再現できるシステムを以下で参照してください。
私のdocker-compose.yml
ファイル:
version: "3.8"
services:
galera0:
image: bitnami/mariadb-galera:10.4.31
hostname: galera0
networks:
- galera_net
volumes:
- ./my.cnf:/opt/bitnami/mariadb/conf/my_custom.cnf:ro
- ./init_db_for_maxscale.sql:/docker-entrypoint-initdb.d/init_db_for_maxscale.sql
environment:
MARIADB_GALERA_CLUSTER_NAME: my_galera
MARIADB_GALERA_MARIABACKUP_USER: my_mariabackup_user
MARIADB_GALERA_MARIABACKUP_PASSWORD: my_mariabackup_password
MARIADB_ROOT_PASSWORD: my_root_password
MARIADB_GALERA_CLUSTER_BOOTSTRAP: "yes"
MARIADB_GALERA_FORCE_SAFETOBOOTSTRAP: "yes"
MARIADB_USER: my_user
MARIADB_PASSWORD: my_password
MARIADB_DATABASE: my_database
MARIADB_REPLICATION_USER: my_replication_user
MARIADB_REPLICATION_PASSWORD: my_replication_password
healthcheck:
test: ['CMD', '/opt/bitnami/scripts/mariadb-galera/healthcheck.sh']
interval: 15s
timeout: 5s
retries: 10
galera1:
image: bitnami/mariadb-galera:10.4.31
hostname: galera1
networks:
- galera_net
volumes:
- ./my.cnf:/opt/bitnami/mariadb/conf/my_custom.cnf:ro
- ./init_db_for_maxscale.sql:/docker-entrypoint-initdb.d/init_db_for_maxscale.sql
environment:
MARIADB_GALERA_CLUSTER_NAME: my_galera
MARIADB_GALERA_CLUSTER_ADDRESS: gcomm://galera0:4567,0:0:0:0:4567
MARIADB_GALERA_MARIABACKUP_USER: my_mariabackup_user
MARIADB_GALERA_MARIABACKUP_PASSWORD: my_mariabackup_password
MARIADB_ROOT_PASSWORD: my_root_password
MARIADB_REPLICATION_USER: my_replication_user
MARIADB_REPLICATION_PASSWORD: my_replication_password
MARIADB_INIT_SLEEP_TIME: 30
healthcheck:
test: [ 'CMD', '/opt/bitnami/scripts/mariadb-galera/healthcheck.sh' ]
interval: 15s
timeout: 5s
retries: 10
depends_on:
galera0:
condition: service_healthy
galera2:
image: bitnami/mariadb-galera:10.4.31
hostname: galera2
networks:
- galera_net
volumes:
- ./my.cnf:/opt/bitnami/mariadb/conf/my_custom.cnf:ro
- ./init_db_for_maxscale.sql:/docker-entrypoint-initdb.d/init_db_for_maxscale.sql
environment:
MARIADB_GALERA_CLUSTER_NAME: my_galera
MARIADB_GALERA_CLUSTER_ADDRESS: gcomm://galera0:4567,0:0:0:0:4567
MARIADB_GALERA_MARIABACKUP_USER: my_mariabackup_user
MARIADB_GALERA_MARIABACKUP_PASSWORD: my_mariabackup_password
MARIADB_ROOT_PASSWORD: my_root_password
MARIADB_REPLICATION_USER: my_replication_user
MARIADB_REPLICATION_PASSWORD: my_replication_password
MARIADB_INIT_SLEEP_TIME: 30
healthcheck:
test: [ 'CMD', '/opt/bitnami/scripts/mariadb-galera/healthcheck.sh' ]
interval: 15s
timeout: 5s
retries: 10
depends_on:
galera0:
condition: service_healthy
mariadb-maxscale:
image: mariadb/maxscale:23.08
hostname: mariadb-maxscale
networks:
- galera_net
volumes:
- ./maxscale.cnf:/etc/maxscale.cnf
depends_on:
galera0:
condition: service_healthy
galera1:
condition: service_healthy
galera2:
condition: service_healthy
networks:
galera_net: {}
maxscale.cfn
コンテンツ:
########################
## Server list
########################
[mariadb1]
type = server
address = galera0
port = 3306
protocol = MariaDBBackend
serv_weight = 1
[mariadb2]
type = server
address = galera1
port = 3306
protocol = MariaDBBackend
serv_weight = 1
[mariadb3]
type = server
address = galera2
port = 3306
protocol = MariaDBBackend
serv_weight = 1
#########################
## MaxScale configuration
#########################
[MaxScale]
threads = auto
log_augmentation = 1
ms_timestamp = 1
syslog = 1
# log_debug = 1
#########################
# Monitor for the servers
#########################
[MariaDB-Monitor]
type = monitor
module = mariadbmon
servers = mariadb1,mariadb2,mariadb3
user = maxscale
password = my_s3cret
# auto_failover = true
# auto_rejoin = true
# enforce_read_only_slaves = 1
monitor_interval = 2000
#########################
## Service definitions for read/write splitting and read-only services.
#########################
[Read-Write-Service]
type = service
router = readwritesplit
servers = mariadb1,mariadb2,mariadb3
user = maxscale
password = my_s3cret
# max_slave_connections = 100%
# max_sescmd_history = 1500
# causal_reads = true
# causal_reads_timeout = 10
# transaction_replay = true
# transaction_replay_max_size = 1Mi
# delayed_retry = true
# master_reconnection = true
# master_failure_mode = fail_on_write
# max_slave_replication_lag = 3
[Read-Only-Service]
type = service
router = readconnroute
servers = mariadb1,mariadb2,mariadb3
router_options = slave
user = maxscale
password = my_s3cret
##########################
## Listener definitions for the service
## Listeners represent the ports the service will listen on.
##########################
[Read-Write-Listener]
type = listener
service = Read-Write-Service
protocol = MariaDBClient
port = 4006
[Read-Only-Listener]
type = listener
service = Read-Only-Service
protocol = MariaDBClient
port = 4008
init_db_for_maxscale.sql
コンテンツ:
CREATE USER IF NOT EXISTS 'maxscale'@'%' IDENTIFIED BY 'my_s3cret';
GRANT SELECT ON mysql.user TO 'maxscale'@'%';
GRANT SELECT ON mysql.db TO 'maxscale'@'%';
GRANT SELECT ON mysql.tables_priv TO 'maxscale'@'%';
GRANT SELECT ON mysql.columns_priv TO 'maxscale'@'%';
GRANT SELECT ON mysql.procs_priv TO 'maxscale'@'%';
GRANT SELECT ON mysql.proxies_priv TO 'maxscale'@'%';
GRANT SELECT ON mysql.roles_mapping TO 'maxscale'@'%';
GRANT SHOW DATABASES ON *.* TO 'maxscale'@'%';
GRANT ALL PRIVILEGES ON *.* TO maxscale@'%';
すべてのMariaDB
コンテナをチェックしたところ、作成されたユーザーは使用可能であり、権限は DB に設定されています ( に基づくselect * from mysql. user;
)。
docker container logs <maxscale_continer>
コマンド出力(無限に繰り返されます):
mariadb-maxscale_1 | Starting...
mariadb-maxscale_1 | MaxScale PID = 1698
mariadb-maxscale_1 |
mariadb-maxscale_1 | Awakened by User defined signal 1
mariadb-maxscale_1 | 'maxscale' monitor action done
mariadb-maxscale_1 | 'maxscale' process is not running
mariadb-maxscale_1 | 'maxscale' trying to restart
mariadb-maxscale_1 | 'maxscale' start: '/usr/bin/maxscale-restart'
mariadb-maxscale_1 | 'mariadb-maxscale' unmonitor on user request
mariadb-maxscale_1 | 'maxscale' unmonitor on user request
mariadb-maxscale_1 | Monit daemon with PID 12 awakened
mariadb-maxscale_1 | 'mariadb-maxscale' monitor on user request
mariadb-maxscale_1 | 'maxscale' monitor on user request
mariadb-maxscale_1 | Monit daemon with PID 12 awakened
mariadb-maxscale_1 | 'mariadb-maxscale' monitor action done
mariadb-maxscale_1 | Awakened by User defined signal 1
mariadb-maxscale_1 | 'maxscale' failed to start (exit status 0) -- '/usr/bin/maxscale-restart': Stopping...
mariadb-maxscale_1 | Starting...
mariadb-maxscale_1 | MaxScale PID = 1713
mariadb-maxscale_1 |
mariadb-maxscale_1 | 'maxscale' monitor action done
mariadb-maxscale_1 | 'maxscale' trying to restart
mariadb-maxscale_1 | 'maxscale' process is not running
mariadb-maxscale_1 | 'maxscale' start: '/usr/bin/maxscale-restart'
mariadb-maxscale_1 | 'mariadb-maxscale' unmonitor on user request
mariadb-maxscale_1 | 'maxscale' unmonitor on user request
mariadb-maxscale_1 | Monit daemon with PID 12 awakened
mariadb-maxscale_1 | 'mariadb-maxscale' monitor on user request
mariadb-maxscale_1 | 'maxscale' monitor on user request
mariadb-maxscale_1 | Monit daemon with PID 12 awakened
mariadb-maxscale_1 | 'maxscale' failed to start (exit status 0) -- '/usr/bin/maxscale-restart': Stopping...
mariadb-maxscale_1 | Starting...
mariadb-maxscale_1 | MaxScale PID = 1728
mariadb-maxscale_1 |
mariadb-maxscale_1 | 'mariadb-maxscale' monitor action done
mariadb-maxscale_1 | Awakened by User defined signal 1
mariadb-maxscale_1 | 'maxscale' monitor action done
mariadb-maxscale_1 | 'maxscale' process is not running
mariadb-maxscale_1 | 'maxscale' trying to restart
mariadb-maxscale_1 | 'maxscale' start: '/usr/bin/maxscale-restart'
mariadb-maxscale_1 | 'mariadb-maxscale' unmonitor on user request
mariadb-maxscale_1 | 'maxscale' unmonitor on user request
mariadb-maxscale_1 | Monit daemon with PID 12 awakened
mariadb-maxscale_1 | 'mariadb-maxscale' monitor on user request
mariadb-maxscale_1 | 'maxscale' monitor on user request
mariadb-maxscale_1 | Monit daemon with PID 12 awakened
ノート:
- 私はすでに多くのドキュメントを読んでおり、maxscale 構成では IP アドレスが「サーバー」に使用されていることを確認していますが、同じ Docker ネットワークであるため、ホスト名 (サービス名) 経由で MariaDB が表示されるはずだと思います。
- Docker ネットワーク内ではすべてのポートにアクセスできるため、ポートは開きませんでした。
答え1
問題の解決策を見つけました。 の完全なログをチェックして、根本原因がどこにあるのかを確認しましたMaxScale
(docker exec -it <container_id> cat var/log/maxscale/maxscale.log
なぜ STDOUT に表示されないのかわかりません...)
MaxScale 構成で次の変更を行う必要がありました。
パラメータ
serv_weight = 1
を に変更する必要がありましたrank = primary
。MaxScale ref.monitor_interval = 2000
を に変更する必要があります(monitor_interval = 2000ms
「ms」が欠落していました)
上記の変更後の出力:
maxctrl list servers
┌──────────┬─────────┬──────┬─────────────┬─────────────────┬────────┬─────────────────┐
│ Server │ Address │ Port │ Connections │ State │ GTID │ Monitor │
├──────────┼─────────┼──────┼─────────────┼─────────────────┼────────┼─────────────────┤
│ mariadb1 │ galera0 │ 3306 │ 0 │ Master, Running │ 0-1-65 │ MariaDB-Monitor │
├──────────┼─────────┼──────┼─────────────┼─────────────────┼────────┼─────────────────┤
│ mariadb2 │ galera1 │ 3306 │ 0 │ Running │ 0-1-65 │ MariaDB-Monitor │
├──────────┼─────────┼──────┼─────────────┼─────────────────┼────────┼─────────────────┤
│ mariadb3 │ galera2 │ 3306 │ 0 │ Running │ 0-1-65 │ MariaDB-Monitor │
└──────────┴─────────┴──────┴─────────────┴─────────────────┴────────┴─────────────────┘