一、libevent是什么
libevent是一個輕量級的開源的高性能的事件觸發的網絡庫,適用于windows、linux、bsd等多種平臺,內部使用select、epoll、kqueue等系統調用管理事件機制。
它被眾多的開源項目使用,例如大名鼎鼎的memcached等。
特點:
事件驅動,高性能;
輕量級,專注于網絡(相對于ACE);
開放源碼,代碼相當精煉、易讀;
跨平臺,支持Windows、Linux、BSD和Mac OS;
支持多種I/O多路復用技術(epoll、poll、dev/poll、select和kqueue等),在不同的操作系統下,做了多路復用模型的抽象,可以選擇使用不同的模型,通過事件函數提供服務;
支持I/O,定時器和信號等事件;
采用Reactor模式;
二、下載
libevent1.4代碼量比較少,結構比較簡單,也適合入門學習,1.4很早以前看過了,大家想學習也可以學習1.4。
這里學習的是libevent2.0以上版本。代碼量也比1.4高很多,也加了很多功能。
libevent下載:http://libevent.org/
我下載的是libevent-2.1.8-stable.tar.gz
下載之后解壓,然后進入目錄就可以安裝了。
[eric@localhost libevent-2.1.8-stable]$ ./configure
[eric@localhost libevent-2.1.8-stable]$ make
[eric@localhost libevent-2.1.8-stable]$ sudo make install
[eric@localhost libevent-2.1.8-stable]$ sudo ldconfig /usr/local/lib/libevent.so
我們可以看到有以下一些庫。
libevent_core:所有核心的事件和緩沖功能,包含了所有的event_base、evbuffer、bufferevent和工具函數。
libevent_extra:定義了程序可能需要,也可能不需要的協議特定功能,包括HTTP、DNS和RPC。
libevent:這個庫因為歷史原因而存在,它包含libevent_core和libevent_extra的內容。不應該使用這個庫,未來版本的libevent可能去掉這個庫。
libevent_pthreads:添加基于pthread可移植線程庫的線程和鎖定實現。它獨立于libevent_core,這樣程序使用libevent時就不需要鏈接到pthread,除非是以多線程方式使用libevent。
三、libevent的功能。
Libevent提供了事件通知,io緩存事件,定時器,超時,異步解析dns,事件驅動的http server以及一個rpc框架。
事件通知:當文件描述符可讀可寫時將執行回調函數。
Io緩存:緩存事件提供了輸入輸出緩存,能自動的讀入和寫入,用戶不必直接操作io。
定時器:libevent提供了定時器的機制,能夠在一定的時間間隔之后調用回調函數。
信號:觸發信號,執行回調。
異步的dns解析:libevent提供了異步解析dns服務器的dns解析函數集。
事件驅動的http服務器:libevent提供了一個簡單的,可集成到應用程序中的HTTP服務器。
RPC客戶端服務器框架:libevent為創建RPC服務器和客戶端創建了一個RPC框架,能自動的封裝和解封數據結構。
四、Reactor(反應器)模式
libevent是一個典型的reactor模式的實現。這里做一下簡單介紹:
我們知道,普通的函數調用機制如下:程序調用某個函數,函數執行,程序等待,函數將結果返回給調用程序(如果含有函數返回值的話),也就是順序執行的。
而Reactor模式的基本流程如下:應用程序需要提供相應的接口并且注冊到reactor反應器上,如果相應的事件發生的話,那么reactor將自動調用相應的注冊的接口函數(類似于回調函數)通知你,所以libevent是事件觸發的網絡庫。
作者:依然飯太稀
鏈接:http://www.lxweimin.com/p/0d177e4743c8
來源:簡書
著作權歸作者所有。商業轉載請聯系作者獲得授權,非商業轉載請注明出處。