性能优化篇之swooole

谈谈php的swoole吧,说到swoole,那么swoole是什么呢?可以用来干啥?能解决啥问题咱得知道吧,那么请看下文:

首先说到swoole,先说swoole是什么呢,swoole是:https://www.swoole.com/

 

 

咱怎么可能给个官方链接就完事了,哈哈,因为官方有很正宗的解释,但是自己理解的话,swoole对于咱们php开发人员来说就是一个扩展,一个用c编写的php扩展,你想想,一般一个请求过来,服务器apache或者nginx接收到,然后处理完交给php处理,这样,php是不是能控制的内容只有自己脚本程序的,那么php要想从服务器接受到数据做验证,做一些访问记录或者用户行为记录日志,有些是不是就够不到,这个时候,我们到猪脚就出现了,swoole,他可以实现tcp,udp,http,http2,websocke服务器,而且只需几行代码就可以创建一个并发甚至比nginx还高的服务,那么为啥swoole这么牛呢,swoole扩展首先直接用c操作底层,调用系统api,而且引入了协程这个大杀器,协程什么呢?说到协程,就有人问了,协程,线程,进程,都是什么,傻傻分不清楚,别慌,这有我专门整理的:

  1、进程

进程是具有一定独立功能的程序关于某个数据集合上的一次运行活动,进程是系统进行资源分配和调度的一个独立单位。每个进程都有自己的独立内存空间,不同进程通过进程间通信来通信。由于进程比较重量,占据独立的内存,所以上下文进程间的切换开销(栈、寄存器、虚拟内存、文件句柄等)比较大,但相对比较稳定安全。

  2、线程

线程是进程的一个实体,是CPU调度和分派的基本单位,它是比进程更小的能独立运行的基本单位.线程自己基本上不拥有系统资源,只拥有一点在运行中必不可少的资源(如程序计数器,一组寄存器和栈),但是它可与同属一个进程的其他的线程共享进程所拥有的全部资源。线程间通信主要通过共享内存,上下文切换很快,资源开销较少,但相比进程不够稳定容易丢失数据。

  3、协程

协程是一种用户态的轻量级线程,协程的调度完全由用户控制。协程拥有自己的寄存器上下文和栈。协程调度切换时,将寄存器上下文和栈保存到其他地方,在切回来的时候,恢复先前保存的寄存器上下文和栈,直接操作栈则基本没有内核切换的开销,可以不加锁的访问全局变量,所以上下文的切换非常快。

 

二、区别:

  1、进程多与线程比较

线程是指进程内的一个执行单元,也是进程内的可调度实体。线程与进程的区别:
1) 地址空间:线程是进程内的一个执行单元,进程内至少有一个线程,它们共享进程的地址空间,而进程有自己独立的地址空间
2) 资源拥有:进程是资源分配和拥有的单位,同一个进程内的线程共享进程的资源
3) 线程是处理器调度的基本单位,但进程不是
4) 二者均可并发执行

5) 每个独立的线程有一个程序运行的入口、顺序执行序列和程序的出口,但是线程不能够独立执行,必须依存在应用程序中,由应用程序提供多个线程执行控制

  2、协程多与线程进行比较

1) 一个线程可以多个协程,一个进程也可以单独拥有多个协程,这样python中则能使用多核CPU。

2) 线程进程都是同步机制,而协程则是异步

3) 协程能保留上一次调用时的状态,每次过程重入时,就相当于进入上一次调用的状态

以上就是进程,线程,协程的基本概念,那么我们接下来看看swoole服务器的并发怎么样,请看下文:

在主进程创建一个http服务,用户请求,访问redis,返回给前段页面,请求不到返回状态码500,一个简单的测试脚本,就是这么一个简单的程序swoole都可以让在256的并发,10000个请求下,qps达到5352,是不是很厉害,有人说,这与自己的预期不一样啊,自己的qps要达到万级,或者像官方说的每秒一万次请求数据库,一万次请求,这些我会在下个博客详细说的!

本篇博客就到这里,奥利给

 

性能优化篇之swooole_第1张图片

 

你可能感兴趣的:(性能优化篇之swooole)