이 기사에서는 Go를 사용하여 웹훅 프록시를 생성하여 GitHub 웹훅을 수신하는 애플리케이션의 로컬 개발을 가능하게 하는 방법에 대해 자세히 설명합니다. 이 솔루션은 맞춤형 서버 및 CLI 애플리케이션을 구축하여 smee.io 또는 ngrok와 같은 타사 서비스 사용을 방지합니다.
문제는 GitHub에서 localhost 개발 환경으로 웹훅 이벤트를 전달하는 것입니다. 이 튜토리얼은 GitHub 이벤트를 수신하는 서버와 이를 로컬 애플리케이션에 전달하는 CLI라는 두 부분으로 구성된 솔루션을 제공합니다.
건축:
시스템에는 다음 네 가지 주요 구성 요소가 포함됩니다.
CLI와 서버 간의 통신에는 간단한 단방향 푸시 기술인 SSE(Server-Sent Events)가 사용됩니다.
구현:
프로젝트 구조에는 CLI 및 서버 실행 파일을 위한 cmd
디렉터리와 공유 패키지를 위한 internal
디렉터리가 포함됩니다. 서버는 SSE 기능을 위해 go-sse
라이브러리를 활용합니다. CLI는 강력한 연결 처리를 위해 backoff
라이브러리를 사용합니다.
*서버(cmd/web/main.go 및 내부/서버/):**
서버에는 두 개의 엔드포인트가 있습니다.
/channel/{channel}
(GET): CLI와 SSE 연결을 설정합니다./channel/{channel}
(POST): GitHub Webhook 이벤트를 수신하고 인코딩하고 연결된 CLI에 게시합니다.CLI(cmd/cli/main.go):
CLI는 서버에 대한 SSE 연결을 설정하고 인코딩된 요청을 수신하여 디코딩한 후 지정된 로컬 애플리케이션에 전달합니다. 오류 처리 및 지수 백오프는 backoff
라이브러리
테스트:
전달된 웹훅 이벤트를 수신하고 처리하기 위한 간단한 테스트 서버(cmd/test/main.go
)가 제공됩니다. 서버를 배포하고 CLI를 실행한 후 GitHub 저장소에 변경 사항을 푸시하면 웹훅이 트리거되고, 이는 로컬 테스트 서버로 전달됩니다.
배포(부록):
문서에서는 배포 도구인 Docker와 Kamal을 사용하여 서버를 배포하는 방법을 자세히 설명합니다. Dockerfile 생성, Kamal 설정, 환경 변수 구성(보안을 위한 비밀번호 관리자 사용 포함) 및 상태 확인 엔드포인트 추가를 다룹니다. 이 프로세스에는 DigitalOcean 드롭릿 설정, SSH 액세스 구성, Kamal의 프록시를 통해 Let's Encrypt를 사용하여 도메인 이름 및 SSL 인증서 관리가 포함됩니다. 추가적인 보안 대책과 개발 환경 개선도 제안됩니다.
이 강력한 솔루션은 로컬 개발 중에 GitHub 웹후크를 처리하기 위한 유연하고 안정적인 방법을 제공하므로 외부 서비스가 필요하지 않습니다. 향후 기사에서는 이를 확장하여 Telegram 봇을 만드는 방법을 살펴볼 것입니다.
위 내용은 Go에서 웹훅 페이로드 전달 서비스 구축의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!