PHP程序员为什么要学习swoole?

2021-07-2410:23:21后端程序开发Comments1,739 views字数 1866阅读模式

什么是swoole文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/21580.html

swoolePHP的异步、并行、高性能网络通信引擎,使用纯C语言编写,提供了PHP语言的异步多线程服务器,异步TCP/UDP网络客户端,异步MySQL,异步Redis,数据库连接池,AsyncTask,消息队列,毫秒定时器,异步文件读写,异步DNS查询。Swoole内置了Http/WebSocket服务器端/客户端、服务器端。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/21580.html

为什么要使用 Swoole文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/21580.html

常驻内存,避免重复加载带来的性能损耗,提升海量性能文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/21580.html

协程异步,提高对 I/O 密集型场景并发处理能力(如:微信开发、支付、登录等)文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/21580.html

方便地开发 Http、WebSocket、TCP、UDP 等应用,可以与硬件通信文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/21580.html

PHP 高性能微服务架构成为现实文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/21580.html

常驻内存文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/21580.html

目前传统 PHP框架,在处理每个请求之前,都要做一遍加载框架文件、配置的操作。这可能已经成为性能问题的一大原因,而使用 Swoole 则没有这个问题,一次加载多次使用。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/21580.html

协程文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/21580.html

如下图所示,这是同一个线程处理并发请求的场景,比如你某个接口中需要调用其它 api 接口或读写大文件,传统同步阻塞和协程异步的优势就体现了出来。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/21580.html

PHP程序员为什么要学习swoole?文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/21580.html

说到协程,就得先简单说说进程和线程,众所周知进程是很占用资源的,为了处理请求大量创建进程肯定是得不偿失的。而多线程应用就比较多了,在 CPU 层面有几个核心就会执行几个任务,线程一旦创建的多了,就会有线程调度的损耗。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/21580.html

协程是在单线程基础上实现的,它可以最大限度利用 CPU 资源,而不会在等待 I/O 时白白浪费。当然,协程数越多占用的内存也就越多,不过这个是可以接受的,相比进程和线程,占用的资源是相对较少的。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/21580.html

使用协程时,遇到读写文件、请求接口等场景,会自动挂起协程,把 CPU 让给其它协程执行任务,这样可以提升单线程的 CPU 资源利用率,减少浪费,从而提高性能。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/21580.html

协程代码示例:文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/21580.html


use Swoole\Coroutine as co;

// 协程
$time = microtime(true);
// 创建10个协程
for($i = 0; $i < 10; ++$i)
{
 // 创建协程
 go(function() use($i){
  co::sleep(); // 模拟请求接口、读写文件等I/O
  echo $i, PHP_EOL;
 });
}
swoole_event_wait();
echo 'co time:', microtime(true) - $time, ' s', PHP_EOL;

// 同步
$time = microtime(true);
// 创建10个协程
for($i = 0; $i < 10; ++$i)
{
 sleep(1); // 模拟请求接口、读写文件等I/O
 echo $i, PHP_EOL;
}
echo 'sync time:', microtime(true) - $time, ' s', PHP_EOL;

运行结果:文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/21580.html

0
9
8
7
6
5
4
3
2
1
co time:087130069733 s
0
1
2
3
4
5
6
7
8
9
sync time: s

从上面结果可以看出,协程方式执行并不是顺序的,性能更高,在sleep时会把当前线程的任务执行权交给其他协程。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/21580.html

创建 Http 服务文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/21580.html

其实也没想象中的难,看代码:文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/21580.html

$http = new swoole_http_server("", 9501);
$http->on('request', function ($request, $response) {
 $response->end("

Hello Swoole. #".rand(1000, 9999)."

");
});
$http->start();

学习Swoole需要掌握哪些基础知识

大概就下面这些文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/21580.html

  • 了解Linux操作系统进程和线程的概念
  • 了解Linux进程/线程切换调度的基本知识
  • 了解进程间通信的基本知识,如管道、UnixSocket、消息队列、共享内存 SOCKET
  • 了解SOCKET的基本操作如accept/connect、send/recv、close、listen、bind
  • 了解SOCKET的接收缓存区、发送缓存区、阻塞/非阻塞、超时等概念 IO复用
  • 了解select/poll/epoll
  • 了解基于select/epoll实现的事件循环,Reactor模型
  • 了解可读事件、可写事件 TCP/IP网络协议
  • 了解TCP/IP协议
  • 了解TCP、UDP传输协议 调试工具
  • 使用 gdb 调试Linux程序
  • 使用 strace 跟踪进程的系统调用
  • 使用 tcpdump 跟踪网络通信过程
  • 其他Linux系统工具,如ps、lsof、top、vmstat、netstat、sar、ss等
文章源自菜鸟学院-https://www.cainiaoxueyuan.com/bc/21580.html
  • 本站内容整理自互联网,仅提供信息存储空间服务,以方便学习之用。如对文章、图片、字体等版权有疑问,请在下方留言,管理员看到后,将第一时间进行处理。
  • 转载请务必保留本文链接:https://www.cainiaoxueyuan.com/bc/21580.html

Comment

匿名网友 填写信息

:?: :razz: :sad: :evil: :!: :smile: :oops: :grin: :eek: :shock: :???: :cool: :lol: :mad: :twisted: :roll: :wink: :idea: :arrow: :neutral: :cry: :mrgreen:

确定