30、LNAP(php和nginx相关优化)
30.1、php-fpm.conf参数优化:
[global]
pid = run/php-fpm.pid
#php后台运行pid路径
error_log = log/php-fpm.log
#php的错误日志路径
rlimit_files = 65535
#php打开文件的描述符大小
[www]
user = nginx
#php所使用的虚拟用户
group = nginx
#php所使用的虚拟用户组
listen = 127.0.0.1:9000
#php所监听的ip及端口号
pm = dynamic
#开启php进程池的动态设置,静态用static
pm.max_children = 70
#在动态方式下限定php-fpm的最大进程数。静态方式下指开启的php-fpm进程数量。
#每个进程数占用20M到30M的内存,以4G的内存为例:4*1024/2/30
pm.start_servers = 40
#动态方式下的起始php-fpm进程数量。
#min_spare_servers + (max_spare_servers - min_spare_servers) / 2
pm.min_spare_servers = 30
#动态方式空闲状态下的最小php-fpm进程数量。
pm.max_spare_servers = 50
#动态方式下空闲状态的最大php-fpm进程数量。
pm.max_requests = 5000
#php-fpm工作进程处理完多少请求后自动重启,主要目的就是为了控制请求处理过
#程中的内存溢出,使得内存占用在一个可接受的范围内,默认是0,表示无休止的
#接受请求。不易设置过大,根据需求进行设置。
request_terminate_timeout = 10
#php脚本最大执行的时间,默认值为 0 秒,也就是说 PHP 脚本会一直执行下去,
#这样,当所有的 php-cgi 进程都卡在 file_get_contents() 函数时,这台
#Nginx+PHP 的WebServer已经无法再处理新的 PHP 请求了。该参数设置为10s或者
#一个合理的值,该参数设置过大或过小都不可。
rlimit_files = 65535
#php打开文件的描述符大小
报错说明:
1、
pm.max_requests
request_terminate_timeout
#以上两个参数如果设置不当会导致nginx error.log 报如下错误,同时网页会短暂出现“502 Bad Gateway”错误。
#[error] 21556#0: *4004 recv() failed (104: Connection reset by peer) while reading response header from upstream,
2、
slowlog = log/$pool.log.slow
#慢请求的记录日志文件路径
request_slowlog_timeout = 10
#当一个请求该设置的超时时间后,就会将对应的PHP调用堆栈信息完整写入到慢日志中。设置为 '0' 表示 'Off'。
#当上面两个参数开启后可能会报ERROR: failed to ptrace(PEEKDATA) pid 27077: Input/output error (5)
30.2、nginx.conf参数优化:
#网页报错:error Connection timed out and 504 error
#nginx报错:[error] 11130#0: *52557 upstream timed out (110: Connection timed out) while reading response header from upstream,
#在server标签内增加以下内容
large_client_header_buffers 4 16k;
#用于读取大型客户端请求头的缓冲区的最大数量和大小。
client_max_body_size 30m;
#客户端请求服务器最大允许大小,包括上传和下载。
#如果请求的正文数据大于client_max_body_size,HTTP协议会报错 413 Request Entity Too Large。
client_body_buffer_size 30m;
#设置请求主体的缓冲区大小。 如果主体超过缓冲区大小,则完整主体或其一部分将写入临时文件,默认路径是/tmp/。
#如果追求效率,就设置和client_max_body_size相同的值,这样就不会存储临时文件,直接存储在内存了。
fastcgi_connect_timeout 300;
#连接到后端fastcgi超时时间
fastcgi_read_timeout 300;
#接收fastcgi应答超时时间(这个指定值已经完成两次握手后向fastcgi传送请求的超时时间)。
fastcgi_send_timeout 300;
#向fastcgi请求超时时间,同理也是2次握手后。
fastcgi_buffer_size 64k;
#读取fastcgi应答第一部分需要多大缓冲区,该值表示使用1个64kb的缓冲区读取应答第一部分(应答头),可以设置为fastcgi_buffers选项缓冲区大小。
fastcgi_buffers 4 64k;
#指定本地需要多少和多大的缓冲区来缓冲fastcgi应答请求,假设一个php或java脚本所产生页面大小为256kb,那么会为其分配4个64kb的缓冲来缓存。
fastcgi_busy_buffers_size 128k;
#默认值是fastcgi_buffers的2倍
fastcgi_temp_file_write_size 128k;
#写入缓存文件使用多大的数据块,默认值是fastcgi_buffers的2倍
30、LNAP(php和nginx相关优化)的更多相关文章
- nginx相关优化
1.配置监控nginx状态信息 vim /usr/locale/nginx/conf/nginx.conf server { listen ; server_name 192.168.1.30; lo ...
- [Nginx] – 性能优化 – 配置文件优化
Nginx基本安全优化 1.调整参数隐藏Nginx版本号信息 一般来说,软件的漏洞都和版本有关,因此我们应尽量隐藏或清除Web服务队访问的用户显示各类敏感信息(例如:Web软件名称及版本号等信 ...
- Nginx软件优化【转】
转自 Nginx软件优化 - 惨绿少年 - 博客园 Nginx软件优化 - 惨绿少年 - 博客园 https://www.cnblogs.com/clsn/p/8484559.html 1.1 Ngi ...
- Nginx软件优化
1.1 Nginx优化分类 安全优化(提升网站安全性配置) 性能优化(提升用户访问网站效率) 1.2 Nginx安全优化 1.2.1 隐藏nginx版本信息优化 官方配置参数说明:http://ngi ...
- 突破10万高并发的nginx性能优化经验(含内核参数优化)
写的很好,推荐阅读. 转载:http://www.cnblogs.com/kevingrace/p/6094007.html 在日常的运维工作中,经常会用到nginx服务,也时常会碰到nginx因高并 ...
- [Nginx] – 安全优化 – 配置文件优化
1.配置Nginx gzip压缩实现性能优化 1.Nginx gzip压缩功能介绍 Nginx gzip压缩模块提供了压缩文件内容的功能,用户请求的内容在发送出用客户端之前,Nginx服务器会根据一 ...
- [NGINX] - 配置文件优化 - NGINX.CONF
Nginx 本文主要针对公司的Nginx负载均衡配置进行解释,配置文件在最下方.因为公司没有使用PHP,所以NGINX里面并没有太多facgi模块相关优化 NGINX.CONF user 语 ...
- The server of Nginx(三)——Nginx企业级优化
相信看过我之前apache文章的朋友们,对服务优化也有了一个大概的了解,相比较而言,Nginx企业中应用的更多一些,因此今天也会详细阐述Nginx的优化,有人说,服务器不需要优化,开虚拟化,分分钟成倍 ...
- 轻量级HTTP服务器Nginx(Nginx性能优化技巧)
轻量级HTTP服务器Nginx(Nginx性能优化技巧) 文章来源于南非蚂蚁 一.编译安装过程优化 1.减小Nginx编译后的文件大小在编译Nginx时,默认以debug模式进行,而在debu ...
随机推荐
- macos查看端口状况
Mac OS netstat命令与CentOS 略有出入 在Mac上正确使用的方法是:即-f需要加上地址族,-p需要加上协议TCP或者UDP等 如果需要查询inet:netstat -anvf ine ...
- Python检查 文件备份是否正常 云备份进程是否正常运行
场景:服务器自动备份数据库文件,每两小时生成一个新备份文件,通过云备份客户端自动上传,需要每天检查是否备份成功. 实现:本脚本实现检查文件是否备份成功,进程是否正常运行,并且发送相关邮件提醒. #! ...
- Linux 用户管理_用户相关配置文件详解
linux的用户管理 linux支持多个用户同时使用同一个用户登陆系统,windows在修改组策略的情况下,也可以多个人使用同一个用户登陆. 远程连接Linux的方式:ssh 远程连接windows的 ...
- SPI总线 通俗易懂讲解——(转载)
SPI总线 MOTOROLA公司的SPI总线的基本信号线为3根传输线,即SI.SO.SCK.传输的速率由时钟信号SCK决定,SI为数据输入.SO为数据输出.采用SPI总线的系统如图8-27所示,它包含 ...
- 第8章 Shell函数的知识与实践
shell 函数常见的语法格式 function 函数名(){ return n } 简化1 function 函数名{ ... } 简化2 函数名(){ ... } ...
- System Verilog MCDF(二)
整形器的接口时序: reg,grant是维持了两个clk的. chid ,length在发送数据期间不可以变化. 第一个data数据必须在start上升沿的同一个clk发送. reg,grant两者之 ...
- synchronized 的超多干货!
前言 synchronized 这个关键字的重要性不言而喻,几乎可以说是并发.多线程必须会问到的关键字了.synchronized 会涉及到锁.升级降级操作.锁的撤销.对象头等.所以理解 synchr ...
- Python+Selenium学习笔记2 - 字符串
跟着网络课程学了几个小程序. 1.判断a字符串是否为b字符串的子串 1 # coding = utf-8 2 3 # 判断str_a字符串是否为str_b字符串的子串 4 5 str_a = &quo ...
- MindSpore Lite整体架构介绍
MindSpore Lite整体架构介绍 MindSpore Lite框架的总体架构如下所示: 前端(Frontend): 负责模型生成,用户可以通过模型构建接口构建模型,将第三方模型和MindSpo ...
- 英伟达TRTTorch
英伟达TRTTorch PyTorch JIT的提前(AOT)编译Ahead of Time (AOT) compiling for PyTorch JIT TRTorch是PyTorch / Tor ...