介绍个apache 的 ab 工具,来进行模拟高并发的场景

日常工作中,我们如果想测试下某一个接口的并发情况,或者想看看自己设计的方案,到底有没有解决了高并发,可以通过下面的案例来试试

 

安装

yum -y install httpd-tools  压测工具(ab)下载
ab -V 来检查是否安装完

 

操作

ab -n100 -c 10 网址.....
-n : 总共访问多少次
-c : 模拟10个并发用户

下面进行模拟

代码如下:

connect('127.0.0.1', 6379);
$redis->auth(123456);

if ($redis->lLen('ooo') >= 100) {// 大于或者等于xxx 就提示队列已满 固定队列长度
    echo '队列已满';
    exit;
}

$int = $redis->lPush('ooo', '1');
echo $int;

 

在服务器中:

 ab -n1000 -c 100 http://39.108.6.204/twj/test/gaoBingFa/2.php

然后再去 redis 中查看这个队列,因为我上面的判断,队列不能大于或等于100,所以下面这个队列,肯定最大只能到99

# 进入redis 中 通过这个命令查看队列当前有多少个值
lrange ooo 0 -1 

 

竟然超过了99,也就是说,这里存在一个并发问题

 

介绍个apache 的 ab 工具,来进行模拟高并发的场景_第1张图片

 

 

简单模拟下了解决方案

队列长度固定为120,也就是说,只可以120个用户进入这个队列

connect('127.0.0.1', 6379);
$redis->auth(123456);
if ($redis->lLen('ooo') + 1 > $llen) {
    echo '队列已满';
    exit;
}
$llen = 120;// 队列固定的长度
$key = 'lock';// 锁的名字
while (true) {
    $redis->set($key, 1);
    //设置键的过期时间
    $redis->setTimeout($key, 1);// 锁的有效时间  1秒
    if ($redis->exists($key)) {// 拿到锁,解决并发

        $int = $redis->lPush('ooo', '1');
        if ($int + 1 > $llen) {// 提示队列已满 固定队列长度
            echo '队列已满';
            break;
        }
    } else {// 没拿到锁
        break;
    }
}


 

执行命令

ab -n1000 -c 101 http://39.108.6.204/twj/test/gaoBingFa/2.php

 

介绍个apache 的 ab 工具,来进行模拟高并发的场景_第2张图片

 

 

 

你可能感兴趣的:(介绍个apache 的 ab 工具,来进行模拟高并发的场景)