免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
楼主: csumck
打印 上一主题 下一主题

[C] 请教一个服务器程序协议设计的问题 [复制链接]

论坛徽章:
1
2015年辞旧岁徽章
日期:2015-03-03 16:54:15
11 [报告]
发表于 2013-09-27 10:53 |只看该作者
回复 9# yulihua49


    多谢,你这个中间件里的socket就是一些路由规则么? 是不是类似cokeboL兄方法里的本机ID的东西。

论坛徽章:
15
射手座
日期:2014-11-29 19:22:4915-16赛季CBA联赛之青岛
日期:2017-11-17 13:20:09黑曼巴
日期:2017-07-13 19:13:4715-16赛季CBA联赛之四川
日期:2017-02-07 21:08:572015年亚冠纪念徽章
日期:2015-11-06 12:31:58每日论坛发贴之星
日期:2015-08-04 06:20:00程序设计版块每日发帖之星
日期:2015-08-04 06:20:00程序设计版块每日发帖之星
日期:2015-07-12 22:20:002015亚冠之浦和红钻
日期:2015-07-08 10:10:132015亚冠之大阪钢巴
日期:2015-06-29 11:21:122015亚冠之广州恒大
日期:2015-05-22 21:55:412015年亚洲杯之伊朗
日期:2015-04-10 16:28:25
12 [报告]
发表于 2013-09-27 10:53 |只看该作者
csumck 发表于 2013-09-27 10:49
回复 5# cokeboL

等会,还没说完呢。
这个交易中间件叫做SDBC,开源,有一个QQ群:100807652

论坛徽章:
36
子鼠
日期:2013-08-28 22:23:29黄金圣斗士
日期:2015-12-01 11:37:51程序设计版块每日发帖之星
日期:2015-12-14 06:20:00CU十四周年纪念徽章
日期:2015-12-22 16:50:40IT运维版块每日发帖之星
日期:2016-01-25 06:20:0015-16赛季CBA联赛之深圳
日期:2016-01-27 10:31:172016猴年福章徽章
日期:2016-02-18 15:30:3415-16赛季CBA联赛之福建
日期:2016-04-07 11:25:2215-16赛季CBA联赛之青岛
日期:2016-04-29 18:02:5915-16赛季CBA联赛之北控
日期:2016-06-20 17:38:50技术图书徽章
日期:2016-07-19 13:54:03程序设计版块每日发帖之星
日期:2016-08-21 06:20:00
13 [报告]
发表于 2013-09-27 11:01 |只看该作者
回复 10# csumck


这个你们自己定啊,比如按照你们机房的关系,弄个config表,标识出上下游的链条关系关系和各机房主机的ip,这样表示统一的,配在每个服务器上,

主机启动时候加载config来初始化自己的转发列表,各机房有变时更新config;

或者config表放在一个固定服务器上,其他主机启动时从该服务器获取并初始化自己。这样就主机有变化时只要更新总服务器;

免得重新编译代码了。

论坛徽章:
15
射手座
日期:2014-11-29 19:22:4915-16赛季CBA联赛之青岛
日期:2017-11-17 13:20:09黑曼巴
日期:2017-07-13 19:13:4715-16赛季CBA联赛之四川
日期:2017-02-07 21:08:572015年亚冠纪念徽章
日期:2015-11-06 12:31:58每日论坛发贴之星
日期:2015-08-04 06:20:00程序设计版块每日发帖之星
日期:2015-08-04 06:20:00程序设计版块每日发帖之星
日期:2015-07-12 22:20:002015亚冠之浦和红钻
日期:2015-07-08 10:10:132015亚冠之大阪钢巴
日期:2015-06-29 11:21:122015亚冠之广州恒大
日期:2015-05-22 21:55:412015年亚洲杯之伊朗
日期:2015-04-10 16:28:25
14 [报告]
发表于 2013-09-27 11:12 |只看该作者
本帖最后由 yulihua49 于 2013-09-27 11:20 编辑
csumck 发表于 2013-09-27 10:53
回复 9# yulihua49

完了,看9楼吧。

接出socket是通过交易路由系统管理的。
它包括一组连接池,每个池都是一组具有特定功能的次级服务器。
当你需要一定功能时,从连接池中查找合适的服务器并获取一个连接。

你可以看到,交易中间件与简单的socket+多线程+epoll有多大距离。

论坛徽章:
1
2015年辞旧岁徽章
日期:2015-03-03 16:54:15
15 [报告]
发表于 2013-09-27 11:15 |只看该作者
回复 9# yulihua49


    非常感谢! 大概了解了,挺不错的东西。

