Java 微服务框架 HP-SOA v1.1.2 发布
HP-SOA —— 功能完备,简单易用,高度可扩展的Java微服务框架。
- 项目主页 : https://www.oschina.net/p/hp-soa
- 下载地址 : https://github.com/ldcsaa/hp-soa
- 开发文档 : https://gitee.com/ldcsaa/hp-soa/blob/master/README.md
- QQ Group: 44636872, 663903943
1.1.2 版本更新内容:
- 优化应用程序打包发布方案。
- 增加 Docker 环境下应用程序镜像构建和容器运行通用方案。
- 补充【应用程序打包发布】方案与实施文档。
- 支持运行期设置应用程序只读(配置参考:Nacos配置中心)
- 支持运行期动态修改日志级别(配置参考:Nacos配置中心)
- 组件更新:
- Spring-Boot -> 3.2.7
- Spring-Cloud -> 2023.0.3
- Dubbo -> 3.2.14
【快速开始】
技术架构
技术集成
- Web服务框架:spring-boot 3.x
- 微服务框架:spring-cloud 4.x
- 微服务框架:Dubbo 3.x
- 服务注册中心:Nacos
- 配置中心:Nacos
- 服务治理中心:Dubbo Admin
- 流量控制中心:Sentinel Dashboard + Nacos
- 数据库:MySQL、Druid、mybatis-plus(支持多数据源)
- 缓存:Redis + Redisson(支持多实例)
- NoSQL数据库:MongoDB
- 搜索引擎:Elasticsearch
- 消息总线:RabbitMQ(支持多实例,支持可靠消息)
- 消息队列:Kafka(支持可靠消息)
- MQTT发布订阅:Eclipse PAHO mqttv5
- 分布式Job:xxl-job
- 轻量级Job:Redisson + Spring Scheduled
- 分布式事务:Seata
- 全局ID:Leaf(支持 Snowflake ID 和 Segment ID)
- 统一日志:Log4j + Kafka + ELK
- 调用链跟踪:Skywalking
- 监控告警:Prometheus + Grafana + Alert Manager
模块说明
- hp-soa-dependencies 依赖管理模块,定义依赖包及其版本
- hp-soa-framework-core 基础模块,定义 HP-SOA 基础组件和工具
- hp-soa-framework-web Web应用模块,集成 spring-boot 和 Dubbo,提供核心微服务功能
- hp-soa-framework-leaf Leaf全局ID模块,基于Leaf,提供分布式全局ID功能
- hp-soa-framework-gelf GELF日志模块,提供TCP、UDP、HTTP、Redis、Kafka等远程日志传输功能
- hp-soa-framework-util 扩展工具包模块,提供文件处理、邮件、远程访问等组件和工具
- hp-soa-starter-web Web应用启动器,配置并启动应用服务,所有 HP-SOA 项目都必须引入该启动器
- hp-soa-starter-web-cloud Spring Cloud 启动器,开启 Spring Cloud 微服务功能,所有 Spring Cloud 微服务项目都必须引入该启动器
- hp-soa-starter-web-dubbo Dubbo启动器,开启Dubbo微服务功能,所有 Dubbo 微服务项目都必须引入该启动器
- hp-soa-starter-task Task启动器,开启 Spring Task 功能,并为 Spring Task 提供日志关联和调用链跟踪能力
- hp-soa-starter-nacos Nacos配置中心启动器,开启配置中心功能,应用程序可以从远程配置中心加载配置
- hp-soa-starter-data-mysql MySQL启动器,开启MySQL数据库访问功能,并提供动态数据源、数据源监控和全局事务管理等能力
- hp-soa-starter-data-redis Redis启动器,开启Redis访问功能,支持多Redis实例,支持Spring Cache
- hp-soa-starter-data-mongodb MongoDB启动器,开启MongoDB访问功能,支持通过 Spring Data 接口方式访问MongoDB
- hp-soa-starter-data-elasticsearch Elasticsearch启动器,开启Elasticsearch访问功能,支持通过 Spring Data 接口方式访问Elasticsearch
- hp-soa-starter-rabbitmq Rabbitmq启动器,开启Rabbitmq访问功能,支持多Rabbitmq实例,提供可靠消息实施方案以及消息跟踪能力
- hp-soa-starter-kafka Kafka启动器,开启Kafka访问功能,提供可靠消息实施方案以及消息跟踪能力
- hp-soa-starter-mqtt MQTT启动器,开启MQTT发布订阅功能,全面支持mqttv5协议
- hp-soa-starter-job-exclusive 轻量级Job启动器,开启轻量级排他Job功能,提供Job执行日志关联和调用链跟踪能力
- hp-soa-starter-job-xxljob Xxl-Job启动器,开启 Xxl-Job 功能,结合 xxl-job-admin 提供分布式Job能力
- hp-soa-starter-leaf Leaf全局ID启动器,开启Leaf全局ID功能,支持通过Snowflake算法和Segment算法生成全局ID
- hp-soa-starter-seata Seata启动器,开启Seata分布式事务功能,结合 Seata TC 提供分布式事务能力
- hp-soa-starter-sentinel Sentinel启动器,开启Sentinel流量控制功能,结合 Sentinel Dashboard 和 Nacos 提供流量控制和流控规则持久化能力
- hp-soa-starter-skywalking Skywalking启动器,开启Skywalking调用链跟踪功能,结合 Skywalking Agent 和 Skywalking Server 提供调用链跟踪能力
应用接入(参考:hp-demo)
- pom.xml 中添加 HP-SOA 依赖
<dependencyManagement> <dependencies> <!-- 添加 hp-soa 依赖管理 --> <dependency> <groupId>io.github.hpsocket</groupId> <artifactId>hp-soa-dependencies</artifactId> <version>${hp-soa.version}</version> <type>pom</type> <scope>import</scope> </dependency> </dependencies> </dependencyManagement> <dependencies> <!-- 普通项目引用 hp-soa-starter-web --> <dependency> <groupId>io.github.hpsocket</groupId> <artifactId>hp-soa-starter-web</artifactId> </dependency> <!-- Spring Cloud 项目引用 hp-soa-starter-web-cloud --> <!-- <dependency> <groupId>io.github.hpsocket</groupId> <artifactId>hp-soa-starter-web-cloud</artifactId> </dependency> --> <!-- Dubbo项目引用 hp-soa-starter-web-dubbo --> <!-- <dependency> <groupId>io.github.hpsocket</groupId> <artifactId>hp-soa-starter-web-dubbo</artifactId> </dependency> --> <!-- 根据项目需要,引用其它 hp-soa starter --> <dependency> <groupId>io.github.hpsocket</groupId> <artifactId>hp-soa-starter-xxx</artifactId> </dependency> </dependencies>
- 修改应用配置(参考 Demo hp-demo-bff-basic 的本地配置文件 ,配置中心的远程配置文件),主要配置项:
- hp.soa.web
- spring.cloud (Spring Cloud 项目)
- dubbo (Dubbo项目)
- server
- spring
- management
- springdoc
- 修改全局配置(可选)
- 系统配置文件,用于设置系统属性,默认配置文件:
/opt/hp-soa/config/system-config.properties
参考:system-config.properties - 扩展配置文件,用于配置注册中心地址、配置中心地址等公共属性,默认配置文件:
/opt/hp-soa/config/extended-config.properties
参考:extended-config.properties
- 系统配置文件,用于设置系统属性,默认配置文件:
- 实现HTTP鉴权接口(可选)
- 如果是Gateway/BFF应用,并且应用属性
hp.soa.web.access-verification.enabled = true
,则需要实现AccessVerificationService接口,用于HTTP请求鉴权。
- 如果是Gateway/BFF应用,并且应用属性
- 启动应用
- 以io.github.hpsocket.soa.framework.web.server.main.AppStarter作为启动类,启动应用程序。
- JVM启动参数参考:JVM启动参数示例
[用户指南]

