返回顶部
首页 > 资讯 > 后端开发 > PHP编程 >PHP细数实现提高并发能力的方法
  • 685
分享到

PHP细数实现提高并发能力的方法

php 2022-08-18 18:08:21 685人浏览 独家记忆
摘要

本篇文章给大家带来了关于PHP的相关知识,主要介绍了php提高并发能力有哪些方案,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,下面一起来看依稀啊,希望对大家有帮助。(推荐教程:PHP视频教程)本文已收录编程学

本篇文章给大家带来了关于PHP的相关知识,主要介绍了php高并发能力有哪些方案,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,下面一起来看依稀啊,希望对大家有帮助。

(推荐教程:PHP视频教程)

本文已收录编程学习笔记gitee。涵盖PHP、javascriptlinuxgolangMysqlRedis开源工具等等相关内容。

用于生产环境中的PHP需要对其进行优化,让PHP自身发挥更好的性能,除了写好PHP代码,还要配置好php-fpm以及php.ini调优。本文从内存、OPcache、上传、会话以及安全等方面讲解php.ini的配置调优。

PHP相对其他的编译性语言,最大的缺点在于每次请求都会去做一些模块解析,真正执行的是work进程。work进程的开启需要消耗更多的资源。同时,来一个请求都会去重新解析一些代码,导致重复解析。

对于PHP的优化,可以重点充这方面去考虑进行优化。

内存优化

运行 PHP 时需要关心每个 PHP 进程要使用多少内存,php.ini 中的memory_limit设置用于设定单个 PHP 进程可以使用的系统内存最大值。

这个设置的默认值是 128M,这对于大多数中小型 PHP 应用来说或许合适,不过,如果运行的是微型 PHP 应用,可以降低这个值,以便节省系统资源,反之,如果运行的是内存集中型 PHP 应用,可以增加这个值。这个值的大小由可用的系统内存决定,确定给 PHP 分配多少值是一门艺术,决定给 PHP 分配多少内存,以及能负担起多少个 PHP-FPM 进程时,可以根据以下维度信息进行判断:

  • 一共可以分配给 PHP 多少内存?以一个 2G 内存的 VPS 为例,这台设备中可能还运行了其他进程,如 mysqlNginx 等,那么留 512M 给 PHP 是合适的。
  • 每个 PHP 进程平均耗费多少内存?这个要监控进程的内存使用量,可以使用命令行命令top,也可以在 PHP 脚本中调用 memory_get_peak_usage() 函数,不管使用哪种方式,都要多次运行同一个脚本,然后取内存消耗的平均值。
  • 能负担起多少个 PHP-FPM 进程?假设我给 PHP 分配了 512M 内存,每个 PHP 进程平均耗费 15M 内存,那么可以负担起 34 个 PHP-FPM 进程。

有足够的系统资源吗?最后还需要确认有足够的系统资源运行 PHP 应用并处理预期的流量。具体的PHP配置信息可以参考php-fpm.config配置文件。

; Time limit for child processes to wait for a Reaction on signals from master.
; Available units: s(econds), m(inutes), h(ours), or d(ays)
; Default Unit: seconds
; Default Value: 0
;process_control_timeout = 0

; The maximum number of processes FPM will fork. This has been designed to control
; the global number of processes when using dynamic PM within a lot of pools.
; Use it with caution.
; Note: A value of 0 indicates no limit
; Default Value: 0
; process.max = 128

; Specify the nice(2) priority to apply to the master process (only if set)
; The value can vary from -19 (highest priority) to 20 (lowest priority)
; Note: - It will only work if the FPM master process is launched as root
; - The pool process will inherit the master process priority
; unless specified otherwise
; Default Value: no set
; process.priority = -19

; Send FPM to background. Set to 'no' to keep FPM in foreground for debugging.
; Default Value: yes
daemonize = no

php-fpm有三种运行模式,分别是固定进程数、按需进程数、完全动态进程数。

  • 按需进程数,默认初始化几个进程数,如果进去量过大,动态创建一些新的进程数,等请求结束之后,新创建的进程数在销毁掉。
  • 固定进程数,默认固定几个进程,如果进程数不够的情况时,新的请求处于等待中,直到其他的进程处理完毕才会处理新的请求。
  • 完全动态进程数,表示完全由请求量控制,来一个请求创建一个进程,处理完毕在销毁掉。

开启Zend OPcache性能加速

确定要分配多少内存后,就可以配置 PHP 的 Zend OPcache 扩展。OPcache主要是将一些代码解析成字节码,在后续的请求中就无需重复去解析、编译这部分代码。减少编译、解析的过程,也能提高PHP的处理速度。

