Skip to content

Latest commit

 

History

History
65 lines (48 loc) · 2.41 KB

README.md

File metadata and controls

65 lines (48 loc) · 2.41 KB

MicroZero(原名ZeroNet)

基于的Rpc的微服务框架,实现服务发现,服务治理,服务监控,负载均衡,服务网关,RPC/HTTP调用等实用功能。

系统模块

1 ZeroCenter

基于Libzmq的C++编写的中心控制类,实现以下几个功能:

  1. SystemMangement
  • 工作站配置管理:安装\卸载\获取
  • 工作站状态管理:启动\关闭\暂停\恢复
  • 工作站心跳管理:加入\就绪\退出\健康分析
  1. SystemMonitor
  • 系统状态广播
  • 工作站状态广播
  • 运行计数定时广播
  1. NetTrace
  • 网络数据保存
  • 网络数据广播
  • 扩展跟踪数据发布
  1. 计划任务
  • 多种形式:定时\延时\循环
  • 计划任务管理:加入\执行\退出\修改
  1. 站点类型
  • Pub:实时消息广播功能
  • Queue:可靠的消息队列,支持重放
  • Api:实现Api站点
  • RouteApiStation:实现定向路由的Api类,可通过用户上下文的组织信息,自动路由到指定的服务器,以此支持混合私有云。
  • Vote:实现多路并发的投票模式

2 Clrzmq.Core

基于Clrzmq重构的C#使用Libzmq的类库,支持.Net Core2.0

3 ZeroNet.Core

.NetCore2.0下ZeroNet站点的核心实现,实现以下几个功能

  1. 包括ZMQ使用在内的与ZeroCenter交互的基础封装
  2. ZeroStation:所有工作站的基类
  3. ApiStation:Api工作站的实现类,特点如下:
  • 实现自动ApiControler发现,保持与MVC方式90%的相似度,使用原使用WebApi的简单移植.
  • 实现跨机器的上下文保持
  • 标准的请求与返回格式定义
  • 自动安装与服务注册,使用方通过与ZeroCenter通讯即可透明调用.
  1. QueueStation:可靠的消息队列处理基类,重载时只需简单调用即可,支持重放功能。
  2. SubStation:消息订阅处理基类,重载时只需要关心业务逻辑,无需关心通讯问题
  3. PubStation:不可靠的消息队列的处理基类,重载时只需简单调用即可
  4. ApiClient:调用API的工具类
  5. ZeroPublisher:通用的简单消息发布类,根据名称即可发布,无需关心更多,也不需要重载.

4 HttpGateway

实现Http请求与ZeroCenter路由,用于保证原有对外接口通讯方式不变,同时提供基础安全功能.

5 ZeroMonitor

可视化系统管理与监控网站.通过WebSocket实时推送消息.

6 ZeroTracer

通过网络数据跟踪,实现网络日志、性能分析、流程还原与API调用链谱分析等 微服务相关的资产分析与管理功能