设为首页 收藏本站
查看: 952|回复: 0

[经验分享] 微服务实践三: 服务编排

[复制链接]

尚未签到

发表于 2018-1-5 18:52:20 | 显示全部楼层 |阅读模式
物理机部署
传统发布流程(以Java spring boot为例)

  • 编译jar包
  • 分发到服务器A,B,C
  • 服务启动,监听到指定端口
  • 配置负载均衡到已启动服务端口
  • 服务发布成功
  关于服务更新,为了实现滚动更新,可以让LB绑定的服务逐渐更新
传统更新流程

  • 编译jar包
  • 分发到服务器A,B,C
  • 将服务器A从LB上解绑,更新服务器A上的服务
  • 启动服务,通过健康检查和QA之后,将服务器A绑定到LB上
  • 继续更新服务器B和C
  • 服务完全更新成功
拓容流程

  • 新增机器节点
  • 启动jar包
  • 将新节点注册到LB上
特点

  • 单机端口有限,同一个服务如果在同一个服务器更新,需要不同的端口
  • 动态更新LB
  • 拓容成本高
服务化部署(这里以kubernetes为例)
k8s发布流程

  • 构建docker镜像
  • 创建deployment和service,可以限制服务的CPU、Memory等资源,k8s寻找空闲节点启动服务
  • 更新iptables将物理机上指定端口路由到VIP(虚拟服务IP)
  • 绑定物理机端口到LB
k8s更新流程

  • 构建docker镜像
  • 更新deployment和service,k8s更新某个pod
  • 轮流更新pod,直到所有pod更新完成
k8s拓容

  • 寻找空闲节点启动服务,直到达到指定数量
特点

  • 几乎无物理端口限制(k8s需要物理端口作为转发,默认为30000+,数量有限)
  • 服务间通信,可以使用serviceName或者服务的VIP进行访问,内网访问更方便
  • 虚拟化物理机资源,隔离物理资源的细节,资源控制如拓容、服务资源限制方便
Kubernetes vs Docker swarm

  • 稳定性上,k8s上基于iptables的网络路由比docker swarm的网络更加稳定
  • 配置性上,k8s比docker swarm要复杂,swarm采用manager-worker架构,由manager调度worker,docker 1.12以上对于swarm原生支持,方便启动集群,不过k8s在新版本之后也越来越易于配置
  • 管理系统上,swarm比k8s的UI界面更友好,操作性更强
微服务架构下的应用

  • 外部访问可以暴露gateway到LB上,外部通过访问LB进行访问
  • 使用k8s或者swarm,服务间通信可以使用serviceName进行访问,也可以利用容器的IP,使用服务注册进行服务查询
  • 自动拓容,当检测到服务的CPU和内存利用率升高,通过水平拓展,增加服务节点;服务压力减少后,逐渐减少服务节点数量

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-432002-1-1.html 上篇帖子: Kubernetes1.6本周正式发布 下篇帖子: K8s client 使用
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表