亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

如何在 Docker Compose 多容器應用程序中使用 GoCQL 連接到

如何在 Docker Compose 多容器應用程序中使用 GoCQL 連接到

Go
蕭十郎 2022-07-11 16:07:22
我正在嘗試構建一個使用用戶名和密碼身份驗證連接到 Cassandra 的應用程序的簡化示例。為此,我改編了docker-compose.yml來自https://hub.docker.com/r/bitnami/cassandra/的內容,如下所示:version: '2'services:  cassandra:    image: 'docker.io/bitnami/cassandra:3-debian-10'    ports:      - '7000:7000'      - '9042:9042'    volumes:      - 'cassandra_data:/bitnami'    environment:      - CASSANDRA_SEEDS=cassandra      - CASSANDRA_PASSWORD_SEEDER=yes      - CASSANDRA_PASSWORD=cassandra  backend:    build: .    environment:      - CASSANDRA_USERNAME=cassandra      - CASSANDRA_PASSWORD=cassandravolumes:  cassandra_data:    driver: local我的目錄結構在哪里.├── Dockerfile├── docker-compose.yml├── go.mod├── go.sum└── main.go多階段Dockerfile是FROM golang AS builderWORKDIR /go/src/app/COPY . .RUN GO111MODULE=on CGO_ENABLED=0 GOOS=linux go build -a -installsuffix cgo -o app .FROM alpine:latest  RUN apk --no-cache add ca-certificatesWORKDIR /root/COPY --from=builder /go/src/app/app .CMD ["./app"]  并main.go嘗試使用以下命令創建 Cassandra 會話gocql:package mainimport (    "log"    "os"    "github.com/gocql/gocql")func main() {    cluster := gocql.NewCluster("cassandra")    cluster.Authenticator = gocql.PasswordAuthenticator{        Username: os.Getenv("CASSANDRA_USERNAME"),        Password: os.Getenv("CASSANDRA_PASSWORD"),    }    if _, err := cluster.CreateSession(); err != nil {        log.Fatalf("CreateSession: %v", err)    }}用戶名和密碼都已設置為“cassandra”的默認值,如https://hub.docker.com/r/bitnami/cassandra/中的“連接到其他容器”示例中所示。問題是,如果我嘗試使用docker-compose build后跟運行這個多容器應用程序docker-compose up,我會收到以下錯誤:backend_1    | 2020/11/04 15:10:34 CreateSession: gocql: unable to create session: unable to discover protocol version: dial tcp 172.18.0.3:9042: connect: connection refused我不明白這里出了什么問題:主機名、端口號、用戶名和密碼似乎都正確。任何想法為什么連接被拒絕?
查看完整描述

1 回答

?
UYOU

TA貢獻1878條經驗 獲得超4個贊

Cassandra 需要幾秒鐘來啟動并開始接受連接;backend在準備好之前嘗試連接。如果您backend在一小段延遲后啟動(使用),您的配置工作正常(對我來說docker-compose start backend)。修改backend以重試連接對我來說可靠,即


for {

    _, err := cluster.CreateSession()

    if  err == nil {

        break

    }

    log.Printf("CreateSession: %v", err)

    time.Sleep(time.Second)

}

log.Printf("Connected OK")

日志:


backend_1    | 2020/11/04 17:53:23 CreateSession: gocql: unable to create session: unable to discover protocol version: dial tcp 172.26.0.2:9042: connect: connection refused

backend_1    | 2020/11/04 17:53:24 CreateSession: gocql: unable to create session: unable to discover protocol version: dial tcp 172.26.0.2:9042: connect: connection refused

.......

backend_1    | 2020/11/04 17:53:36 CreateSession: gocql: unable to create session: unable to discover protocol version: dial tcp 172.26.0.2:9042: connect: connection refused

backend_1    | 2020/11/04 17:53:37 Connected OK


查看完整回答
反對 回復 2022-07-11
  • 1 回答
  • 0 關注
  • 180 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號