在此记录下Nginx服务器nginx.conf的配置文件说明, 部分注释收集于网络.
user www-data; #运行用户
worker_processes 1; #启动进程,通常设置成和cpu的数量相等
error_log /var/log/nginx/error.log; #全局错误日志及PID文件
pid /var/run/nginx.pid;
events {
use epoll; #工作模式及连接数上限#epoll是多路复用IO(I/O Multiplexing)中的一种方式,但是仅用于linux2.6以上内核,可以大大提高nginx的性能
worker_connections 1024;
#单个后台worker process进程的最大并发链接数
# multi_accept on;
}#设定http服务器,利用它的反向代理功能提供负载均衡支持
http {
include /etc/nginx/mime.types; #设定mime类型,类型由mime.type文件定义
default_type application/octet-stream;
log_format main '$remote_addr - $remote_user [$time_local] "$request" ''$status $body_bytes_sent "$http_referer" '
'"$http_user_agent" "$http_x_forwarded_for"';
access_log logs/access.log main; #设定日志格式
sendfile on; #sendfile 指令指定 nginx 是否调用 sendfile 函数(zero copy 方式)来输出文件,对于普通应用,必须设为 on,如果用来进行下载等应用磁盘IO重负载应用,可设置为 off,以平衡磁盘与网络I/O处理速度,降低系统的uptime.
#tcp_nopush on;
#keepalive_timeout 0;
keepalive_timeout 65; #连接超时时间
tcp_nodelay on;
gzip on; #开启gzip压缩
gzip_disable "MSIE [1-6]\.(?!.*SV1)";
client_header_buffer_size 1k; #设定请求缓冲
large_client_header_buffers 44k;include /etc/nginx/conf.d/*.conf;
include /etc/nginx/sites-enabled/*;
#设定负载均衡的服务器列表
upstream mysvr {
server 192.168.8.1:3128 weight=5; #本机上的Squid开启3128端口
server 192.168.8.2:80 weight=1;
server 192.168.8.3:80 weight=6; #weigth参数表示权值,权值越高被分配到的几率越大
}
server {
listen 80; #侦听80端口
server_name www.xx.com; #定义使用www.xx.com访问access_log logs/www.xx.com.access.log main;
#设定本虚拟主机的访问日志#默认请求
location / { #location允许对不同的URL使用不同的配置,即可以使用字符串也可以使用与正则表达式。
root /root; #定义服务器的默认网站根目录位置
index index.php index.html index.htm; #定义首页索引文件的名称fastcgi_pass www.xx.com;
fastcgi_param SCRIPT_FILENAME $document_root/$fastcgi_script_name;
include /etc/nginx/fastcgi_params;
}
error_page 500 502 503 504 /50x.html; # 如果出现指定的http错误状态码,则返回给客户端指定的url地址。
location = /50x.html {
root /root;
}
-----------------------------------
生产环境中一例(29.70-video部分):(aaron 2011-08-11)
error_page 404 = @fetch; #如果响应错误代码的页面是php等FastCGI程序,则最好在error_page中加上等号,如本例示
location @fetch { #location项允许对不同的路径进行不同的配置。@为一命名标记,不会处理正常请求,只会处理内部重定向。
internal; #设定某个location路径只能在内部使用,不能用于外部。
proxy_store on; #存储从后端服务器传过来的文件。
proxy_next_upstream error timeout http_500 http_503 http_404;
#在哪种情况下将请求转发到负载均衡代理服务器池中的下一台服务器。
proxy_store_access user:rw group:rw all:r;
#指定用于创建文件和目录的权限。
proxy_temp_path /tmp; #指定用于缓冲较大代理请求的本地路径。
proxy_set_header Host root.video.att.xinpindao.com;
#在转发给反向代理服务器(后端)的信息中重新定义或者设置header行。(即更改转发给反向代理服务器的信息)
proxy_set_header referer http://video.att.xinpindao.com;
proxy_pass http://video.backend; #设置被代理服务器的端口或套接字,以及URL。
#default root same as server root
#root /data/attachment/video;
}
------------------------------------------
#静态文件,nginx自己处理
location ~ ^/(images|javascript|js|css|flash|media|static)/ {
root /var/www/virtual/htdocs;
expires 30d; #过期30天,静态文件不怎么更新,过期可以设大一点,如果频繁更新,则可以设置得小一点。
}
#PHP 脚本请求全部转发到 FastCGI处理. 使用FastCGI默认配置.
location ~ \.php$ {
root /root;
fastcgi_pass 127.0.0.1:9000;
fastcgi_index index.php;
fastcgi_param SCRIPT_FILENAME /home/www/www$fastcgi_script_name;
include fastcgi_params;
}
#设定查看Nginx状态的地址
location /NginxStatus {
stub_status on;
access_log on;
auth_basic "NginxStatus";
auth_basic_user_file conf/htpasswd;
}
#禁止访问 .htxxx 文件
location ~ /\.ht {
deny all;
}
}
}
以上是一些基本的配置,使用Nginx最大的好处就是负载均衡
如果要使用负载均衡的话,可以修改配置http节点如下:
#设定http服务器,利用它的反向代理功能提供负载均衡支持
http {
include /etc/nginx/mime.types; #设定mime类型,类型由mime.type文件定义
default_type application/octet-stream;
access_log /var/log/nginx/access.log; #设定日志格式#省略上文有的一些配置节点
#。。。。。。。。。。
#设定负载均衡的服务器列表
upstream mysvr { #upstream指令用于设置一组可以在proxy_pass指令中使用的代理服务器,默认的代理方式为轮询。
server 192.168.8.1x:3128 weight=5;#本机上的Squid开启3128端口
server 192.168.8.2x:80 weight=1; #server指令用于指定后端服务器的名称和参数。
server 192.168.8.3x:80 weight=6; #weigth参数表示权值,权值越高被分配到的几率越大
}upstream mysvr2 {
server 192.168.8.x:80 weight=1;server 192.168.8.x:80 weight=6; #weigth参数表示权值,权值越高被分配到的几率越大
}#第一个虚拟服务器
server { #在server{...}虚拟主机内可通过proxy_pass指令设置关于反向代理的upstream服务器集群。
listen 80; #侦听192.168.8.x的80端口
server_name 192.168.8.x;
location ~ .*\.aspx$ { #对aspx后缀的进行负载均衡请求root /root; #定义服务器的默认网站根目录位置
index index.php index.html index.htm; #定义首页索引文件的名称proxy_pass http://mysvr ; #请求转向mysvr 定义的服务器列表
#以下是一些反向代理的配置可删除.
proxy_redirect off;
#后端的Web服务器可以通过X-Forwarded-For获取用户真实IP
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
client_max_body_size 10m; #允许客户端请求的最大单文件字节数
client_body_buffer_size 128k; #缓冲区代理缓冲用户端请求的最大字节数,
proxy_connect_timeout 90; #nginx跟后端服务器连接超时时间(代理连接超时)
proxy_send_timeout 90; #后端服务器数据回传时间(代理发送超时)
proxy_read_timeout 90; #连接成功后,后端服务器响应时间(代理接收超时)
proxy_buffer_size 4k; #设置代理服务器(nginx)保存用户头信息的缓冲区大小
proxy_buffers 4 32k; #proxy_buffers缓冲区,网页平均在32k以下的话,这样设置
proxy_busy_buffers_size 64k; #高负荷下缓冲大小(proxy_buffers*2)
proxy_temp_file_write_size 64k; #设定缓存文件夹大小,大于这个值,将从upstream服务器传}
}
}
相关推荐
Nginx完整配置说明 Nginx是当前最流行的Web服务器软件之一,常用于搭建Web服务器、反向代理服务器、负载均衡器等。下面是Nginx的完整配置说明,涵盖基本配置、反向代理、FastCGI等方面的知识点。 一、基本配置 在...
nginx配置文件主要由以下几个部分组成: * main块:定义nginx服务器的基本设置,例如进程数、错误日志路径等。 * events块:定义事件处理相关的设置,例如worker连接数、worker进程的affinity等。 * http块:定义...
通过自定义这些规则,可以确保Notepad++能够准确地识别和高亮显示Nginx配置文件的各个部分。 此外,Notepad++的这个特性不仅适用于Nginx,还可以扩展到其他非标准或特定领域的文本格式。只要拥有相应的XML定义文件...
总结,Nginx的多域名配置、访问统计、日志请求头管理、反向代理和手机访问判断是其强大功能的一部分,可以帮助我们构建高效、灵活的Web服务架构。通过深入理解并正确配置这些选项,你可以更好地满足网站的需求,提升...
设置监听地址和端口,与Nginx配置中的`fastcgi_pass`对应: ```ini listen = 127.0.0.1:9000 ``` 启动Nginx和PHP-FPM服务。如果一切配置无误,现在你应该可以通过浏览器访问`http://localhost/`并看到Nginz的欢迎...
6. 反向代理配置:在nginx配置中,proxy_pass指令用于指定后端的服务器地址,这里指向了本地的8080端口。同时,还通过proxy_set_header指令设置了传递给后端服务器的HTTP头信息,如X-Forwarded-For(客户端IP地址)...
在此记录下Nginx服务器nginx.conf的配置文件说明, 部分注释收集与网络. #运行用户 user www-data; #启动进程,通常设置成和cpu的数量相等 worker_processes 1; #全局错误日志及PID文件 error_log /var/log/...
5. **location**块:这是Nginx配置中最细粒度的部分,用于匹配请求的URL并执行相应的操作。 ### 二、Nginx负载均衡 Nginx支持多种负载均衡策略,如轮询、最少连接数、IP哈希等,可以有效地分发客户端请求到后端...
总结一下,"squid和nginx配置正向代理访问API接口"涉及的关键知识点包括正向代理的概念、Squid和Nginx的代理功能、配置这两者的步骤、以及安全性控制和优化策略。正确配置和使用这两个工具可以帮助企业构建高效、...
Nginx配置文件中关于SSL/TLS证书的配置部分确保了网站通信的安全性。使用`listen 443 ssl`指令表明监听443端口并启用SSL。`ssl_certificate`和`ssl_certificate_key`指令分别指定了SSL证书和私钥的路径。 修改Nginx...
本文将详细解析Nginx配置文件中的各个组成部分及其作用。 #### 二、Nginx配置文件整体结构 Nginx配置文件主要由以下几部分组成: 1. **全局块**:包含Nginx的基础配置信息。 2. **events块**:定义Nginx如何处理...
本文将深入探讨如何通过Nginx配置文件来设置一级域名和二级域名,以及如何利用Nginx的反向代理功能。 首先,了解一级域名和二级域名的概念至关重要。一级域名是互联网上顶级的域名,如.com、.org、.net等。二级域名...
在Nginx的配置文件中,主要有以下几个部分: 1. **全局块**:这部分设置影响Nginx服务器整体的行为,如运行用户(`user`),工作进程数量(`worker_processes`),错误日志路径(`error_log`)和PID文件位置(`pid`...
在上面的配置文件中,我们可以看到,nginx的基本配置包括error_log、worker_processes、events、http等部分。其中,error_log用于记录nginx的错误日志,worker_processes用于设置nginx的工作进程数,events用于设置...
在修改Nginx配置文件后,应先检查语法是否正确。可以使用`nginx -t`或`sudo nginx -t`命令进行测试,如果返回`configuration file /etc/nginx/nginx.conf test is successful`,则说明配置无误。然后重启Nginx以使...
1. **全局块**:这部分配置影响Nginx服务器整体的行为,如工作进程数、日志文件位置等。例如: ```conf worker_processes auto; # 自动分配CPU核心数 error_log /var/log/nginx/error.log warn; # 错误日志路径及...
**Nginx配置文件详解** Nginx是一款高性能的HTTP和反向代理服务器,广泛应用于Web服务领域。其配置文件是Nginx的核心部分,它决定了Nginx如何响应请求和处理网络流量。本篇文章将深入探讨Linux环境下Nginx的配置...
接下来是 `http` 模块,这是 Nginx 配置的核心部分。`include conf/mime.types;` 引入 MIME 类型定义文件,用于识别不同类型的文件。`default_type application/octet-stream;` 设定了默认的 MIME 类型。 日志记录...
本文将详细解释 Nginx 配置文件的结构和各个组件的作用。 全局配置 Nginx 配置文件的第一部分是全局配置,包括运行用户、启动进程数、错误日志和 PID 文件等设置。 * `user www-data;`:设置 Nginx 运行的用户为 ...