当前位置:首页 > 科技  > 软件

接手外包团队开发的微服务项目,我感觉我的头快要裂开了

来源: 责编: 时间:2024-02-06 10:11:05 409观看
导读嗨,大家好,我是飘渺。最近,我和小伙伴一起接手了一个由外包团队开发的微服务项目,这个项目采用了当前流行的Spring Cloud Alibaba微服务架构,并且是基于一个“大名鼎鼎”的微服务开源脚手架(附带着模块代码截图,相信很多同学

嗨,大家好,我是飘渺。JfF28资讯网——每日最新资讯28at.com

最近,我和小伙伴一起接手了一个由外包团队开发的微服务项目,这个项目采用了当前流行的Spring Cloud Alibaba微服务架构,并且是基于一个“大名鼎鼎”的微服务开源脚手架(附带着模块代码截图,相信很多同学一看就能认出来)。然而,在这段时间里,我受到了来自"外包"和"微服务"这双重debuff的折磨。JfF28资讯网——每日最新资讯28at.com

今天,我想和大家分享一下我在这几天中遇到的问题。希望这几个问题能引起大家的共鸣,以便在未来的微服务开发中避免再次陷入相似的困境。JfF28资讯网——每日最新资讯28at.com

1、服务模块拆分不合理

绝大部分网上的微服务开源框架都是基于后台管理进行模块拆分的。然而在实际业务开发中,应该以领域建模为基础来划分子服务。JfF28资讯网——每日最新资讯28at.com

目前的服务拆分方式往往是按照团队或功能来拆分,这种不合理的拆分方式导致了服务调用的混乱,同时增加了分布式事务的风险。JfF28资讯网——每日最新资讯28at.com

2、微服务拆分后数据库并没拆分

所有服务都共用同一个数据库,这在物理层面无法对数据进行隔离,也导致一些团队为了赶进度,直接读取其他服务的数据表。JfF28资讯网——每日最新资讯28at.com

这里不禁要问:如果不拆分数据库,那拆分微服务还有何意义?JfF28资讯网——每日最新资讯28at.com

3、功能复制,不是双倍快乐

在项目中存在一个基础设施模块,其中包括文件上传、数据字典、日志等基础功能。然而,文件上传功能居然在其他模块中重复实现了一遍。就像这样:JfF28资讯网——每日最新资讯28at.com

图片图片JfF28资讯网——每日最新资讯28at.com

4、到处都是无用组件堆彻

在项目的基础模块中,自定义了许多公共的Starter,并且这些组件在各个微服务中被全都引入。比如第三方登录组件、微信支付组件、不明所以的流程引擎组件、验证码组件等等……JfF28资讯网——每日最新资讯28at.com

图片图片JfF28资讯网——每日最新资讯28at.com

图片图片JfF28资讯网——每日最新资讯28at.com

拜托,我们已经有自己的SSO登录,不需要微信支付,还有自己的流程引擎。那些根本用不到的东西,干嘛要引入呢?JfF28资讯网——每日最新资讯28at.com

5、明显的错误没人解决

这个问题是由上面的问题所导致的,由于引入了一个根本不需要的消息中间件,项目运行时不断出现如下所示的连接异常。JfF28资讯网——每日最新资讯28at.com

图片图片JfF28资讯网——每日最新资讯28at.com

项目开发了这么久,出错了这么久,居然没有一个人去解决,真的让人不得不佩服他们的忍受力。JfF28资讯网——每日最新资讯28at.com

6、配置文件一团乱麻

你看到服务中这一堆配置文件,是不是心里咯噔了一下?JfF28资讯网——每日最新资讯28at.com

图片图片JfF28资讯网——每日最新资讯28at.com

或许有人会说:"没什么问题呀,按照不同环境划分不同的配置文件”。可是在微服务架构下,已经有了配置中心,为什么还要这么做呢?这不是画蛇添足吗?JfF28资讯网——每日最新资讯28at.com

7、乱用配置中心

项目一开始就明确要使用Apollo配置中心,一个微服务对应一个appid,appid一般与application.name一致。JfF28资讯网——每日最新资讯28at.com

但实际上,多个服务却使用了相同的appid,多个服务的配置文件还塞在了同一个appid下。JfF28资讯网——每日最新资讯28at.com

更让人费解的是,有些微服务又不使用配置中心。JfF28资讯网——每日最新资讯28at.com

8、Nacos注册中心混乱

由于项目有众多参与的团队,为了联调代码,开发人员在启动服务时不得不修改配置文件中Nacos的spring.cloud.nacos.discovery.group属性,同时需要启动所有相关服务。JfF28资讯网——每日最新资讯28at.com

这导致了两个问题:一是某个用户提交了自己的配置文件,导致其他人的服务注册到了别的group,影响他人的联调;二是Nacos注册中心会存在一大堆不同的Group,查找服务变得相当麻烦。JfF28资讯网——每日最新资讯28at.com

其实要解决这个问题只需要重写一下网关的负载均衡策略,让流量调度到指定的服务即可。据我所知,他们使用的开源框架应该支持这个功能,只是他们不知道怎么使用。JfF28资讯网——每日最新资讯28at.com

9、接口协议混乱

使用的开源脚手架支持Dubbo协议和OpenFeign调用,然而在我们的项目中并不会使用Dubbo协议,微服务之间只使用OpenFeign进行调用。然而,在对外提供接口时,却暴露了一堆支持Dubbo协议的接口。JfF28资讯网——每日最新资讯28at.com

10、部署方式混乱

项目部署到Kubernetes云环境,一般来说,服务部署到云上的内部服务应该使用ClusterIP的方式进行部署,只有网关服务需要对外访问,网关可以通过NodePort或Ingress进行访问。JfF28资讯网——每日最新资讯28at.com

这样做可以避免其他人或服务绕过网关直接访问后端微服务。JfF28资讯网——每日最新资讯28at.com

然而,他们的部署方式是所有服务都开启了NodePort访问,然后在云主机上还要部署一套Nginx来反向代理网关服务的NodePort端口。JfF28资讯网——每日最新资讯28at.com

结语

网络上涌现着众多微服务开源脚手架,它们吸引用户的方式是将各种功能一股脑地集成进去。然而,它们往往只是告诉你“如何集成”却忽略了“为什么要集成”。JfF28资讯网——每日最新资讯28at.com

尽管这些开源项目能够在学习微服务方面事半功倍,但在实际微服务项目中,我们不能盲目照搬,而应该根据项目的实际情况来有选择地裁剪或扩展功能。这样,我们才能更好地应对项目的需求,避免陷入不必要的复杂性,从而更加成功地实施微服务架构。JfF28资讯网——每日最新资讯28at.com

最后,这个开源项目你们认识吗?JfF28资讯网——每日最新资讯28at.com

本文链接:http://www.28at.com/showinfo-26-74663-0.html接手外包团队开发的微服务项目,我感觉我的头快要裂开了

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。邮件:2376512515@qq.com

上一篇: Python字典操作的得力助手Get()函数

下一篇: 学到了!Figma 原来是这样表示矩形的

标签:
  • 热门焦点
  • K60至尊版刚预热 一加Ace2 Pro正面硬刚

    Redmi这边刚如火如荼的宣传了K60 Ultra的各种技术和硬件配置,作为竞品的一加也坐不住了。一加中国区总裁李杰发布了两条微博,表示在自家的一加Ace2上早就已经采用了和PixelWo
  • 天猫精灵Sound Pro体验:智能音箱没有音质?来听听我的

    这几年除了手机作为智能生活终端最主要的核心之外,第二个可以成为中心点的产品是什么?——是智能音箱。 手机在执行命令的时候有两种操作方式,手和智能语音助手,而智能音箱只
  • 三言两语说透设计模式的艺术-简单工厂模式

    一、写在前面工厂模式是最常见的一种创建型设计模式,通常说的工厂模式指的是工厂方法模式,是使用频率最高的工厂模式。简单工厂模式又称为静态工厂方法模式,不属于GoF 23种设计
  • 服务存储设计模式:Cache-Aside模式

    Cache-Aside模式一种常用的缓存方式,通常是把数据从主存储加载到KV缓存中,加速后续的访问。在存在重复度的场景,Cache-Aside可以提升服务性能,降低底层存储的压力,缺点是缓存和底
  • 阿里大调整

    来源:产品刘有媒体报道称,近期淘宝天猫集团启动了近年来最大的人力制度改革,涉及员工绩效、层级体系等多个核心事项,目前已形成一个初步的“征求意见版”:1、取消P序列
  • 7月4日见!iQOO 11S官宣:“鸡血版”骁龙8 Gen2+200W快充加持

    上半年已接近尾声,截至目前各大品牌旗下的顶级旗舰都已悉数亮相,而下半年即将推出的顶级旗舰已经成为了数码圈爆料的主流,其中就包括全新的iQOO 11S系
  • iQOO Neo8系列今日官宣:首发天玑9200+ 全球安卓最强芯!

    在昨日举行的的联发科新一代旗舰芯片天玑9200+的发布会上,iQOO官方也正式宣布,全新的iQOO Neo8系列新品将全球首发搭载这款当前性能最强大的移动平台
  • OPPO K11搭载长寿版100W超级闪充:26分钟充满100%

    据此前官方宣布,OPPO将于7月25日也就是今天下午14:30举办新品发布会,届时全新的OPPO K11将正式与大家见面,将主打旗舰影像,和同档位竞品相比,其最大的卖
  • 联想YOGA 16s 2022笔记本将要推出,屏幕支持触控功能

    联想此前宣布,将于11月2日19:30召开联想秋季轻薄新品发布会,推出联想 YOGA 16s 2022 笔记本等新品。官方称,YOGA 16s 2022 笔记本将搭载 16 英寸屏幕,并且是一
Top