"일꾼이 일을 잘하려면 먼저 도구를 갈고 닦아야 한다." - 공자, 『논어』.
첫 장 > 프로그램 작성 > 초보자에서 로드 밸런서까지: 학습 모험을 떠나보세요

초보자에서 로드 밸런서까지: 학습 모험을 떠나보세요

2024-08-15에 게시됨
검색:392

From Novice to Load Balancer: Go Learning Adventure

저는 한동안 주로 Python과 JavaScript로 코딩을 해왔습니다. 저는 웹 앱과 스크립트를 구축하고 심지어 기계 학습도 해봤습니다. 그러나 나는 좀 더 낮은 수준의 시스템과 네트워킹에 손을 더럽힐 수 있는 것을 원했습니다. Go는 해당 업무에 완벽한 언어인 것 같았습니다.

그래서 저는 로드밸런서를 구축하기로 결정했습니다. 트래픽 관리 방법, 다중 연결 처리 방법, Go의 동시성 기능에 대해 자세히 알아볼 수 있는 기회였습니다. 제가 어떻게 했는지 분석해 보겠습니다.

숙제

코드 작성에 뛰어들기 전에 공부를 좀 해야 했어요. 컴퓨터가 인터넷에서 사용하는 언어와 서로를 찾는 방법 등 컴퓨터가 서로 어떻게 대화하는지 이해해야 했습니다. 누가 어떤 일을 하는지 등 컴퓨터 간에 작업을 공유하는 다양한 방법도 살펴봤습니다.

그런 다음 작업 공간을 설정했습니다. 나는 올바른 도구를 얻었고 내 컴퓨터가 사용할 준비가 되었는지 확인했습니다. 뭔가 멋진 것을 만들기 전에 작업장을 준비하는 것과 같았습니다.

왜 로드 밸런서인가?

자, 현실화해 보겠습니다. 왜 로드 밸런서에 신경을 쓰나요? 귀하의 웹사이트가 매우 인기 있는 피자 가게라고 상상해 보십시오. 당신은 그것을 죽이고 있어요, 그렇죠? 그런데 갑자기 마을 사람들 모두가 당신의 피자를 원합니다. 기본적으로 온라인 오븐인 웹사이트가 과열되기 시작합니다. 주문이 쌓이고 고객이 화를 내며 결국 반죽 더미가 쌓이게 됩니다(비유적으로 말하면).

여기서 로드 밸런서가 필요합니다. 이는 매우 똑똑한 피자 배달원을 고용하는 것과 같습니다. 이 사람은 어떤 오븐(또는 서버)이 무료인지 항상 찾고 있습니다. 주문(혹은 요청)이 들어오면 재빠르게 용량이 가장 많은 오븐으로 넘겨준다. 이렇게 하면 오븐(또는 서버)이 과로하지 않고 모두가 제 시간에 피자(또는 웹사이트 콘텐츠)를 받을 수 있습니다.

간단히 말하면 로드 밸런서는 웹 사이트의 교통 경찰과 같습니다. 상황이 좋지 않은 경우에도 모든 것이 원활하게 실행되도록 합니다.

그런데 왜 구축해야 할까요? 시중에는 로드 밸런서가 많이 있습니다. 그렇죠? 글쎄, 그들이 내부적으로 어떻게 작동하는지 이해하는 것은 판도를 바꿀 수 있습니다. 또한 직접 구축하는 것은 네트워킹, 동시성 및 시스템 설계에 대해 배울 수 있는 좋은 방법입니다. 그것은 단지 자동차를 운전하는 것이 아니라 자신의 차를 만드는 것과 같습니다. 관련된 엔지니어링에 대해 더 깊이 감사하게 됩니다.

폭풍 전의 침묵: REST API 구축

로드 밸런서를 시작하기 전에 트래픽을 분산할 서비스가 필요했습니다. 상태 확인 및 더미 워크로드를 위한 기본 엔드포인트가 포함된 간단한 REST API를 만들었습니다. 이는 로드 밸런서의 테스트베드 역할을 했습니다.

