marioTcp
https://github.com/nicholaszj/marioTcp
MarioTCP
MarioTCP 是使用libevent模型来建立的一个性能强大的TCP服务器.
1:Getting Started
用MarioTCP来建立一个性能强大的TCP服务器非常简易.工程源码下有一个非常简洁的例子:
- mario.c:是简单的main程序:
- 1:直接make编译出maritcp,一个TCP服务器;
- 2:业务逻辑是:统计在线的socket的数量,每1分钟输出一次;
- test文件夹:简陋的客户端测试程序:
- 1:与服务器建立连接、发送LOGIN包登陆服务器;
- 2:maritcp服务器会使同时在线加1,客户端断开时服务器在线数减1;
###2:如何定制一个自己业务逻辑的tcp服务器 ### ####2.1 初始化Server####
- SERVER *server = init_server(conf->port, conf->workernum, conf->connnum, conf->timeout, conf->timeout);
- 参数
- port: 服务器Listen端口;
- workernum: 工作线程数;
- connnum: 每个线程支持的连接数;
- timeout: 读超时时间;
- timeout: 写超时时间。 ####2.2 实现业务逻辑函数并注册####
- 具体业务逻辑函数请见Function模块。可通过mario.h中定义的名为“regist_*”的函数来注册。
- 例子:
- 注册业务处理函数
void regist_akg_func(uint16 id, FUNC_PTR func);typedef enum _CMD { CMD_FUNCTION_BASE = 0x6100, CMD_FUNCTION_LOGIN = 0x6101 } CMDid可以是0-65535的任意数,此id封装在MarioTCP的协议中(见本文最后)。 id的范围,可以根据业务逻辑来定制,例如maritcp通过protocol.h中定义的CMD结构体来设定,如上代码.
- --你想为maritcp增加一个"say_hello"的服务
- 1)在CMD中增加:
CMD_FUNCTION_SAY_HELLO = 0x602 - 2)在function中增加函数:
sint32 say_hello(CONN c) { I)通过CONN来解析客户端发过来请求的参数 II)将“hello”设定到c->out_buf III)bufferevent_write(c->bufev, c->out_buf, hrsp->pkglen); IV)return 0; } - 3)在mario.c中增加:
regist_akg_func(CMD_FUNCTION_SAY_HELLO, say_hello);
####2.3 启动日志线程####
- maritcp增加一个线程start_log_thread()
####2.4 启动服务器####
- OK,一个可以支持100万甚至更多长连接的TCP服务器,诞生了!
为什么高效
1:网络服务用到的所有结构体和内存都是启动程序时初始化的,无销毁,无回收。无销毁好理解,不解释。无回收,是指所有内存单元拿来即用,用完及可,不用做reset操作。
2、一个master线程进行accept经过测试发现多进程或线程进行accept和一个进程或线程accept,在极限压力下区别不大。一个master比多个master好在不用再通过锁来解决同步问题。
3、master与worker时单一生产者消费者模式,完全无锁通信不光accept无锁,分配connection、后续的conncetion处理都是无锁的。甚至业务逻辑(见示例maritcp的统计在线数功能)、MarioTCP的日志系统(这也是日志系统抽象不够的一个原因,之前的设计太依赖于整体架构了)都是无锁处理的!
4、一个worker一套libevent环境libevent处理10万长连接的网络读写事件,其性能达到最大化了。每个worker都独立一套libevent,这个结构经过测试,发现开销很小、性能很高。
测试环境的搭建
单机百万长连接、四万CPS(连接每秒)如何做测试
1、设置系统最大文件数为unlimited
2、设置系统的tcp内存内核参数到256M以上
3、设置系统的ip到15个,那么可服务的长连接数理论上最少15*(65535-1024)个
4、用epoll或libevent开一个可同时连接5w的客户端程序;程序还要实现每秒随机挑选1000个连接断掉,并再新创建1000个连接。另外在随机挑选几千连接发包。
5、设置服务端可重用SYN_WAIT的连接;客户端断连接的方式是主动断掉(防止客户端程序端口堆积)
marioTcp的更多相关文章
- MarioTCP:一个单机可日30亿的百万并发长连接服务器
原文:http://blog.csdn.net/everlastinging/article/details/10894493 注:如果用此服务器做变长data的传输,请在业务处理函数中为input ...
- MarioTCP, take it..
MrioTCP,超级马里奥,顾名思义,他不仅高效,而且超级简易和好玩.同时他可以是一个很简洁的Linux C 开发学习工程.毫不夸张的说,如果全部掌握这一个工程,你会成为一个Linux C的牛人:当然 ...
随机推荐
- 老爷机iphone4s 9.2.1降级6.1.3
原帖见威锋网 sunnyskyline 2017年1月10日发的贴. 本文中加了一些我自己的情况,也是一知半解,抛砖引玉吧. 首先进行备份.进行备份.进行备份. 感谢大神@极端阴险 感谢@shuaig ...
- [BZOJ5252][八省联考2018]林克卡特树lct
bzoj(上面可以下数据) luogu description 在树上选出\(k\)条点不相交的链,求最大权值. 一个点也算是一条退化的链,其权值为\(0\). sol 别问我为什么现在才写这题 首先 ...
- hasura graphql server (haskell)构建
安装 &&运行pg(docker) version: '3.6' services: postgres: image: postgres environment: - "PO ...
- 关于CCRANDOM_0_1
CCRANDOM_0_1的范围是[0,1)包括0但不包括1 CCRANDOM_0_1() * 1400.0f / 100.0f是0-13 另外每次随机都是相同的数,要随机下种子 srand((unsi ...
- (原创)AP6212蓝牙模块在am335x控制板上的应用
主控板wifi模块调通后接着调试蓝牙,经过两周的摸索,终于把蓝牙应用基本建立起来,下面记录下大概流程. 1.硬件管脚设置 static void uart4_init(int evm_id, int ...
- POJ2226Muddy Fields
题目:http://poj.org/problem?id=2226 巧妙建图:以行或列上的联通块作为点,每个泥格子作为边,求最小点覆盖就可以了! 于是用匈牙利算法找最大匹配.注意要对右部点记录每一个左 ...
- MyEclipse部署项目到Tomcat上,但是classes文件夹下没有编译项目
在MyEclipse中把项目部署到Tomcat上,但是Tomcat下的classes文件夹下没有编译项目解决方法:1-直接在点击菜单栏的Project--clean,对项目进行clean2-查看菜单栏 ...
- Java的序列化算法--解释序列后字节含义
Java的序列化算法 序列化算法一般会按步骤做如下事情: ◆将对象实例相关的类元数据输出. ◆递归地输出类的超类描述直到不再有超类. ◆类元数据完了以后,开始从最顶层的超类开始输出对象实例的实际数据值 ...
- linux(centOs)下memcached安装
1.libevent安装.为啥先安装它?因为不先装,memcached这座房子就没打地基: yum install libevent-devel 敲回车后出现: Loaded plugins: fas ...
- servlet转发与重定向
HttpServletRequest: 表示浏览器向服务器发送的请求报文,由Tomcat创建然后作为参数传递给我们doget,dopost方法. 功能:getParameter()获取请求参数 get ...