docker-compose를 사용하여 CockroachDB에 어떻게 연결하나요?

王林
풀어 주다: 2024-02-15 12:03:09
앞으로
1038명이 탐색했습니다.

如何使用 docker-compose 连接到 CockroachDB?

php editor Strawberry에서는 docker-compose를 사용하여 CockroachDB에 연결하는 방법을 소개하겠습니다. Docker-compose는 여러 Docker 컨테이너를 정의하고 실행하기 위한 도구이고 CockroachDB는 분산 관계형 데이터베이스 관리 시스템입니다. docker-compose를 사용하면 CockroachDB 컨테이너를 쉽게 생성 및 관리하고 이를 다른 컨테이너와 연결할 수 있습니다. 이 기사에서는 CockroachDB에 연결하기 위해 docker-compose 파일을 구성하는 방법을 자세히 설명하고 몇 가지 실용적인 팁과 고려 사항을 제공합니다. 초보자이든 숙련된 개발자이든 관계없이 이 글은 docker-compose를 사용하여 CockroachDB에 연결하는 데 빠르게 시작하는 데 도움이 되는 유용한 지침을 제공합니다.

질문 내용

데이터베이스를 배포하고 애플리케이션을 로컬로 이동하는 docker-compose 파일이 있습니다

으아악

파일로 이동:

으아악

데이터베이스에 대한 연결이 설정되었습니다. 그러나 연결이 실패했고 잘못된 포트가 전달되었습니다. 26257 대신 26258이었습니다. 이 문제를 해결하는 방법?

솔루션

  1. 사용하지 마세요. links 이 기능은 수년 동안 더 이상 사용되지 않으며 이전 버전과의 호환성을 위해서만 유지됩니다. Docker는 컨테이너에 대한 DNS를 유지 관리하므로 연결을 설정할 때 서비스 이름을 호스트 이름으로 사용하기만 하면 됩니다.

  2. network_mode 结合使用:host을 사용하여 포트를 전달할 수 없습니다.

  3. depends_on을 사용하면 사실상 무작동입니다. 데이터베이스가 연결을 처리할 준비가 되기 전에 애플리케이션이 데이터베이스에 연결을 시도할 가능성이 높습니다.

    실제로 데이터베이스 클러스터는 실행하기 전까지 연결을 허용하지 않으므로 cockroach init이 문제가 확실히 발생합니다.

  4. 다음 오류로 인해 작성 파일이 실행되지 않습니다 node_1.

    으아악
  5. 귀하의 node_1 포트 전달이 올바르지 않습니다. 컨테이너의 어떤 것도 포트 8081에서 수신 대기하고 있지 않습니다. 다음과 같은 것을 원할 수도 있습니다:

    으아악

마지막으로, 예제 코드의 storage 모듈이 어디서 왔는지 표시하지 않았기 때문에 테스트에 사용할 수 없습니다. 나는 데이터베이스가 연결을 수락하기를 기다리는 루프를 포함하는 다음 테스트 프로그램을 작성했습니다.

으아악

위의 문제를 모두 해결하고 작성 파일을 정리하면 다음과 같이 끝납니다.

으아악

이 구성은 애플리케이션이 데이터베이스에 액세스하는 데 필요하지 않으므로 의도적으로 호스트에 데이터베이스 포트를 게시하지 않습니다.

이 구성을 docker 编写 하면 데이터베이스 서비스에서 다음을 볼 수 있습니다.

으아악

샘플 애플리케이션에는 다음이 포함됩니다(예상).

으아악

데이터베이스를 초기화해야 합니다.

으아악

이후 데이터베이스 서비스에서 다음을 볼 수 있습니다:

으아악

예제 애플리케이션은 쿼리를 연결하고 실행할 수 있습니다:

으아악

이러한 노드의 웹 UI는 호스트 포트에 노출됩니다 80808081.

마지막으로 데이터베이스 데이터를 보관할 볼륨을 생성할 수 있습니다. 예를 들어 이 문서마운팅 볼륨을 참조하세요.

위 내용은 docker-compose를 사용하여 CockroachDB에 어떻게 연결하나요?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:stackoverflow.com
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