PHP5.5.0+内置了这个扩展,下面罗列几项必要的配置信息:

opcache.memory_consumption = 64:为操作码缓存分配的内存(单位是MB),分配的内存量应该可以保存应用中所有 PHP 脚本编译得到的操作码,这个值根据应用的体量可以设置成不同大小的值。

opcache.interned_strings_buffer = 16:用来存储驻留字符串的内存量(单位是MB),什么是驻留字符串呢?PHP 解释器在背后会找到相同字符串的多个实例,把这个字符串保存在内存中,如果再次使用相同的字符串,PHP 解释器会使用指针,这么做的目的是节省内存。默认情况下,PHP 驻留字符串会隔离在各个 PHP 进程中,这个设置能让 PHP-FPM 进程池把所有进程驻留字符串存储到共享的缓冲区中,以便在 PHP-FPM 进程池中的多个进程之间引用驻留字符串,这样能节省更多内存。

opcache.max_accelerated_files = 4000:操作码缓存中最多能存储多少个 PHP 脚本,这个值的区间是 2000 到 100000 之间,这个值一定要比 PHP 应用中的文件数大。

opcache.validate_timestamps = 1:这个设置的值为1时,经过一段时间后 PHP 会检查 PHP 脚本的内容是否有变化,检查的时间间隔由opcache.revalidate_freq设置指定。如果这个设置的值为0,PHP 不会检查 PHP 脚本的内容是否有变化,我们必须自己动手清除缓存的操作码。建议在开发环境中设置为1,生产环境中设置为0。

opcache.revalidate_freq = 0:设置多久(单位是秒)检查一次 PHP 脚本内容是否有变化。设置为0秒的含义是仅当opcache.validate_timestamps设置为1时,才会在每次请求时都重新验证 PHP 文件,因此,在开发环境中每次都会重新验证 PHP 文件,在生产环境中则不验证。

opcache.fast_shutdown = 1:这么设置能让操作码使用更快的停机步骤,把对象析构和内存释放交给 Zend Engine 的内存管理器完成。

文件上传

如果你的应用允许上传文件,最好设置最大能上传的文件大小。除此之外,最好还要设置最多能同时上传多少个文件:

file_uploads = 1
upload_max_filesize = 10M
max_file_uploads = 3

默认情况下,PHP 允许在单次请求中上传 20 个文件,上传的文件最大为 2MB,这里我设置为单次请求最多只能上传 3 个文件,每个文件最大为 10MB,这个值不要设置太大,否则会出现超时。

注:如果非要上传大文件,WEB 服务器的配置也要做相应调整。除了在 php.ini 中设置之外,还要调整 Nginx 虚拟主机配置中的 client_max_body_size 设置。

此外,如果是上传特大文件,我建议使用Webuploader专门的上传组件,前端对大文件进行切片,后端php对分片数据进行合并还原文件。有关WebUploader应用请参考本站文章:功能强大的文件上传组件-WebUploader。

执行时间

max_execution_time 用于设置单个 PHP 进程在终止之前最长可运行时间。这个设置默认是 30 秒,建议将其设置为 5 秒:

max_execution_time = 5

在 PHP 脚本中可以调用set_limit_time()函数覆盖这个设置。

假设我们想要生成报告,并把结果制作成 pdf 文件,这个任务可能要花 10 分钟才能完成,而我们肯定不想让 PHP 请求等待 10 分钟,我们应该单独编写一个 PHP 文件,让其在单独的后台进程中执行,Web 应用只需几毫秒就可以派生一个单独的后台进程,然后返回 Http 响应。

实际上,我们在跑需要消耗大量时间来完成的任务,一般采用后台进程方式,比如我们可以使用PHP的swoole扩展来生成报表、批量发送邮件耗时长的任务。

处理会话

PHP默认的情况是将会话产生的信息存在磁盘中,例如所谓的session信息。在创建和读取session时,都会对磁盘进行I/O操作,读写磁盘其实是比较耗时的一个操作。并且session不方便做分布式应用的会话机制处理。推荐可以放在Redis、memcached这样的内存性服务中,读写速度快,并且可以做分布式会话机制处理。

下面举例将session这样的信息,存储在memcached内存中。

session.save_handler = "memcached"
session.save_path = "服务地址:端口号"

缓冲区

如果是在较少的块中发送更多数据,而不是在较多的块中发送较少的数据,那么网络的效率会更高,也就是说,在较少的片段中把内容传递给访问者的浏览器,能减少 HTTP 请求总数。

因此,我们要让 PHP 缓冲输出,默认情况下,PHP 已经启用了输出缓冲功能,PHP 缓冲 4096 字节的输出之后才会把内容发送给 Web 服务器,推荐配置如下:

output_buffering = 4096
implicit_flush = false

如果想要修改输出缓冲区的大小,确保使用的值是4(32位系统)或8(64位系统)的倍数。

安全设置

open_basedir:使用open_basedir选项能够控制PHP脚本只能访问指定的目录,这样能够避免PHP脚本访问不应该访问的文件,一定程度上限制了phpshell的危害。我们一般可以设置为只能访问网站目录:

open_basedir = /data/www

disable_functions:一般我们要禁止系统函数和禁止任何文件和目录的操作,如:

disable_functions = '.....'

expose_php = Off:将此项设置为false即不会再header头输出PHP版本信息。

display_errors = Off:生产环境中,我们应该禁止错误提示,如果是本地开发环境,可以设置为On。

log_errors = On:建议在关闭display_errors后能够把错误信息记录下来,便于查找服务器运行的原因。

error_log:设置PHP错误日志存放的目录。

(推荐教程:PHP视频教程)

以上就是PHP细数实现提高并发能力的方法的详细内容,更多请关注编程网其它相关文章!

--结束END--

本文标题: PHP细数实现提高并发能力的方法

