ProfitBricks 클라우드에 NGINX Plus 배포

ProfitBricks 는 2012년에 출시된 클라우드 기반 인프라 서비스(IaaS) 플랫폼입니다. 이 플랫폼을 사용하면 클라우드에서 고성능이면서도 비용 효율적인 솔루션을 쉽고 빠르게 배포할 수 있습니다. ProfitBricks에서 NGINX Plus 를 쉽게 배포하여 고급 로드 밸런싱, 캐싱, 웹 서빙 및 미디어 스트리밍 기능을 갖춘 완전한 애플리케이션 전달 플랫폼으로 사용할 수 있습니다.

이 포스트에서는 ProfitBricks 환경에서 고가용성을 갖춘 NGINX Plus 인스턴스를 설정하는 방법에 대해 설명합니다.

목차

1. ProfitBricks에서 고가용성 NGINX Plus 구성
 1-1. ProfitBricks Data Center 생성
 1-2. ProfitBricks IP 주소 예약
 1-3. Primary NGINX Plus 인스턴스 생성
 1-4. ProfitBricks 인터넷 액세스 설정
 1-5. Primary NGINX Plus 인스턴스 시작
 1-6. NGINX Plus 설치, 구성 및 테스트
 1-7. NGINX Plus HA 패키지 설치
 1-8. NGINX Plus 인스턴스 스냅샷
 1-9. Backup NGINX Plus 인스턴스 생성
 1-10. ProfitBricks 네트워킹 구성 완료
 1-11. Backup NGINX Plus 인스턴스 실행 및 테스트
 1-12. 고가용성 구성
2. NGINX Plus HA 구성 테스트
3. ProfitBricks 결론

1. ProfitBricks에서 고가용성 NGINX Plus 구성

ProfitBricks는 Data Center Designer라는 사용하기 쉬운 그래픽 사용자 인터페이스(GUI)를 제공하여 환경을 구축할 수 있습니다. 이 블로그 게시물에서는 이를 사용하고 있습니다.

ProfitBricks 클라우드에 NGINX Plus를 설치하고 배포하려면 Data Center 개체가 필요합니다. 기존 개체를 사용하거나 1-1의 지침에 따라 개체를 생성할 수 있습니다. Data Center 내에서 NGINX Plus를 일반적인 방법으로 설치할 Linux 인스턴스를 생성합니다. 다음 예제에서는 고가용성 액티브-패시브 쌍으로 NGINX Plus 인스턴스를 배포하고 Active Primary 인스턴스에 할당하기 위해 가상 IP 주소(VIP)를 제공합니다.

이 포스트에서는 ProfitBricks 계정에 로그인되어 있다고 가정합니다.

1-1. ProfitBricks Data Center 생성

만약 이미 Data Center가 없다면, 아래를 따라 하나를 생성하세요.

1. 페이지 상단의 ProfitBricks 주 메뉴 바에서 Data Center를 클릭하세요. Start Center 탭이 열립니다.

Create new Data Center

2. 새로운 데이터 센터의 이름을 지정하세요. 이 예시에서는 “My Data Center“를 사용합니다.
3. 드롭다운 메뉴에서 Region을 선택하세요. 이 예시에서는 “USA / Las Vegas“를 사용합니다.
4. “Create Data Center” 버튼을 클릭하세요. “My Data Center” 탭이 열립니다.

1-2. ProfitBricks IP 주소 예약

Active-passive 형태의 NGINX Plus 인스턴스를 각각 생성하기 위해서는 적어도 세 개의 Public IP 주소가 필요합니다: 각 NGINX Plus 인스턴스에 대한 Static Public IP 주소 하나씩, 그리고 Active NGINX Plus 인스턴스에 할당될 가상 IP 주소 하나입니다.

1. 메인 ProfitBricks 메뉴 바에서 “My Data Center” 탭 위에 있는 “IP Manager“를 클릭하세요. “Manage IP Addresses” 창이 나타납니다.

Reserve IP addresses

2. “Reserve IPs“을 클릭하세요.
3. IP 주소 세트에 이름을 지정하세요. 이 예시에서는 “MyIPs“를 사용합니다.
4. Number of IPs의 수를 3으로 설정하세요.
5. 드롭다운 메뉴에서 Region을 선택하세요. 이 예시에서는 “USA / Las Vegas“를 사용합니다.
6. 3개의 IP 주소를 예약하기 위해 “Reserve IPs now” 버튼을 클릭하세요. 예약된 IP 주소 중 하나를 VIP로 선택하고, 나머지 두 개를 NGINX 인스턴스의 정적 IP 주소로 선택하세요. 예시에서의 IP 주소는 다음과 같습니다.

  • 158.xxx.xxx.122 – Primary NGINX Plus 인스턴스의 Static Public IP 주소
  • 158.xxx.xxx.123 – Backup NGINX Plus 인스턴스의 Static Public IP 주소
  • 158.xxx.xxx.124 – Virtual IP 주소

