基於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

        煩躁,不寫了。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM