我们可以模拟100个并发用户,对一个页面发送1000个请求 如
$/bin/ab -n1000 -c100 URL
1000个并发 要看是静态页面,还是动态页面。
静态页面2台服务器,配置大概 4核CPU 8G 内存 可以满足。
动态页面就要看应用服务器和数据库服务器了。
并发就是多个执行单元或多个进程并行执行,而这多个执行单元对资源进行共享,比如访问同一个变量或同一个硬件资源,这个时候就很容易出现竞态(说简单点就是竞争同一个”女朋友”)。
为了处理并发带来的问题,Linux有几种处理方法:
1. 中断屏蔽
2. 原子 *** 作
3. 自旋锁
4. 信号量
5. 互斥体
6. 完成量
以上几种处理并发的方式各有利弊,需要根据实际情况来选择使用哪一种。
它的原理就是让CPU不响应中断,一般使用这种方法的要求代码段要比较少,不能占用大量的时间。一般在驱动中不推荐使用这种方式。
原子量保证对一个整形数据的 *** 作是排他性的。就是该 *** 作绝不会在执行完毕前被任何其他任务或事件打断。
自旋锁是一种典型的对临界资源进行互斥访问的手段。当一个自旋锁已经被其他线程持有,而另一个线程试图去获取自旋锁,这时候就会一直在那里等待(原地自旋等待)。如果递归调用自旋锁,就会导致系统死锁。
与自旋锁不同的是,当获取不到信号量时,进程不会原地打转而是进入休眠等待状态。新的Linux内核倾向于直接使用mutex作为互斥手段,信号量用作互斥不再被推荐使用。
当进程占用资源时间较长时,用互斥体会比较好。
使用方法:
完成量的机制是实现一个线程发送一个信号通知另一个线程完成某个任务。一个线程调用wait_for_completion后就进入休眠,另一个线程执行完某个任务后就发送通知给进入休眠的线程,然后它就执行wait_for_completion后面的代码。
查看httpd进程数:Linux命令:
ps -ef | grep httpd | wc -l
返回结果示例:1388
表示服务器能够处理1388个并发请求,这个值服务器可根据负载情况自动调整。
查看服务器的并发请求数及其TCP连接状态:
Linux命令:
netstat -n | awk '/^tcp/ {++S[$NF]} END {for(a in S) print a, S[a]}'
返回结果示例:
LAST_ACK 5
SYN_RECV 30
ESTABLISHED 1597
FIN_WAIT1 51
FIN_WAIT2 504
TIME_WAIT 1057
其中的SYN_RECV表示正在等待处理的请求数;ESTABLISHED表示正常数据传输状态;TIME_WAIT表示处理完毕,等待超时结束的请求数。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)