我正在使用 weave 启动一些形成数据库集群的容器。通过执行以下操作,我已经在 EC2 中的两台主机上手动完成了这项工作:
$HOST1> weave launch
$HOST2> weave launch $HOST1
$HOST1> eval $(weave env)
$HOST2> eval $(weave env)
$HOST1> docker run --name neo-1 -d -P ... my/neo4j-cluster
$HOST2> docker run --name neo-2 -d -P ... my/neo4j-cluster
$HOST3> docker run --name neo-1 -d -P -e ARBITER=true ... my/neo4j-cluster
我可以检查日志,一切正常。
使用 ansible 时,我可以使用command: ...
模块和环境变量来完成上述工作:
- name: Start Neo Arbiter
command: 'docker run --name neo-2 -d -P ... my/neo4j-cluster'
environment:
DOCKER_HOST: 'unix:///var/run/weave/weave.sock'
基本上就是eval $(weave env)
这样。
但是,当我将docker
模块用于 ansible 时,即使docker_url
参数设置为您在上面看到的相同内容DOCKER_HOST
,DNS 也不会在主机之间解析。看起来是这样的:
- name: Start Neo Arbiter
docker:
image: "my/neo4j-cluster:{{neo4j_version}}"
docker_url: unix:///var/run/weave/weave.sock
name: neo-3
pull: missing
state: reloaded
detach: True
publish_all_ports: True
或者
- name: Start Neo Arbiter
docker:
image: "my/neo4j-cluster:{{neo4j_version}}"
docker_url: unix:///var/run/weave/weave.sock
name: neo-3
pull: missing
state: reloaded
detach: True
publish_all_ports: True
environment:
DOCKER_HOST: 'unix:///var/run/weave/weave.sock'
这些都不起作用。DNS 无法解析,因此服务器永远不会启动。我确实有其他服务器选项(例如 Neo4j 的 SERVER_ID 等,为简单起见,此处未显示)。
有人遇到这个吗?我知道用于 ansible 用途docker-py
和东西的 docker 模块。我想知道是否有某种与编织不兼容的类型?
编辑
我应该提到,当容器启动时,它们实际上出现在 WeaveDNS 中,并且似乎已添加到系统中。只要它在主机上,我就可以 ping 每个容器的本地主机名。但是,当我转到另一台主机时,它无法 ping 另一台主机上的主机。尽管他们在 WeaveDNS ( weave status dns
) 中注册并weave status
显示正确的对等点数和已建立的连接,但仍然如此。