Nginx官网完整配置例子

本文详细介绍了Nginx的配置参数及其应用场景,包括用户组设置、进程管理、连接数配置、事件模型选择、HTTP服务器设置、日志格式、性能优化等关键配置项,并提供了负载均衡和反向代理的具体配置实例。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Nginx官网完整配置例子
# Nginx用户组
user www www;
# 两个worker,根据硬件调整,通常等于CPU数量或者CPU的核数
worker_processes 2;
# 进程标识符
pid /var/run/nginx.pid;
#[ debug | info | notice | warn | error | crit ]
# 错误日志
error_log /var/log/nginx.error_log info;
events {
# 每个worker的最大连接数,一个nginx能建立的最大连接数,应该是worker_connections* worker_processes。当然,这里说的是最大连接数,
对于HTTP请求本地资源来说,能够支持的最大并发数量是worker_connections* worker_processes,而如果是HTTP作为反向代理来说,最大并发数
量应该是worker_connections * worker_processes/2。因为作为反向代理服务器,每个并发会建立与客户端的连接和与后端服务的连接,会占用两
个连接。
worker_connections 2000;
# 工作模式,linux建议epollFreeBSD建议采用kqueuewindow下不指定。
补充说明:
apache相类,nginx针对不同的操作系统,有不同的事件模型
A
)标准事件模型
Select
poll属于标准事件模型,如果当前系统不存在更有效的方法,nginx会选择selectpoll
B
)高效事件模型
Kqueue
:使用于FreeBSD 4.1+, OpenBSD 2.9+, NetBSD 2.0 MacOS X.使用双处理器的MacOS X系统使用kqueue可能会造成内核崩溃。
Epoll
:使用于Linux内核2.6版本及以后的系统。
/dev/poll
:使用于Solaris 7 11/99+HP/UX 11.22+(eventport)IRIX 6.5.15+ Tru64 UNIX5.1A+
# use [ kqueue | epoll | /dev/poll | select | poll ];
    use kqueue;
} #
设置HTTP服务器,利用它的反向代理功能来提供负载均衡支持
http {
# 设定mime类型,类型由mime.types文件定义
    include conf/mime.types;
    default_type application/octet-stream;
    # 日志格式设置。
        $remote_addr
$http_x_forwarded_for用以记录客户端的ip地址;
        $remote_user
:用来记录客户端用户名称;
$time_local
用来记录访问时间与时区;
$request
用来记录请求的urlhttp协议;
$status
用来记录请求状态;成功是200
$body_bytes_sent
:记录发送给客户端文件主体内容大小;
$http_referer
:用来记录从那个页面链接访问过来的;
$http_user_agent
:记录客户浏览器的相关信息;
通常web服务器放在反向代理的后面,这样就不能获取到客户的IP地址了,通过$remote_add拿到的IP地址是反向代理服务器的iP地址。反向代
理服务器在转发请求的http头信息中,可以增加x_forwarded_for信息,用以记录原有客户端的IP地址和原来客户端的请求的服务器地址。

log_format main     '$remote_addr - $remote_user [$time_local] '

'"$request" $status $bytes_sent '

'"$http_referer" "$http_user_agent" '

'"$gzip_ratio"';

log_format download  '$remote_addr - $remote_user [$time_local] '

'"$request" $status $bytes_sent '

'"$http_referer" "$http_user_agent" '

'"$http_range" "$sent_http_content_range"';

client_header_timeout 3m;

client_body_timeout 3m;

send_timeout 3m;

#设定请求缓冲
client_header_buffer_size 1k;
large_client_header_buffers 4 4k;
# 开启gzip模式

gzip on;

gzip_min_length    1100;

gzip_buffers    48k;

gzip_typestext/plain;


output_buffers 1 32k;
postpone_output 1460;
# 指定nginx是否调用sendfile函数来输出文件,对于普通应用,必须设定为on,如果用来进行下载等应用磁盘IO重负载应用,可设置为off
以平衡磁盘与网络IO处理速度,降低系统uptime

sendfile on;

# 允许或禁止使用socket的TCP_CORK的选项

tcp_nopush on;
tcp_nodelay on;
send_lowat 12000;

# keepalive超时时间
keepalive_timeout 75 20;
#lingering_time 30;
#lingering_timeout 10;
#reset_timedout_connection on;

# 配置虚拟机
server {

#设置本虚拟主机的访问日志
access_log /var/log/nginx.access_log main;
# "/"启用负载均衡
location / {
proxy_pass http://127.0.0.1/;
proxy_redirect off;
# 目的是将代理服务器收到的用户的信息传到真实服务器上
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
#proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
# 设定通过nginx上传文件的大小
client_max_body_size     10m;
client_body_buffer_size   128k;
client_body_temp_path   /var/nginx/client_body_temp;
# 后端服务器连接的超时时间,发起握手等候响应超时时间
proxy_connect_timeout 70;
# 后端服务器数据回传时间_就是在规定时间之内后端服务器必须传完所有的数据
proxy_send_timeout 90;
# 连接成功后,等候后端服务器响应时间,其实已经进入后端的排队之中等候处理(也可以说是后端服务器处理请求的时间)

proxy_read_timeout 90;
proxy_send_lowat 12000;

#设置从被代理服务器读取的第一部分应答的缓冲区大小,通常情况下这部分应答中包含一个小的应答头,默认情况下这个值的大小为指
proxy_buffers中指定的一个缓冲区的大小,不过可以将其设置为更小

  proxy_buffer_size 4k;
# 设置用于读取应答(来自被代理服务器)的缓冲区数目和大小,默认情况也为分页大小,根据操作系统的不同可能是4k或者8k
proxy_buffers 4 32k;
proxy_busy_buffers_size 64k;

#设置在写入proxy_temp_path时数据的大小,预防一个工作进程在传递文件时阻塞太长
proxy_temp_file_write_size 64k;
# proxy_temp_pathproxy_cache_path指定的路径必须在同一分区
proxy_temp_path   /var/nginx/proxy_temp;
charset koi8-r;
}
error_page 404 /404.html;
location /404.html {
root /spool/www;

location /old_stuff/ {
rewrite ^/old_stuff/(.*)$ /new_stuff/$1 permanent;

location /download/ {
valid_referers none blocked server_names *.example.com;
if ($invalid_referer) {
#rewrite ^/ http://www.example.com/;
return 403;
}
# rewrite_log on;
# rewrite /download/*/mp3/*.any_ext to /download/*/mp3/*.mp3
rewrite ^/(download/.*)/mp3/(.*)\..*$
/$1/mp3/$2.mp3 break;

root   /spool/www;
#autoindex  on;
access_log /var/log/nginx-download.access_log  download;

}

# 静态资源处理
location ~* \.(jpg|jpeg|gif)$ {
root /spool/www;
access_log off;
expires 30d;
}
# 设定查看Nginx状态的地址
location /NginxStatus {
stub_status on;
access_log on;
# 默认是 off
# auth_basic "NginxStatus";
# auth_basic_user_file conf/htpasswd;
}

  }


查看Nginx运行状态:
输入地址 http://XXX.XXX.X.X/NginxStatus/,输入帐号密码,即可以看到如下内容:
# 当前活跃的连接数
Active connections: 10
server accepts handled requests
#Nginx当前时间接受到的总请求数
23 43 54
#读写等待
Reading: 1 writing: 3 Waiting: 6
active connections –活跃的连接数量
server accepts handled requests —
总共处理了xxx个连接 ,成功创建xxx次握手,总共处理了xxx个请求
reading —
读取客户端的连接数
writing —
响应数据到客户端的数量
waiting —
开启 keep-alive的情况下,这个值等于 active –(reading+writing),意思就是 Nginx已经处理完正在等候下一次请求指令的驻留连接

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值