Go의 net/http 패키지를 사용하면 API 자체를 구축하는 것이 매우 간단했습니다. 상태 확인 및 기본 작업에 대한 엔드포인트를 정의했습니다. 상태 확인 엔드포인트는 서버의 상태를 나타내는 간단한 상태를 반환한 반면, 다른 엔드포인트는 워크로드를 시뮬레이션하기 위해 몇 가지 더미 계산을 수행했습니다.

그러나 이러한 백엔드 서비스의 안정성을 보장하는 것이 중요했습니다. 상태를 모니터링하기 위해 기본적인 상태 점검을 구현했습니다. 여기에는 정기적으로 상태 확인 엔드포인트에 요청을 보내고 서버가 특정 기간 내에 응답하지 못한 경우 서버를 비정상으로 표시하는 작업이 포함되었습니다.

제발: 로드 밸런서 구축

다음 단계는 실제 로드 밸런서를 구축하는 것이었습니다. 여기에는 몇 가지 주요 구성 요소가 포함되었습니다. 첫째, 사용 가능한 모든 서버를 추적할 수 있는 방법이 필요했습니다. 주소, 상태 등 각 서버에 대한 정보를 저장하기 위해 레지스트리를 만들었습니다. 이번 프로젝트에서는 단순한 인메모리 구조를 사용했지만, 프로덕션 환경에서는 etcd와 같은 분산 시스템이 더 적합할 것 같습니다.

로드밸런서의 핵심은 트래픽을 분산하는데 사용되는 알고리즘입니다. 기본적인 라운드 로빈 접근 방식으로 시작했지만 특정 요구 사항에 따라 최소 연결 또는 가중치 라운드 로빈과 같은 더 복잡한 전략을 구현할 수 있습니다.

들어오는 연결을 처리하기 위해 Go의 net 패키지를 사용하여 리스너 소켓을 만들었습니다. 들어오는 각 연결은 별도의 고루틴에 의해 처리되어 동시 처리가 가능합니다. 이는 많은 양의 트래픽을 효율적으로 처리하는 데 매우 중요했습니다.

백엔드 서버의 가용성을 보장하는 것이 최우선 과제였습니다. 서버 상태를 모니터링하기 위해 기본 상태 점검을 구현했습니다. 서버가 비정상인 것으로 확인되면 로드 밸런서의 순환에서 제거되었습니다. 그러나 프로덕션 환경의 경우 활성 프로브 또는 로드 기반 검사와 같은 보다 정교한 상태 검사가 필요한 경우가 많습니다.

강력한 로드 밸런서를 구축하는 것은 성능, 확장성, 내결함성과 같은 요소를 신중하게 고려하는 복잡한 작업입니다. 이 프로젝트는 탄탄한 기반을 제공했지만 프로덕션 등급 로드 밸런서는 일반적으로 추가 기능과 최적화가 필요합니다.

그럼, 다음은 무엇입니까?

이 로드 밸런서를 구축하는 것은 퍼즐을 맞추는 것과 같았습니다. 분명 수건을 던지고 싶을 때도 있었지만, 모든 것이 하나로 합쳐지는 것을 보는 만족감은 그만한 가치가 있었습니다.

저는 다중 연결과 백그라운드 작업을 처리하는 데 필수적인 Go의 동시성 기능에 대해 많은 것을 배웠습니다. 리소스를 효율적으로 관리하는 방법을 이해하는 것도 중요한 내용이었습니다. 또한 네트워킹 개념과 탄력적인 시스템을 구축하는 방법을 확실히 이해했습니다.

이 로드 밸런서는 좋은 출발점이기는 하지만 아직 갈 길이 멉니다. 더 발전된 로드 밸런싱 알고리즘을 탐색하고, 고정 세션과 같은 기능을 구현하고, 서비스 검색 시스템과 통합하고 싶습니다.

로드 밸런싱이나 Go에 대해 더 자세히 알아보고 싶다면 한번 시도해 보시기 바랍니다. 힘들지만 보람있는 여행입니다. 아래 댓글로 자유롭게 경험을 공유하거나 질문을 남겨주세요.

