has

module
v1.0.2 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: May 13, 2022 License: MIT

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: 工具类

使用规范

  1. 所有错误不在使用原生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的支持
  • 更好的自动化测试工具
    • 联通性测试
    • 压力测试
    • 功能测试

Directories

Path Synopsis
common
hlogger
Package logs provide a general log interface Usage: import "github.com/astaxie/beego/logs" log := NewLogger(10000) log.SetLogger("console", "") > the first params stand for how many channel Use it like this: log.Trace("trace") log.Info("info") log.Warn("warning") log.Debug("debug") log.Critical("critical") more docs http://beego.me/docs/module/logs.md
Package logs provide a general log interface Usage: import "github.com/astaxie/beego/logs" log := NewLogger(10000) log.SetLogger("console", "") > the first params stand for how many channel Use it like this: log.Trace("trace") log.Info("info") log.Warn("warning") log.Debug("debug") log.Critical("critical") more docs http://beego.me/docs/module/logs.md
connectors
datapackers
middlewares
hpermmw
* API 权限控制中间件 表达式语法参考:https://github.com/antonmedv/expr/blob/master/docs/Language-Definition.md·
* API 权限控制中间件 表达式语法参考:https://github.com/antonmedv/expr/blob/master/docs/Language-Definition.md·
plugins
routers
utils
hio

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL