微服务项目搭建,到底要不要聚合工程?
云栖号资讯:【点击查看更多行业资讯】
在这里您可以找到不同行业的第一手的上云资讯,还在等什么,快来!
这是一个入门问题,做微服务项目,首先就是要搭建 Project,代码采用什么样的形式来组织,这是我们面临的第一个问题。
在传统的项目中,我们经常需要搭建聚合工程,这样可以方便的对项目进行分模块管理,降低维护难度。
微服务项目中,我们是否还需要继续这种开发方式呢?今天结合自己在项目中的经验和大家简单聊一下,微服务项目中代码的组织形式。
1.开发模式
要搞清楚代码如何组织,首先大家要明白微服务架构到底是什么样子!
在微服务架构中,一个完整的项目被拆分成很多独立的微服务,例如一个电商项目,可能分为商品管理、商家管理、用户管理、交易管理、SEO 管理、App 管理、财务管理、系统管理等很多微服务。
这些微服务都是一个个独立的项目,由不同的团队负责开发维护。
不同的团队独立开发、独立维护、独立测试(看情况)、独立上线,这样可以有效提高项目的开发效率。
结合项目的实际情况,不同的团队甚至可以选择不同的技术栈,比如商品管理模块用 Java、交易管理可能用 Go、门户网站可能用 PHP 等等,从微服务架构上来说,这些都是支持的,这也是微服务的优势之一,即同一系统不必拘泥于同一种语言,当然在具体实践中,还需要结合团队的技术栈以及语言的特性来选择。
其实看到这里,你大概就明白了,聚合工程在这里还能不能用了!
2.要不要聚合工程
首先从整体上来说,也就是整个项目层面,我们不再需要聚合工程了。聚合工程可以让项目统一打包,解决项目中的依赖问题,还可以对依赖的版本进行统一管理,但是这些特性对微服务项目来说,其实并不重要。
假如商品管理模块用 Java、交易管理用 Go、门户网站用 PHP,那么这三个独立的微服务肯定是没有必要做成一个聚合工程的,你也没法聚合。当然这是一种比较极端的情况,即使不同微服务模块都是使用 Java 语言开发,那也没有必要聚合,因为不同的微服务实际上都是一个个独立运行的项目,由不同的团队开发维护,微服务的一大优势就是各个团队对独立开发,互不影响,如果搞个聚合工程,又把各个团队绑定在一起了。
但是不同的微服务之间,不可避免的要使用一些公共类库,这些可以统一打包上传到公司 Maven 私服上,然后不同的团队自行依赖即可,或者通过 git subtree 的方式来使用。
这是从大的层面来说。具体到每一个微服务,聚合工程的优势还在,该用还是要用,例如在商品管理模块,聚合工程还是可以继续使用的。
3.为什么会有疑问
微服务中用不用聚合工程这个问题,本来是个很小的问题,但是为什么很多小伙伴会有疑问呢?
我说一下我了解到几种情况。
一种情况就是公司的微服务是在旧项目的基础上改造的,仓促上马,改来改去,面目全非,已经顾不上架构这些东西了,功能能实现就行了,这种时候甚至在大的层面就使用了聚合工程,结果不同团队开发起来,还是牵一发而动全身,如果有小伙伴也开发过这种项目,可能就会对聚合工程的使用产生疑问。松哥有一个朋友在广州做某央企的项目,就是这种情况。
另一种情况可能是因为公司人少,微服务项目开发为了方便,也就从整体上做成了聚合工程,这样在项目人少并且工程量不大的情况下,修改起来非常方便。
总之,这个问题实际上也不能一概而论,结合项目的实际情况,选择适合自己的方案才是最好的。
【云栖号在线课堂】每天都有产品技术专家分享!
课程地址:https://yqh.aliyun.com/live立即加入社群,与专家面对面,及时了解课程最新动态!
【云栖号在线课堂 社群】https://c.tb.cn/F3.Z8gvnK
原文发布时间:2020-05-25
本文作者:江南一点雨
本文来自:“掘金”,了解相关信息可以关注“掘金”
低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。
持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。
- 上一篇
吴翰清(道哥)眼中的机器智能:计算机的再发展
云栖号资讯:【点击查看更多行业资讯】在这里您可以找到不同行业的第一手的上云资讯,还在等什么,快来! 阿里妹导读:人类社会的发展离不开技术的革新。一项新技术的成熟需要经历哪些考验?为什么说对于计算机、AI 的发展而言,算力和数据都是重要的生产资料?如何实现数据的智能化?通过本文,吴翰清(道哥)将从人类社会的发展讲起,梳理总结技术革新的规律和脉络,分享他对当前技术发展及机器智能的看法。 一 从历史和社会的角度看技术的发展 想要理清技术发展脉络,就需要回顾人类历史,因为人类历史本身就是技术的发展史。马克思对于人的定义中有一项是:劳动使人变得和动物不一样。而具体是什么不一样呢?我认为是技术赋予了人类独有的特性。 农业革命之前,人类大多是以社群的形式生活。当时,人类获取食物的主要手段是狩猎和采集,因此效率非常低。大概在八千到一万年以前,人类历史上发生了农业革命,出现了种植以及畜牧。在此之后,人类在单位面积土地上获取食物的效率就大大提升了。因为不需要所有人都去从事农业生产,所以多出的劳动力形成了最早的社会分工,比如有的人开始进入手工业制造工具,进一步形成了人群的聚集和交换,由此出现了最早的城邦,也...
- 下一篇
中国5G大起底
云栖号资讯:【点击查看更多行业资讯】在这里您可以找到不同行业的第一手的上云资讯,还在等什么,快来! 据新华社报道,今年政府工作报告中提到,重点支持既促消费惠民生又调结构增后劲的“两新一重”建设,主要内容包括:加强新型基础设施建设、发展新一代信息网络、拓展5G应用、建设充电桩、推广新能源汽车、激发新消费需求、助力产业升级。 作为政府重点扶持的5G产业,在我国的发展现状怎样?腾讯科技从运营商和城市布局的角度,来探索5G的发展历程和成果。 中国移动更占频谱优势,5G用户超三千万 在第五代通信技术的浪潮里,各大运营商的竞争从获取频谱开始。“频谱”是指无线通信技术中电磁波的工作范围。频率越低,其穿透性越强,传输距离越远。 移动获取了最低频段2.6GHz,也就获得了比其他运营商更广的覆盖范围。虽然联通和电信获取的3.5GHz频段,在技术上优势稍弱,但是该频段是现阶段最主流的频段,国际上的通用程度最高,因此具有很大的规模和成本优势。 值得一提的是,中国广电在掌握了700MHz的基础上,又再次获得了4.9GHz的频段,这结合了广覆盖和容量大两大优势,有利于中国广电做普惠性的电视广播和进行网络平台的转型...
相关文章
文章评论
共有0条评论来说两句吧...
文章二维码
点击排行
推荐阅读
最新文章
- CentOS7安装Docker,走上虚拟化容器引擎之路
- CentOS6,7,8上安装Nginx,支持https2.0的开启
- Docker快速安装Oracle11G,搭建oracle11g学习环境
- Docker安装Oracle12C,快速搭建Oracle学习环境
- Eclipse初始化配置,告别卡顿、闪退、编译时间过长
- CentOS7,8上快速安装Gitea,搭建Git服务器
- CentOS关闭SELinux安全模块
- SpringBoot2更换Tomcat为Jetty,小型站点的福音
- SpringBoot2编写第一个Controller,响应你的http请求并返回结果
- CentOS8安装Docker,最新的服务器搭配容器使用