php 堵塞 消息队列,PHP的并发处理

PHP如何处理并发

什么是进程、线程、协程

进程 Process计算机中的程序关于某数据集合上的一次运行活动,“一个执行中的程序”

系统进行资源分配和调度的基本单位

三态模型:

多道程序系统中,进程在处理器上交替运行,状态不断地发生变化运行:正在处理机上运行;

就绪:当一个进程获得了除处理机以外的一切所需资源,一旦得到处理机即可运行,则称处于就绪状态。可按多个优先级来划分队列。如,当一个进程由于时间片用完而进入就绪状态时,排入低优先级;当进程由IO操作完成而进入就绪状态时,排入高优先级队列。

阻塞:也称为等待或睡眠状态,一个进程正在等待某一事件发生(例如请求IO而等待IO完成等)而暂时停止运行,这时即使把处理机分配给进程也无法运行。

五态模型:活跃阻塞,是指进程已在主存,一旦等待的事件发生便进入活跃就绪状态;

静止阻塞,进程对换到辅存时的阻塞状态,一旦等待的事件发生便进入静止就绪状态。

活跃就绪,指进程在主存并且可被调度的状态;

静止就绪,是指进程被对换到辅存时的就绪状态,是不能被直接调度的状态,只有当主存中没有活跃就绪态进程,或者是挂起就绪态进程具有更高的优先级,系统将把挂起就绪态进程调回主存并转换为活跃就绪。

新建态:进程刚刚被创建时没有被提交的状态,等待系统完成创建进程的所有必要信息。

活跃就绪/静止就绪:

运行:-

活跃阻塞/静止阻塞:

终止态:进程已结束运行,回收除进程控制块之外的其他资源,并让其他进程从进程控制块中收集有关信息。

线程 Thread有时被称为轻量级进程(LightWeight Process, LWP),程序执行流的最小单元。

一个相对独立的、可调度的执行单元,系统独立调度和分配CPU的基本单位。

共享进程的地址空间和资源。

状态:就绪、阻塞、运行就绪状态:具备运行的所有条件,逻辑上可以运行,在等待处理机

运行状态:占有处理机正在运行

阻塞状态:在等待一个事件(如某个信号量),逻辑上不可执行

协程 Coroutine一种用户态的轻量级线程,调度完全由用户控制

拥有自己的寄存器上下文和栈

调度切换时,将寄存器上下文和栈保存到其他地方,切回来的时候恢复,基本没有内核切换的开销

可以不加锁的访问全局变量

异步

什么是多进程、多线程

多进程

同一个时间里,同一个计算机系统中如果允许两个或两个以上的进程处于运行状态,就是多进程

多线程

单个程序中同时运行多个线程完成不同的工作,就是多线程

同步阻塞模型

多进程,最早的服务端程序都是通过多进程、多线程来解决并发IO的问题;

一个请求创建一个进程,然后子进程进入循环同步堵塞地与客户端连接进行交互,收发处理数据。

多线程,用多线程模式实现非常简单,线程中直接向某一个客户端连接发送数据。

缺点严重依赖进程的数量解决并发问题

启动大量进程会带来额外的进程调度消耗

9b8210f692a66f006215e1b35f469b2d.png

异步非阻塞模型select 系统的查询,一个进程内建立1024个连接,poll 模型,循环检测是否有连接。

现在各种高并发异步IO的服务器程序都是基于 epoll 实现的。

IO复用异步非阻塞程序使用经典的 Reactor 模型,顾名思义就是反应堆的意思,本身不处理任何数据收发。只是可以监视一个socket句柄的事件变化。

Reactor模型Add: 添加一个socket到Reactor

Set: 修改socket对应的事件,如可读可写

Del: 从Reactor中移除,不再监听事件

Callback: 事件发生后回调指定的函数

Nginx:多线程Reactor

Swoole:多线程Reactor + 多进程Worker

7ca1c535ad623dacd4e5226952d99740.png

PHP并发编程实践

Swoole扩展异步、并行、高性能网络通信引擎,使用C语言编写,提供了PHP语言的异步多线程服务器,异步TCP/UDP网络客户端,异步MySQL,异步Redis,数据库连接池,AsyncTask,消息队列,毫秒定时器,异步文件读写,异步DNS查询

为PHP多进程的模式设计了多个并发数据结构和IPC通信机制,可以大大简化多进程并发编程的工作

Swoole2.0支持了类似Go语言的协程,可以使用完全同步的代码实现异步程序

消息队列经典场景,注册成功后发送邮件,发送短信

