独立开发者系列(25)——大白话进程

很多小型的规模场景限制下,复杂概念弊端大于利端。不同模式的实现,是根据具体需求来判定,但是理解底层最基础的原理有助于理解很多工具背后的诞生。比如php的swoole  workerman 要解决的问题。

   首先理解,进程概念,进程(Process)是指正在运行中的程序的实例。当一个程序被加载到内存中并开始执行时,它就成为一个进程。每个进程都有自己的地址空间、内存、数据栈以及其他用于管理运行时所需资源的系统属性。用通俗的我们可视化的角度,就是我们在win里面点开一个exe执行文件,然后可以在任务管理器里面可以看到该任务运行。点开我们win的任务管理器,密密麻麻的,我们看到的都是一个个进程,也就是我们电脑当前运行了这么多进程,只是并不是每个进程我们都在用,很多进程是在背后默默工作的。

 而在Linux的进程同样,可以看到茫茫的进程,从每个pid代表了一个当前正在运行的进程,保持着系统的稳定或者运行了某种功能。而需要说明的,有些程序为了提升软件的运行稳定性,会开多个进程。比如我们最常用的web服务器,nginx.,当前默认情况下,会开四个进程(这个是可以通过配置设定)。但是我们会发现其实它们都是有个主进程的,是1413,

为啥nginx要开这么多进程呢,其实是为了提升nginx自身的性能,还有防止一些异常错误导致服务器的崩溃,而在通常情况下,不同的进程有以下不同的通途:

主进程(Master Process):主进程是 Nginx 的管理者,负责控制其他所有的工作进程。主要任务包括接受来自管理员或者控制台的信号,管理工作进程的生命周期,以及在需要时重新加载配置文件或者重启服务。主进程通常只有一个。

工作进程(Worker Processes):工作进程是实际处理客户端请求的进程。Nginx 通过配置文件中的 worker_processes 指令来指定启动多少个工作进程。每个工作进程是独立运行的,它们并发地处理客户端的请求,可以充分利用多核处理器的性能优势。每个工作进程之间是相互独立的,不共享内存空间,这样可以提高系统的稳定性和安全性。

Cache Loader 进程(Cache Loader Process,可选):当 Nginx 使用了文件缓存(例如代理缓存或者 FastCGI 缓存)时,会有一个专门的 Cache Loader 进程负责预加载缓存文件到内存中,以加速对这些文件的访问。这个进程通常在启动时创建,完成加载后就退出。

事件处理器(Event Handler): Nginx 使用事件驱动模型来处理并发请求,通常会有一个或多个事件处理器进程。这些进程负责监听套接字和处理事件,例如接受客户端连接、读取请求、发送响应等。事件处理器通常与工作进程集成,确保 Nginx 在高并发情况下仍能高效地处理请求。

  看完为了nginx服务,nginx软件不惜开启四个进程保持稳定性/可靠性。我们再来看php的进程运行方式。

  可以看到php的进程也很多。但是主进程只有一个是1412的主进程。

而PHP 进程被 web(我们这里是nginx) 服务器作为 FastCGI 进程管理器(例如 PHP-FPM)管理,而不是直接由用户调用。每个 PHP 进程在处理客户端请求时会被动态创建,处理完请求后可能会被重用,以提高性能和效率。

 也就是在没有php-fpm之前,都是直接cgi模块直接请求php-cgi.exe,这样很快就发现问题,每个用户的请求都要去初始化php,并跑程序代码,于是为了提高请求性能,开发出了php-fpm,专门来管理本来直接cgi到php的链接。于是我们才可以看到php-fpm池子里面这么多程序等待着nginx的请求。

小结: 我们通过日常经验,直观的看到了进程,同时理解了很多软件在设计的时候,通常开辟多进程来保持程序性能和安全的高效性。

这种运行模式稳定运行了很久,从流程上看并没有问题,我们发出一个请求,nginx接收,然后启动php-fpm管理php程序。受制于nginx本身的一些特性,还有php-fpm本身的代码限制,到最后,会发现其实我们可以直接使用一个程序从接收到程序,直接去调度使用php的,这样没有劣质中间商(php-fpm )耗时,必然让我们的请求效率大幅度提升。于是这款底层php的容器叫workerman。