1-3. Primary NGINX Plus 인스턴스 생성

1. My Data Center 탭의 왼쪽에 있는 Palette 열에서 서버 아이콘을 중앙 작업 영역으로 끌어다 놓으세요.
2. 작업 영역 오른쪽에 있는 Inspector 열에서 서버에 이름을 지정하세요. 이 예시에서는 “HA Primary“를 사용합니다.

Create primary NGINX Plus server instance

3. 스토리지를 추가합니다.

  • Inspector 열에서 Storage 탭을 클릭하여 열어주세요.
  • Add HDD Storage를 클릭하세요. Create new attached Storage 창이 나타납니다.
Allocate storage for the primary NGINX Plus instance in ProfitBricks
  • 스토리지에 이름을 지정해주세요. 이 예시에서는 Primary HDD를 사용합니다.
  • Image 드롭다운 메뉴에서 ProfitBricks 이미지를 선택한 다음 운영 체제를 선택해주세요. 이 예시에서는 Ubuntu-14.04-LTS-server-2015-10-01을 사용합니다.
  • Create HDD Storage 버튼을 클릭하세요.

4. 네트워킹 구성을 진행합니다.

  • Network 탭을 클릭하여 엽니다.
  • Add NIC을 클릭하세요.
  • Name 필드에 eth0을 입력하세요.
  • Primary IP 필드에는 주 NGINX 인스턴스의 Static Public IP 주소를 입력하세요. 이 예시에서는 158.xxx.xxx.122를 사용합니다.
  • Add IP 드롭다운 메뉴를 클릭하여 가상 IP 주소 (VIP)를 이 인스턴스와 연결하세요. 이렇게 하면 VIP가 Primary 서버 인스턴스와 Backup 서버 인스턴스 간에 이동할 수 있습니다.
    • 예약된 IP 주소 그룹에 할당한 이름을 선택하세요 (2단계의 하위 단계 3에서 할당한 이름입니다). 이 예시에서는 MyIPs입니다.
    • VIP로 사용할 주소를 선택하세요. 이 예시에서는 158.xxx.xxx.124입니다.
  • 다시 Add NIC을 클릭하세요. 두 번째 인터페이스를 추가하는 것은 필수는 아니지만, Primary 서버와 Backup 인스턴스의 HA 구성을 테스트할 때 사용할 것입니다.
  • Name 필드에 eth1을 입력하세요.
  • 다른 필드는 그대로 두세요. ProfitBricks는 자동으로 eth1에 개인 IP 주소를 연결합니다. 이는 인스턴스를 시작한 후 Add IP 필드에 표시됩니다.
ProfitBricks의 기본 NGINX Plus 인스턴스에서 네트워크 인터페이스 구성

5. 이 서버의 구성을 완료하고, 메모리 양이나 코어 수와 같은 다른 설정을 필요에 맞게 조정하세요.

1-4. ProfitBricks 인터넷 액세스 설정

1. Palette 열에서 Internet Access 아이콘을 작업 영역으로 드래그(drag)하세요. (다음 단계에서 그릴 선이 인터넷 액세스 아이콘의 아래부터 HA Primary 아이콘의 위로 이어지기 때문에 작업 영역을 최대한 읽기 쉽게 유지하기 위해 이 아이콘을 HA Primary 아이콘 위에 배치하세요.)

2. Internet Access 아이콘의 하단 가장자리에 있는 원을 클릭하고 커서를 HA Primary 아이콘의 상단 가장자리에 있는 가장 왼쪽 원으로 드래그하여 두 아이콘 사이에 선을 그려주세요. 이 원은 eth0 인터페이스에 해당하는 것으로, 예시에서는 빨간색으로 표시되어 있습니다. eth1에 해당하는 원은 초록색입니다.

Configure Internet access for the primary instance in ProfitBricks

1-5. Primary NGINX Plus 인스턴스 시작

1. 작업 영역의 왼쪽 상단에 있는 Provision 버튼을 클릭하세요. Provision Data Center 창이 나타납니다. 팝업 창에 나타나는 다음 경고 메시지는 무시해도 됩니다. 왜냐하면 우리는 10단계에서 eth1 인터페이스의 구성을 완료할 것이기 때문입니다.

