标签:
lamp-cloud微服务脚手架的前身是zuihou-admin-cloud,从3.0.0版别开端,改名为lamp-cloud,它是lamp项意图其间一员。
lamp-cloud微服务脚手架是一个根据SpringCloud(Hoxton.SR10) + SpringBoot(2.3.10.RELEASE)的SaaS微服务脚手架,具有一致授权、认证后台办理体系,其间包括具有用户办理、资源权限办理、网关API、散布式业务、大文件断点分片续传等多个模块,支撑多业务体系并行开发,能够作为后端服务的开发脚手架。代码简练,架构明晰,合适学习和直接项目中运用。核心技术选用Nacos、Fegin、Ribbon、Zuul、Hystrix、JWT Token、Mybatis、SpringBoot、Redis、RibbitMQ等首要结构和中间件。
lamp-cloud微服务脚手架功用:
1、服务注册&发现与调用:
根据Nacos来完成的服务注册与发现,运用运用Feign来完成服务互调, 能够做到运用HTTP恳求长途调用时能与调用本地办法相同的编码体会,开发者彻底感知不到这是长途办法,更感知不到这是个HTTP恳求。
2、服务鉴权:
经过JWT的方法来加强服务之间调度的权限验证,确保内部服务的安全性。
3、负载均衡:
将服务保存的rest进行署理和网关操控,除了往常常常运用的node.js、nginx外,Spring Cloud系列的zuul和ribbon,能够帮咱们进行正常的网关管控和负载均衡。其间扩展和学习国外项意图扩展根据JWT的Zuul限流插件,方面进行限流。
4、熔断机制:
因为采取了服务的散布,为了防止服务之间的调用“雪崩”,选用了Hystrix的作为熔断器,防止了服务之间的“雪崩”。
5、监控:
运用Spring Boot Admin 来监控各个独立Service的运转状况;运用turbine来实时检查接口的运转状况和调用频率;经过Zipkin来检查各个服务之间的调用链等。
6、链路调用监控:
运用Zipkin完成微服务的全链路功用监控, 从全体维度到部分维度展示各项方针,将跨运用的一切调用链功用信息会集展示,可便利衡量全体和部分功用,而且便利找到毛病发生的源头,生产上可极大缩短毛病扫除时刻。有了它,咱们能做到:
恳求链路追寻,毛病快速定位:能够经过调用链结合业务日志快速定位错误信息。 可视化:各个阶段耗时,进行功用剖析。 依靠优化:各个调用环节的可用性、整理服务依靠联系以及优化。 数据剖析,优化链路:能够得到用户的行为途径,汇总剖析运用在许多业务场景。
7、数据权限
运用根据Mybatis的DataScopeInterceptor阻拦器完成了简略的数据权限
8、SaaS(多租户)的无感处理方案
运用Mybatis阻拦器完成对一切SQL的阻拦,修正默许的Schema,然后完成多租户数据阻隔的意图。 而且支撑可插拔。
9、二级缓存
选用J2Cache操作缓存,榜首级缓存运用内存(Caffeine),第二级缓存运用 Redis。 因为很多的缓存读取会导致 L2 的网络成为整个体系的瓶颈,因而 L1 的方针是下降对 L2 的读取次数。 该缓存结构首要用于集群环境中。单机也可运用,用于防止运用重启导致的缓存冷发动后对后端业务的冲击。
10、高雅的Bean转化
选用Dozer组件来对 DTO、DO、PO等目标的优化转化
11、前后端一致表单验证
谨慎的表单验证一般需求 前端+后端一起验证, 但传统的项目,均只能前后端各做一次查验, 后期规矩改动,又得前后端一起修正。 故在hibernate-validator的基础上封装了zuihou-validator-starter起步依靠,供给一个通用接口,能够获取需求校验表单的规矩,然后前端运用后端回来的规矩, 今后若规矩改动,只需求后端修正即可。
12、防跨站脚本进犯(XSS)
经过过滤器对一切恳求中的 表单参数 进行过滤
经过Json反序列化器完成对一切 application/json 类型的参数 进行过滤
13、当时登录用户信息注入器
经过注解完成用户身份注入
14、在线API
因为原生swagger-ui某些功用支撑不行友爱,故选用了国内开源的swagger-bootstrap-ui,并制作了stater,便利springboot用户运用。
15、代码生成器
根据Mybatis-plus-generator自定义了一套代码生成器, 经过装备数据库字段的注释,主动生成枚举类、数据字典注解、SaveDTO、UpdateDTO、表单验证规矩注解、Swagger注解等。
16、守时使命调度器:
根据xxl-jobs进行了功用增强。(如:指守时刻发送使命、履行器和调度器兼并项目、多数据源)
17、大文件/断点/分片续传
前端选用webupload.js、后端选用NIO完成了大文件断点分片续传,发动Eureka、Zuul、File服务后,直接翻开docs/chunkUploadDemo/demo.html即可进行测验。 经测验,本地约束仓库最大内存128M发动File服务,5分钟内能成功上传4.6G+的大文件,正式服耗时则会遭到用户带宽和服务器带宽的影响,时刻比较长。
18、散布式业务
集成了阿里的散布式业务中间件:seata,以 高效 而且对业务 0侵入 的方法,处理 微服务 场景下面对的散布式业务问题。
19、跨表、跨库、跨服务的相关数据主动注入器
用于处理跨表、跨库、跨服务分页数据的特点或单个目标的特点 回显相关数据之痛, 支撑对静态数据特点(数据字典)、动态主键数据进行主动注入。
20、灰度发布
为了处理频频的服务更新上线,版别回退,快速迭代,公司内部协同开发,本项目选用修正ribbon的负载均衡战略来完成来灰度发布。
lamp-cloud 更新日志:
v3.2.4
新增
seata 1.4.2 的装备
用户办理页面,头像回显功用完善
新增可装备选项:在履行sql时,疏忽 租户插件主动拼接租户编码的表 (仅 COLUMN 形式有用)
新增可装备选项:分页插件支撑更多的装备参数
增强
注释完善
默许的Controller分页查询,支撑更多的扩展参数
修正
实时获取文件拜访地址失利时,疏忽报错
token 过期后,一致回来401状况码,使页面主动跳转到从头登录
扫除slf4j抵触jar,处理操控台发动正告
加载全部内容
MaxKey单点登录认证系统 官方版20.59MB108人下载 MaxKey(马克思的钥匙)用户单点登录认证系统(Sigle Sign On System),寓意是最大钥匙,是业界领先的企业级IAM身份管理和身份认证产品,支持OAuth 2.0/OpenID Connect、SAML 2.0、JWT、CAS等标准化的开放协议,提供简单、标准、安全和开放的用户身份管理(IDM)、身份认证(AM)、单点登录(SSO)、RBAC权限管理和资源管理等。
下载bishengjdk-8 毕昇JDK8131.38MB107人下载毕昇JDK 8是华为内部OpenJDK定制版Huawei JDK的开源版本,是一个高性能、可用于生产环境的OpenJDK发行版。Huawei JDK运行在华为内部500多个产品上,积累了大量使用场景和java开发者反馈的问题和诉求,解决了业务实际运行中遇到的多个问题,并在ARM架构上进行了性能优化,毕昇JDK运行在大数据等场景下可以获得更好的性能。毕昇JDK 8与Java SE标准兼容,目前仅支持
下载Jpom 监控管理系统 正式版1.55MB106人下载Jpom项目监控软件是一款简而轻的低侵入式在线构建、自动部署、日常运维、项目监控软件。Jpom项目监控软件主要功能及特点:1、创建、修改、删除项目、Jar包管理2、实时查看控制台日志、备份日志、删除日志、导出日志3、cpu、ram 监控、导出堆栈信息、查看项目进程端口、服务器状态监控4、多节点管理、多节点自动分发5、实时监控项目状态异常自动报警6、在线构建项目发布项目一键搞定7、多用户管理,用户项
下载jdchain 区块链框架系统943KB105人下载京东区块链 JD Chain 是一个企业级的区块链框架系统,具有简洁、易用、可扩展和高性能的特点。 核心实现采用 Java 语言,学习门槛低,运维简便,无缝兼容企业应用IT架构。 这是主项目仓库,主要包括了文档和集成打包的结构,以及多个Git子模块仓库framework, core, explore 等。JD Chain 的目标是实现一个面向企业应用场景的通用区块链框架系统,能够作为企业级基础设施
下载Jenkins持续集成引擎 正式版17.87MB105人下载 Jenkins持续集成引擎的前身是Hudson是一个可扩展的持续集成引擎。Jenkins是一款开源CI&CD软件,用于自动化各种任务,包括构建、测试和部署软件。Jenkins支持各种运行方式,可通过系统包、Docker或者通过一个独立的Java程序。
下载SkyWalking应用性能监控系统4.16MB105人下载SkyWalking 是一款开源的应用性能监控系统,包括指标监控,分布式追踪,分布式系统性能诊断。功能:1、服务,服务实例,端点指标分析2、根本原因分析。在运行时分析代码。阅读Apache SkyWalking:使用性能分析来修复分布式跟踪的盲点。3、服务拓扑图分析4、服务,服务实例和端点依赖关系分析5、检测到慢速服务和端点6、性能优化7、分布式跟踪和上下文传播8、数据库访问指标。检测慢速数据库访
下载kkFileView在线预览 最新版286.18MB103人下载 kkFileView在线预览是一款使用spring boot打造的文件文档在线预览项目解决方案,支持doc、docx、ppt、pptx、xls、xlsx、zip、rar、mp4、mp3以及众多类文本如txt、html、xml、java、properties、sql、js、md、json、conf、ini、vue、php、py、bat、gitignore等文件在线预览。项目特性:支持office,p
下载ApacheMaven项目构建工具4.41MB103人下载Apache Maven项目构建工具是一个流行的Java项目构建系统。目前,绝大多数开发人员都把Ant当作Java编程项目的标准构建工具。遗憾的是,Ant的项目管理工具(作为make的替代工具)不能满足绝大多数开发人员的需要。通过检查Ant构建文件,很难发现项目的相关性信息和其它元信息(如开发人员/拥有者、版本或站点主页)。Maven除了以程序构建能力为特色之外,还提供Ant所缺少的高级项目管理工
下载Monibuca流媒体服务器开发框架29KB102人下载Monibuca是一个开源的流媒体服务器开发框架,适用于快速定制化开发流媒体服务器,可以对接CDN厂商,作为回源服务器,也可以自己搭建集群部署环境。丰富的内置插件提供了流媒体服务器的常见功能,例如rtmpserver、http-flv、视频录制、QoS等。除此以外还内置了后台web界面,方便观察服务器运行的状态。也可以自己开发后台管理界面,通过api方式获取服务器的运行信息。Monibuca提供了
下载kkFileView在线预览 官方版184.50MB102人下载 kkFileView在线预览是一款使用spring boot打造的文件文档在线预览项目解决方案,支持doc、docx、ppt、pptx、xls、xlsx、zip、rar、mp4、mp3以及众多类文本如txt、html、xml、java、properties、sql、js、md、json、conf、ini、vue、php、py、bat、gitignore等文件在线预览。
下载