使用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已经配置并且正在运行

Swarm: active
 NodeID: d9h5xa832ax7wzeq8q44fjld3
 Is Manager: true
 ClusterID: 9cztoin3gy2ntbwehsmrkjuxi
 Managers: 1
 Nodes: 3
 Orchestration:
  Task History Retention Limit: 5
 Raft:
  Snapshot Interval: 10000
  Heartbeat Tick: 1
  Election Tick: 3
 Dispatcher:
  Heartbeat Period: 5 seconds
 CA Configuration:
  Expiry Duration: 3 months
 Node Address: 10.25.190.209

从具有此代码的剧本开始

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

哪个叫这个角色:

- name: Deploy tpcds_tpg service to swarm
  docker_service:
    project_name: tpcds-tpg
    definition:
      version: '2'
      services:
        run_tests: 
          image: 'pbench/tpcds_tpg'
          volumes: 
            - /opt/pbench/run_output/
          command: ./run_jmeter.sh "{{jmeter_output_dir}}" 
  register: output
- debug: var=output

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

[pdo@sdl02133 tpcds-tpg]$docker ps -a
CONTAINER ID        IMAGE              COMMAND                  CREATED             STATUS              PORTS               NAMES
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相关文章