基于libevent进程池服务器 - Another 9527 - 博

系统 1890 0

基于libevent进程池服务器 - Another 9527 - 博客园

基于libevent进程池服务器

        本程序仅是为了学习libevent而写的,但可以当作是简单的程序框架扩展为实际的应用。程序本身没有经过广泛的功能测试和压力测试,仅作简单的功能测试,如果在实际应用中产生任何问题与作者无关,也不提供任何技术支持。但欢迎讨论相关技术问题。

        本程序设计思路很简单,一个控制进程,M个业务进程(M可以配置),其中一个业务进程又负责N个TCP连接(N可以配置,因为是在同一个进程内,又没有用于线程,所以从本质来说,还是属于同步传输数据的)。控制进程负责监听连接,当接收到一个TCP连接的时候,按照一定的规则分发到空闲的业务进程中。每个业务进程就负责处理各个分配到的连接,接收到数据后又分发到业务模块,业务模块是可以根据实际的需要扩展的(本程序中则是一个回射服务器的)。

        这个程序且叫一个名字:jmm。下载: jmm

        压缩包里一些特别的文件介绍。

文件名 说明
Makefile Makefile 文件。如果是扩展应用,则修改第6行
JMM_MY_OBJ=myserver.o
改为自己的要编译的文件即可。
jmm.conf 一个简单的配置。
tcpclt.py 一个简单的python TCP客户端测试程序。
myserver.c 业务实现模块。这个就是简单的回射而已。
jmm_cmmhdr.h 对外提供的扩展程序的头文件,包含一些常量的定义。
jmm.h 对外提供的扩展程序的头文件
clog.h
clog.c
简单的日志处理模块。可独立应用于任何应用程序。
ciniconfig.h
ciniconfig.c
简单的读取INI配置文件的模块。可独立应用于任何应用程序。

        编译说明:

  1. 安装libevent. 下载地址: libevent.org
  2. 解压gzip –d jmm.tar.gz; tar xvf jmm.tar
  3. 建立文件夹mkdir conf log bin
  4. 最后make可以了。
  5. 如果会Makefile直接看Makefile

        扩展说明:

typedef struct jmm_hook
{
const char* (*prog_name)();
const char* (*prog_version)();
const char* (*prog_desc)();

int (*prog_init)(char*);
int (*prog_service)(jmm_prog_in*, jmm_prog_out*);
int (*prog_uninit)();

void* (*prog_malloc)(size_t); // sys/types.h
void (*prog_free)(void*);

}jmm_hook;

typedef void (*prog_init_hook)(jmm_hook* hook);

  1. 除了分配内存的那个外,提供其它所有函数的实现。
  2. 用REG_INIT_HOOK_FUN(myserver_init_hook)注册回调函数。
  3. 参考myserver.c

        烦躁,不写了。

基于libevent进程池服务器 - Another 9527 - 博客园


更多文章、技术交流、商务合作、联系博主

微信扫码或搜索:z360901061

微信扫一扫加我为好友

QQ号联系: 360901061

您的支持是博主写作最大的动力,如果您喜欢我的文章,感觉我的文章对您有帮助,请用微信扫描下面二维码支持博主2元、5元、10元、20元等您想捐的金额吧,狠狠点击下面给点支持吧,站长非常感激您!手机微信长按不能支付解决办法:请将微信支付二维码保存到相册,切换到微信,然后点击微信右上角扫一扫功能,选择支付二维码完成支付。

【本文对您有帮助就好】

您的支持是博主写作最大的动力,如果您喜欢我的文章,感觉我的文章对您有帮助,请用微信扫描上面二维码支持博主2元、5元、10元、自定义金额等您想捐的金额吧,站长会非常 感谢您的哦!!!

发表我的评论
最新评论 总共0条评论