论坛徽章:
15
射手座
日期:2014-11-29 19:22:4915-16赛季CBA联赛之青岛
日期:2017-11-17 13:20:09黑曼巴
日期:2017-07-13 19:13:4715-16赛季CBA联赛之四川
日期:2017-02-07 21:08:572015年亚冠纪念徽章
日期:2015-11-06 12:31:58每日论坛发贴之星
日期:2015-08-04 06:20:00程序设计版块每日发帖之星
日期:2015-08-04 06:20:00程序设计版块每日发帖之星
日期:2015-07-12 22:20:002015亚冠之浦和红钻
日期:2015-07-08 10:10:132015亚冠之大阪钢巴
日期:2015-06-29 11:21:122015亚冠之广州恒大
日期:2015-05-22 21:55:412015年亚洲杯之伊朗
日期:2015-04-10 16:28:25
16 [报告]
发表于 2013-09-27 11:24 |只看该作者
本帖最后由 yulihua49 于 2013-09-27 11:42 编辑
csumck 发表于 2013-09-27 11:15
回复 9# yulihua49

回到你的主题:
交易中间件的包头设计:
交易命令
交易参数
数据包长度
如果支持压缩,还要提供未压缩长度。
数据包校验
包头校验

包序号我没用,需要这自己加。

论坛徽章:
4
水瓶座
日期:2013-09-06 12:27:30摩羯座
日期:2013-09-28 14:07:46处女座
日期:2013-10-24 14:25:01酉鸡
日期:2014-04-07 11:54:15
17 [报告]
发表于 2013-09-27 11:29 |只看该作者
为什么要把服务做成有状态的, 在包里记录整个来源路径链就是了.

论坛徽章:
15
射手座
日期:2014-11-29 19:22:4915-16赛季CBA联赛之青岛
日期:2017-11-17 13:20:09黑曼巴
日期:2017-07-13 19:13:4715-16赛季CBA联赛之四川
日期:2017-02-07 21:08:572015年亚冠纪念徽章
日期:2015-11-06 12:31:58每日论坛发贴之星
日期:2015-08-04 06:20:00程序设计版块每日发帖之星
日期:2015-08-04 06:20:00程序设计版块每日发帖之星
日期:2015-07-12 22:20:002015亚冠之浦和红钻
日期:2015-07-08 10:10:132015亚冠之大阪钢巴
日期:2015-06-29 11:21:122015亚冠之广州恒大
日期:2015-05-22 21:55:412015年亚洲杯之伊朗
日期:2015-04-10 16:28:25
18 [报告]
发表于 2013-09-27 11:33 |只看该作者
本帖最后由 yulihua49 于 2013-09-27 11:35 编辑
linux_c_py_php 发表于 2013-09-27 11:29
为什么要把服务做成有状态的, 在包里记录整个来源路径链就是了.

无需记录路径链,有可能是无穷长。
我们并不限制交易的转接次数。
每一个节点管好自己的事,你的前驱,你的后继,其他的,不要管那么多。

论坛徽章:
4
水瓶座
日期:2013-09-06 12:27:30摩羯座
日期:2013-09-28 14:07:46处女座
日期:2013-10-24 14:25:01酉鸡
日期:2014-04-07 11:54:15
19 [报告]
发表于 2013-09-27 11:37 |只看该作者
做有状态记录的服务, 小心网络不稳定, 请求大量超时服务崩盘.

论坛徽章:
15
射手座
日期:2014-11-29 19:22:4915-16赛季CBA联赛之青岛
日期:2017-11-17 13:20:09黑曼巴
日期:2017-07-13 19:13:4715-16赛季CBA联赛之四川
日期:2017-02-07 21:08:572015年亚冠纪念徽章
日期:2015-11-06 12:31:58每日论坛发贴之星
日期:2015-08-04 06:20:00程序设计版块每日发帖之星
日期:2015-08-04 06:20:00程序设计版块每日发帖之星
日期:2015-07-12 22:20:002015亚冠之浦和红钻
日期:2015-07-08 10:10:132015亚冠之大阪钢巴
日期:2015-06-29 11:21:122015亚冠之广州恒大
日期:2015-05-22 21:55:412015年亚洲杯之伊朗
日期:2015-04-10 16:28:25
20 [报告]
发表于 2013-09-27 11:44 |只看该作者
本帖最后由 yulihua49 于 2013-09-27 12:02 编辑
linux_c_py_php 发表于 2013-09-27 11:37
做有状态记录的服务, 小心网络不稳定, 请求大量超时服务崩盘.

这在交易中间件里都考虑并妥善处理了。

它不保证每个操作的可靠性,但是保证交易的完整性。夭折事务会被rollback。

它的连接池管理系统是自愈的,次级服务器故障会导致事务夭折,但是恢复后就可以继续使用,本级服务器无需重启或复位。
它的协议能够抗攻击,能应对种种不按常理出牌的请求。

你的话也是提醒楼主,做一个级联交易系统不是那么简单,要面临种种挑战。
这种工作大多数要找一个成熟的交易中间件产品,而不是自己摸石头过河。


您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP