物联网架构成长之路(24)-Docker练习之Compose容器编排

0.前言
  一开始学的之后,是想一步到位直接上Kubernetes(K8s)的,后面没想到,好像有点复杂,有些概念不是很懂。因此学习东西还是要循序渐进,慢慢来。先了解单机编排技术Docker Compose,了解一些技术细节及原理后,在入手K8s。还是不能一口吃成胖子,要多吃几口才可以。而且目前公司都是一些小项目,能用得上DockerCompose已经很不错了,还想要上K8s,估计是不现实的。

 

1. 安装

  可以通过运行下面命令进行安装,

1 curl -L https://github.com/docker/compose/releases/download/1.23.1/docker-compose-`uname -s`-`uname -m` -o docker-compose
2 chmod +x docker-compose
3 mv docker-compose /usr/local/bin

  安装Tab自动补全

curl -L https://raw.githubusercontent.com/docker/compose/1.23.1/contrib/completion/bash/docker-compose -o /etc/bash_completion.d/docker-compose

  由于我看得是《Spring Cloud与Docker微服务架构实战 第二版》这本书,里面刚好有个例子,这里就用这个做练手。

1 git clone https://github.com/itmuch/spring-cloud-docker-microservice-book-code-docker/
2 cd spring-cloud-docker-microservice-book-code-docker
3 cd docker-1-simple
4 mvn clean package docker:build

  里面的每个微服务都构建成一个Docker Image,然后就可以开干了。

 

2. 简单例子

  从一个简单的例子开始
  Dockerfile 文件

1 FROM java:latest
2 VOLUME /tmp
3 ADD microservice-discovery-eureka-0.0.1-SNAPSHOT.jar app.jar
4 RUN bash -c 'touch /app.jar'
5 EXPOSE 9000
6 ENTRYPOINT ["java", "-Djava.security.egd=file:/dev/./urandom", "-jar", "/app.jar"]

  docker-compose.yml 文件

1 version: '3'
2 services:
3     eureka:
4         build: .
5         ports:
6             - "8761:8761"

  执行 docker-compose up

  从下图可以看出,docker-compose 执行后,分别创建了 compose_eureka Image, compose_default Network, compose_eureka_1_b5 Container

  以上就是入门了,关于docker-compose更多的语法,这里就不展开了,具体肯定是参考其他博客,或者官方文档吧

 

3. 实战练习

  参考书本上的例子进行练习

  3.1 基于Spring Boot微服务的Compose编写

  这里要使用上述 github 代码里 docker-1-simple 这个目录下的代码进行编译

 1 version: '3'
 2 services:
 3     discovery:
 4         image: registry.cn-shenzhen.aliyuncs.com/wunaozai/microservice-discovery-eureka:0.0.1-SNAPSHOT
 5         ports:
 6             - "8761:8761"
 7     microservice-provider-user:
 8         image: registry.cn-shenzhen.aliyuncs.com/wunaozai/microservice-provider-user:0.0.1-SNAPSHOT
 9     microservice-consumer-movie-ribbon-hystrix:
10         image: registry.cn-shenzhen.aliyuncs.com/wunaozai/microservice-consumer-movie-ribbon-hystrix:0.0.1-SNAPSHOT
11     microservice-gateway-zuul:
12         image: registry.cn-shenzhen.aliyuncs.com/wunaozai/microservice-gateway-zuul:0.0.1-SNAPSHOT
13     microservice-hystrix-dashboard:
14         image: registry.cn-shenzhen.aliyuncs.com/wunaozai/microservice-hystrix-dashboard:0.0.1-SNAPSHOT
15         ports:
16             - "8030:8030"
17     microservice-hystrix-turbine:
18         image: registry.cn-shenzhen.aliyuncs.com/wunaozai/microservice-hystrix-turbine:0.0.1-SNAPSHOT

  运行后,就启动对应的6个Image,以下是运行后效果

  使用之前的weave scope工具查看docker, 可以看到5个微服务通过Spring Boot的Eureka连接在一起了。还有一个microservice-hystrix-dashboard这个没有在里面是因为这个是一个仪表盘(Dashboard),不属于实际业务,所以代码里面没有关联起来,实际上是已启动的。
  从图中还可以看到,后面的那两个集群etcd和elasticsearch,这两个是之前做练习时创建的。初学者,利用这个weave scope工具来查看和监控,挺好用的。

  3.2 基于Eureka高可用(HA)的Compose编写

  这里要使用上述 github 代码里 docker-2-eureka-ha 这个目录下的代码进行编译

 1 version: "3"
 2 services:
 3   peer1:      # 默认情况下,其他服务可使用服务名称连接到该服务。对于peer2节点,它需连接http://peer1:8761/eureka/,因此,我们可配置该服务的名称为peer1。
 4     image: registry.cn-shenzhen.aliyuncs.com/wunaozai/microservice-discovery-eureka-ha:0.0.1-SNAPSHOT
 5     ports:
 6       - "8761:8761"
 7     environment:
 8       - spring.profiles.active=peer1
 9   peer2:
10     image: registry.cn-shenzhen.aliyuncs.com/wunaozai/microservice-discovery-eureka-ha:0.0.1-SNAPSHOT
11     hostname: peer2
12     ports:
13       - "8762:8762"
14     environment:
15       - spring.profiles.active=peer2
16 
17 ## 使用Compose编排高可用的Eureka Server

  通过Eureka自带的Dashboard可以看到启动的两个容器已经互相注册,实现高可用(HA)功能

  3.3 基于Spring Boot微服务集群及动态伸缩的Compose编写

  这里要使用上述 github 代码里 docker-3-complex 这个目录下的代码进行编译,要在每个项目的根目录下,执行 mvn clean package docker:build

 1 version: "3"
 2 services:
 3   peer1:
 4     image: itmuch/microservice-discovery-eureka-ha:0.0.1-SNAPSHOT
 5     ports:
 6       - "8761:8761"
 7     environment:
 8       - spring.profiles.active=peer1
 9   peer2:
10     image: itmuch/microservice-discovery-eureka-ha:0.0.1-SNAPSHOT
11     hostname: peer2
12     ports:
13       - "8762:8762"
14     environment:
15       - spring.profiles.active=peer2
16   microservice-provider-user:
17     image: itmuch/microservice-provider-user:0.0.1-SNAPSHOT
18   microservice-consumer-movie-ribbon-hystrix:
19     image: itmuch/microservice-consumer-movie-ribbon-hystrix:0.0.1-SNAPSHOT
20   microservice-gateway-zuul:
21     image: itmuch/microservice-gateway-zuul:0.0.1-SNAPSHOT
22   microservice-hystrix-turbine:
23     image: itmuch/microservice-hystrix-turbine:0.0.1-SNAPSHOT

  通过Eureka的Dashboard查看

  仔细查看下图,可以观察到各个Container间箭头的指向,用于理解Spring Boot各个微服务间关系

  执行以下命令,为各个微服务动态扩容。让各个微服务都执行3个实例,由于docker-compose版本问题,建议使用 --scale 参数来设置启动实例。

1 docker-compose up --scale microservice-provider-user=3 \
2     --scale microservice-consumer-movie-ribbon-hystrix=3 \
3     --scale microservice-gateway-zuul=3 \
4     --scale microservice-hystrix-turbine=3

  Eureka的Dashboard查看

 


  3.4 修改之前博客中的etcd集群配置,改为docker-compose方式启动(自己实践)

 1 version: "3"
 2 services:
 3     etcd01:
 4         image: etcd:3.3
 5         ports:
 6             - "10001:2379"
 7             - "10011:2380"
 8         #volumes:
 9         #- "/root/workspace/docker/k8s/etcd/data11:/data"
10         command:
11             - /bin/etcd
12             - --data-dir
13             - /data
14             - -name
15             - etcd01
16             - -advertise-client-urls
17             - http://etcd01:2379
18             - -listen-client-urls
19             - http://0.0.0.0:2379
20             - -initial-advertise-peer-urls
21             - http://etcd01:2380
22             - -listen-peer-urls
23             - http://0.0.0.0:2380
24             - -initial-cluster-state
25             - new
26             - -initial-cluster-token
27             - docker-etcd
28             - -initial-cluster
29             - etcd01=http://etcd01:2380,etcd02=http://etcd02:2380,etcd03=http://etcd03:2380
30     etcd02:
31         image: etcd:3.3
32         ports:
33             - "10002:2379"
34             - "10012:2380"
35         #volumes:
36         #- "/root/workspace/docker/k8s/etcd/data22:/data"
37         command:
38             - /bin/etcd
39             - --data-dir
40             - /data
41             - -name
42             - etcd02
43             - -advertise-client-urls
44             - http://etcd02:2379
45             - -listen-client-urls
46             - http://0.0.0.0:2379
47             - -initial-advertise-peer-urls
48             - http://etcd02:2380
49             - -listen-peer-urls
50             - http://0.0.0.0:2380
51             - -initial-cluster-state
52             - new
53             - -initial-cluster-token
54             - docker-etcd
55             - -initial-cluster
56             - etcd01=http://etcd01:2380,etcd02=http://etcd02:2380,etcd03=http://etcd03:2380
57     etcd03:
58         image: etcd:3.3
59         ports:
60             - "10003:2379"
61             - "10013:2380"
62         #volumes:
63         #- "/root/workspace/docker/k8s/etcd/data33:/data"
64         command:
65             - /bin/etcd
66             - --data-dir
67             - /data
68             - -name
69             - etcd03
70             - -advertise-client-urls
71             - http://etcd03:2379
72             - -listen-client-urls
73             - http://0.0.0.0:2379
74             - -initial-advertise-peer-urls
75             - http://etcd03:2380
76             - -listen-peer-urls
77             - http://0.0.0.0:2380
78             - -initial-cluster-state
79             - new
80             - -initial-cluster-token
81             - docker-etcd
82             - -initial-cluster
83             - etcd01=http://etcd01:2380,etcd02=http://etcd02:2380,etcd03=http://etcd03:2380
View Code

  测试,实际效果是,对3个节点的增删改查操作都是等效的

curl http://127.0.0.1:10001/v2/keys/hello -XPUT -d value="hello world"

 

4. 小结

  这几天的练习与了解,算是对Docker及Docker Compose有了一定的了解,接下来,就以实际项目中需要用到的服务构建成一个个Docker Image并推送到阿里云容器私有仓库上。初期会构建的有STUN服务、Nginx-RTMP服务、EMQ-MQTT服务、Redis与MongoDB服务,暂时会先构建这几个服务。服务间还涉及到认证与鉴权的,还会写代码,业务代码应该还是用Spring Cloud全家桶,以练促学,未来之路,任重而道远呀!加油!

 

本文地址: https://www.cnblogs.com/wunaozai/p/9936306.html

转载于:https://www.cnblogs.com/wunaozai/p/9936306.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/366720.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

CSS原理解析之模型篇

写在前面:尝试回答几个问题:什么是盒模型,控制盒模型的属性有哪些?Margin、Padding、Border、Width、Height这些属性改变/影响盒模型,但每个属性都会在所有元素上生效么?如果存在区别,那么和元素…

Quartz遇到的问题

本文首次发布于My Blog,作者张琦(Ian),转载请保留原文链接。 有状态和无状态 使用有状态(StatefulJob)还是无状态的任务(Job) 在 Quartz 中,基本来说,任务分为有状态和无状态两种。实现 Job 接口的任务缺省…

android baseactivity,Android应用开发Android通过BaseActivity获取到当前启动的Activity名称...

本文将带你了解Android应用开发Android通过BaseActivity获取到当前启动的Activity名称&#xff0c;希望本文对大家学Android有所帮助。<在BaseActivity的onCreate方法中:public class BaseActivity extends AppCompatActivity { Override protected void onCreate(Nul…

RIP RETE时间获得PHREAKY

我刚刚完成了我称为PHREAK的新规则算法的一些高级文档&#xff0c;这是混合推理中的一个文字游戏。 它仍然有点粗糙和高水平&#xff0c;但希望仍然很有趣。 它建立在ReteOO之上&#xff0c;非常好阅读。 ReteOO算法 ReteOO是在3、4和5系列发行版中开发的。 它采用RETE算法并应…

Hadoop自学笔记(三)MapReduce简单介绍

1. MapReduce Architecture MapReduce是一套可编程的框架&#xff0c;大部分MapReduce的工作都能够用Pig或者Hive完毕。可是还是要了解MapReduce本身是怎样工作的&#xff0c;由于这才是Hadoop的核心&#xff0c;而且能够为以后优化和自己写做准备。 Job Client, 就是用户 Job …

洛谷 P2051 [AHOI2009]中国象棋 解题报告

P2051 [AHOI2009]中国象棋 题目描述 这次小可可想解决的难题和中国象棋有关&#xff0c;在一个N行M列的棋盘上&#xff0c;让你放若干个炮&#xff08;可以是0个&#xff09;&#xff0c;使得没有一个炮可以攻击到另一个炮&#xff0c;请问有多少种放置方法。大家肯定很清楚&am…

VirtualDOM与diff(Vue实现)

写在前面 因为对Vue.js很感兴趣&#xff0c;而且平时工作的技术栈也是Vue.js&#xff0c;这几个月花了些时间研究学习了一下Vue.js源码&#xff0c;并做了总结与输出。文章的原地址&#xff1a;https://github.com/answershuto/learnVue。在学习过程中&#xff0c;为Vue加上了…

使用Java的RESTful Web服务

REST代表“代表性状态转移”&#xff0c;由Roy Fielding于2000年在其论文“建筑风格和基于网络的软件体系结构设计”中首次提出。 REST是一种建筑风格。 HTTP是一种协议&#xff0c;其中包含一组REST体系结构约束。 REST基础 REST中的所有内容都被视为资源。 每个资源都由UR…

android 基础应用程序,android应用程序基本实现(基础篇).ppt

