文档章节

Java高可用集群架构与微服务架构简单分析

yzChen233
 yzChen233
发布于 10/28 18:48
字数 1226
阅读 1659
收藏 21

可能大部分读者都在想,为什么在这以 dubbo、spring cloud 为代表的微服务时代,我要还要整理这种已经“过时”高可用集群架构?

本人工作上大部分团队都是7-15人编制的开发团队,对应的公司项目也大都是中小型项目,最大的项目 PV/UV 也就只有 10w/2w 。在这样的场景下,中小型公司一般都是创业起步没多久,大部分都需要本着“开源节流”、“以最小的成本把产出最大化”。微服务架构相比于高可用集群架构,个人理解,对于技术团队的成员编制相对要多一点,服务器部署成本相对也要高一点。

作为技术团队负责人,肯定要为企业整体成本考虑,否则要不了多久,便是讨薪大军的一员了吧。。。

一、如何选择

1、高可用集群

适用于中小型创业公司项目架构,小型技术团队快速迭代版本发布部署需求,前期低成本运行,爆发时可通过投入适量成本横向扩容服务器抗压。

特点:

  • 前期技术开发成本低
  • 一定的服务器扩容成本
  • 核心团队编制及技能要求较少
  • 项目发布部署基本无依赖,时间成本低
  • 服务器运维成本一般
  • 大而全的项目模块分离设计
  • 更省更稳的技术架构选择
  • 微服务架构强迫症不适用

2、微服务架构

适用于业务架构较大的中大型科技公司项目架构,系统可拆分多个项目单独运营,大型技术团队、平台产品规范化管理,前期投入一定的成本,可以低成本扩容指定服务的服务器抗压。

  • 前期一定的技术开发成本
  • 较低的服务器扩容成本
  • 核心团队编制及技能要求较高
  • 项目发布部署存在依赖,逐个部署,时间成本较高
  • 服务器运维成本一般或较高
  • 较清晰的项目模块分离设计
  • 更潮更时尚的技术架构选择

二、高可用集群架构

1、必备服务器清单

  • 负载均衡服务器
  • web项目服务器
  • 缓存服务器
  • 数据库服务器(主备)

注意:可能有人会问,若是小型项目单机服务,负载均衡是否就不需要?负载均衡主要工作是分发请求到源服务器,另一个作用也是为了保护源服务器,不暴露服务器真实IP,大幅度降低服务器被DDoS攻击的风险,可参考《被人DDoS攻击了,分析一下原理和防护》 一文。

2、扩展服务器清单

  • 更多web项目服务器(集群负载)
  • 异步服务服务器(配置中心、消息队列、job任务等)
  • 数据库服务器(读写分离、主从复制)
  • 文件服务器

2、架构图

集群架构图

三、微服务架构

1、服务器清单

  • dubbo / spring cloud 全家桶组件服务器
  • 负载均衡服务器
  • A模块 web项目服务器
  • B模块 web项目服务器
  • C模块 web项目服务器
  • XXX模块 web项目服务器
  • 缓存服务器
  • 数据库服务器
  • 文件服务器
  • 异步服务服务器(配置中心、消息队列、job任务等)

2、架构图

微服务架构

注:图片来源 http://yun.itheima.com/open/217.html

四、总结

综上,我们对于高可用集群和微服务架构做了简单的场景和架构图分析,并不是说什么场景下一定要用什么架构,也不是说什么最潮流就用什么架构,而是根据实际成本和产出作为出发点做选择。

创业公司刚起步,资金可能也就百来万,搞微服务架构,光技术团队和服务器一个月的成本就占了公司一大头,产品还没上线,公司就已经倒闭了;

有资源的公司,动不动就能获得千万级甚至更高级别的融资,业务方向众多,若还只是用高可用架构,所有的业务模块都臃肿在一个项目里,不论是代码管理还是人员管理上,都是巨大的资源消耗。

My Blog

blog.guijianpan.com

技术交流

weixin-x175.jpg

© 著作权归作者所有

yzChen233

yzChen233

粉丝 58
博文 13
码字总数 13943
作品 1
长沙
部门经理
私信 提问
加载中

评论(10)

