README ¶
HAS-人性化应用服务框架
简介
框架核心
设计原则
- 保持简单,第一原则
- 工具大于约定和文档
- 高可用
- 高并发
- 易扩展
- 对业务开发友好,封装复杂度
- 部署方便
- 便于服务编排
- 便于服务监控
- 尽可能降低对外部组件的依赖
框架功能
- API开发:支持Web API(Rest待定),RPC API, WebSocket API等,并便于扩展其对他API类型的支持
- 业务逻辑:方便的业务服务搭建
服务
Web API 服务
- 账密认证
NOTICE
- 所有需要管理的entity,class定义中不能包括下划线 _
特点
- 基于RPCX(如果是单进程服务,不通过RPC调用以提交效率)
- 清晰的分层结构,便于用户进行定制
- 提供常用基础包(参考:go-frame,go-zero)
- 自动定义API接口
- 自动进行API参数检查
目录结构
- common: 通用包,包括配置hconf, 错误处理 herrors, 日志记录hlogger
- core: 微服务核心框架代码,包括只有框架紧密集成的组件
- plugins: 插件
- services: 服务
- connectors: 连接器
- middlewares: 中间件
- routers: 服务路由
- datapackers: 数据打包类
- utils: 工具类
使用规范
- 所有错误不在使用原生error包,而是使用框架自带的 herrors
更新记录
- 基于redis的路由机制 @2022.5
- 支持API版本号 @2021.6
- 支持服务对插件的依赖声明和检查 @2021.6
- 支持埋点 @2021.6
- 改进middleware,支持指明是indoor,outdoor,以及inoutdoor的middleware(done)
- 需要在一次请求中增加一个流水号,已保证in/out middleware时能够识别是不是同一个请求(done)
- 服务限流 @2021.6
- 通过配置,可以指定针对指定api进行限流,也可以统一对服务请求进行限流
- 服务器熔断 @2021.6
- 通过配置,可以指定对service、ip、用户进行熔断控制
- connector支持多packer @2021.7
- fileservice支持minio存取 @2021.10
TODO
- 分布式事务(DT)
- 配套AdminWeb 服务
- 服务管理
- 服务监视(集成grafana)
- 应用安全监控与防御
- 创建分布式临界资源分配服务 GlobalResourceService
- 多级状态机
- 使用mysql
- 支持状态依赖
- 支持状态分级
- 支持状态自动合并
- 死循环检测
- 添加待签名API类型(partially done)
- 集群化能力
- 增加一个反代,来实现http-rpcx的负载均衡,同时支持反代的集群部署
- 全局缓存
- 全局任务分发
- 全局日志
- 更好的服务监测与治理
- 自动工具,集成 grafana?
- 服务治理的支撑功能可以划分为三个层次:治理支撑服务,功能支撑服务,线下支撑服务。
- 治理支撑服务包括服务注册/发现,流量控制,容错熔断,服务升级/回滚,链路跟踪,路由分发,超时重试,智能恢复等支撑工具集成。
- 功能支撑服务包括监控告警,日志服务,认证鉴权,计量计费,消息服务,负载均衡,持久化服务,网管服务等支撑工具。
- 线下支撑服务包括DevOps流程支撑服务,运行环境支撑。
- 更好的发布支持
- docker打包
- 更好的自动文档支持
- 基于api.json的自动接口文档支持
- 更好的数据库支持
- 增加对Oracle DB的支持
- 更好的自动化测试工具
- 联通性测试
- 压力测试
- 功能测试
Click to show internal directories.
Click to hide internal directories.