服务化框架设计实现(重造轮子,借事修人)
来源:互联网 发布:求马士兵java视频教程 编辑:程序博客网 时间:2024/06/08 16:00
最近一段时间没有工作,为此也有大把的时间,可以做一些平时没有时间做的事情,借事情来重建自己的知识体系,查漏补缺。
决定要利用这一段时间来实现一个服务化框架,实现得七七八八的时候再在github上开源。
(一)服务化框架特征
1、支持无状态、多版本
2、支持热部署、自发现、fail over(自动发布服务、自动发现服务、自动失败转移)
3、支持路径跟踪(统一的调用跟踪信息,可还原)
4、支持可配置的负载均衡(采用默认负载均衡、可配置的负载均衡机制)
5、序列化协议可配置(默认、Java、Hessian、Google protocal buffer、thrift等几种)
6、网络框架可置换(自实现一个类似Hadoop IO框架、Mina等)
7、Spring配置支持(强限制)
8、服务可管理(调用支持配额制、支持自动降级、服务依赖跟踪)
(二)基本功能(V0.1)
1、定义完整的消息格式
2、序列化支持Hessian
3、支持自实现的类似Hadoop I/O框架
4、支持无状态、多版本
(三)设计概要
(1)远程请求消息格式
元数据版本号(版本号变化可以支持不同的元数据格式)
请求元数据字节长度
请求参数字节长度
请求元数据定义:
接口名称(服务提供方的接口名称)
方法名(服务提供方的方法名称)
版本号(同一方法支持多版本,不同逻辑)
协议名(参数序列化协议名称,比如hessian)
父事物标识(调用来源,可以串起首发请求以及依赖的请求调用)
来源APP、来源IP(待定,支持流控与降级)
请求方法参数定义:
方法请求参数列表
(2)rpc概要
服务端支持NIO
客户端使用阻塞方式,客户端与服务端之间采用长连接
- 服务化框架设计实现(重造轮子,借事修人)
- 重造轮子-栈实现队列
- 重造轮子-sqrt
- 重造轮子-最小栈
- 分布式服务框架原理(一)设计和实现
- 重视积累,不再重造轮子
- 重造轮子:学写函数配接器
- 重造轮子-random5到random7
- c# List筛选~ 重造轮子
- 远程服务调用框架设计与实现
- 远程服务调用框架设计与实现
- 远程服务调用框架设计与实现
- 远程服务调用框架设计与实现
- 自己造轮子系列(一)------数据库连接池的实现
- C#实现自动完成功能(人生第一次造轮子)
- [造轮子]Android动态加载框架总结
- 重复造轮子之symfony框架
- C++ 开发 Web 服务框架 - HTTP Web 框架的设计与实现(二)
- linux驱动之入门
- 物理STANDBY的SWITCHOVER切换
- VS2008LINK : fatal error LNK1000: Internal error during IncrBuildImage
- 防止程序启动两次的方法CreateMutex()
- 百度算法频频更新,草根站长的出路何在?
- 服务化框架设计实现(重造轮子,借事修人)
- ORACLE RMAN ACTIVE COPY
- fzu 2129 子序列个数 (dp)
- 所有Mac用户都需要知道的9个实用终端命令行
- link2005错误 .obj重定义
- android 滑动菜单SlidingMenu的实现
- 文献求助论坛
- TraceView issue
- codeforces 325A. Square and Rectangles