앱 중심 미래를 향해 가는 쿠버네티스…OAM과 Rudr로 멀티클라우드 분산 앱 확장
쿠버네티스를 위한 확장은 풍부하다. 헴(Helm)과 같은 툴을 사용하면 클러스터에 리소스를 손쉽게 배포할 수 있고, CNAB(Cloud Native Application Bundle)는 애플리케이션과 모든 종속성을 즉시 배포 가능하도록 래핑한다. 하위 수준에서는 드래프트(Draft)와 같은 서비스가 기본적인 서비스를 설계하고 빌드하는 데 도움이 된다. 코드를 빌드해서 익숙한 컨테이너를 사용해 배포할 수 있고, 각 요소를 손쉽게 쿠버네티스 애플리케이션으로 조합할 수 있다. 애저 쿠버네티스 서비스를 사용해서 관리를 자동화할 수도 있다.
서비스 인프라를 백그라운드에 두고 있다는 점을 고려하면(구글의 보그(Borg) 작업), 쿠버네티스와 이를 둘러싼 각종 툴이 기본적으로 운영에 초점을 두는 것은 지극히 자연스럽다. 분산 시스템 운영은 오랜 과제이며, 보그에서 메소스(Mesos), 도커 스웜과 쿠버네티스에 이르기까지 전반적인 데이터센터 OS 추세에는 데브옵스 중에서 ‘데브’보다 ‘옵스’ 측면이 훨씬 더 크다.
이 상황을 넘어 쿠버네티스의 데브 측면을 강화하려면 어떻게 해야 할까? 생태계를 구축하고, 마이크로서비스 원칙을 기반으로 하는 분산 애플리케이션을 구축하기 위한 패턴과 방법을 코드화하는 측면에서는 많은 일이 이뤄졌다. 이제 이 모든 조각을 모아서 전체 그림에서 빠진 조각이자 개발자에게 필수적인 조각, 즉 쿠버네티스에 대한 애플리케이션 중심의 시야를 확보해야 한다.
OAM(Open Application Model)
마이크로소프트와 알리바바 클라우드는 최근 현대적인 분산 애플리케이션을 구성하는 다양한 계층과 역할 간의 경계에 대한 이해를 바탕으로 마이크로서비스 기반 애플리케이션 구축과 관리에 초점을 두는 OAM(Open Application Model)을 발표했다. OAM은 모든 쿠버네티스 기반 환경이 다르다는 점을 명확히 하지만, 데브옵스 문화가 주는 혜택을 버리지 않고도 애플리케이션을 인프라의 지원 서비스로부터 분리할 수 있는 공통적인 부분이 여전히 있다.OAM의 시작은 현대적인 애플리케이션의 구축과 운영에 관여하는 팀의 역할과 책임을 정의하는 것이다. 개발자와 운영자라는 전통적인 구분 대신 조금 더 세분화된 방식을 사용하며, 애플리케이션 운영자와 인프라 운영자 역할이라는 개념을 사용한다. 합리적인 모델이다. 쿠버네티스와 같은 툴과 이를 둘러싸는 서비스는 본실적으로 기반 데이터센터 및 코어 애플리케이션의 추상화다.
OAM에는 개발 팀이 제공하는 마이크로서비스를 관리하고 배포하는 애플리케이션 운영자가 있다. 이들은 팟과 컨테이너를 관리하고 배포하면서 모니터링 및 관찰 툴을 사용해서 애플리케이션 안정성과 확장성을 보장하는 팀이다. 또한 서비스 메시 구성요소를 사용해서 애플리케이션 네트워크와 그 동작을 정의하고, 선언적인 툴을 사용해서 서비스 정책을 구축하는 팀이기도 하다.
인프라 운영자는 전통적이 옵스 역할과 비슷하지만 쿠버네티스 자체, 또는 서비스 메시 정책에 의해 관리되는 소프트웨어 정의 네트워크와 마찬가지로 책임의 범위가 인프라 서비스에 국한된다. 이들은 실행 중인 애플리케이션에 대해 알아야 할 필요가 없으며, 제공하는 모든 서비스가 가용하며 API가 작동하도록 보장하기만 하면 된다. 이들의 역할이 가진 중요성을 폄하하려는 것이 아니다. 갈수록 복잡해지는 현대 시스템 운영을 위해서는 서비스 수준에서 숙련된 전문가가 필요하다. 예를 들어 다중 테넌트 데이터베이스의 관리와 배포에는 상당한 지식과 기술이 필요하다.
OAM의 애플리케이션 정의
OAM의 중심에는 애플리케이션 개념이 있다. 이는 애플리케이션이 배포되는 방법, 기반 인프라와 통합되는 방법으로부터 애플리케이션을 분리한다. 이것은 내가 다른 사람과 다른 방법으로 애플리케이션을 배포하고 관리하며, 애저와 AWS가 애플리케이션을 다루는 방식이 서로 다르다는 것을 이해하는 길이다.애플리케이션은 구성요소로 이뤄진다. 구성요소는 배포 패키지에 포함될 수도, 그렇지 않을 수도 있다. 애플리케이션 구성요소는 호스팅되는 데이터베이스이거나 네트워킹 규칙 집합, 또는 메시지 엔드포인트 집합일 수 있다. 이러한 요소가 구현되는 방법은 기반 플랫폼에 따라 결정되지만, 애플리케이션은 제자리에 배치되기 전에는 배포할 수 없다. 다양한 애플리케이션 구성요소 간의 관계는 매니페스트에 설명되며 이 매니페스트를 사용해서 애플리케이션 마이크로서비스를 배포 가능한 모듈로 빌드할 수 있다.
애플리케이션을 패키징하는 CNAB와 같은 툴에 사용되는 방법에서 한 걸음 더 나간 것이다. 패키지를 제공하는 대신, 가용한 플랫폼 리소스를 사용해서 사이트 또는 서비스별 애플리케이션 버전으로 조합된 구성요소를 제공한다. 그 결과는 애플리케이션 패키징과는 전혀 다른 접근 방법이다. 애플리케이션 운영자 측의 작업이 더 많이 필요하고 인프라 운영자 측에서 필요한 작업은 줄어든다.
트레이트를 사용한 인프라 작업
애플리케이션 패키지를 플랫폼에서 분리하면 그 결과는 앱을 어디에 설치하든 모든 구성요소와 리소스가 동일한 표준화된 퍼블릭 클라우드, 그리고 기성 하드웨어와 구글 클라우드 플랫폼의 안토스(Anthos) 같은 툴을 혼합한 맞춤형 온프레미스 프라이빗 클라우드 간의 차이점에 대처할 수 있는, 애플리케이션 개발에 대한 더 불가지론적인 접근 방법이다. 이를 위한 열쇠는 OAM의 트레이트(Trait) 개념이다.트레이트는 애플리케이션 환경이 어떻게 작동해야 하는지를 기술하는 데 사용되며 기계와 사람이 모두 읽을 수 있는 방식으로 확장 및 기타 주요 분산 컴퓨팅 개념을 설명한다. 트레이트에는 이름과 일련의 속성이 있다. 예를 들어 자동 확장 트레이트는 허용되는 최소 및 최대 복제본 수를 정의하고, 이는 쿠버네티스 설치를 위한 적절한 YAML로 변환되거나 서비스 메시 또는 KEDA(쿠버네티스 기반 이벤트 중심 자동 확장)와 같은 서비스를 위한 구성 파일로 변환될 수 있다.
결국 OAM이 확산되면 네트워킹 및 보안 툴과 기타 클라우드에서 사용 중인 인프라 자동화 기능에서 직접 트레이트와 트레이트 정의를 지원해야 한다. 트레이트와 다른 OAM 애플리케이션 개념은 벤더 중립적이어야 한다. 그러면 어느 인프라에서든 관계없이 애플리케이션을 설치하고 실행할 수 있다. 이 접근 방법은 코드가 클라이언트 가까이에서 실행되고 가용한 장비가 클라우드플레어(Cloudflare)와 같은 콘텐츠 제공 네트워크 또는 AT&T와 같은 대도시 수준 통신 사업자에 의존할 수 있는 엣지 환경에서 잘 작동할 것이다.
Rudr, 쿠버네티스를 위한 OAM 기준 구현
OAM과 같은 사양에는 기준 구현이 필요하다. 마이크로소프트는 쿠버네티스와 함께 사용하기 위한 구현인 Rudr를 출시했다. Rudr은 OAM 정의를 취해서 맞춤형 리소스 정의를 사용해 쿠버네티스 구성요소 및 서비스로 변환한다. 흥미로운 점은 러스트(Rust)로 작성되어 이 언어의 메모리 안전 기능을 활용해 애플리케이션의 위험을 낮춘다는 것이다. 공개된 가이드를 사용해서 간단한 파이썬 앱 컨테이너를 호스팅하는 기본적인 구성요소를 만들 수 있다.Rudr은 여전히 알파 단계의 코드이다. 따르는 사양 자체가 빠르게 변화하고 있기 때문이다. 그러나 사설 클라우드에서 OAM 애플리케이션을 관리하는 방법, 애저와 같은 서비스가 훨씬 더 큰 규모의 인프라에서 이를 구현하는 방법에 대한 감을 잡을 수 있게 해준다. editor@itworld.co.kr
함께 보면 좋은 콘텐츠
Sponsored
Surfshark
“유료 VPN, 분명한 가치 있다” VPN 선택 가이드
ⓒ Surfshark VPN(가상 사설 네트워크, Virtual Private Network)은 인터넷 사용자에게 개인 정보 보호와 보안을 제공하는 중요한 도구로 널리 인정받고 있다. VPN은 공공 와이파이 환경에서도 데이터를 안전하게 전송할 수 있고, 개인 정보를 보호하는 데 도움을 준다. VPN 서비스의 수요가 증가하는 것도 같은 이유에서다. 동시에 유료와 무료 중 어떤 VPN을 선택해야 할지 많은 관심을 가지고 살펴보는 사용자가 많다. 가장 먼저 사용자의 관심을 끄는 것은 별도의 예산 부담이 없는 무료 VPN이지만, 그만큼의 한계도 있다. 무료 VPN, 정말 괜찮을까? 무료 VPN 서비스는 편리하고 경제적 부담도 없지만 고려할 점이 아예 없는 것은 아니다. 보안 우려 대부분의 무료 VPN 서비스는 유료 서비스에 비해 보안 수준이 낮을 수 있다. 일부 무료 VPN은 사용자 데이터를 수집해 광고주나 서드파티 업체에 판매하는 경우도 있다. 이러한 상황에서 개인 정보가 유출될 우려가 있다. 속도와 대역폭 제한 무료 VPN 서비스는 종종 속도와 대역폭에 제한을 생긴다. 따라서 사용자는 느린 인터넷 속도를 경험할 수 있으며, 높은 대역폭이 필요한 작업을 수행하는 데 제약을 받을 수 있다. 서비스 제한 무료 VPN 서비스는 종종 서버 위치가 적거나 특정 서비스 또는 웹사이트에 액세스하지 못하는 경우가 생긴다. 또한 사용자 수가 늘어나 서버 부하가 증가하면 서비스의 안정성이 저하될 수 있다. 광고 및 추적 위험 일부 무료 VPN은 광고를 삽입하거나 사용자의 온라인 활동을 추적하여 광고주에게 판매할 수 있다. 이 경우 사용자가 광고를 보아야 하거나 개인 정보를 노출해야 할 수도 있다. 제한된 기능 무료 VPN은 유료 버전에 비해 기능이 제한될 수 있다. 예를 들어, 특정 프로토콜이나 고급 보안 기능을 지원하지 않는 경우가 그렇다. 유료 VPN의 필요성 최근 유행하는 로맨스 스캠은 인터넷 사기의 일종으로, 온라인 데이트나 소셜 미디어를 통해 가짜 프로필을 만들어 상대를 속이는 행위다. 이러한 상황에서 VPN은 사용자가 안전한 연결을 유지하고 사기 행위를 방지하는 데 도움이 된다. VPN을 통해 사용자는 상대방의 신원을 확인하고 의심스러운 활동을 감지할 수 있다. 서프샤크 VPN은 구독 요금제 가입 후 7일간의 무료 체험을 제공하고 있다. ⓒ Surfshark 그 외에도 유료 VPN만의 강점을 적극 이용해야 하는 이유는 다음 3가지로 요약할 수 있다. 보안 강화 해외 여행객이 증가함에 따라 공공 와이파이를 사용하는 경우가 늘어나고 있다. 그러나 공공 와이파이는 보안이 취약해 개인 정보를 노출할 위험이 있다. 따라서 VPN을 사용하여 데이터를 암호화하고 개인 정보를 보호하는 것이 중요하다. 서프샤크 VPN은 사용자의 개인 정보를 안전하게 유지하고 해킹을 방지하는 데 유용하다. 개인정보 보호 인터넷 사용자의 검색 기록과 콘텐츠 소비 패턴은 플랫폼에 의해 추적될 수 있다. VPN을 사용하면 사용자의 IP 주소와 로그를 숨길 수 있으며, 개인 정보를 보호할 수 있다. 또한 VPN은 사용자의 위치를 숨기고 인터넷 활동을 익명으로 유지하는 데 도움이 된다. 지역 제한 해제 해외 여행 중에도 한국에서 송금이 필요한 경우가 생길 수 있다. 그러나 IP가 해외 주소이므로 은행 앱에 접근하는 것이 제한될 수 있다. VPN을 사용하면 지역 제한을 해제해 해외에서도 한국 인터넷 서비스를 이용할 수 있다. 따라서 해외에서도 안전하고 편리하게 인터넷을 이용할 수 있다. 빠르고 안전한 유료 VPN, 서프샤크 VPN ⓒ Surfshark 뛰어난 보안 서프샤크 VPN은 강력한 암호화 기술을 사용하여 사용자의 인터넷 연결을 안전하게 보호한다. 이는 사용자의 개인 정보와 데이터를 보호하고 외부 공격으로부터 사용자를 보호하는 데 도움이 된다. 다양한 서버 위치 서프샤크 VPN은 전 세계 곳곳에 여러 서버가 위치하고 있어, 사용자가 지역 제한된 콘텐츠에 액세스할 수 있다. 해외에서도 로컬 콘텐츠에 손쉽게 접근할 수 있음은 물론이다. 속도와 대역폭 서프샤크 VPN은 빠른 속도와 무제한 대역폭을 제공하여 사용자가 원활한 인터넷 경험을 누릴 수 있도록 지원한다. 온라인 게임, 스트리밍, 다운로드 등 대역폭이 필요한 활동에 이상적이다. 다양한 플랫폼 지원 서프샤크 VPN은 다양한 플랫폼 및 디바이스에서 사용할 수 있다. 윈도우, 맥OS, iOS, 안드로이드 등 다양한 운영체제 및 디바이스에서 호환되어 사용자가 어디서나 안전한 인터넷을 즐길 수 있다. 디바이스 무제한 연결 서프샤크 VPN은 무제한 연결을 제공하여 사용자가 필요할 때 언제든지 디바이스의 갯수에 상관없이 VPN을 사용할 수 있다.