NIC 1 [eth1] on "HA Primary" is unconnected and has no peers

2. 팝업 창 하단에 있는 “Provision Now” 버튼을 클릭하세요.

인스턴스가 성공적으로 시작되면, ProfitBricks로부터 이메일을 받게 될 것입니다. 이메일에는 루트(root) 비밀번호를 포함하여 설정에 대한 자세한 내용이 포함되어 있습니다.

1-6. NGINX Plus 설치, 구성 및 테스트

  1. 터미널 창에서 ssh를 사용하여 새로 생성된 NGINX Plus 인스턴스에 연결하십시오. 이때, ProfitBricks로부터 이메일로 제공된 루트(root) 비밀번호를 사용하십시오. 새 비밀번호를 설정하기 위해 프롬프트에 따라 진행하십시오.
  2. NGINX Plus를 설치하려면 NGINX STORE의 NGINX Plus Docs를 따르십시오.
  3. NGINX Plus에 필요한 구성 변경 사항을 수행하십시오. 이 예제에서는 NGINX Plus 설치 패키지의 기본 구성 파일을 사용하고 있습니다.
  4. eth0에 할당된 IP 주소로 요청을 보낼 때 예상한 응답을 받는지 확인하십시오. 기본 구성을 사용하고 있으므로, 우리에게 예상되는 응답은 NGINX 환영 페이지입니다.

1-7. NGINX Plus HA 패키지 설치

동일한 터미널 창에서 Primary 서버인 NGINX Plus 인스턴스에 NGINX Plus HA 패키지를 설치하십시오. 이 명령은 Ubuntu에 적합합니다.

$ apt-get install nginx-ha-keepalived

1-8. NGINX Plus 인스턴스 스냅샷

작동하는 NGINX Plus 인스턴스가 있으므로 HA 쌍의 두 번째 (Backup) 인스턴스의 기반으로 사용할 스냅샷을 찍습니다. 이렇게하면 두 번째 인스턴스에 NGINX Plus를 설치할 필요가 없습니다.

  1. ProfitBricks 작업 영역에서 HA Primary 아이콘 하단에 연결된 Storage 아이콘을 클릭하십시오. Inspector 열이 변경되어 해당 정보가 표시됩니다 (예: 저장소 이름은 Primary HDD Storage입니다).
  2. Create Snapshot 버튼을 클릭하십시오. Create Snap Shot 창이 나타납니다.
  3. 이름 필드에 스냅샷의 이름을 입력하십시오. 이 예제에서는 “NGINX Plus Config“를 사용합니다.
  4. Create Snapshot 버튼을 클릭하십시오.
Create a snapshot of the primary instance in ProfitBricks

스냅샷 생성에는 시간이 걸릴 수 있습니다. 메인 ProfitBricks 메뉴 바의 My Data Center 탭 위에있는 Image Manager를 클릭하여 진행 상황을 추적할 수 있으며, 팝업 창에서 Manage Images and Snap Shots 창의 Snapshot 탭을 열 수 있습니다.

스냅샷 생성 중에는 진행 중인 메시지가 표시됩니다. 완료되면 날짜와 타임스탬프가 표시됩니다.

1-9. Backup NGINX Plus 인스턴스 생성

1. Palette 열에서 다른 Server 아이콘을 작업 영역으로 끌어다 놓으세요. (HA Primary 아이콘 옆에 배치합니다. 왜냐하면 이미 HA Primary가 연결된 Internet Access 아이콘에 연결할 것이기 때문입니다.)
2. Inspector 열에서 Name 필드에 서버 이름을 입력하세요. 이 예시에서는 HA Backup을 사용합니다.
3. 스토리지 추가

  • Inspector 열에서 Storage 탭을 클릭하세요.
  • Add HDD Storage를 클릭하세요. 새로운 첨부된 저장소 생성 창이 나타납니다.
Allocate storage for the backup NGINX Plus instance in ProfitBricks
  • 저장소에 이름을 지정하세요. 이 예시에서는 “Backup HDD“를 사용합니다.
  • Image 드롭다운 메뉴에서 Snapshots을 선택한 다음, 8단계에서 생성한 스냅샷을 선택하세요. 이 예시에서는 “NGINX Plus Config“입니다.
  • Create HDD Storage” 버튼을 클릭하세요.
  • 4. 네트워킹 구성:
  • Network 탭을 클릭하여 엽니다.
  • “Add NIC”을 클릭하세요.
  • Name 필드에 “eth0″을 입력하세요.
  • Primary IP 필드에 Backup NGINX 인스턴스의 Static Public IP 주소를 입력하세요. 이 예시에서는 158.xxx.xxx.123을 사용합니다.
  • 다시 “Add NIC“을 클릭하세요.
  • Name 필드에 “eth1“을 입력하세요.
  • 나머지 필드는 그대로 두세요. ProfitBricks는 자동으로 eth1에 개인 IP 주소를 연결합니다. 이는 11단계에서 인스턴스를 시작한 후에 Primary IP 필드에 표시됩니다.
