apache的prefork和worker模式详解

2023-10-09 23:33

本文主要是介绍apache的prefork和worker模式详解,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

apache 的 prefork 和 worker 模式详解

 

什么是 prefork 模式


这个多路处理模块(MPM) 实现了一个非线程型的、预派生的web 服务器,

它的工作方式类似于Apache 1.3 。

它适合于没有线程安全库,

需要避免线程兼容性问题的系统。

它是要求将每个请求相互独立的情况下最好的MPM ,

这样若一个请求出现问题就不会影响到 其他请求。

这个MPM 具有很强的自我调节能力,只需要很少的配置指令调整。

最重要的是将MaxClients 设置为一个足够大的数值以处理潜在的请求高峰,

同时又不能太大,以致需要使用的内存超出物理内存的大小。

说的简单点就是用进程来处理http 请求,而不用线程来处理。

为什么要这样处理的原因是为了避免线程安全问题。

什么是 worker 模 式


此多路处理模块 (MPM) 使网络服务器支持混合的多线程多进程。

由于使用线程来处理请求,所以可以处理海量请求,

而系统资源的开销小于基于进程的 MPM 。

但是,它也使用了多进程,每个进程又有多个线程,

以获得基于进程的 MPM 的稳定性。

主要是启动多个进程,每个进程又可以启动好几个线程。
怎么样进程切换

怎么样切换

将当前的prefork 模式启动文件改名
cd /usr/local/apache/bin

mv httpd httpd.prefork
将worker 模式的启动文件改名
mv httpd.worker httpd

重新启动服务
/etc/init.d/httpd restart
即可换成worker 方式启动apache2

Prefork 参数设置


如果是源码安装的话此文件在/usr/local/apache/conf/extra/httpd-mpm.conf

<IfModule mpm_prefork_module>

    StartServers          5 // 启动时开启的进程数目

    MinSpareServers       5 // 保有的备用进程的最小数目

    MaxSpareServers      10 // 保有的备用进程的最大数目

    MaxClients          150 // 服务器允许启动的最大进程数

    MaxRequestsPerChild   0 // 一个服务进程允许的最大请求数

</IfModule>

Worker 参数设置


<IfModule mpm_worker_module>

    StartServers          2 // 服务器启动时的服务进程数目

    MaxClients          150 // 许同时连接的最大用户数目

    MinSpareThreads      25 // 保有的最小工作线程数目

    MaxSpareThreads      75 // 允许保有的最大工作线程数目

    ThreadsPerChild      25 // 每个服务进程中的工作线程常数

    MaxRequestsPerChild   0 // 服务进程中允许的最大请求数目

</IfModule>



Locations of visitors to this page

统计

这篇关于apache的prefork和worker模式详解的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/176357

相关文章

C++使用栈实现括号匹配的代码详解

《C++使用栈实现括号匹配的代码详解》在编程中,括号匹配是一个常见问题,尤其是在处理数学表达式、编译器解析等任务时,栈是一种非常适合处理此类问题的数据结构,能够精确地管理括号的匹配问题,本文将通过C+... 目录引言问题描述代码讲解代码解析栈的状态表示测试总结引言在编程中,括号匹配是一个常见问题,尤其是在

Debezium 与 Apache Kafka 的集成方式步骤详解

《Debezium与ApacheKafka的集成方式步骤详解》本文详细介绍了如何将Debezium与ApacheKafka集成,包括集成概述、步骤、注意事项等,通过KafkaConnect,D... 目录一、集成概述二、集成步骤1. 准备 Kafka 环境2. 配置 Kafka Connect3. 安装 D

Java中ArrayList和LinkedList有什么区别举例详解

《Java中ArrayList和LinkedList有什么区别举例详解》:本文主要介绍Java中ArrayList和LinkedList区别的相关资料,包括数据结构特性、核心操作性能、内存与GC影... 目录一、底层数据结构二、核心操作性能对比三、内存与 GC 影响四、扩容机制五、线程安全与并发方案六、工程

Spring Cloud LoadBalancer 负载均衡详解

《SpringCloudLoadBalancer负载均衡详解》本文介绍了如何在SpringCloud中使用SpringCloudLoadBalancer实现客户端负载均衡,并详细讲解了轮询策略和... 目录1. 在 idea 上运行多个服务2. 问题引入3. 负载均衡4. Spring Cloud Load

Springboot中分析SQL性能的两种方式详解

《Springboot中分析SQL性能的两种方式详解》文章介绍了SQL性能分析的两种方式:MyBatis-Plus性能分析插件和p6spy框架,MyBatis-Plus插件配置简单,适用于开发和测试环... 目录SQL性能分析的两种方式:功能介绍实现方式:实现步骤:SQL性能分析的两种方式:功能介绍记录

在 Spring Boot 中使用 @Autowired和 @Bean注解的示例详解

《在SpringBoot中使用@Autowired和@Bean注解的示例详解》本文通过一个示例演示了如何在SpringBoot中使用@Autowired和@Bean注解进行依赖注入和Bean... 目录在 Spring Boot 中使用 @Autowired 和 @Bean 注解示例背景1. 定义 Stud

如何通过海康威视设备网络SDK进行Java二次开发摄像头车牌识别详解

《如何通过海康威视设备网络SDK进行Java二次开发摄像头车牌识别详解》:本文主要介绍如何通过海康威视设备网络SDK进行Java二次开发摄像头车牌识别的相关资料,描述了如何使用海康威视设备网络SD... 目录前言开发流程问题和解决方案dll库加载不到的问题老旧版本sdk不兼容的问题关键实现流程总结前言作为

SQL 中多表查询的常见连接方式详解

《SQL中多表查询的常见连接方式详解》本文介绍SQL中多表查询的常见连接方式,包括内连接(INNERJOIN)、左连接(LEFTJOIN)、右连接(RIGHTJOIN)、全外连接(FULLOUTER... 目录一、连接类型图表(ASCII 形式)二、前置代码(创建示例表)三、连接方式代码示例1. 内连接(I

Go路由注册方法详解

《Go路由注册方法详解》Go语言中,http.NewServeMux()和http.HandleFunc()是两种不同的路由注册方式,前者创建独立的ServeMux实例,适合模块化和分层路由,灵活性高... 目录Go路由注册方法1. 路由注册的方式2. 路由器的独立性3. 灵活性4. 启动服务器的方式5.

Java中八大包装类举例详解(通俗易懂)

《Java中八大包装类举例详解(通俗易懂)》:本文主要介绍Java中的包装类,包括它们的作用、特点、用途以及如何进行装箱和拆箱,包装类还提供了许多实用方法,如转换、获取基本类型值、比较和类型检测,... 目录一、包装类(Wrapper Class)1、简要介绍2、包装类特点3、包装类用途二、装箱和拆箱1、装