목차
질문 내용
해결 방법
백엔드 개발 Golang Go: 공유 코드가 있는 마이크로서비스를 위한 저장소 레이아웃

Go: 공유 코드가 있는 마이크로서비스를 위한 저장소 레이아웃

Feb 09, 2024 am 09:33 AM
overflow

Go: 공유 코드가 있는 마이크로서비스를 위한 저장소 레이아웃

Go는 최근 몇 년 동안 마이크로서비스 아키텍처에서 점점 인기를 얻고 있는 강력한 프로그래밍 언어입니다. 단순성, 효율성 및 동시성으로 인해 고성능 애플리케이션을 구축하는 데 이상적입니다. Go로 마이크로서비스를 구축할 때 저장소의 레이아웃은 중요한 고려 사항입니다. 이 기사에서 PHP Editor Banana는 공유 코드가 포함된 마이크로서비스 저장소 레이아웃을 소개하여 코드를 더 잘 구성하고 관리하는 데 도움을 줍니다.

질문 내용

저희는 최근 새로운 마이크로서비스를 개발하기 위해 go를 사용하기 시작했습니다. 각 마이크로서비스는 Go 모듈이며 우리는 이를 단일 저장소로 관리합니다.

으아악

이것은 잘 작동하지만 이제 s1s2 두 서비스에서 사용되는 일부 구조, s3에 업로드된 함수 등 일부 코드를 공유해야 합니다.

이 상황을 처리하는 올바른 방법은 무엇입니까? 이상적으로는 저장소 루트에 common 디렉터리(services의 형제)를 두고 거기에 공통 코드를 넣습니다. 하지만 common 目录(services 的同级目录)并将公共代码放在那里 - 但是在编译 s1s2 컴파일할 때 코드를 어떻게 얻을 수 있나요? 거기에서?

해결 방법

제 생각에 당신이 요구하는 것은 실제로 "여러 바이너리를 생성하는 Go 애플리케이션을 구축하는 방법은 무엇입니까? "인 것 같습니다.

다음 레이아웃을 갖도록 go.mod을 최상위 디렉터리 이름 바꾸기로 이동할 수 있습니다.

으아악

다음과 같이 시작하는 go.mod도 있습니다.

으아악

만약 common/common.go이 다음과 같다면:

으아악

그런 다음 services/s1/main.go中,可以导入common 모듈에서:

으아악

다음과 같이 s1 서비스를 구축하게 됩니다.

으아악

빌드 s2 유사:

으아악

일반적으로 여러 서비스를 자동으로 구축하기 위한 최상위 수준 makefile이 있습니다.

위 내용은 Go: 공유 코드가 있는 마이크로서비스를 위한 저장소 레이아웃의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

2018-2024 USD의 Bitcoin의 최신 가격 2018-2024 USD의 Bitcoin의 최신 가격 Feb 15, 2025 pm 07:12 PM

실시간 비트 코인 USD 가격 비트 코인 가격에 영향을 미치는 요인 향후 비트 코인 가격을 예측하기위한 지표 다음은 2018-2024 년 비트 코인 가격에 대한 몇 가지 주요 정보입니다.

H5 페이지 제작은 프론트 엔드 개발입니까? H5 페이지 제작은 프론트 엔드 개발입니까? Apr 05, 2025 pm 11:42 PM

예, H5 페이지 제작은 HTML, CSS 및 JavaScript와 같은 핵심 기술을 포함하는 프론트 엔드 개발을위한 중요한 구현 방법입니다. 개발자는 & lt; canvas & gt; 그래픽을 그리거나 상호 작용 동작을 제어하기 위해 JavaScript를 사용하는 태그.

CSS를 통해 크기 조정 기호를 사용자 정의하고 배경색으로 균일하게 만드는 방법은 무엇입니까? CSS를 통해 크기 조정 기호를 사용자 정의하고 배경색으로 균일하게 만드는 방법은 무엇입니까? Apr 05, 2025 pm 02:30 PM

CSS에서 크기 조정 기호를 사용자 정의하는 방법은 배경색으로 통합됩니다. 매일 개발에서, 우리는 종종 조정과 같은 사용자 인터페이스 세부 정보를 사용자 정의 해야하는 상황을 발생시킵니다.

인라인 블록 요소가 왜 잘못 정렬됩니까? 이 문제를 해결하는 방법? 인라인 블록 요소가 왜 잘못 정렬됩니까? 이 문제를 해결하는 방법? Apr 04, 2025 pm 10:39 PM

인라인 블록 요소의 잘못 정렬 된 디스플레이에 대한 이유와 솔루션과 관련하여. 웹 페이지 레이아웃을 작성할 때, 우리는 종종 이상하게 겉보기에 이상한 디스플레이 문제가 발생합니다. 비교하다...

JavaScript 또는 CSS를 통해 브라우저 인쇄 설정에서 페이지 상단 및 끝을 제어하는 ​​방법은 무엇입니까? JavaScript 또는 CSS를 통해 브라우저 인쇄 설정에서 페이지 상단 및 끝을 제어하는 ​​방법은 무엇입니까? Apr 05, 2025 pm 10:39 PM

브라우저의 인쇄 설정에서 페이지의 상단과 끝을 제어하기 위해 JavaScript 또는 CSS를 사용하는 방법. 브라우저의 인쇄 설정에는 디스플레이가 ...인지 제어 할 수있는 옵션이 있습니다.

CSS의 클립 경로 속성을 사용하여 세그먼터의 45도 곡선 효과를 달성하는 방법은 무엇입니까? CSS의 클립 경로 속성을 사용하여 세그먼터의 45도 곡선 효과를 달성하는 방법은 무엇입니까? Apr 04, 2025 pm 11:45 PM

세그먼터의 45도 곡선 효과를 달성하는 방법은 무엇입니까? 세분화 장치를 구현하는 과정에서 왼쪽 버튼을 클릭 할 때 오른쪽 테두리를 45도 곡선으로 바꾸는 방법과 포인트 ...

플렉스 레이아웃 아래의 텍스트는 생략되지만 컨테이너가 열려 있습니까? 그것을 해결하는 방법? 플렉스 레이아웃 아래의 텍스트는 생략되지만 컨테이너가 열려 있습니까? 그것을 해결하는 방법? Apr 05, 2025 pm 11:00 PM

Flex 레이아웃 및 솔루션에서 텍스트를 과도하게 누락하여 컨테이너 개구부 문제가 사용됩니다 ...

45도 곡선 테두리로 분할 효과를 달성하는 방법? 45도 곡선 테두리로 분할 효과를 달성하는 방법? Apr 04, 2025 pm 11:48 PM

사용자 인터페이스 디자인에서 세그먼트 효과를 구현하기위한 팁, 세그먼터는 특히 모바일 애플리케이션 및 반응 형 웹 페이지에서 일반적인 탐색 요소입니다. ...

See all articles