低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。
持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。
- 上一篇
openKylin 社区塞拉利昂用户组首场活动圆满举行!
openKylin用户组是为方便全球各国家及地区开源爱好者交流openKylin系统版本及用户体验、推广openKylin操作系统而成立的开源爱好者组织,其目的在于将开源社区的相关合作拓展至全球范围,吸引更多国际开发者贡献代码、想法和经验,提升openKylin社区的国际品牌影响力,并获得持续发展的创新动力。截至目前,openKylin社区已累计成立11个国际用户组。 近日,openKylin社区国际用户组活动在西非国家塞拉利昂成功举行。这次活动是由不久前成立的塞拉利昂openKylin用户组组织的首次小型活动,标志着openKylin在非洲大陆的推广工作迈出了重要一步。 活动主持人Moses Kargbo是openKylin社区国际推广大使,也是塞拉利昂用户组的创始人。他在深入参与openKylin国际交流后,回国着手组建起本地用户组,并积极筹划了这次推广活动。活动于当地时间下午举行,吸引了20名热情的参与者。 活动期间,Moses Kargbo为各位参与者详细介绍了openKylin的发展历程和社区成果,引导参与者深入了解openKylin社区,展示openKylin系统的功能和优...
- 下一篇
Rust 通用代码生成器:莲花,代码生成物登录系统讲读
Rust通用代码生成器:莲花,代码生成物登录系统讲读 Rust通用代码生成器:莲花可以生成带登录系统,现在,已经发布了视频,解释了其代码生成物的登录系统。视频请见:https://www.bilibili.com/video/BV1kZ421T7oT/ 莲花代码生成物中的登录系统主要包含了LoginController,LoginService,LoginMiddleware。采用了sha1算法散列,jwt登录框架。实现细节请见视频。 Rust通用代码生成器莲花,红莲尝鲜版二十六,此版本完善了数据库自动反射功能。完善了多对多候选功能,完善了下拉列表的空值。 Rust通用代码生成器:莲花将强大的生产力赋能广大程序员。无论是新开发的软件还是通过遗留数据库反射以再次开发的遗留项目,您都可以使用动词算子式通用代码生成器的强大生产力大大加速研发速度。莲花永远是广大程序员的瑞士军刀,是加快开发速度和提高开发质量的利器。 代码生成器的项目地址:https://gitee.com/jerryshensjf/Lotus 二进制 war 包的下载地址:https://gitee.com/jerryshe...
相关文章
文章评论
共有0条评论来说两句吧...
文章二维码
点击排行
推荐阅读
最新文章
- MySQL8.0.19开启GTID主从同步CentOS8
- CentOS8安装Docker,最新的服务器搭配容器使用
- Linux系统CentOS6、CentOS7手动修改IP地址
- 2048小游戏-低调大师作品
- Springboot2将连接池hikari替换为druid,体验最强大的数据库连接池
- CentOS8安装MyCat,轻松搞定数据库的读写分离、垂直分库、水平分库
- CentOS8编译安装MySQL8.0.19
- CentOS6,CentOS7官方镜像安装Oracle11G
- CentOS7,8上快速安装Gitea,搭建Git服务器
- SpringBoot2整合Thymeleaf,官方推荐html解决方案