本文链接: https://lsjlt.com/news/33763.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • PHP细数实现提高并发能力的方法
    本篇文章给大家带来了关于PHP的相关知识,主要介绍了PHP提高并发能力有哪些方案,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,下面一起来看依稀啊,希望对大家有帮助。(推荐教程:PHP视频教程)本文已收录编程学...
    99+
    2022-08-18
    php
  • PHP-FPM性能优化:提高网站并发处理能力的方法
    概述:在如今互联网时代,网站的并发访问量越来越大,为了迎接高并发的访问量,提高网站的并发处理能力变得非常重要。PHP-FPM(PHP-FastCGI Process Manager)作为一个高性能的PHP解决方案,可以有效地提高网站的并发处...
    99+
    2023-10-21
    性能优化 php-fpm 并发处理能力
  • PHP如何优化以提高高并发能力?
    用于生产环境中的PHP需要对其进行优化,让PHP自身发挥更好的性能,除了写好PHP代码,还要配置好php-fpm以及php.ini调优。本文从内存、OPcache、上传、会话以及安全等方面讲解php.ini的配置调优。PHP相对其他的编译性...
    99+
    2022-08-22
    php
  • PHP 函数的并发编程能力提升
    php 函数具备并发编程能力,支持协程、生成器和异步调用等并发模式。实战案例包括:协程实现多任务、生成器生成斐波那契数列、异步调用进行外部分析等,展示了如何利用 php 函数的并发编程能...
    99+
    2024-05-01
    php 并发编程
  • ASP API的并发处理能力如何提高性能?
    在现代互联网应用中,高性能和高可伸缩性是至关重要的。在ASP API开发中,如何提高并发处理能力是一个必须要面对的问题。本文将介绍几种提高ASP API性能的方法。 使用异步编程模型 ASP API支持异步编程模型,这种模型可以提高并...
    99+
    2023-07-28
    api 并发 数据类型
  • 怎么提高服务器的并发处理能力
    这篇文章主要介绍怎么提高服务器的并发处理能力,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!什么是服务器并发处理能力一台服务器在单位时间里能处理的请求越多,服务器的能力越高,也就是服务器并发处理能力越强有什么方法衡量服...
    99+
    2023-06-04
  • 如何使用PHP开发缓存提高网站的并发处理能力
    如何使用PHP开发缓存提高网站的并发处理能力 随着互联网的高速发展,网站的并发处理能力变得越来越重要。而提高网站并发处理能力的一种常见手段就是使用缓存。缓存可以大大减轻数据库的负担,提高网站的性能和响应速度。PHP作为一种流行的服务器端编程...
    99+
    2023-11-07
    网站开发 并发处理 PHP 缓存
  • 利用Memcache缓存技术提高PHP应用的并发处理能力
    随着互联网的飞速发展,越来越多的应用程序需要面对大量的并发请求,如何提高应用的并发处理能力成为开发者们需要解决的问题。其中,利用Memcache缓存技术进行并发优化成为了相对较为流行的一种方案。Memcache是一种高效的缓存技术,适用于大...
    99+
    2023-05-18
    PHP Memcache 并发处理
  • 如何使用Windows函数来提高ASP网站的并发处理能力?
    在ASP网站开发中,提高并发处理能力是非常重要的。Windows操作系统提供了一些强大的函数来优化ASP网站的并发处理能力,这篇文章将介绍如何使用这些函数来提高ASP网站的性能。 一、使用Windows API函数创建线程 Windows ...
    99+
    2023-09-01
    并发 函数 windows
  • Swoole和Workerman对PHP与MySQL的并发处理能力的提升
    一、Swoole简介Swoole是一个基于C语言开发、针对PHP应用的扩展,它提供了一套完整的异步、并发的网络编程框架。Swoole通过引入协程的概念来实现高效的并发处理,能够在PHP中实现类似Node.js的事件驱动编程模型。优势Swoo...
    99+
    2023-10-21
    swoole Workerman 并发处理能力
  • PHP 分布式架构中的缓存优化:如何提高并发处理能力?
    PHP分布式架构中的缓存优化:如何提高并发处理能力? 在现代的大型Web应用程序中,处理并发请求是一个非常重要的问题。为了满足大量请求的需求,许多应用程序都采用了分布式架构,其中缓存是一个非常重要的组成部分。在本文中,我们将讨论如何在PHP...
    99+
    2023-09-22
    分布式 并发 缓存
  • 如何通过PHP的分布式函数提高并发性能?
    PHP是一门流行的Web编程语言,但是在高并发的情况下,PHP的性能可能会受到限制。为了解决这个问题,可以使用PHP的分布式函数来提高并发性能。本文将介绍如何使用PHP的分布式函数来提高并发性能。 首先,我们需要了解什么是PHP的分布式函数...
    99+
    2023-10-06
    分布式 函数 并发
  • PHP函数如何实现高并发系统的开发?
    在高并发系统开发中,php 语言提供了内置函数,如:1. 并行处理函数(pcntl_fork())可创建子进程并行执行任务;2. 非阻塞 i/o 函数(stream_socket_cli...
    99+
    2024-04-14
    php 高并发 swoole
  • 快速提高web数据分析能力的方法有哪些
    这篇文章主要介绍“快速提高web数据分析能力的方法有哪些”,在日常操作中,相信很多人在快速提高web数据分析能力的方法有哪些问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”快速...
    99+
    2024-04-02
  • 实现高性能的Select Channels Go并发式编程的golang方法
    要实现高性能的Select Channels Go并发式编程的golang方法,可以按照以下步骤进行:1. 定义所需的通道和数据结构...
    99+
    2023-10-20
    Golang
  • Apache ab并发负载压力测试实现方法
    ab命令原理 Apache的ab命令模拟多线程并发请求,测试服务器负载压力,也可以测试nginx、lighthttp、IIS等其它Web服务器的压力。 ab命令对发出负载的计算机要求很低,既不会占用很多CPU,也不会...
    99+
    2022-06-04
    Apache ab 并发 负载压力
  • PHP 分布式缓存方案:如何提高系统的并发性能?
    随着互联网的快速发展,很多网站和应用程序面临的最大问题是高并发访问。为了解决这个问题,开发人员通常会使用缓存技术。PHP 分布式缓存是一种非常有效的缓存技术,可以帮助我们提高系统的并发性能。 什么是 PHP 分布式缓存? PHP 分布式缓...
    99+
    2023-09-22
    分布式 并发 缓存
  • PHP和Unix下的并发编程算法如何提高程序性能?
    随着Web应用程序的不断发展,越来越多的Web应用程序需要同时处理多个请求。这种需求不仅仅存在于Web应用程序中,也存在于其他类型的应用程序中。而并发编程算法正是为了解决这种需求而设计的。在本文中,我们将讨论PHP和Unix下的并发编程算...
    99+
    2023-08-13
    unix 并发 编程算法
  • PHP数组如何实现高效并发缓存?
    在现代的Web应用程序中,缓存是非常重要的一个概念。缓存可以大大提高应用程序的性能,减轻服务器的负担。在PHP中,数组是一种非常方便的数据结构,可以用来实现高效的并发缓存。 下面我们将介绍如何使用PHP数组来实现高效的并发缓存。 使用P...
    99+
    2023-09-21
    数组 并发 缓存
  • php大数据高并发处理的方法是什么
    处理大数据和高并发的方法很多,以下是一些常用的方法:1. 分布式存储和计算:使用分布式存储和计算技术,将数据分散存储在多个节点上,并...
    99+
    2023-09-27
    php
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作