其实到这里php的逻辑已经变了,之前设计的时候,只是写个简单能跑web的脚本,所以就使用自己php-fpm跟web服务器交互的逻辑运行。但是当php的容器改变之后,可以自定义改变端口和实现异步之后,基本一般的IM和简单交互也可以实现。

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

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

相关文章

【C语言】深入解析归并排序

文章目录 什么是归并排序?归并排序的基本实现代码解释归并排序的优化归并排序的性能分析归并排序的实际应用结论 在C语言编程中,归并排序是一种高效且稳定的排序算法。它采用分治法将问题分解成更小的子问题进行解决,然后合并结果。本文将详细…

Qt基础 | Qt Creator的基本介绍与使用 | 在Visual Studio中创建Qt项目

文章目录 一、Qt Creator的基本介绍与使用1.新建一个项目2.项目的文件组成3.项目文件介绍3.1 项目管理文件3.2 界面文件3.3 主函数文件3.4 窗体相关的文件 4.项目的编译、调试与运行 二、在Visual Studio中创建Qt项目 Qt C开发环境的安装,请参考https://liujie.blog…

maven私有镜像仓库nexus部署使用

maven私有镜像仓库nexus部署使用 1、Nexus部署 #查找镜像 docker search sonatype/nexus3 #拉取镜像 docker pull sonatype/nexus3 #持久化目录 mkdir -p /data/nexus/data chmod 777 -R /data/nexus/data #启动服务 docker run -d --name nexus3 -p 8081:8081 --restart alw…

MyBatis where标签内嵌foreach标签查询报错‘缺失右括号‘或‘命令未正确结束‘

MyBatis <where>标签内嵌<foreach>标签查询报错’缺失右括号’或’命令未正确结束’ <where>标签内嵌<foreach>标签 截取一段脱敏xml&#xff0c;写明大概意思 <select id"queryLogByIds" resultMap"BaseResultMap">SELE…

深度学习基础:Numpy 数组包

数组基础 在使用导入 Numpy 时&#xff0c;通常给其一个别名 “np”&#xff0c;即 import numpy as np 。 数据类型 整数类型数组与浮点类型数组 为了克服列表的缺点&#xff0c;一个 Numpy 数组只容纳一种数据类型&#xff0c;以节约内存。为方便起见&#xff0c;可将 Nu…

lnmp+DISCUZ+WORDPRESS

lnmpDISCUZWORDPRESS lnmpDISCUZ&#xff08;论坛的一个服务&#xff09; l&#xff1a;linux操作系统 n&#xff1a;nginx前端页面的web服务 php&#xff1a;动态请求转发的中间件 mysql&#xff1a;数据库 保存用户和密码以及论坛的相关内容 mysql8.0.30安装&#xff1a…

html(抽奖设计)

