빅데이터 시대가 도래하면서 점점 더 많은 기업과 조직에서 Linux 운영 체제를 서버 플랫폼으로 사용하기 시작했습니다. 애플리케이션의 가용성과 안정성을 보장하기 위해 고가용성 아키텍처는 Linux 서버에서 없어서는 안 될 부분이 되었습니다. 이 기사에서는 Linux에서 고가용성 아키텍처를 배포하는 방법을 소개합니다.
고가용성 아키텍처란 무엇입니까?
고가용성(HA)은 시스템 장애가 발생해도 계속해서 서비스를 제공할 수 있는 시스템 아키텍처를 의미합니다. HA는 로드 밸런싱, 중복 백업, 장애 조치 등 다양한 기술을 통해 구현될 수 있습니다. 엔터프라이즈 수준 애플리케이션의 경우 예상치 못한 상황이 발생하더라도 애플리케이션이 계속해서 정상적으로 작동할 수 있도록 보장하기 때문에 고가용성을 유지하는 것이 중요합니다.
Linux에서 고가용성 아키텍처를 배포하는 단계
먼저 네트워크를 계획해야 합니다. 고가용성을 보장하려면 클러스터의 각 노드에 독립 IP 주소를 할당하고 가상 IP 주소로 결합해야 합니다. 또한, 클러스터가 노드 간에 데이터를 공유하려면 네트워크 스토리지를 구성해야 합니다.
소프트웨어를 설치하기 전에 각 노드에 heartbeat, corosync 및 PC 패키지와 같은 필수 소프트웨어 패키지를 설치하세요. 다음 명령을 사용하여 CentOS에 설치할 수 있습니다.
sudo yum install corosync pcs pacemaker resource-agents
다음으로 두 노드 간의 통신이 가능하도록 Corosync 및 Heartbeat를 구성해야 합니다. 이는 고가용성을 보장하기 위한 주요 단계 중 하나입니다. 구성 파일에서 노드의 IP 주소, 채널 이름 및 채널 포트를 설정합니다. 이 구성 프로세스 중에 다음 정보가 구성되었는지 확인하십시오.
totem { version: 2 secauth: off interface { ringnumber: 0 bindnetaddr: 192.168.50.0 mcastaddr: 226.94.1.1 mcastport: 5405 } transport: udpu } logging { to_logfile: yes logfile: /var/log/corosync/corosync.log to_syslog: yes }
하트비트 구성 파일에는 노드의 IP 주소와 가상 IP 주소를 설정해야 합니다. 가상 IP 주소를 제공하는 애플리케이션이 설치되어 있는지 확인하세요.
#设定hacluster集群名称 cluster hacluster #设定故障探测时间间隔 必须<ping的-send值 keepalive 2 #每次探测(waitting)会加入2秒 deadtime 10 #装备ping用的参数,每次等待10秒 warntime 10 initdead 20 udpport 694 #主服务节点IP,可多行填写 node node1.example.com node node2.example.com #关联的主节点为node1,次节点为node2 crm respawn #virtual_ip是虚拟IP #Ethernet Bridge 和IP假设设为192.168.0.1/24 primitive virtual_ip ocf:heartbeat:IPaddr2 params ip="192.168.0.5" cidr_netmask="24" op monitor interval="10s" #IP暂停服务后强制迁移 location virtual_ip-primary virtual_ip rule $id="virtual_ip-rule" inf: virtual_ip
Pacemaker 클러스터 관리 소프트웨어를 구성하는 데 사용되는 명령줄 도구인 PC 도구를 설치합니다. 다음 명령을 사용하여 설치할 수 있습니다:
sudo yum install pcs sudo systemctl enable pcsd.service && sudo systemctl start pcsd.service
모든 노드의 방화벽이 통신을 허용하도록 방화벽을 구성합니다. CentOS7에서는 다음 명령을 사용할 수 있습니다.
sudo firewall-cmd --add-service=high-availability --permanent sudo firewall-cmd --reload
각 노드에서 hacluster 사용자를 생성하고 향후 Pacemaker 클러스터 관리를 위해 이를 pcsd 그룹에 추가합니다.
sudo useradd hacluster sudo passwd hacluster sudo usermod -aG pcsd hacluster
pcsd 서비스를 활성화하려면 다음 명령을 사용합니다.
sudo systemctl enable pcsd sudo systemctl start pcsd
다음 명령을 사용하여 Pacemaker에서 인증 키를 구성하고 동일한 옵션을 사용하여 다른 모든 노드에 인증 키를 복사합니다.
sudo pcs cluster auth <node1.example.com> <node2.example.com> -u hacluster -p <password> --force
TCP 및 HTTP 애플리케이션용 고속 서버인 HAproxy 설치 및 구성 로드 밸런싱 도구. 다음 명령을 사용하여 CentOS에 설치할 수 있습니다.
sudo yum -y install haproxy sudo systemctl enable haproxy
haproxy 구성 파일에서 로드 밸런싱 알고리즘, 백엔드 서버의 IP 주소 및 포트 번호를 설정해야 합니다.
global log 127.0.0.1 local2 chroot /var/lib/haproxy pidfile /var/run/haproxy.pid maxconn 4000 user haproxy group haproxy daemon # Enables HAProxy in daemon mode defaults log global mode http option httplog option dontlognull retries 3 option redispatch maxconn 2000 contimeout 5000 clitimeout 50000 srvtimeout 50000 frontend web bind *:80 mode http default_backend web-backend backend web-backend mode http balance roundrobin option httpchk HEAD / HTTP/1.1 Host:localhost server node1 10.0.0.2:80 check server node2 10.0.0.3:80 check
마지막으로 고가용성을 테스트합니다. 노드 중 하나의 연결을 끊고 가상 IP가 자동으로 다른 노드로 전송되는지 확인하십시오. 고가용성을 보장하기 위해 다른 노드의 애플리케이션이 가상 IP에서 정상적으로 실행되고 있는지 확인합니다.
결론
Linux에 고가용성 아키텍처를 배포하면 예상치 못한 오류가 발생하더라도 엔터프라이즈 애플리케이션의 안정성과 가용성을 보장할 수 있습니다. Corosync 및 Heartbeat 기반의 HA 아키텍처를 사용하면 애플리케이션을 가상 IP 주소 및 로드 밸런싱 알고리즘을 통해 다양한 서버 노드에 배포하여 고가용성과 성능을 보장할 수 있습니다.
위 내용은 Linux에서 고가용성 아키텍처를 배포하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!