質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
MySQL

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

Linux

Linuxは、Unixをベースにして開発されたオペレーティングシステムです。日本では「リナックス」と呼ばれています。 主にWebサーバやDNSサーバ、イントラネットなどのサーバ用OSとして利用されています。 上位500のスーパーコンピュータの90%以上はLinuxを使用しています。 携帯端末用のプラットフォームAndroidは、Linuxカーネル上に構築されています。

ネットワーク

ネットワークとは、複数のコンピューター間を接続する技術です。インターネットが最も主流なネットワークの形態で、TCP/IP・HTTP・DNSなどの様々なプロトコルや、ルータやサーバーなどの様々な機器の上に成り立っています。

Q&A

解決済

1回答

3333閲覧

ロードバランシングされるサーバ自体からVIPへのアクセスができない

mosa

総合スコア218

MySQL

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

Linux

Linuxは、Unixをベースにして開発されたオペレーティングシステムです。日本では「リナックス」と呼ばれています。 主にWebサーバやDNSサーバ、イントラネットなどのサーバ用OSとして利用されています。 上位500のスーパーコンピュータの90%以上はLinuxを使用しています。 携帯端末用のプラットフォームAndroidは、Linuxカーネル上に構築されています。

ネットワーク

ネットワークとは、複数のコンピューター間を接続する技術です。インターネットが最も主流なネットワークの形態で、TCP/IP・HTTP・DNSなどの様々なプロトコルや、ルータやサーバーなどの様々な機器の上に成り立っています。

0グッド

0クリップ

投稿2016/12/06 06:00

keepalivedのDSRでロードバランサを構築しました。
ロードバランシング対象は MariaDB Galera Cluster 10.0(MySQL) です。
外部のサーバからVIPに対してアクセスを行う分には問題ないのですが、
振り分け先のMySQLサーバ自体(下記の192.168.1.3, 192.168.1.4)からVIPにアクセスしようとする止まってしまいます。

  • 他のサーバからは接続できる。
$ mysql -h 192.168.1.1 -u root -p***** Reading table information for completion of table and column names You can turn off this feature to get a quicker startup with -A . . →OK
  • 振り分け先のMySQLサーバ自体(下記の192.168.1.3, 192.168.1.4)からはアクセスできない。
$ mysql -h 192.168.1.1 -u root -p***** ↑この状態で止まってしまう。

パケットがサーバまで振り分けられているとは思うのですが、該当サーバで捨てられているようにも見えます。
解決策などご教示いただけますでしょうか。



●情報

1.VIP 192.168.1.1

2.ロードバランサ(keepalived) 192.168.1.2

keepalived.conf

~略~ virtual_server_group DEVEL_DB1 { 192.168.1.1 3306 } virtual_server group DEVEL_DB1 { delay_loop 17 # リアルサーバのヘルスチェック間隔 lvs_sched rr # 振り分けの方法(ラウンドロビン) lvs_method DR # 動作モード DSR or NAT protocol TCP # プロトコル # 振り分け先1 real_server 192.168.1.3 3306 { weight 1 # 重み inhibit_on_failure # 停止時に削除とせず、weightを落とす TCP_CHECK { connect_port 3306 connect_timeout 30 nb_get_retry 3 delay_before_retry 3 } } # 振り分け先2 real_server 192.168.1.4 3306 { weight 1 # 重み inhibit_on_failure # 停止時に削除とせず、weightを落とす TCP_CHECK { connect_port 3306 connect_timeout 30 nb_get_retry 3 delay_before_retry 3 } } }
$ ipvsadm -ln IP Virtual Server version 1.2.1 (size=4096) Prot LocalAddress:Port Scheduler Flags -> RemoteAddress:Port Forward Weight ActiveConn InActConn TCP 192.168.1.1:3306 rr -> 192.168.1.3:3306 Route 1 0 0 -> 192.168.1.4:3306 Route 1 0 0

3.MySQL Cluster サーバ 192.168.1.3, 192.168.1.4

$ sudo iptables -F
$ sudo iptables -t nat -A PREROUTING -p tcp -d 192.168.1.1 -j REDIRECT
$ sudo service iptables save


気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

coco_bauer

2016/12/06 06:30

各マシンのログファイルにエラーなどの記録が残されているのではないでしょうか? ログの内容を質問に追記すれば、回答が得られるかもしれません。
guest

回答1

0

ベストアンサー

$ sudo iptables -t nat -A PREROUTING -p tcp -d 192.168.1.1 -j REDIRECT

外へ出ようとするパケットは PREROUTING チェーンを通りません。OUTPUT チェーンでREDIRECTする必要があるのではないでしょうか? 以下を追加してみてはどうでしょうか?

sudo iptables -t nat -A OUTPUT -p tcp -d 192.168.1.1 -j REDIRECT

(すみません。未検証です)

参考:80番ポートへ届いたパケットをiptablesでローカルの上位ポートに転送する

投稿2016/12/06 07:08

mit0223

総合スコア3401

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

mosa

2016/12/06 07:44

まさにおっしゃる通りでした。 ありがとうございました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問