php向隊列服務裏插入一條insert sql例如

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)

<pphp-cgi 開啓進程數

 

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

相關文章
相關標籤/搜索