Iserver簡介php
Iserver是一個用python編寫的網絡服務框架(編譯版本3.4.1),使用的是epool網絡模型python
測試機配置nginx
處理器 2x Genuine Intel(R) CPU T2050 @ 1.60GHzweb
內存 2060MB (673MB used)sql
nginx開啓進程數json
root 2413 2409 0 09:17 pts/0 00:00:00 grep -i nginx網絡
www 2414 2411 2 09:17 ? 00:00:00 nginx: worker process併發
www 2415 2411 0 09:17 ? 00:00:00 nginx: master processapp
www 2416 2411 0 09:17 ? 00:00:00 nginx: master process框架
www 2417 2411 0 09:17 ? 00:00:00 nginx: master process
www 2418 2411 0 09:17 ? 00:00:00 nginx: master process
www 2419 2411 0 09:17 ? 00:00:00 nginx: master process
www 2420 2411 0 09:17 ? 00:00:00 nginx: master process
www 2421 2411 0 09:17 ? 00:00:00 nginx: master process
開啓8個nginx進程消耗120M內存(15M * 8 = 120M)
root 2424 1 0 09:17 ? 00:00:00 php-fpm: master process
www 2425 2424 0 09:17 ? 00:00:00 php-fpm: pool www
www 2426 2424 0 09:17 ? 00:00:00 php-fpm: pool www
www 2427 2424 0 09:17 ? 00:00:00 php-fpm: pool www
www 2428 2424 0 09:17 ? 00:00:00 php-fpm: pool www
www 2429 2424 0 09:17 ? 00:00:00 php-fpm: pool www
www 2430 2424 0 09:17 ? 00:00:00 php-fpm: pool www
www 2431 2424 0 09:17 ? 00:00:00 php-fpm: pool www
www 2432 2424 0 09:17 ? 00:00:00 php-fpm: pool www
www 2433 2424 0 09:17 ? 00:00:00 php-fpm: pool www
www 2434 2424 0 09:17 ? 00:00:00 php-fpm: pool www
www 2435 2424 0 09:17 ? 00:00:00 php-fpm: pool www
開啓12個php-cgi進程消耗掉240M內存(20M * 12 = 240M)
測試流程
首先啓動隊列網絡服務,php向隊列服務裏插入一條insert sql,例如
client.php
複製代碼
1 /**
2 * socket client
3 * a NULL填充字符串
4 * n 表式無符號短整形
5 * 無符號短整型, 老是16點,大端字節序
6 */
7 function insert_queue($cmd, $sql) {
8 $s = socket_create(AF_INET, SOCK_STREAM, SOL_TCP);
9 try {
10 socket_connect($s, "127.0.0.1", 8888);
11 $list = json_encode(array(
12 "sql"=>$sql
13 ));
14 $len = strlen($list);
15 $param = pack("nna{$len}",$cmd, $len, $list);
16 socket_write($s, $param, strlen($param));
17 socket_recv($s, $head, 4, 0);
18 //var_dump($head);
19 if($head != '') {
20 $a = unpack("ncmd/nlen", $head);
21 $cmd = $a['cmd'];
22 $len = $a['len'];
23 if($cmd == 8001) {
24 socket_recv($s, $body, $len, 0);
25 //echo $body;exit;
26 $b = json_decode($body, true);
27 socket_close($s);
28 return $b;
29 }
30 }
31 socket_close($s);
32 } catch(Exception $e) {
33 echo $e->getMessage();
34 }
35 }
36 $temp = insert_queue(8001, "insert into (num) values (%d)");
複製代碼
CircularQueue.py
複製代碼
1 # !/usr/bin/python
2 # coding=utf-8
3 #
4 # @Author: LiXiaoYu
5 # @Time: 2013-11-06
6 # @Info: CircularQueue Server.
7
8 import Epoll
9 from Config import Config
10 from App.Queue.CircularQueue import CircularQueue
11
12 #獲取隊列服務配置
13 _config = Config("Queue")
14
15 #初始參數
16 _port = _config.get("queue.port") #服務端口
17 _app = CircularQueue()
18 #_allow_ip = ['192.168.1.100'] #白名單IP列表
19
20 #開始服務
21 s = Epoll.createServer(_app)
22 #s.setAllowIp(_allow_ip)
23 s.listen(_port)
24 2881064151
25 啓動服務
26 python3 circularQueue.py
複製代碼
測試工具
使用webbench模擬1萬併發
webbench -c 10000 -t 30 http://192.168.1.100/client.php
測試結果
lxy@lenovo-pc:~$ webbench -c 10000 -t 30 http://localhost/client.php
Webbench - Simple Web Benchmark 1.5
Copyright (c) Radim Kolar 1997-2004, GPL Open Source Software.
Benchmarking: GET http://192.168.1.100/client.php
10000 clients, running 30 sec.
Speed=43226 pages/min, 129975 bytes/sec.
Requests: 21613 susceed, 0 failed.
每分鐘相應請求數43226 pages/min,每秒鐘傳輸數據量129975 bytes/sec