Configure network interfaces for the backup NGINX Plus instance in ProfitBricks
  • 이 서버의 구성을 완료하고, 메모리 양이나 코어 수와 같은 다른 설정을 필요에 맞게 조정하세요.

1-10. ProfitBricks 네트워킹 구성 완료

1. Backup 인스턴스에 대한 인터넷 액세스를 활성화하세요. Internet Access 아이콘의 하단 가장자리에 있는 원을 클릭하고 커서를 HA Backup 아이콘의 상단 가장자리에 있는 가장 왼쪽 원으로 드래그하여 eth0 인터페이스에 해당하는 곳에 선을 그리세요. 예시에서는 eth0에 해당하는 원이 빨간색입니다.
2. 주요 NGINX Plus 인스턴스와 Backup NGINX Plus 인스턴스의 내부 네트워크 인터페이스를 연결하기 위해 HA Backupeth1에서 HA Primaryeth1로 선을 그려주세요 (이 예시에서 eth1은 양쪽 아이콘의 상단 가장자리에 있는 녹색 원으로 표시됩니다).

Configure networking connections for the primary and backup NGINX Plus instances in ProfitBricks

1-11. Backup NGINX Plus 인스턴스 실행 및 테스트

  1. 작업 영역의 왼쪽 상단에있는 Provision 버튼을 클릭 한 다음 나타나는 Provision Data Center 창의 하단에있는 Provision Now 버튼을 클릭하세요.
  2. 새 터미널에서 Backup NGINX Plus 인스턴스에 연결하기 위해 ssh를 사용하세요. 이 인스턴스의 기반으로 주요 인스턴스의 스냅샷을 사용했으므로 루트 암호는 두 인스턴스 모두 동일합니다.
  3. Backup 인스턴스의 eth0에 할당 된 IP 주소 (예 : 158.xxx.xxx.123)로 요청을 보낼 때 예상되는 응답을 받는지 확인하세요. 이 예시에서는 기본 구성을 사용하므로 예상되는 응답은 NGINX Welcome 페이지입니다.

1-12. 고가용성 구성

7단계에서는 주요 인스턴스에 NGINX Plus 고가용성 패키지를 설치했습니다. 이 패키지는 주요 인스턴스의 스냅샷에서 Backup 인스턴스를 생성했기 때문에 Backup 인스턴스에도 사용할 수 있습니다. 이 단계에서는 패키지에 포함된 nginx-ha-setup 스크립트를 실행하여 두 인스턴스에서 고가용성을 구성합니다.

1. 주요 및 Backup NGINX Plus 인스턴스에 대해 별도의 터미널 창에서 동시에 nginx-ha-setup 명령을 실행하세요.

$ nginx-ha-setup

각 인스턴스에 할당된 Public IP 주소를 사용하여 prompt에 따라 진행하세요.

2. 클러스터 IP 주소로는 VIP(두 인스턴스 중 Static IP 주소로 할당되지 않은 Public IP 주소)를 입력하세요. 예를 들어, 158.xxx.xxx.124입니다.

구성이 성공하면, 작동 중이며 고가용성을 갖춘 Activce-passive 형태의 NGINX Plus 인스턴스 두 개가 생성됩니다. 두 인스턴스가 모두 정상적으로 작동할 때, VIP는 primary 서버(primary)에 할당됩니다. primary 서버(primary)가 다운되면, keepalived가 VIP를 Backup 서버(backup)로 전환합니다.

Primary 서버와 Backup 서버 간에 기능이 변경되었을 때 동일한 작동을 유지하기 위해 NGINX Plus 구성은 Primary 서버와 Backup 서버에서 동일해야 합니다. 한 인스턴스에서 NGINX Plus 구성을 변경하면, 다른 인스턴스에서도 동일한 변경을 해야 함을 기억하세요.

NGINX Plus HA에 대한 자세한 정보는 NGINX STORE의 NGINX Plus Docs를 참조하세요.

2. NGINX Plus HA 구성 테스트

