クラスタの設定
クラスタの設定
Heartbeatでクラスタを動作させるには、次の3つのファイルが必要です。
- Heartbeat設定ファイル:/etc/ha.d/ha.cf
- リソース設定ファイル:/etc/ha.d/haresources
- 認証方法設定ファイル:/etc/ha.d/authkeys
上記のどのファイルもソースからインストールした場合にはありませんので、ソースの"doc"ディレクトリ以下のサンプルファイルをコピーして使用するとよいでしょう。
参考までに、eth1を使用してブロードキャストによりハートビートを行った場合の必要最小限の設定例を次に示します。詳細な設定を行う場合、 ha.cfファイルのコメントを参考にしていけば難しいものはありません。nodeの項目には、対象となるノードのホスト名を登録します。
ha.cfの設定例
logfile /var/log/ha-log
keepalive 2
deadtime 30
warntime 10
initdead 120
udpport 694
bcast eth1
auto_failback on
node fedora-node1 fedora-node2
haresourecesファイルにリソースを登録します。設定例はサンプルファイルのコメントに記されています。稼動系ノードとしたいホスト名を 最初に記述し、その後に起動したいリソースを指定します。複数ある場合には、スペースで区切ってエントリすると左から順に起動されます。 haresourcesファイルは、ノードが変わっても同じファイルを使用しますので、注意してください。
haresourecesの設定例(仮想IPのみの場合)
fedora-node1 192.168.1.175/24
haresourecesの設定例
(仮想IPの後にApacheのサービスを起動する場合)
fedora-node1 192.168.1.175/24 httpd
最後のauthkeysでは、ハートビートの通信を安全に行うための認証方法を選択できます。次の例では認証も暗号化もないCRCによる整合性 チェックのみを指定していますが、SHA1やMD5といった暗号化も選択できます。重要なこととして、パーミッションを600に設定しておく必要があり、 設定がない場合にはheartbeatサービス起動時にエラーになります。
authkeysの設定例
auth 1
1 crc
#2 sha1 HI!
#3 md5 Hello!
以上でクラスタの設定例を紹介しましたが、どれも仮想IPをフェイルオーバーさせるという動作に必要最小限の内容になっています。実際に使用する際 にはwatchdogの設定やPING監視、リソース監視などの他の項目も詳細に設定することを勧めます。また、困ったときにはソースの"doc"フォル ダにあるGettingStartedを見ると一通りの手順が書いてありますので、参考にしてください。
Heartbeatサービスの起動と動作例
Heartbeatの設定後にサービスを起動しますが、デフォルトで"/etc/init.d/"以下にサービススクリプトがインストールされているため、通常のサービス同様に起動するだけで動作します。
サービスの起動
[root@fedora-node1 ~]# /etc/init.d/heartbeat start
Starting High-Availability services:
[ OK ]
[root@fedora-node2 ~]# /etc/init.d/heartbeat start
Starting High-Availability services:
[ OK ]
この状態でnode1の仮想IPの状態を確認すると、正しく設定されていることがわかります。
node1の仮想IPの状態の確認
| [root@fedora-node1 ~]# ifconfig -a eth0:0 | |
| eth0:0 | Link encap:Ethernet HWaddr 00:0C:29:6A:78:B3 |
| inet addr:192.168.1.175 Bcast:192.168.1.255 Mask:255.255.255.0 | |
| UP BROADCAST RUNNING MULTICAST MTU:1500 Metric:1 | |
| Interrupt:10 Base address:0x1080 | |
強制的にnode1側のサービスを停止させると、仮想IPはnode2に切り替わっているのが確認できます。
強制的にnode1側のサービスを停止した場合
| [root@fedora-node1 ~]# /etc/init.d/heartbeat stop | |
| Stopping High-Availability services: | |
| [ OK ] | |
| [root@fedora-node2 ~]# ifconfig -a eth0:0 | |
| eth0:0 | Interrupt:10 Base address:0x1080 |
| Link encap:Ethernet HWaddr 00:0C:29:D9:01:DC | |
| inet addr:192.168.1.175 Bcast:192.168.1.255 Mask:255.255.255.0 | |
| UP BROADCAST RUNNING MULTICAST MTU:1500 Metric:1 | |
| Interrupt:10 Base address:0x1080 | |
以上、駆け足でオープンソースにおけるクラスタソフトウェアをみてきました。オープンソースソフトウェアといえば、Webサーバ/Mailサーバ/DNSサーバなどの用途に多くのソフトウェアが圧倒的なシェアを持って使用されています。
Heartbeatはそうしたサービスの高可用化に対してとてもサービスと相性よく動作します。またどんなに貧弱な環境(VMwareのような仮想マシン上でも)でも動きますので、興味がある方は実際に試してみることをお勧めします。