nginx调优

5 篇文章 0 订阅

基本参数优化
server_tokens off;

#关闭在错误页面中的nginx版本号,安全性是有好处的

sendfile on;

#传输文件时发挥作用

tcp_nopush on;

#一个数据包里发送所有头文件

tcp_nodelay on;

#不缓存数据

keepalive_timeout 10;

#在这个超时时间过后关闭客户端链接

client_header_timeout 10;

#设置请求头的超时时间

client_body_timeout 10;

#设置请求体的超时时间

reset_timeout_connection on;

#开启关闭不响应的客户端连接功能,释放客户端所占的内存空间

send_timeout 10;

#客户端的响应超时时间。如果在这段时间内,客户端没有读取任何数据,nginx就会关闭连接。

#limit_conn_zone 设置用于保存各种key(比如当前连接数)的共享内存的参数。5m就是5兆字节,这个值应该被设置的足够大以存储(32K5)32byte状态或者(16K5)64byte状态。

limit_conn

#为给定的key设置最大连接数。这里key是addr,我们设置的值是100,也就是说我们允许每一个IP地址最多同时打开有100个连接。

default_type

#设置文件使用的默认的MIME-type。

charset

#设置我们的头文件中的默认的字符集

Gzip压缩优化
gzip_types

#压缩的文件类型

text/plain text/css

application/json

application/x-javascript

text/xml application/xml

application/xml+rss

text/javascript

gzip on;

#采用gzip压缩的形式发送数据

gzip_disable “msie6”

#为指定的客户端禁用gzip功能

gzip_static;

#压缩前查找是否有预先gzip处理过的资源

gzip_proxied any;

#允许或者禁止压缩基于请求和响应的响应流

gzip_min_length 1000;

#设置对数据启用压缩的最少字节数

gzip_comp_level 6;

#设置数据的压缩等级

FastCGI参数优化
fastcgi_cache_path

/data/ngx_fcgi_cache #缓存路径

levels=2:2 #目录结构等级

keys_zone=ngx_fcgi_cache:512m

   #关键字区域存储时间

inactive=1d #非活动删除时间

fastcgi_connect_timeout 240;

#连接到后端fastcgi的超时时间

fastcgi_send_timeout 240;

#建立连接后多久不传送数据就断开

fastcgi_read_timeout 240;

#接收fastcgi应答的超时时间

fastcgi_buffer_size 64k;

#指定读取fastcgi应答缓冲区大小

fastcgi_buffers 4 64k;

#指定本地缓冲区大小(缓冲FaseCGI应答请求)

fastcgi_busy_buffers_size 128k;

#繁忙时的buffer,可以是fastcgi_buffer的两倍

fastcgi_temp_file_write_size 128k;

#在写入缓存文件时用多大的数据块,默认是fastcgi_buffer的两倍

fastcgi_cache mingongge;

#开启缓存时指定一个名称

fastcgi_cache_valid 200 302 1h;

#指定应答码200 302 缓存一小时

fastcgi_cache_valid 301 1d;

#指定应答码301缓存一天

fastcgi_cache_valid any 1m;

#指定其它应答码缓存一月

其它参数优化
open_file_cache

#指定缓存最大数目以及缓存的时间

open_file_cache_valid

#在open_file_cache中指定检测正确信息的间隔时间

open_file_cache_min_uses

#定义了open_file_cache中指令参数不活动时间期间里最小的文件数

open_file_cache_errors

#指定了当搜索一个文件时是否缓存错误信息

location ~ .*.(gif|jpg|jpeg|png|bmp|swf)$

#指定缓存文件的类型

    {

    expires 3650d;    

       #指定缓存时间

    }

    location ~ .*\.(js|css)?$

    {

    expires 3d;                     

    }

expires有个缺点就是如果更新WEB数据后,用户没有清理缓存,会看到旧的数据,因此建议将时间设置短一点

优化后完整的配置文件
user www;

pid /var/run/nginx.pid;

worker_processes auto;

worker_rlimit_nofile 100000;

events {

worker_connections 2048;

multi_accept on;

use epoll;

}

http {

server_tokens off;

sendfile on;

tcp_nopush on;

tcp_nodelay on;

access_log off;

error_log /var/log/nginx/error.log crit;

keepalive_timeout 10;

client_header_timeout 10;

client_body_timeout 10;

reset_timedout_connection on;

send_timeout 10;

limit_conn_zone $binary_remote_addr zone=addr:5m;

limit_conn addr 100;

include /etc/nginx/mime.types;

default_type text/html;

charset UTF-8;

gzip on;

gzip_disable “msie6”;

gzip_proxied any;

gzip_min_length 1000;

gzip_comp_level 6;

gzip_types text/plain text/css application/json application/x-javascript text/xml application/xml application/xml+rss text/javascript;

open_file_cache max=100000 inactive=20s;

open_file_cache_valid 30s;

open_file_cache_min_uses 2;

open_file_cache_errors on;

include /etc/nginx/conf.d/*.conf;

include /etc/nginx/sites-enabled/*;

}

当涉及到Nginx和JVM的调优时,我们可以从两个方面来讨论。 首先是Nginx调优Nginx是一个高性能的Web服务器和反向代理服务器,以下是一些常见的Nginx调优方法: 1. 调整worker_processes和worker_connections:根据服务器的硬件配置和负载情况,适当调整worker_processes(工作进程数)和worker_connections(每个工作进程的最大连接数)参数,以提高并发处理能力。 2. 启用gzip压缩:开启gzip压缩可以减小传输的数据量,提高网站的响应速度。 3. 调整缓冲区大小:通过调整proxy_buffer_size、proxy_buffers和proxy_busy_buffers_size等参数,可以优化Nginx对后端服务器的请求和响应的缓冲区管理,提高性能。 4. 使用缓存:使用Nginx的缓存功能可以减轻后端服务器的负载,提高响应速度。可以通过配置proxy_cache和相关参数来启用缓存。 5. 负载均衡:通过配置upstream模块,可以实现Nginx的负载均衡功能,将请求分发到多个后端服务器上,提高系统的可用性和性能。 接下来是JVM的调优。JVM是Java虚拟机的缩写,以下是一些常见的JVM调优方法: 1. 调整堆内存大小:通过调整-Xms和-Xmx参数,可以设置JVM的初始堆大小和最大堆大小,以适应应用程序的内存需求。 2. 设置垃圾回收器:根据应用程序的特点和性能需求,选择合适的垃圾回收器,如Serial GC、Parallel GC、CMS GC或G1 GC,并通过相关参数进行配置。 3. 调整线程数:通过调整-Xss参数,可以设置线程栈的大小,以及通过调整-XX:ParallelGCThreads参数来设置并行垃圾回收线程数,以提高并发处理能力。 4. 监控和分析工具:使用JVM提供的监控和分析工具,如jstat、jconsole、jvisualvm等,可以实时监控JVM的运行状态和性能指标,帮助定位性能瓶颈和优化机会。 5. 代码优化:通过对代码进行优化,如减少对象的创建、避免过多的同步、合理使用缓存等,可以减少JVM的负载,提高性能。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值