不灭的焱

革命尚未成功,同志仍须努力

作者:php-note.com  发布于:2017-12-11 22:47  分类:Linux_C基础 

异步网络模型在服务开发中应用非常广泛,相关资料和开源库也非常多。项目中,使用现成的轮子提高了开发效率,除了能使用轮子,还是有必要了解一下轮子的内部构造。

这篇文章从最基础的5种I/O模型切入,到I/O事件处理模型,再到并发模式,最后以Swoole开源库来做具体分析,逐步深入。文中提到的模型都是一些通用的模型,在《linux高性能服务器编程》中也都有涉及。文章不涉及模型的实现细节,最重要的是去理解各个模型的工作模式以及其优缺点。

作者:php-note.com  发布于:2017-11-28 23:35  分类:PHP库/系统/微信 

Swoole 是用php快速开发高效的tcp/udp服务,其中tcp是用的更多的一个场景,http虽然是基于tcp协议的,但和直接开发tcp服务还是有明显的区别的。

TCP是数据流

tcp是数据流,这是一个基本的概念,这里有两个要点:

  1. 数据没有边界

    你可以理解为水在一个水管里的流动,我们不知道哪段数据是一个我们需要的完整数据

  2. 收发有缓冲区

    比如:当水从一端流到了另一端,我们在收数据的时候,不可能每来一滴水就处理一次,这个缓冲区就相当于有了一个水桶,再接了一定的水之后内核再给数据交到用户空间,这样可以大大提升性能。

作者:php-note.com  发布于:2017-11-28 23:34  分类:PHP库/系统/微信 

从上篇的执行流程,可以得出第一个需要思维转换的点:

Swoole是完全的长驻内存的

这个是和web开发第一个很大的不同,之前我们在做web开发,基本不怎么考虑内存控制的问题,这里从两个方面来进行结比:

作者:php-note.com  发布于:2017-11-28 23:24  分类:PHP库/系统/微信 

PHP与SWOOLE的运行模式

php做为swoole的宿主,所以了解php本身的运行模式是必不可少的,下图是以cli下执行一个php文件时的完整流程

作者:php-note.com  发布于:2017-11-07 10:18  分类:PHP库/系统/微信 

Mix:高性能 • 极简 • 多功能『 内置 Server 基于 Swoole 的次世代 PHP 开发框架 

Group-Co:优雅的PHP异步协程框架,支持SOA服务化调用,适用于API、Http Server、Rpc Server、构建微服务、中间件。适用于高并发,io密集型场景

作者:php-note.com  发布于:2017-10-31 09:54  分类:PHP库/系统/微信 

Swoole 用到的系统调用

(1) 内存管理

     FixedPool 固定分配内存池

     RingBuffer 环形内存缓冲区

(2) 定时器:timefd

(3) 信号处理:signalfd

(4) 数据通信:eventfd  + mmap

作者:php-note.com  发布于:2017-10-08 21:32  分类:PHP库/系统/微信 
作者:php-note.com  发布于:2016-01-10 15:22  分类:PHP库/系统/微信 

介绍swoole扩展,从源码的下载,环境依赖,编译参数配置,常见编译问题,安装,配置等内容。期间还会介绍:

  • Linux发行版本的选择
  • 不同版本内核的差异
  • gcc/g++/clang 3种编译器介绍
  • autoconf、cmake的介绍
  • ldconfig介绍
  • nm/strip介绍
  • 生成libswoole.so动态链接库
作者:php-note.com  发布于:2016-01-09 11:18  分类:PHP库/系统/微信 

Rango会讲解在Linux下从零开始写一个PHP扩展,并编译安装到PHP里,一直到执行扩展中的函数。包含的内容有:

  • 为什么要开发PHP扩展
  • ext_skel工具的使用
  • 修改config.m4
  • phpize的使用
  • 必备工具,autoconf / gcc / make / php5 / php5-dev
  • ZendAPI的使用简介,会介绍几个重要的API