MrPei
MrPei
你说的我也懂,就差个创业想法了
yzChen233
yzChen233 博主
看来兄弟不缺资金啊。😏
MrPei
MrPei
资金都是吹来的
卡布达巨人
卡布达巨人
微服务。。从我给了预算方案后就被拒绝了o_O
像规模点的一些微服务会有自己的主从数据库,跨库查询和跨库事务也需要加组件解决咯
yzChen233
yzChen233 博主
预算方案做出来,算一下还是很恐怖的。服务器之类的支出,一般都按年付,最可怕的还是人力成本,多一个后端开发,一般月薪至少一万多,一年下来就是十几万,也就是一个人开发的工资成本,足以支撑中小型规模平台的一年服务器支出。
我叫金正恩
我叫金正恩
你需要的是k3s 或者 k8s
yzChen233
yzChen233 博主
不,我需要的,是巨额融资
我叫金正恩
我叫金正恩
666
程序员Coder
程序员Coder
我个人觉得目前在前期投入还是普遍偏低,基础的业务架构都是拿来主义,针对数据结构的设计也是很草率! 也许适合现在的互联网环境相符吧,捞金阶段!
yzChen233
yzChen233 博主
是的,这个“捞金阶段”很形象。
微服务架构~携程Apollo配置中心架构剖析

一、介绍 Apollo(阿波罗)[参考附录1]是携程框架部研发并开源的一款生产级的配置中心产品,它能够集中管理应用在不同环境、不同集群的配置,配置修改后能够实时推送到应用端,并且具备规范的...

波波微课
2018/06/07
0
0
微服务+zookeeper+log=轻量级SoA

在分布式Java框架中,dubbo算是比较成熟的了,但是好像现在不开发了。 dubbo仅仅支持Java开发,这对异构系统支持不是很理想。可能和ali的技术路线相关。 最近看了一下微服务的概念,想了一下...

精通吹水
2016/03/27
1K
2
中国JAVA开发者大会

一年一度的中国Java开发者大会震撼来袭了!JavaCon2016将于5月28日在上海浦软大厦二楼会议厅盛大召开,届时大会将云集来自五湖四海的400名IT极客们。 从2009年到现在,TopGeek伴随着中国的I...

TopGeek
2016/05/05
690
0
阿里P8架构师总结的互联网Java架构系统化学习路线

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/t4i2b10X4c22nF6A/article/details/83181980 网络应用,最常见的研发语言是Java的和PHP。 后端服务,最常见的...

JAVA高级架构v
2018/10/19
0
0
【小马哥】Spring Cloud系列讲座

这里为大家推荐一个不错的Spring Cloud系列讲座,讲师介绍如下: 小马哥,阿里巴巴技术专家,从事十余年Java EE 开发,国内微服务技术讲师。目前主要负责微服务技术推广、架构设计、基础设施...

杜琪
2018/03/02
0
0

没有更多内容

加载失败,请刷新页面

加载更多

使用zabbix自带的模板监控MySQL自带

一、安装zabbix server 略 二、安装zabbix agent 略 三、给主机套自带的模板 略 四、创建授权用户 mysql> grant all on *.* to 'zabbix'@'localhost' identified by 'musingtec2019';Quer......

雁南飞丶
5分钟前
1
0
notepad++快捷键

notepad++也情有独钟,最近发现了一个快捷键,就是选中单词,ctrl+shift+enter。不过现在想知道一个快捷键,假设有三行代码,选中后一般按TAB就可以三行全部缩进. Notepad++绝对是windows下进...

zhengzhixiang
27分钟前
3
0
区块链背景是什么?区块链的意义是什么?

一、前言 区块链技术的首次也是最著名的应用是比特币,一个在2009年1月初正式上线运行的去中心化数字货币应用,他的创始人叫中本聪,但目前大家并不知道此人的真实身份。 比特币不同于现代国...

daxiongdi
32分钟前
2
0
在Bash中循环浏览文件内容

如何使用Bash遍历文本文件的每一行? 使用此脚本: echo "Start!"for p in (peptides.txt)do echo "${p}"done 我在屏幕上得到以下输出: Start!./runPep.sh: line 3: syntax error......

技术盛宴
35分钟前
8
0
史上最强IP正则表达式

port ([0-9]|[1-9]\\d{1,3}|[1-5]\\d{4}|6[0-4]\\d{4}|65[0-4]\\d{2}|655[0-2]\\d|6553[0-5]) ipv4 ^((25[0-5]|2[0-4]\\d|[01]?\\d\\d?)\\.){3}(25[0-5]|2[0-4]\\d|[01]?\\d\\d?)$ ipv4+mask......

蜗牛伊
38分钟前
10
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部