docker swarm 集群服务通信

前置要求

  1. 服务需要在同一个docker swarm集群中
  2. 服务需要处于同一个overlay网络上
  3. 服务需要暴露容器端口
  4. 有2个以上服务名不同的服务

服务部署流程(手动方式)

1、 创建overlay网络

1
2
docker network create
docker network ls

2、 创建swarm服务

1
2
docker service create --name ai_voice_engine-development --network lvdoo-networ
--replicas 1 --with-registry-auth ai_voice_engine-development:1.1.112

参数说明

  • network: 指定overloy网络,只有在同一网络中的服务才可以通过服务名+端口号进行通信
  • replicas: 可以理解为在swarm集群中会起多少个实例
  • with-registry-auth: 启动容器所指定的镜像

3、 暴露端口

1
docker service update --publish-add published=18088,target=18088 ai_voice_engine-development

参数说明

  • published:对外暴露的端口
  • target: 容器暴露的端口

自动化部署swarm服务

ansible脚本示例

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
- name: 概要信息
debug:
msg:
- "应用名: {{ application_name }}"
- "工作空间: {{ workspace_path }}"
- "服务名: {{ service_name }}"
- "是否重新创建服务: {{ is_recreate_service }}"
- "服务副本数量: {{ replicas }}"
- "镜像名: {{ image_name }}"
- "激活的Profiles: {{ active_profiles }}"
- "Swarm 网络名称: {{ lvdoo_network }}"
- name: 登录到仓库,准备拉取镜像
shell: "docker login -u root -p 123456 {{ hub_host }}"
- name: 拉取镜像
shell: "docker pull {{ image_name }}"
ignore_errors: yes
- name: 移除正在运行的Swarm服务
shell: "docker service rm {{ service_name }}"
when: is_recreate_service
ignore_errors: yes
- name: 检查Swarm此前是否已经创建该服务
shell: "docker service ls"
register: "docker_service_check_output"
- name: 创建新的Swarm服务 | 如果当前服务尚未创建
shell: "docker service create --name {{ service_name }} --network {{ lvdoo_network }}
--replicas {{ replicas }} --update-failure-action rollback --restart-max-attempts 3
--update-parallelism 1 --update-delay 10s --update-monitor 10s -e
'SPRING_PROFILES_ACTIVE={{ active_profiles }}' -e JAVA_OPTS='-Xmx512m'
--with-registry-auth {{ image_name }}"
when: 'service_name not in docker_service_check_output.stdout'
- name: 暴露端口 | 如果当前服务需要暴露指定端口
shell: "docker service update --publish-add published={{ application_exposed_port }},target={{ application_startup_port }} {{ service_name }} "
when: not( (application_exposed_port is undefined) or (application_exposed_port is none) or (application_exposed_port | trim == '') )
- name: 开启XXL-Job端口 | 如果当前服务指定了xxl-job端口
shell: "docker service update --publish-add published={{ xxl_port_to_expose }},target={{ xxl_port_in_container }} {{ service_name }} "
when: xxl_port_to_expose is defined
- name: 更新Swarm服务 | 如果当前服务此前已创建
shell: "docker service update {{ service_name }} --image {{ image_name }} --update-delay 10s"
when: 'service_name in docker_service_check_output.stdout'
- name: 暂停10秒,等待服务启动并准备收集日志
pause:
seconds: 10
- name: 检查服务启动状态
shell: "docker service ps {{ service_name }} -f 'desired-state=running' | grep -v ID "
register: "docker_swarm_service_status"
- name: 当前服务状态
debug:
msg:
- "{{ docker_swarm_service_status.stdout | to_yaml }}"
- name: 检查服务是否已经启动
fail:
msg: "服务未启动成功,请检查。"
when: docker_swarm_service_status.stdout == ""

测试容器间通信

已部署好两个docker swarm 服务,如下图:

服务名 容器内端口 对外暴露端口
ai_callcenter-development 8080 18084
ai_voice_engine-development 18088 18088

登录ai_callcenter-development 容器中

1
2
docker ps |grep ai_callcenter
docker exec -it 容器id /bin/bash

访问ai_voice_engine-development服务

注意:服务名+端口号,这个端口号是容器内的端口,而不是对外暴露的端口,这里正好两个端口是一致的。如下图所示,出现Hello world表示两个服务间通信成功。

