Wercker服务未与主要容器相关联

时间:2016-03-01 01:23:44

标签: docker wercker

我遇到的 Wercker 问题是我的wercker.yml中的特定linked services没有链接到我的主Docker容器。

在我的节点应用程序在成功的 Wercker 部署之后没有在端口3001上运行时,我注意到了这个问题,在下面的图片中可以看到它的输出。

enter image description here

因此,我使用以下方式将SSH连接到我的服务器和运行在Wercker部署之后运行的docker容器中:

docker exec -i -t <my-container-name> ./bin/bash

在我的PM2日志中发现以下 MongoDB 错误:

[MongoError: connect EHOSTUNREACH 172.17.0.7:27017

奇怪的是,从下面的图片可以看出,我已经设置了每个相应服务所需的两个环境变量:

enter image description here

enter image description here

有没有人知道为什么即使设置了环境变量,也无法从我的主容器访问服务容器?

以下是我正在使用的wercker.yml文件。

box: node

services:
  - id: mongo
  - id: redis

build:
  steps:
    - npm-install

deploy:
  steps:
    - npm-install
    - script:
        name: install pm2
        code: npm install pm2 -g
    - internal/docker-push:
        username: $DOCKER_USERNAME
        password: $DOCKER_PASSWORD
        repository: /
        ports: "3001"
        cmd: /bin/bash -c "cd /pipeline/source && pm2 start processes_prod.json --no-daemon"
        env: "MONGO_PORT_27017_TCP_ADDR"=$MONGO_PORT_27017_TCP_ADDR,"REDIS_PORT_6379_TCP_ADDR"=$REDIS_PORT_6379_TCP_ADDR
    - add-ssh-key:
        keyname: DIGITAL_OCEAN_KEY
    - add-to-known_hosts:
        hostname: 
    - script:
        name: pull latest image
        code: ssh root@ docker pull /:latest
    - script:
        name: stop running container
        code: ssh root@ docker stop  || echo ‘failed to stop running container’
    - script:
        name: remove stopped container
        code: ssh root@ docker rm  || echo ‘failed to remove stopped container’
    - script:
        name: remove image behind stopped container
        code: ssh root@ docker rmi /:current || echo ‘failed to remove image behind stopped container’
    - script:
        name: tag newly pulled image
        code: ssh root@ docker tag /:latest /:current
    - script:
        name: run new container
        code: ssh root@ docker run -d -p 8080:3001 --name  /:current
    - script:
        name: env
        code: env

1 个答案:

答案 0 :(得分:1)

AFAIK Wercker服务仅在构建过程中可用,而不是在部署过程中可用。 Mongo和Redis是持久化数据存储 - 这意味着每次部署时都不应重新安装它们 因此,请确保在部署环境中手动设置Redis和Mongo。