串行方式:注册成功后,先发送邮件,在发送短信

并行方式:注册成功后,同时发送邮件和短信

消息队列方式(离线方式):注册成功后,将成功消息写入队列,此时直接返回成功给用户,写入队列的时间非常短,可以忽略不计,然后异步发送邮件和短信 -

应用解耦场景说明:用户下单后,订单系统需要通知库存系统。

假如库存系统无法访问,则订单减库存将失败,从而导致订单失败。

订单系统与库存系统耦合

引用队列,用户下单后,订单系统完成持久化处理,将消息写入消息队列,返回用户订单下单成功。

订阅下单的消息,采用拉/推的方式,获取下单信息,库存系统根据下单信息,进行库存操作。

流量削峰秒杀活动,流量瞬时激增,服务器压力过大。

用户发起请求,服务器接收后,先写入消息队列。假如消息队列长度超过最大值,则直接报错或提示用户。

后续程序读取消息队列再做处理。

控制请求量,缓解高流量。

日志处理场景:解决大量日志的传输

日志采集程序将程序写入消息队列,然后通过日志处理程序的订阅消费日志。

消息通讯场景:聊天室

多个客户端订阅同一主题,进行消息发布和接收

常见消息队列产品Kafka

ActiveMQ

ZeroMQ

RabbitMQ

Redis

接口的并发请求

curl_multi_init

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/442568.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

python执行文件函数,python如何运行函数

运行Python的函数,只需要调用函数名,在传递参数就可以,不必关心函数体内部的代码块。函数是带名字的代码块,用于完成具体的工作需要在程序中多次执行同一项任务时,你无需反复编写完成该任务的代码,而只需调…

php小白书,php小白的自学第一天

