使用Ansible docker_service模块将服务部署到swarm

前端之家收集整理的这篇文章主要介绍了使用Ansible docker_service模块将服务部署到swarm前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

我正在尝试将一个Docker服务部署到swarm中但最终总是在我的localhost上运行容器(我用作docker swarm管理器的那个)并且没有服务

这是我的设置:

我有3个节点Docker(v.1.12.2)swarm,其中包括一个作为管理器运行的主机和两个全部运行在CentOS 7上的工作节点.在管理器节点(localhost)上运行Ansible(v.2.1.1.0)playbook和swarm已经配置并且正在运行

  1. Swarm: active
  2. NodeID: d9h5xa832ax7wzeq8q44fjld3
  3. Is Manager: true
  4. ClusterID: 9cztoin3gy2ntbwehsmrkjuxi
  5. Managers: 1
  6. Nodes: 3
  7. Orchestration:
  8. Task History Retention Limit: 5
  9. Raft:
  10. Snapshot Interval: 10000
  11. Heartbeat Tick: 1
  12. Election Tick: 3
  13. Dispatcher:
  14. Heartbeat Period: 5 seconds
  15. CA Configuration:
  16. Expiry Duration: 3 months
  17. Node Address: 10.25.190.209

从具有此代码的剧本开始

  1. - hosts: localhost
  2. name: Run JMeter test
  3. vars_files:
  4. - user.config.yml
  5. vars:
  6. execute_tpcds_test : "{{ run_tpcds_test }}"
  7. roles:
  8. - { role: run_jmeter,when: execute_tpcds_test is defined and execute_tpcds_test ==1 }

哪个叫这个角色:

  1. - name: Deploy tpcds_tpg service to swarm
  2. docker_service:
  3. project_name: tpcds-tpg
  4. definition:
  5. version: '2'
  6. services:
  7. run_tests:
  8. image: 'pbench/tpcds_tpg'
  9. volumes:
  10. - /opt/pbench/run_output/
  11. command: ./run_jmeter.sh "{{jmeter_output_dir}}"
  12. register: output
  13. - debug: var=output

当我运行ansible-playbook ./site.yml时,我最终得到一个正在运行的容器.做docker ps -a显示

  1. [pdo@sdl02133 tpcds-tpg]$docker ps -a
  2. CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
  3. fef245b41365 pbench/tpcds_tpg "./run_jmeter.sh /opt" 21 seconds ago Up 20 seconds tpcdstpg_run_tests_1

并且做Docker服务ls显示没有服务正在运行,所以看起来像docker_service将我的图像部署为本地容器​​而不是作为群上的服务

所以我的假设是如果我在机器上有一个活跃的swarm是一个swarm管理器并且我使用Ansible docker_service模块,那么它将自动知道swarm并将服务部署到它.看起来我的假设是错误的,我找不到任何文件,博客文章等会暗示我该做什么和我缺少什么. Ansible专家请帮忙!

最佳答案
终于找到了答案.基本上我在最后一段中的假设是错误的.至少现在(是.事实证明,ansible的docker_service只是docker compose的一个包装,而且(非常不幸的是)在编写时并没有与docker swarm集成.根据this support thread,我基本上没有运气
如果你有兴趣,同样的线程gives a possible workaround

猜你在找的Docker相关文章