登录
首页 >  Golang >  Go问答

当我运行 docker compose 时,我的 golang(摄取)容器失败并显示“建立 Mongo 会话时出错”

来源:stackoverflow

时间:2024-04-14 15:54:38 307浏览 收藏

亲爱的编程学习爱好者,如果你点开了这篇文章,说明你对《当我运行 docker compose 时,我的 golang(摄取)容器失败并显示“建立 Mongo 会话时出错”》很感兴趣。本篇文章就来给大家详细解析一下,主要介绍一下,希望所有认真读完的童鞋们,都有实质性的提高。

问题内容

我运行了 docker-compose up,我的 golang 容器出现错误,显示“建立 mongo 会话时出错”,然后容器退出。我不确定问题是否始于我的 golang 容器或 mongo。

此时我已经尝试了很多方法。这是我的 golang 容器的 docker 日志文件。

golang 的 docker 日志

to run in debug mode, run with '-d true' option

time="2019-08-20t20:12:12z" level=info msg="logging in info mode"
time="2019-08-20t20:12:12z" level=info msg="go version go1.7.3"
time="2019-08-20t20:12:12z" level=info msg="starting ingest service on port 4001"
time="2019-08-20t20:12:12z" level=info msg="koala version number: v19.33.0"
time="2019-08-20t20:12:23z" level=error msg="error establishing mongo session"
panic: no reachable servers

goroutine 1 [running]:
panic(0x933c00, 0xc4201b4f70)
        /usr/local/go/src/runtime/panic.go:500 +0x1a1
ingest/mongo.initdb(0x0, 0x0)
        /home/jsikala/documents/koala/go/src/ingest/mongo/mongo.go:34 +0x27e
main.setup()
        /home/jsikala/documents/koala/go/ingest.go:118 +0x3ce
main.main()
        /home/jsikala/documents/koala/go/ingest.go:56 +0x292

这是我运行 docker compose up 时遇到的错误。

这是我的docker-compose.yml文件。

version: "3"
volumes:
    data:
        external:
            name: ${mongo_volume_name}
services:
    rails:
        image: rails2
        container_name: koala_rails_${user}
        environment: 
            - koala_env
            - rails_port
            - koala_ingest_url=${ingest_protocol}://ingest:${ingest_port}
            - koala_mongo_url=mongo_service:27017
            - koala_redis_url=redis_service:6379
            - koala_pki_in_dev
            - koala_user_id_header
            - user
            - username
            - koala_register_user_url
            - koala_security_validator_url
            - cert_file_pem=/usr/src/app/certs/public.pem
            - private_cert_file_pem=/usr/src/app/certs/private-key.pem
            - ssl_ca_file=/usr/src/app/certs/ca.pem
            - logname
            - koala_secret_key_base
            - koala_mongo_username
            - koala_mongo_password
            - koala_help_url
            - koala_contact_email
            - koala_use_certs
            - bundle_gemfile
            - koala_server_url
            - rails_serve_static_files
            - rails_log_to_stdout
        ports:
            - "${rails_port}:${rails_port}"
        volumes:
            - ${cert_file_pem}:/usr/src/app/certs/public.pem
            - ${private_cert_file_pem}:/usr/src/app/certs/private-key.pem
            - ${ssl_ca_file}:/usr/src/app/certs/ca.pem
    mongo_service:
        image: mongo:3.2.0
        volumes:
            - data:/data/db
        ports:
            - "27017:27017"
    redis_service:
        image: redis:4.0.8
        ports:
            - "6379:6379"
    ingest:
        image: ingest
        container_name: koala_ingest_${user}
        extra_hosts:
            - csie.as.northgrum.com:10.8.131.12
        environment: 
            - koala_env
            - koala_config_file=/go/config.yml
            - ingest_port
            - logname
            - koala_mongo_url
            - koala_jira_url
            - koala_jira_session_url
            - cert_file_pem=/go/certs/public.pem
            - private_cert_file_pem=/go/certs/private-key.pem
            - ssl_ca_file=/go/certs/ca.pem
            - koala_redis_url=redis_service:6379
            - koala_use_certs
            - koala_mongo_username
            - koala_mongo_password
            - jira_username
            - jira_password
        ports:
            - "${ingest_port}:${ingest_port}"
        volumes:
            - ${cert_file_pem}:/go/certs/public.pem
            - ${private_cert_file_pem}:/go/certs/private-key.pem
            - ${ssl_ca_file}:/go/certs/ca.pem
        links:
            - mongo_service
        depends_on:
            - mongo_service
            - redis_service

注意:摄取是 golang 服务

这是我的 golang docker dockerfile

FROM golang:1.11.5

COPY . .

WORKDIR /go
COPY config.yml /go
RUN mkdir -p $WORKDIR/logs
RUN mkdir -p $WORKDIR/certs

RUN cd $WORKDIR

ENV PATH $PATH:$WORKDIR

CMD ["./runIngest"]

如果按预期运行,golang 将在 mongo 中摄取数据。知道是什么导致了这个问题吗?


解决方案


为了从 Golang 容器连接到 Mongo 容器,Mongo 主机必须设置为 mongo_service_name:mongo_port。并确保 Golang 容器可以访问 Mongo 容器(通过使用网络或链接指令)。

请在 ingest 服务中检查您的 KOALA_MONGO_URL

我不知道你的 ingest 服务中的 Mongo 客户端到底是什么。但正常情况下,KOALA_MONGO_URL 可能是 mongo_service:27017mongodb://mongo_service:27017/database_name

以上就是《当我运行 docker compose 时,我的 golang(摄取)容器失败并显示“建立 Mongo 会话时出错”》的详细内容,更多关于的资料请关注golang学习网公众号!

声明:本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>