>  기사  >  운영 및 유지보수  >  Linux에서 고가용성 아키텍처를 배포하는 방법

Linux에서 고가용성 아키텍처를 배포하는 방법

WBOY
WBOY원래의
2023-06-18 12:21:261816검색

빅데이터 시대가 도래하면서 점점 더 많은 기업과 조직에서 Linux 운영 체제를 서버 플랫폼으로 사용하기 시작했습니다. 애플리케이션의 가용성과 안정성을 보장하기 위해 고가용성 아키텍처는 Linux 서버에서 없어서는 안 될 부분이 되었습니다. 이 기사에서는 Linux에서 고가용성 아키텍처를 배포하는 방법을 소개합니다.

고가용성 아키텍처란 무엇입니까?

고가용성(HA)은 시스템 장애가 발생해도 계속해서 서비스를 제공할 수 있는 시스템 아키텍처를 의미합니다. HA는 로드 밸런싱, 중복 백업, 장애 조치 등 다양한 기술을 통해 구현될 수 있습니다. 엔터프라이즈 수준 애플리케이션의 경우 예상치 못한 상황이 발생하더라도 애플리케이션이 계속해서 정상적으로 작동할 수 있도록 보장하기 때문에 고가용성을 유지하는 것이 중요합니다.

Linux에서 고가용성 아키텍처를 배포하는 단계

  1. 네트워크 계획

먼저 네트워크를 계획해야 합니다. 고가용성을 보장하려면 클러스터의 각 노드에 독립 IP 주소를 할당하고 가상 IP 주소로 결합해야 합니다. 또한, 클러스터가 노드 간에 데이터를 공유하려면 네트워크 스토리지를 구성해야 합니다.

  1. 소프트웨어 설치

소프트웨어를 설치하기 전에 각 노드에 heartbeat, corosync 및 PC 패키지와 같은 필수 소프트웨어 패키지를 설치하세요. 다음 명령을 사용하여 CentOS에 설치할 수 있습니다.

sudo yum install corosync pcs pacemaker resource-agents
  1. Corosync 및 Heartbeat 구성

다음으로 두 노드 간의 통신이 가능하도록 Corosync 및 Heartbeat를 구성해야 합니다. 이는 고가용성을 보장하기 위한 주요 단계 중 하나입니다. 구성 파일에서 노드의 IP 주소, 채널 이름 및 채널 포트를 설정합니다. 이 구성 프로세스 중에 다음 정보가 구성되었는지 확인하십시오.

  • bindnetaddr: 노드 간 통신을 위한 네트워크 인터페이스 주소를 지정하는 데 사용됩니다.
  • mcastaddr: 멀티캐스트 주소를 지정하는 데 사용됩니다.
  • mcastport: 멀티캐스트 채널의 포트 번호를 지정하는 데 사용됩니다.
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
  1. 클러스터 관리 도구 구성

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
  1. 부하 분산 구성

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
  1. 고가용성 아키텍처 테스트

마지막으로 고가용성을 테스트합니다. 노드 중 하나의 연결을 끊고 가상 IP가 자동으로 다른 노드로 전송되는지 확인하십시오. 고가용성을 보장하기 위해 다른 노드의 애플리케이션이 가상 IP에서 정상적으로 실행되고 있는지 확인합니다.

결론

Linux에 고가용성 아키텍처를 배포하면 예상치 못한 오류가 발생하더라도 엔터프라이즈 애플리케이션의 안정성과 가용성을 보장할 수 있습니다. Corosync 및 Heartbeat 기반의 HA 아키텍처를 사용하면 애플리케이션을 가상 IP 주소 및 로드 밸런싱 알고리즘을 통해 다양한 서버 노드에 배포하여 고가용성과 성능을 보장할 수 있습니다.

위 내용은 Linux에서 고가용성 아키텍처를 배포하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.