虽然我还没有学会Python,但是已经开学了……然后老师要验收以php编写的网页……(wdnmd )这两天先把这个网页设计处理了,Python也会学,Linux还没开始,web更是啥也不会……谁再和我说大学比高中轻松我跟他拼命(听说只要先熟悉了HTML…

linux配置文件为yum,yum的配置文件说明

1、网上的可供yum的链接,要求里面有repodata目录,该目录就是分析 RPM 软体后所产生的软体属性相依资料放置处。2、配置文件:/etc/yum.repos.d/CentOS-Base.repo,也可以此目录下建别的以.repo后缀的文件就行[base]:代表…

linux操作系统权限详解,Linux权限详解

权限权限是操作系统用来限制对资源访问的机制。权限一般分为读、写、执行。每个用户都有特定的权限、所属用户、所属组,通过这样的机制来限制哪些用户、哪些组可以对待特定的文件进行怎么样的操作。每个进程都是以某个用户的身份运行,所以进程的权限与该…

Linux 内核 颜色,Linux操作系统内核版的表示方法是( )

(8分)将煤粉隔绝空气加强热,除主要得到焦炭外,还能得到下表所列的物质:序号①②③④⑤⑥⑦名称甲烷一氧化碳乙烯苯在家庭中进行的下列实验或做法可行的是()A.用食醋区分食盐和纯碱B.将食盐经溶解、过滤、蒸发来制纯净的…

linux上听FM程序,安装和使用Odio在Linux上收听FM收音机的方法

Linux平台上有一些很棒的无线电应用程序可用于在Linux上收听FM Radio(收音机),本文介绍Odio,包括安装和使用它来收听FM收音机的方法。启用S​​nap支持和安装Odio由于Snap软件包,Odio无线电应用在Linux上得到了支持,在Linux上&…

go linux 源码编译环境,修改并编译golang源码

Go 语言诞生5周年!友情提示:本文使用Markdown编写,黑色背景文字可能需要横向拖动才能看清全文最近为了做Hyperledger Fabric国密改造,涉及到了golang源码的改动。特将操作过程整理如下,以供参考:golang的源…

linux如何用cat看一行数据库,linux的cat命令

linux下cat命令最基本的用法是用来查看文件内容。那么它的其他用法是什么呢?下面由学习啦小编为大家整理了linux的cat命令的相关知识,希望大家喜欢!linux的cat命令用法1:查看文件内容主要用法1、cat f1.txt,查看f1.txt文件的内容。2、cat -n f1.txt&…

linux 内核空间 sy,在 Linux 下用户空间与内核空间数据交换的方式,第 1 部分: 内核启动参数、模块参数与sysf...

级别: 初级燚 杨 (), 计算机科学硕士2006 年 2 月 16 日本系列文章包括两篇,它们文详细地介绍了 Linux 系统下用户空间与内核空间数据交换的九种方式,包括内核启动参数、模块参数与 sysfs、sysctl、系统调用、netlink、procfs、seq_file、deb…

linux 计划任务格式,linux crontab 定时任务格式和使用方法2019-01-13

前一天学习了 at 命令是针对仅运行一次的任务,循环运行的例行性计划任务,linux系统则是由 cron (crond) 这个系统服务来控制的。Linux 系统上面原本就有非常多的计划性工作,因此这个系统服务是默认启动的。另外, 由于使用者自己也可以设置计划…

c语言折半查找输出坐标,数据结构(C语言版)——有序表查找(折半查找)(代码版)...

数据结构(C语言版)——有序表查找(折半查找)(代码版)数据结构(C语言版)——有序表查找(折半查找)(代码版)#include #include #define ERROR 0#define OK 1#define MAXSIZE 20typedef int Status;Status binarySearch(int arr[],int arrLenght,int wantSearchElement);int main(…

android显示过程,Android 桌面加载图标过程分析

桌面应用图标流程前言本人工作上碰到这么一个需求,开发一款滤镜引擎,将桌面上所有的图标进行统一的滤镜化,这就需要了解一下整个桌面去取图标的过程,了解了整个过程,找到真正拿图标的地方,在真正取图标的地…

android开发者选项打开方式,打开、关闭安卓手机的开发者选项的方法详解

现在使用安卓手机的用户人群很多,大家都知道安卓手机中的“开发人员选项”吧,最近,有用户在问如何关闭或者打开开发者选项。那么小编今天就给大家带来一个打开、关闭安卓手机的开发者选项的方法,有需要的小伙伴赶紧来看看吧。打开…

zynq linux opencv效率,2 - 基于ZYNQ7000的交叉编译工具链Qt+OpenCV+ffmpeg等库支持总结

可以通过输入echo $PATH命令检查环境变量是否设置正确,如下图:可以,编译C文件进行测试,使用gedit在任意目录下编辑hello.c文件如图所示,保存后进入终端。以root身份进入到当前目录下,输入arm-xilinx-linux-…

android l 效果,[原]Android L中水波纹点击效果的实现

博主参加了2014 CSDN博客之星评选,帮我投一票吧。前言前段时间android L(android 5.0)出来了,界面上做了一些改动,主要是添加了若干动画和一些新的控件,相信大家对view的点击效果-水波纹很有印象吧,点击一个view&#…

html表情选择器,原生JS写的emoji表情选择器

//生成表情window.onload function() {var face document.getElementById(‘face‘);for(var i 0; i < 38; i) {var a document.createElement("a");a.href "javascript:;";if(i < 10) {a.innerHTML ‘‘;}else{a.innerHTML ‘‘;}face.appendCh…

3dmax里面cr材质转换vr材质_3DMAX零基础入门视频全套教程

3Dmax基础教程全套视频&#xff1a;点链接就行1.3dmax界面介绍2、3dmax主工具栏3、创建面板与修改面板4、时间轴与视口按钮5、3D视口讲解6、3dmax样条线界面7、CAD如何导入3dmax8、3DMAX绘制初步空间9、3DMAX导入图片与车削10、倒角和倒角剖面11、修改器堆栈|12、弯曲命令13、对…

html5 自定义 datepicker,如何使用 React 构建自定义日期选择器(3)

本文作者&#xff1a;IMWeb howenhuo未经同意&#xff0c;禁止转载Datepicker 组件构建 Datepicker 组件要开始构建 Datepicker 组件&#xff0c;请将以下代码片段添加到 src/components/Datepicker/index.js 文件。import React from "react";import PropTypes from…

群签名和环签名的区别_超级签名和TF签名使用个人开发者账号的区别是什么?...

了解过当前ios签名的朋友都知道&#xff0c;目前ios签名共分为企业签名、超级签名和TF签名&#xff0c;其中企业签名作为签名行业的“老大哥”&#xff0c;深受各路开发者和App运营商的喜爱。而我们今天的主角却是其他两种&#xff1a;超级签名和TF签名。这两种签名方式与企业签…

matlab水蒸气焓值计算_从第一性原理计算出发来理解含能配合物宏观行为的趋势...

欢迎关注微信公众平台"计算材料学"&#xff0c;微信ID&#xff1a;jisuancailiao近日&#xff0c;北京理工大学物理学院郭伟课题组&#xff08;博士研究生孙矗丽&#xff09;与北京理工大学爆炸科学与技术国家重点实验室、机电学院张同来课题组在Physical Chemistry …