vsftpd を監視2008/08/15 |
vftpdをクラスタ対象として設定してみます。
そのため vsftpd はインストール済みが前提です。
なお、2つのFTPサーバーは(2)の項で設定したものと同じく以下のような構成です。
また、設定は (2) で設定した httpd に vsftpd を追加する形で行います。
(1) www1.server-linux.info [eth0:192.168.0.21] [eth1:10.0.0.21]
(2) www2.server-linux.info [eth0:192.168.0.22] [eth1:10.0.0.22] (3) cluster.server-linux.info [仮想IP:192.168.0.100]
ちなみにここでは vsftpd を例にしましたが、この設定は samba や postfix 等、他の /etc/rc.d/init.d/ 配下の起動スクリプトに応用できます。
前項の httpd も以下の1行への変更でまかなうことが可能です。
基本は <primitive id="(テキトーなID名)" class="lsb" type="(起動スクリプト名)"/> でいけます。 |
|
[1] | 両ホストで以下のように同じ設定をします。なお、vsftpd が起動している場合は、以下の設定をする前に停止して、自動起動もオフにしておいてください。 vsftpd の起動や停止は HeartBeat が制御します。 |
[root@www1 ~]# /etc/rc.d/init.d/heartbeat stop Stopping High-Availability services: [ OK ] [root@www1 ~]# cd /var/lib/heartbeat/crm [root@www1 crm]# rm -f cib.xml.*
[root@www1 crm]#
<cib generated="true" admin_epoch="0" epoch="1" have_quorum="true" ignore_dtd="false" ccm_transition="2" num_peers="2" cib_feature_revision="2.0" dc_uuid="f8719a77-70b4-4e5f-851b-dafa7d65d3a2" num_updates="4" cib-last-written="Sun Jun 15 05:04:30 2008">vi cib.xml <configuration> <crm_config> <cluster_property_set id="cib-bootstrap-options"> <attributes> <nvpair id="cib-bootstrap-options-dc-version" name="dc-version" value="2.1.3-node: 552305612591183b1628baa5bc6e903e0f1e26a3"/> </attributes> </cluster_property_set> </crm_config> <nodes> <node id="2bbd6408-ec01-4b8c-bb8e-207237af3a99" uname="www1.server-linux.info" type="normal"/> <node id="f8719a77-70b4-4e5f-851b-dafa7d65d3a2" uname="www2.server-linux.info" type="normal"/> </nodes> <resources> <group id="group_apache"> <primitive id="ipaddr" class="ocf" type="IPaddr" provider="heartbeat"> <instance_attributes id="ia_ipaddr"> <attributes> <nvpair id="ia_ipaddr_ip" name="ip" value="192.168.0.100"/> <nvpair id="ia_ipaddr_nic" name="nic" value="eth0"/> <nvpair id="ia_ipaddr_netmask" name="netmask" value="24"/> </attributes> </instance_attributes> </primitive> # vsftpd用設定追記 <primitive id="vsftpd" class="lsb" type="vsftpd"/> <instance_attributes id="ia_apache"> <attributes> <nvpair id="ia_apache_configfile" name="configfile" value="/etc/httpd/conf/httpd.conf"/> </attributes> </instance_attributes> </primitive> </group> </resources> <constraints/> </configuration>
</cib>
[root@www1 crm]# /etc/rc.d/init.d/heartbeat start Starting High-Availability services: [ OK ] |
[2] | しばらく時間をおいて、両サーバーで crm_mon を実行して、以下のような結果が返ってくれば問題なしです。 プライマリ側で vsftpd が追加されて起動していることが分かります。 |
[root@www1 ~]# crm_mon -i 3 Defaulting to one-shot mode
You need to have curses available at compile time to enable console mode
============Last updated: Sun Jun 15 21:03:32 2008 Current DC: www2.server-linux.info (f8719a77-70b4-4e5f-851b-dafa7d65d3a2) 2 Nodes configured. 1 Resources configured.
============
Node: www1.server-linux.info (2bbd6408-ec01-4b8c-bb8e-207237af3a99): online
Node: www2.server-linux.info (f8719a77-70b4-4e5f-851b-dafa7d65d3a2): online
Resource Group: group_apacheipaddr (heartbeat::ocf:IPaddr): Started www1.server-linux.info vsftpd (lsb:vsftpd): Started www1.server-linux.info apache (heartbeat::ocf:apache): Started www1.server-linux.info |
[3] | テキトーにテストページを両サーバーのホームディレクトリに作成しておき、 FTPクライアントから仮想IPのアドレスにアクセスしてみます。 しっかりとプライマリサーバーが応答してくれています。 |
[4] | プライマリ側で HeartBeat を強制的に落とし、フェイルオーバーするか確認してみます。 |
[root@www1 ~]# /etc/rc.d/init.d/heartbeat stop Stopping High-Availability services: [ OK ] |
数秒して仮想IPのアドレスにアクセスしてみると、しっかりと切り替わってくれています。 |
[5] | プライマリ側で HeartBeat を再び起動し、フェイルバックするか確認してみます。 |
[root@www1 ~]# /etc/rc.d/init.d/heartbeat start Starting High-Availability services: [ OK ] |
数秒して仮想IPのアドレスにアクセスしてみると、しっかりと元に戻ってくれています。 |
Sponsored Link |