在开发中,我们不得不考虑并发的问题,抗高并发的能力是一个优秀程序员必备的技能之一,而很多朋友对于高并发和多线程,集群不太清除是什么东西,我就简单的将自己的心得分享一下。
1. 高并发
在理解高并发之前,首先要理解并发
并发:与单位时间相关,在单位时间内可以处理事情的能力
通俗理解,就是在同一时间有多少人访问你的项目
高并发就是一瞬间超出程序可承受的压力。我再举一个形象的例子。
把程序比作和尚,正常情况下。
这样的话,和尚一点事都没有,甚至还能偷个懒摸个鱼啥的。
忽然有一次… …
这一次,忽然让他去挑500斤的水,和尚当场被水压死了。
高并发其实就是在某个时间内,请求太多,超出了程序可以处理的速度,导致很多请求挤压,堵塞,最后程序崩溃。
其实高并发没有具体的范围规定多少并发算是高并发,如果这个和尚是真佛转世,500斤的水他也能挑走,就跟程序一样,你的程序最大并发是100,那么101并发对你来说就是高并发,但是这个并发数放在淘宝上,什么都不算。
2. 多线程
抗并发,其实就是提高程序的处理速度,而多线程就是提高程序效率的显著方式。
现在让这一个和尚去挑这一千斤水,他一桶桶的挑,效率是不是很慢!
而我们让这么多和尚同时去挑这些水,是不是就效率就大大的提高了。
这就是多线程。
代码中的案例。
一个用户来注册会员,原本我们的流程是:
- 将用户名,密码,手机号存入数据库
- 给用户发送一条短信
- 在给他发送一张会员优惠券
- 在数据库中增加一次pv
- 返回给用户注册成功的页面
这样是单线程的做法,效率是不是很低。
但是我们使用了多线程就成了这样的流程。
- 将用户名,密码,手机号存入数据库
- 调用多线程,给用户发短信,发券,增加pv
- 返回给用户成功页面