项目中docker swarm实践的更多相关文章

  1. 在Java项目中整合Scala

    Scala是一个运行在Java JVM上的面向对象的语言.它支持函数编程,在语法上比Java更加灵活,同时通过Akka库,Scala支持强大的基于Actor的多线程编程.具有这些优势,使得我最近很想在 ...

  2. Docker Swarm和Kubernetes在大规模集群中的性能比较

    Contents 这篇文章主要针对Docker Swarm和Kubernetes在大规模部署的条件下的3个问题展开讨论.在大规模部署下,它们的性能如何?它们是否可以被批量操作?需要采取何种措施来支持他 ...

  3. Docker在云环境中的应用实践初探:优势、局限性与效能评测

    作者 商之狄 发布于 2014年11月10日 本文依据笔者所在团队的一些近期开发和应用的实践,整理出一些有意义的信息,拿出来和社区分享.其中既包括在云端应用Docker与相关技术的讨论,同时也有实施过 ...

  4. 生产环境中使用Docker Swarm的一些建议

    译者按: 实践中会发现,生产环境中使用单个Docker节点是远远不够的,搭建Docker集群势在必行.然而,面对Kubernetes, Mesos以及Swarm等众多容器集群系统,我们该如何选择呢?它 ...

  5. Docker Swarm 中最重要的概念- 每天5分钟玩转 Docker 容器技术(94)

    从主机的层面来看,Docker Swarm 管理的是 Docker Host 集群.所以先来讨论一个重要的概念 - 集群化(Clustering). 服务器集群由一组网络上相互连接的服务器组成,它们一 ...

  6. Docker 系列六(Docker Swarm 项目).

    一.前言 随着互联网快速发展,以及微服务架构的流行,服务器的压力越来越大.上一篇介绍的 Docker Compose 项目,可以将多个容器捏合在一起,实现容器间的通信,比如 Web 项目对 DB.Ca ...

  7. docker swarm实现java项目的发布/滚动更新/回滚/镜像管理

    使用docker swarm滚动更新java项目,部署集群,这一切的前提是使用Jenkins+maven进行项目打包,分发等功能 具体可以参考我的另外三篇文章 https://www.cnblogs. ...

  8. docker 实践九:docker swarm

    介绍了 docker 三剑客中的 docker-machine 和 docker-compose 之后,就剩下一个 docker swarm 了.那本篇的主角就是它了. 注:环境为 CentOS7,d ...

  9. Java SpringBoot 项目构建 Docker 镜像调优实践

    PS:已经在生产实践中验证,解决在生产环境下,网速带宽小,每次推拉镜像影响线上服务问题,按本文方式构建镜像,除了第一次拉取.推送.构建镜像慢,第二.三-次都是几百K大小传输,速度非常快,构建.打包.推 ...

随机推荐

  1. kaggle——TMDB 电影票房收入预测

    介绍 看电影是目前人们休闲娱乐,消遣时光的选择之一.我们都知道,有些电影的票房很高,有的电影票房却很低,那么决定票房的因素是什么呢?本次将介绍,如何根据电影上映前的一些信息来预测出该电影的票房. 知识 ...

  2. maven项目编译报错处理

    1.问题一: [ERROR] Failed to execute goal on project data-common: Could not resolve dependencies for pro ...

  3. 吴裕雄--天生自然MySQL学习笔记:MySQL GROUP BY 语句

    GROUP BY 语句根据一个或多个列对结果集进行分组. 在分组的列上我们可以使用 COUNT, SUM, AVG,等函数. GROUP BY 语法 SELECT column_name, funct ...

  4. SQL基础教程(第2版)第3章 聚合与排序:3-1 对表进行聚合查询

    3-1 对表进行聚合查询 ● 使用聚合函数对表中的列进行计算合计值或者平均值等的汇总操作.● 通常,聚合函数会对NULL以外的对象进行汇总.但是只有COUNT函数例外,使用COUNT(*)可以查出包含 ...

  5. [FJOI2015]火星商店问题(线段树分治+可持久化Trie)

    重新写一年前抄题解的那题,当时我啥都不会只是Ctrl+C,Ctrl+V写过的题,今天重新写一遍. 题解: 不会线段树分治,还是学一下这东西吧,这是我的第一道线段树分治. 首先对于特殊商品,可以直接可持 ...

  6. 使用cropper插件裁剪并上传图片(Spring mvc)

    cropper是一款使用简单且功能强大的图片剪裁jQuery插件.该图片剪裁插件支持图片放大缩小,支持图片旋转,支持触摸屏设备,支持canvas,并且支持跨浏览器使用. cropper有两种方式上传截 ...

  7. header() 被用来发送自定义的 HTTP 报文

    header() 被用来发送自定义的 HTTP 报文.关于HTTP报文的更多信息请参考» HTTP/1.1 specification. 请注意一点header()必须在任何实际输出之前调用,不管是普 ...

  8. 你需要了解的JIT Debugging

    原总结debug调试dump转储文件windbgprocdumpJIT Debugger 如果你还不清楚什么是转储文件,不知道什么时候需要转储文件,请参考转储文件系列文章的第一篇 -- 转储文件知多少 ...

  9. 通过OAuth2.0 获取授权访问SF 用户数据

    站长资讯: 创建应用程序 新建应用程序   访问示例(Python+django) 环境准备: index.html 两种方式: 方式一:采用由用户授权,调用者无需知道SF的用户名与密码 方式二:直接 ...

  10. tensorflow object detection api android

    https://blog.csdn.net/weixin_40355324/article/details/80651350