릴리스 선언문 이 글은 https://dev.to/thelamedev/from-novice-to-load-balancer-go-learning-adventure-4e2b?1에서 복제됩니다. 침해 내용이 있는 경우, [email protected]으로 연락하여 삭제하시기 바랍니다. 그것
최신 튜토리얼 더>
  • 제로에서 웹 개발자로 전환: PHP의 기초 익히기
    제로에서 웹 개발자로 전환: PHP의 기초 익히기
    PHP의 기본을 마스터하는 것은 필수입니다. PHP 설치 PHP 파일 만들기 코드 실행 변수 및 데이터 유형 이해 표현식 및 연산자 사용 기술 향상을 위한 실제 프로젝트 만들기 PHP 개발 시작하기: PHP 기본 익히기PHP는 동적 및 대화형 웹 애플리케이션을 만들...
    프로그램 작성 2024-11-05에 게시됨
  • 버퍼: Node.js
    버퍼: Node.js
    Node.js의 버퍼에 대한 간단한 가이드 Node.js의 버퍼는 원시 바이너리 데이터를 처리하는 데 사용되며, 이는 스트림, 파일 또는 네트워크 데이터로 작업할 때 유용합니다. 버퍼를 만드는 방법 문자열에서: const buf = ...
    프로그램 작성 2024-11-05에 게시됨
  • Node.js의 버전 관리 마스터하기
    Node.js의 버전 관리 마스터하기
    개발자로서 우리는 다양한 Node.js 버전을 요구하는 프로젝트를 자주 접하게 됩니다. 이 시나리오는 Node.js 프로젝트에 정기적으로 참여하지 않는 신규 개발자와 숙련된 개발자 모두에게 함정입니다. 즉, 각 프로젝트에 올바른 Node.js 버전이 사용되는지 확인하는...
    프로그램 작성 2024-11-05에 게시됨
  • 문제 해결을 위해 Go 바이너리에 Git 개정 정보를 포함하는 방법은 무엇입니까?
    문제 해결을 위해 Go 바이너리에 Git 개정 정보를 포함하는 방법은 무엇입니까?
    Go 바이너리에서 Git 개정 확인코드를 배포할 때 바이너리를 빌드된 Git 개정과 연결하는 것이 도움이 될 수 있습니다. 문제 해결 목적. 그러나 개정 번호로 소스 코드를 직접 업데이트하는 것은 소스를 변경하므로 불가능합니다.해결책: 빌드 플래그 활용이 문제에 대한 ...
    프로그램 작성 2024-11-05에 게시됨
  • 일반적인 HTML 태그: 관점
    일반적인 HTML 태그: 관점
    HTML(HyperText Markup Language)은 웹 개발의 기초를 형성하며 인터넷의 모든 웹페이지 구조 역할을 합니다. 2024년 가장 일반적인 HTML 태그와 고급 용도를 이해함으로써 개발자는 보다 효율적이고 접근 가능하며 시각적으로 매력적인 웹 페이지를 ...
    프로그램 작성 2024-11-05에 게시됨
  • CSS 미디어 쿼리
    CSS 미디어 쿼리
    웹사이트가 다양한 기기에서 원활하게 작동하도록 보장하는 것이 그 어느 때보다 중요합니다. 사용자가 데스크톱, 노트북, 태블릿, 스마트폰에서 웹사이트에 액세스함에 따라 반응형 디자인이 필수가 되었습니다. 반응형 디자인의 중심에는 개발자가 사용자 기기의 특성에 따라 다양한...
    프로그램 작성 2024-11-05에 게시됨
  • JavaScript의 호이스팅 이해: 종합 가이드
    JavaScript의 호이스팅 이해: 종합 가이드
    자바스크립트에서 호이스팅 호이스팅은 변수 및 함수 선언을 포함 범위(전역 범위 또는 함수 범위)의 맨 위로 이동(또는 "호이스팅")하는 동작입니다. 코드가 실행됩니다. 즉, 코드에서 실제로 선언되기 전에 변수와 함수를 사용할 수 있습니...
    프로그램 작성 2024-11-05에 게시됨
  • Stripe를 단일 제품 Django Python Shop에 통합
    Stripe를 단일 제품 Django Python Shop에 통합
    In the first part of this series, we created a Django online shop with htmx. In this second part, we'll handle orders using Stripe. What We'll...
    프로그램 작성 2024-11-05에 게시됨
  • Laravel에서 대기 중인 작업을 테스트하기 위한 팁
    Laravel에서 대기 중인 작업을 테스트하기 위한 팁
    Laravel 애플리케이션으로 작업할 때 명령이 비용이 많이 드는 작업을 수행해야 하는 시나리오를 접하는 것이 일반적입니다. 기본 프로세스를 차단하지 않으려면 대기열에서 처리할 수 있는 작업으로 작업을 오프로드하기로 결정할 수 있습니다. 예제를 살펴보겠습니다. app:...
    프로그램 작성 2024-11-05에 게시됨
  • 인간 수준의 자연어 이해(NLU) 시스템을 만드는 방법
    인간 수준의 자연어 이해(NLU) 시스템을 만드는 방법
    Scope: Creating an NLU system that fully understands and processes human languages in a wide range of contexts, from conversations to literature. ...
    프로그램 작성 2024-11-05에 게시됨
  • JSTL을 사용하여 HashMap 내에서 ArrayList를 반복하는 방법은 무엇입니까?
    JSTL을 사용하여 HashMap 내에서 ArrayList를 반복하는 방법은 무엇입니까?
    JSTL을 사용하여 HashMap 내에서 ArrayList 반복웹 개발에서 JSTL(JavaServer Pages Standard Tag Library)은 JSP( 자바 서버 페이지). 그러한 작업 중 하나는 데이터 구조를 반복하는 것입니다.HashMap과 그 안에 포...
    프로그램 작성 2024-11-05에 게시됨
  • Encore.ts — ElysiaJS 및 Hono보다 빠릅니다.
    Encore.ts — ElysiaJS 및 Hono보다 빠릅니다.
    몇 달 전 우리는 TypeScript용 오픈 소스 백엔드 프레임워크인 Encore.ts를 출시했습니다. 이미 많은 프레임워크가 있으므로 우리는 우리가 내린 흔하지 않은 디자인 결정과 그것이 어떻게 놀라운 성능 수치로 이어지는지 공유하고 싶었습니다. 성능 ...
    프로그램 작성 2024-11-05에 게시됨
  • 문자열 리터럴에서 +를 사용한 문자열 연결이 실패하는 이유는 무엇입니까?
    문자열 리터럴에서 +를 사용한 문자열 연결이 실패하는 이유는 무엇입니까?
    문자열 리터럴을 문자열과 연결C에서는 연산자를 사용하여 문자열과 문자열 리터럴을 연결할 수 있습니다. 그러나 이 기능에는 혼란을 초래할 수 있는 제한 사항이 있습니다.질문에서 작성자는 문자열 리터럴 "Hello", ",world" 및...
    프로그램 작성 2024-11-05에 게시됨
  • React Re-Rendering: 최적의 성능을 위한 모범 사례
    React Re-Rendering: 최적의 성능을 위한 모범 사례
    React의 효율적인 렌더링 메커니즘은 React가 인기를 얻는 주요 이유 중 하나입니다. 그러나 애플리케이션이 복잡해짐에 따라 구성 요소 다시 렌더링을 관리하는 것이 성능을 최적화하는 데 중요해졌습니다. React의 렌더링 동작을 최적화하고 불필요한 재렌더링을 방지하...
    프로그램 작성 2024-11-05에 게시됨
  • 조건부 열 생성을 달성하는 방법: Pandas DataFrame에서 If-Elif-Else 탐색?
    조건부 열 생성을 달성하는 방법: Pandas DataFrame에서 If-Elif-Else 탐색?
    조건부 열 생성: Pandas의 If-Elif-Else주어진 문제에서는 DataFrame에 새 열을 추가해야 합니다. 일련의 조건부 기준을 기반으로 합니다. 문제는 코드 효율성과 가독성을 유지하면서 이러한 조건을 구현하는 것입니다.함수 적용을 사용한 솔루션한 가지 접근...
    프로그램 작성 2024-11-05에 게시됨

부인 성명: 제공된 모든 리소스는 부분적으로 인터넷에서 가져온 것입니다. 귀하의 저작권이나 기타 권리 및 이익이 침해된 경우 자세한 이유를 설명하고 저작권 또는 권리 및 이익에 대한 증거를 제공한 후 이메일([email protected])로 보내주십시오. 최대한 빨리 처리해 드리겠습니다.

Copyright© 2022 湘ICP备2022001581号-3