IBP框架描述 | ||||||||||||||||
一、后端分布式架构 1、增强数据安全性 引入了网关这个组件,非内部后端应用都需要从网关去访问数据,未授权的调用都是不允许对数据进行访问/操作。 数据控制粒度到接口级别。 2、增强运维可行性 配置中心组件的出现,可支持在线动态修改应用配置并及时生效,还支持环境、版本等高级功能,再也不需要忍受修改一个配置项就得重启应用的痛苦。 日志监控组件,可以让查日志、定位问题更便捷,不需要到服务器拷贝日志再查阅。 链路监控组件,可以让我们更了解我的应用健康状况,为我们提升性能提供非常必要的数据支持。 灰度发布(金丝雀),可以实现接口逐步上线,大大降低了风险。 3、后端业务独立 后端按业务模块划分应用(代码、数据库),每个应用独立维护(更专注),集群原生支持,扩容特别方便(同机扩容只需改端口即可、不同机扩容直接复制部署文件即可启动),大大提升吞吐能力,更好的保证系统的稳定性; 二、前后端分离模式 为优质产品打造精益团队 术业有专攻,通过前后端分离,让前后端工程师只需要专注于前端或者后端的开发工作,有利于编写出高质量的代码,培养开发工程师独特的技术特性,然后构建出一个全栈式的精益开发团队。 1、增强应用的吞吐能力 前端使用nginx静态容器,后端每个微服务都是原生支持集群,可动态扩容,大大增强了应用的负载/吞吐能力。 3、提高工作效率,分工更加明确 前后端分离的工作流程可以使得前端专心前端,后端关心后端,两者开发同时进行,提高开发效率,页面的增加和路由的修改也不必再去麻烦后端,开发更加灵活。 前端可以借助mock系统模拟接口完成前端开发。 3、增强代码的可维护性 前后端分离后,应用的代码不再是前后端混合,只有在运行期才会调用依赖关系,并且分层明确,应用代码变得整洁清晰。 前端代码全面模块化,所有功能代码都是独立的,且抽离很多公用组件,可快速实现特定功能。 后端接口只需维护一套,即可适应各端的调用要求,无需重复维护接口。 4、降低服务器负载,系统性能提升 通过前端路由的配置,我们可以实现页面的按需加载,无需一开始加载首页便加载网站的所有资源,服务器也不再需要解析前端页面,在页面交互及用户体验上有所提升。
|