상태 비저장 리소스와 함께 심장박동기 마스터 리소스를 함께 배치합니다.

상태 비저장 리소스와 함께 심장박동기 마스터 리소스를 함께 배치합니다.

DRBD와 몇 가지 네트워크 기반 마스터/슬레이브 리소스를 사용하여 간단한 2노드 클러스터를 구현했습니다.

ethmonitor RA를 사용하여 ethmon 변수가 "1"인 노드에서만 마스터 역할을 제한하여 마스터/기본 노드가 지정된 이더넷 물리적 장치에서 링크를 잃을 때마다 장애 조치를 설정했습니다.

그러나 공동 배치 제약 조건에 문제가 있습니다. eth1의 링크를 모니터링하도록 DRBDFS 리소스를 설정한 경우 기본 노드에서 eth1을 분리하면 예상대로 장애 조치가 발생합니다. 모든 마스터 리소스가 "슬레이브"로 강등되고 반대쪽으로 승격됩니다. 노드가 있고 "정상" DRBDFS는 예상대로 다른 노드로 이동합니다.

그러나 네트워크 기반 마스터/슬레이브 리소스에 동일한 ethmonitor 제약 조건을 적용하면 해당 특정 리소스만 장애 조치됩니다. DRBDFS는 다른 마스터/슬레이브 리소스와 마찬가지로 동일한 위치에 유지됩니다(중지됨).

이것냄새가 난다나에게 제약 문제와 같습니다. 내가 뭘 잘못하고 있는지 아는 사람이 있습니까?

PCS 이전:

Cluster name: node1.hostname.com_node2.hostname.com
Stack: corosync
Current DC: node2.hostname.com_0 (version 1.1.16-12.el7_4.4-94ff4df) - partition with quorum
Last updated: Tue Mar 20 16:25:47 2018
Last change: Tue Mar 20 16:00:33 2018 by hacluster via crmd on node2.hostname.com_0

2 nodes configured
11 resources configured

Online: [ node1.hostname.com_0 node2.hostname.com_0 ]

Full list of resources:

 Master/Slave Set: drbd.master [drbd.slave]
     Masters: [ node1.hostname.com_0 ]
     Slaves: [ node2.hostname.com_0 ]
 drbdfs (ocf::heartbeat:Filesystem):    Started node1.hostname.com_0
 Master/Slave Set: inside-interface-sameip.master [inside-interface-sameip.slave]
     Masters: [ node1.hostname.com_0 ]
     Slaves: [ node2.hostname.com_0 ]
 Master/Slave Set: outside-interface-sameip.master [outside-interface-sameip.slave]
     Masters: [ node1.hostname.com_0 ]
     Slaves: [ node2.hostname.com_0 ]
 Clone Set: monitor-eth1-clone [monitor-eth1]
     Started: [ node1.hostname.com_0 node2.hostname.com_0 ]
 Clone Set: monitor-eth2-clone [monitor-eth2]
     Started: [ node1.hostname.com_0 node2.hostname.com_0 ]

Daemon Status:
  corosync: active/enabled
  pacemaker: active/enabled
  pcsd: inactive/disabled

PCS 이후:

Cluster name: node1.hostname.com_node2.hostname.com
Stack: corosync
Current DC: node2.hostname.com_0 (version 1.1.16-12.el7_4.4-94ff4df) - partition with quorum
Last updated: Tue Mar 20 16:29:40 2018
Last change: Tue Mar 20 16:00:33 2018 by hacluster via crmd on node2.hostname.com_0

2 nodes configured
11 resources configured

Online: [ node1.hostname.com_0 node2.hostname.com_0 ]

Full list of resources:

 Master/Slave Set: drbd.master [drbd.slave]
     Masters: [ node1.hostname.com_0 ]
     Slaves: [ node2.hostname.com_0 ]
 drbdfs (ocf::heartbeat:Filesystem):    Stopped
 Master/Slave Set: inside-interface-sameip.master [inside-interface-sameip.slave]
     Masters: [ node2.hostname.com_0 ]
     Stopped: [ node1.hostname.com_0 ]
 Master/Slave Set: outside-interface-sameip.master [outside-interface-sameip.slave]
     Masters: [ node1.hostname.com_0 ]
     Slaves: [ node2.hostname.com_0 ]
 Clone Set: monitor-eth1-clone [monitor-eth1]
     Started: [ node1.hostname.com_0 node2.hostname.com_0 ]
 Clone Set: monitor-eth2-clone [monitor-eth2]
     Started: [ node1.hostname.com_0 node2.hostname.com_0 ]

Daemon Status:
  corosync: active/enabled
  pacemaker: active/enabled
  pcsd: inactive/disabled

이것은 내 CIB의 "제약 조건" 섹션입니다.

<constraints>
    <rsc_colocation id="pcs_rsc_colocation_set_drbdfs_set_drbd.master_inside-interface-sameip.master_outside-interface-sameip.master" score="INFINITY">
        <resource_set id="pcs_rsc_set_drbdfs" sequential="false">
            <resource_ref id="drbdfs"/>
        </resource_set>
        <resource_set id="pcs_rsc_set_drbd.master_inside-interface-sameip.master_outside-interface-sameip.master" role="Master" sequential="false">
            <resource_ref id="drbd.master"/>
            <resource_ref id="inside-interface-sameip.master"/>
            <resource_ref id="outside-interface-sameip.master"/>
        </resource_set>
    </rsc_colocation>
    <rsc_order id="pcs_rsc_order_set_drbd.master_inside-interface-sameip.master_outside-interface-sameip.master_set_drbdfs" kind="Serialize" symmetrical="false">
        <resource_set action="promote" id="pcs_rsc_set_drbd.master_inside-interface-sameip.master_outside-interface-sameip.master-1" role="Master">
            <resource_ref id="drbd.master"/>
            <resource_ref id="inside-interface-sameip.master"/>
            <resource_ref id="outside-interface-sameip.master"/>
        </resource_set>
        <resource_set id="pcs_rsc_set_drbdfs-1">
            <resource_ref id="drbdfs"/>
        </resource_set>
    </rsc_order>
    <rsc_location id="location-inside-interface-sameip.master" rsc="inside-interface-sameip.master">
        <rule id="location-inside-interface-sameip.master-rule" score="-INFINITY">
            <expression attribute="ethmon_result-eth1" id="location-inside-interface-sameip.master-rule-expr" operation="ne" value="1"/>
        </rule>
    </rsc_location>
    <rsc_location id="location-outside-interface-sameip.master" rsc="outside-interface-sameip.master">
        <rule id="location-outside-interface-sameip.master-rule" score="-INFINITY">
            <expression attribute="ethmon_result-eth2" id="location-outside-interface-sameip.master-rule-expr" operation="ne" value="1"/>
        </rule>
    </rsc_location>
</constraints>

관련 정보