《android应用程序基本实现(基础篇).ppt》由会员分享&#xff0c;可在线阅读&#xff0c;更多相关《android应用程序基本实现(基础篇).ppt(22页珍藏版)》请在人人文库网上搜索。1、Android应用程序基本实现,复杂的应用,上节课&#xff0c;我们实现了一个基本的android的应用程序…

windows npm安装webpack

Webpack: Webpack 是一个前端资源加载/打包工具。 它将根据模块的依赖关系进行静态分析&#xff0c;然后将这些模块按照指定的规则生成对应的静态资源。 参考下图&#xff1a; 安装Webpack: 1.首先需要安装node.js&#xff08;npm&#xff09; 下载地址&#xff1a;node.js dow…

ThreadLocal如何实现?

这是我上周的帖子的后续文章&#xff0c;在那篇文章中我解释了ThreadLocal用法的动机 。 从帖子中我们可以回想起&#xff0c;如果您希望每个线程都有一个独立初始化的变量副本&#xff0c;则ThreadLocal确实是一个很酷的概念。 现在&#xff0c;好奇的人可能已经开始问“我如何…

WPFの操作文件浏览框几种方式

WPFの操作文件浏览框几种方式 原文:WPFの操作文件浏览框几种方式方式1&#xff1a; 使用win32控件OpenFileDialog Microsoft.Win32.OpenFileDialog ofd new Microsoft.Win32.OpenFileDialog(); ofd.DefaultExt ".xml"; ofd.Filter "xml file|*.xml"; if…

为什么你应该尝试@reach/router

最近react-router的一个作者另外写了一个类react-router的组件 reach/router&#xff0c;尝试后感觉太棒了。如果你的项目只是web端的话我认为可以把你的react-router换掉了。下面是我到目前看到的所有非常好的点。 小&#xff0c;就4kb,压缩后比react-router小40kb左右。 更少…

android 浏览器 div穿透,解决IE 上重叠div 对 mouseover 事件的穿透方法之一

解决IE 下重叠div 对 mouseover 事件的穿透方法之一? ? ? ? 历经一天半的时间&#xff0c;我这前端的白痴终于想到了一个解决IE 下重叠div ?对 mouseover 事件的穿透方法。??现象&#xff1a; 两个并列关系的Div(没有父子关系)&#xff0c;但是两个Div在位置上面有重叠&…

类加载器工作机制

类加载器工作机制&#xff1a;1.装载&#xff1a;将Java二进制代码导入jvm中&#xff0c;生成Class文件。2.连接&#xff1a;a&#xff09;校验&#xff1a;检查载入Class文件数据的正确性 b&#xff09;准备&#xff1a;给类的静态变量分配存储空间 c&#xff09;解析&#xf…

webviewjavascriptbridge android ios,js与ios交互使用WebViewJavascriptBridge如何写多个函数

//js与webview交互初始化function setupWebViewJavascriptBridge(callback) {if (window.WebViewJavascriptBridge) {return callback(WebViewJavascriptBridge);}if (window.WVJBCallbacks) {return window.WVJBCallbacks.push(callback);}window.WVJBCallbacks [callback];v…

JavaFX中的塔防

我想长时间使用我的游戏引擎来编写《塔防》游戏&#xff0c;但是由于另一个小组努力创建JavaFX《塔防》游戏&#xff0c;所以我认为我宁愿创建另一款游戏。 从邮件列表中&#xff0c;我了解到不再开发其他游戏。 因此&#xff0c;我决定尝试一下。 塔防是一款非常适合基于图块…

CSS pointer-events属性的使用

楔子 在前端的开发中&#xff0c;我们都是直接与用户接触&#xff0c;应该尽量让用户感到操作畅快愉悦&#xff0c;获得类似native的感觉。其中动画是最常用的方法。 这里的需求是&#xff0c;弹层的设计&#xff0c;这个弹层希望可以像 native 上的弹层一样&#xff0c;点击…

海思NB-IOT的SDK看门狗的使用

1. 看门狗需要喂狗&#xff0c;如果自己写的任务一直运行&#xff0c;那么空闲任务无法运行会导致看门狗复位&#xff0c;来看下看门狗的机制&#xff0c;首先系统启动的时候创建了空闲任务 在这个函数里面void vTaskStartScheduler( void )创建了下面的空闲任务 xReturn xTas…

分布式Session框架

分布式Session框架 配置服务器&#xff0c;Zookeeper集群管理服务器可以统一管理所有服务器的配置文件共享这些Session存储在一个分布式缓存中&#xff0c;可以随时写入和读取&#xff0c;而且性能要很好&#xff0c;如Memcache&#xff0c;Tair。封装一个类继承自HttpSession&…