Iserver简介

Iserver是一个用python编写的网络服务框架(编译版本3.4.1),使用的是epool网络模型

测试机配置

处理器 2x Genuine Intel(R) CPU T2050 @ 1.60GHz

内存 2060MB (673MB used)

nginx开启进程数

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 process

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

php向队列服务里插入一条insert sql例如的更多相关文章

  1. mybatis笔记之一次插入多条数据sql语句写法

    <insert id="insertList" parameterType="java.util.List"> insert into balanc ...

  2. mybatis用mysql数据库自增主键,插入一条记录返回新增记录的自增主键ID

    今天在敲代码的时候遇到一个问题,就是往数据库里插入一条记录后需要返回这个新增记录的ID(自增主键), 公司框架用的是mybatis的通用Mapper接口,里面的插入方法貌似是不能把新纪录的ID回填到对 ...

  3. 跟我一起学WCF(11)——WCF中队列服务详解

    一.引言 在前面的WCF服务中,它都要求服务与客户端两端都必须启动并且运行,从而实现彼此间的交互.然而,还有相当多的情况希望一个面向服务的应用中拥有离线交互的能力.WCF通过服务队列的方法来支持客户端 ...

  4. 【阿里云产品公测】消息队列服务MQS java SDK 机器人应用初体验

    [阿里云产品公测]消息队列服务MQS java SDK 机器人应用初体验 作者:阿里云用户啊里新人   初体验 之 测评环境 由于MQS支持外网访问,因此我在本地做了一些简单测试(可能有些业余),之后 ...

  5. 转:基于HTTP协议的轻量级开源简单队列服务:HTTPSQS

    [文章作者:张宴 本文版本:v1.7.1 最后修改:2011.11.04 转载请注明原文链接:http://blog.zyan.cc/httpsqs/] HTTPSQS(HTTP Simple Que ...

  6. WCF中队列服务详解

    WCF中队列服务详解 一.引言 在前面的WCF服务中,它都要求服务与客户端两端都必须启动并且运行,从而实现彼此间的交互.然而,还有相当多的情况希望一个面向服务的应用中拥有离线交互的能力.WCF通过服务 ...

  7. 基于HTTP协议的轻量级开源简单队列服务:HTTPSQS[转]

    HTTPSQS(HTTP Simple Queue Service)是一款基于 HTTP GET/POST 协议的轻量级开源简单消息队列服务,使用 Tokyo Cabinet 的 B+Tree Key ...

  8. NoSQL初探之人人都爱Redis:(3)使用Redis作为消息队列服务场景应用案例

    一.消息队列场景简介 “消息”是在两台计算机间传送的数据单位.消息可以非常简单,例如只包含文本字符串:也可以更复杂,可能包含嵌入对象.消息被发送到队列中,“消息队列”是在消息的传输过程中保存消息的容器 ...

  9. Redis作为消息队列服务场景应用案例

    NoSQL初探之人人都爱Redis:(3)使用Redis作为消息队列服务场景应用案例   一.消息队列场景简介 “消息”是在两台计算机间传送的数据单位.消息可以非常简单,例如只包含文本字符串:也可以更 ...

随机推荐

  1. Windows 8操作技巧之快捷键大全

    Windows 8操作系统发布之后,因为其新颖的界面和对触屏友好的设计,使许多长期使用Windows系统的用户,也觉得一时难以适应,一些操作方式也不知道如何去实现.在Windows系统中,快捷键无疑是 ...

  2. codeforces A. IQ Test 解题报告

    题目链接:http://codeforces.com/problemset/problem/328/A 一开始单纯地直接判断给出的序列是等差还是等比,连这一句“You should also prin ...

  3. github优秀开源项目大全-iOS

    github优秀开源项目大全-iOS APR 25TH, 2014 前言 本文旨在搜集github上优秀的开源项目 本文搜集的项目都是用于iOS开发 本文会持续更新… 完整客户端 ioctocat g ...

  4. ajax 中文乱码问题 主要是IE浏览器

    解决方案: 提交前采用encodeURI两次编码,注:一定是两次 举例: var taText = $("#txtName").val(); taText = encodeURI( ...

  5. 第六步:Lucene查询索引

    package cn.harmel.lucene; import java.io.IOException; import java.nio.file.Paths; import org.apache. ...

  6. 8.桥接模式(Bridge Pattern)

    using System; namespace ConsoleApplication6 { class Program { static void Main(string[] args) { // 创 ...

  7. VS读取文件或写入文件时出现中文乱码问题

    最近我发现我从文本文档中读取文件处理后再存入新文本文档后,只要是有中文的都显示乱码了~~当我把中文去掉后一切又都正常了,而在我处理过程中,很确定没有对中文进行处理.使用记事本打开发现没有乱码现象,但是 ...

  8. POJ 1523 SPF tarjan求割点

                                                                   SPF Time Limit: 1000MS   Memory Limit ...

  9. 小甲鱼PE详解之输入表(导入表)详解(PE详解07)

    捷径并不是把弯路改直了,而是帮你把岔道堵上! 走得弯路跟成长的速度是成正比的!不要害怕走上弯路,弯路会让你懂得更多,最终还是会在终点交汇! 岔路会将你引入万劫不复的深渊,并越走越深…… 在开始讲解输入 ...

  10. chche缓存

    打开一张图片,先从缓存中找,如果没有,再去sccard中找,如果还没有,就去网络下载.下载好了以后,先保存到sdcard中,再保存到缓存中 public class ImageAsyncTask ex ...