NGINX Plus HA 구성을 테스트하는 여러 가지 방법이 있습니다. 다음 예제에서는 Primary 인스턴스가 Public 인터페이스 (eth0)에서 자체 IP 주소와 VIP를 모두 삭제하도록 표준 ip 명령을 사용하고, VIP가 Backup 인스턴스로 이동하는지 확인합니다.

IP 주소를 모두 삭제하면 Primary 인스턴스의 eth0 인터페이스에 접근할 수 없으므로 직접 연결하는 대신 Backup 인스턴스에 먼저 연결한 다음 Primary 인스턴스의 내부 eth1 인터페이스로 연결합니다. 이것이 우리가 Primary 및 Backup 인스턴스에 eth1 인터페이스를 생성한 이유입니다.

1. 두 개의 별도 터미널에서 Backup NGINX Plus 인스턴스에 대한 SSH 연결을 엽니다. (11단계의 2단계 하위 단계에서 열었던 연결이 여전히 열려 있다면 그 중 하나를 사용할 수 있습니다.)
2. 하나의 터미널에서 Primary 인스턴스의 내부 IP 주소 (eth1에 매핑된)로 SSH 연결을 엽니다. (ProfitBricks에서 주소를 얻으려면 작업 영역에서 HA Primary 아이콘을 클릭한 다음 Inspector 열의 Network 탭을 열고 eth1 인터페이스의 Primary IP 필드를 확인하십시오.)

다음 단계에서는 이 터미널을 B2P (backup에서 primary로)로 지칭하고 다른 터미널을 B (Backup)로 지칭할 것입니다.

3. 각 터미널에서 HA 상태를 확인하기 위해 다음 명령을 실행하세요.

# Terminal B2P
$ cat /var/run/nginx-ha-keepalived.state
STATE=MASTER
 
# Terminal B
$ cat /var/run/nginx-ha-keepalived.state
STATE=BACKUP

4. 터미널 B2P에서 eth0의 IP 주소 목록을 나열하기 위해 다음 명령을 실행하세요.

# Terminal B2P
$ ip addr show

출력 결과는 VIP가 Primary 인스턴스에 할당되었음을 확인합니다.

VIP 할당 여부를 확인하는 또 다른 방법은 해당 VIP로 요청을 보내는 것입니다(브라우저나 curl 명령을 사용하여). VIP가 Primary에 할당되었다면, 해당 요청에 해당하는 항목이 Primary의 NGINX 액세스 로그 파일에 나타납니다. 기

적으로 이 파일은 /var/log/nginx/access.log에 위치합니다.

5. 터미널 B2P에서 다음 명령을 실행하여 Primary 인스턴스의 eth0(Primary의 Static Public 주소와 VIP)에서 IP 주소를 모두 삭제합니다.

# Terminal B2P
$ ifdown eth0

결과적으로, keepalived는 VIP를 Backup 인스턴스로 이동시킵니다.

6. 각 터미널에서 이 명령을 실행하여 각 인스턴스의 HA 상태를 확인하세요. 출력은 3단계와 반대로 되어 있으며, 원래의 Backup이 이제 Primary인 것을 나타냅니다.

# Terminal B2P
$ cat /var/run/nginx-ha-keepalived.state
STATE=BACKUP
 
# Terminal B
$ cat /var/run/nginx-ha-keepalived.state
STATE=MASTER

7. 터미널 B에서 다음 명령을 실행하세요.

# Terminal B
$ ip addr show

출력 결과는 VIP가 이제 원래의 Backup 인스턴스에 할당되었음을 확인합니다. 다시 VIP에 요청을 보내고, 해당 요청에 대한 항목이 원래의 Primary 서버가 아닌 원래의 Backup 인스턴스의 NGINX 액세스 로그 파일에 나타나는지 확인할 수 있습니다.

8. 원래의 Primary 서버와 Backup의 할당으로 돌아가려면, 터미널 B2P에서 다음 명령을 실행하여 Primary 서버가 VIP를 회수하도록 할 수 있습니다.

# Terminal B2P
$ ifup eth0

3. ProfitBricks 결론

ProfitBricks는 사용하기 쉬운 클라우드 플랫폼이며, NGINX Plus를 추가하여 고가용성 및 완전한 기능을 갖춘 애플리케이션 전달 플랫폼을 생성할 수 있습니다.

NGINX Plus로 시작하려면 오늘부터 30일 무료 평가판에 등록하거나 사용 사례에 대해 논의하기 위해 NGINX STORE에게 문의하십시오.

아래 뉴스레터를 구독하고 NGINX와 NGINX STORE의 최신 정보들을 빠르게 전달 받아보세요.