<!DOCTYPE html> <html><head><meta charset"UTF-8"><title>抽奖</title><style type"text/css">* {margin: 0;padding: 0;}.container {width: 800px;height: 800px;border: 1px dashed red;position: absolut…

数字营销以打造“会员体系”为主要目标的好处和优势

​蚓链数字化营销实践观察&#xff1a;在数字化时代&#xff0c;企业的营销方式发生了深刻的变革。会员体系作为一种常见的营销策略&#xff0c;在数字营销领域中发挥着越来越重要的作用。 首先&#xff0c;我们来总结一下会员体系的特点和优势 &#xff08;一&#xff09;个性…

7/13 - 7/15

vo.setId(rs.getLong("id"))什么意思&#xff1f; vo.setId(rs.getLong("id")); 这行代码是在Java中使用ResultSet对象&#xff08;通常用于从数据库中检索数据&#xff09;获取一个名为"id"的列&#xff0c;并将其作为long类型设置为一个对象…

c语言中的字符串函数

strstr函数 函数介绍 strstr 用于在一个字符串中查找另一个字符串的首次出现。 我们来看这个函数的参数名字&#xff1a;haysytack&#xff08;干草堆&#xff09;needle&#xff08;针&#xff09;,这个其实就是外国的一句谚语&#xff1a;在干草堆中找一根针&#xff0c;就…

抗量子密码算法:保障未来信息安全的新盾牌

随着量子计算的迅猛发展&#xff0c;传统加密算法正面临着前所未有的挑战。量子计算机利用量子比特的特殊性质&#xff0c;能在极短时间内破解目前广泛使用的公钥加密体系&#xff0c;如RSA、ECC等。这使得我国及全球的信息安全体系遭受严重威胁。为了应对这一挑战&#xff0c;…

unity宏编译版本

在写c程序的时候我们通常可以用不同的宏定义来控制不同版本的编译内容&#xff0c;最近有个需求就是根据需要编译一个完全体验版本&#xff0c;就想到了用vs的那套方法。经过研究发现unity也有类似的控制方法。 注意这里设置完后要点击右下的应用&#xff0c;我起先就没有设置…

09 函数基础

目录 一、定义一个函数 二、调用函数 三、函数的参数 1.形参和实参 2. 参数的分类 3.参数默认值 4.参数类型说明 5.不定长参数 四、函数的返回值 1.定义 2.关键字return 五、变量的作用域 六、匿名函数 七、实参高阶函数 1.定义 2.常见实参高阶函数 max、min、so…

10.1 JSP语言入门

JSP语言入门 目录一、 基础概念1. 什么是JSP&#xff1f;2. 工作原理3. 基本语法 二、 表达式语言&#xff08;EL&#xff09;1. 简介2. 语法 三、 JSTL&#xff08;JSP Standard Tag Library&#xff09;1. 简介2. 核心标签库3. 常用标签 四、 高级话题1. 会话管理2. 自定义标…

【学习笔记】无人机(UAV)在3GPP系统中的增强支持(十一)-无人机服务可用性用例需求

引言 本文是3GPP TR 22.829 V17.1.0技术报告&#xff0c;专注于无人机&#xff08;UAV&#xff09;在3GPP系统中的增强支持。文章提出了多个无人机应用场景&#xff0c;分析了相应的能力要求&#xff0c;并建议了新的服务级别要求和关键性能指标&#xff08;KPIs&#xff09;。…

Python:while循环

while循环体 while 条件: 符合条件执行语句 .... 执行完后需执行的语句 # while循环 i1 while i<5:print(i)ii1 print("Done") test. 做一颗圣诞树吧 答案&#xff1a; # while循环 i 1 j5 while i < 5:print( * j* * i)i i 2jj-1 print("Done"…

护佑未来!引领儿童安全新时代的AI大模型

引领儿童安全新时代的AI大模型 一. 前言1.1 AI在儿童安全方面的潜在作用1.2 实时监控与预警1.3 个性化安全教育与引导1.4 家长监护与安全意识提升 二. AI大模型的优势2.1. 保护儿童隐私和安全的重要性2.2. AI大模型如何应用于儿童安全领域2.1 儿童内容过滤2.2.1 儿童行为监测 2…

代码检查规则语言CodeNavi中代码语句的节点和节点属性

本文分享至华为云社区《CodeNavi 中代码语句的节点和节点属性》。作者&#xff1a;Uncle_Tom 1. 前期回顾 《寻找适合编写静态分析规则的语言》 根据代码检查中的一些痛点&#xff0c;提出了希望寻找一种适合编写静态分析规则的语言。 可以满足用户对代码检查不断增加的各种需求…

使用 PyAMF / Django 实现 Flex 类映射

1、问题背景 PyAMF 是一个用于在 Flex 和 Python 之间进行通信的库&#xff0c;在使用 PyAMF 与 Flex 应用进行通信时&#xff0c;经常会遇到错误。例如&#xff0c;在发送一个 Flex Investor 对象到 Python 时&#xff0c;会得到一个 ‘KeyError: first_name’ 的错误。这是因…

DevToys-开源免费开发工具箱

个人觉得相较于那些在线的工具箱&#xff0c;这种离线的工具箱客户端更加可信一些。 DevToys 提供了30 个默认工具&#xff1a; 转换器&#xff1a;JSON <> YAML、日期、数字基数......编码器/解码器&#xff1a;HTML、URL、Base64、GZip、JWT、二维码......格式化程序…