Go 및 Docker-Compose를 사용하여 데이터베이스 마이그레이션
golang- migration 도구를 사용하여 마이그레이션을 실행하면 데이터베이스 스키마 일관성을 보장하는 데 도움이 될 수 있습니다. 그러나 Docker-Compose에서 --network 호스트가 더 이상 사용되지 않으면 마이그레이션을 실행할 때 문제에 직면할 수 있습니다. 이 문서에서는 업데이트된 구문에 적응하는 방법과 별도의 컨테이너에 있는 데이터베이스에 연결하는 방법을 살펴봅니다.
새로운 Docker-Compose 구문에 적응
실행하려면 --network 호스트 없이 마이그레이션하는 경우 docker-compose.yml에 다음 구성을 추가할 수 있습니다. file:
db: image: postgres networks: new: aliases: - database environment: POSTGRES_DB: mydbname POSTGRES_USER: mydbuser POSTGRES_PASSWORD: mydbpwd ports: - "5432" migrate: image: migrate/migrate networks: - new volumes: - .:/migrations command: ["-path", "/migrations", "-database", "postgres://mydbuser:mydbpwd@database:5432/mydbname?sslmode=disable", "up", "3"] links: - db networks: new:
이 구성에서는 new라는 네트워크가 생성되고 마이그레이션 서비스는 데이터베이스 별칭을 통해 db 서비스에 연결됩니다.
원격에 연결 데이터베이스
별도의 컨테이너에 있는 데이터베이스에 연결하려면 연결에 다음 형식을 사용하세요. 문자열:
"postgres://mydbuser:mydbpwd@database:5432/mydbname?sslmode=disable"
여기서 데이터베이스는 네트워크 구성에 정의된 별칭입니다. 이를 통해 마치 로컬에서 실행 중인 것처럼 원격 데이터베이스에 연결할 수 있습니다.
위 내용은 `--networkhost` 지원 중단 후 Go 및 Docker Compose를 사용하여 데이터베이스 마이그레이션을 실행하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!