这里我给来2张图,对正向代理与反响代理做个诠释,具体细节,大家可以翻阅下资料。
nginx在做反向代理时,提供性能稳定,并且能够提供配置灵活的转发功能。nginx可以根据不同的正则匹配,采取不同的转发策略,比如图片文件结尾的走文件服务器,动态页面走web服务器,只要你正则写的没问题,又有相对应的服务器解决方案,你就可以随心所欲的玩。并且nginx对返回结果进行错误页跳转,异常判断等。如果被分发的服务器存在异常,他可以将请求重新转发给另外一台服务器,然后自动去除异常服务器。
2、负载均衡
nginx提供的负载均衡策略有2种:内置策略和扩展策略。内置策略为轮询,加权轮询,iphash。扩展策略,就天马行空,只有你想不到的没有他做不到的啦,你可以参照所有的负载均衡算法,给他一一找出来做下实现。
上3个图,理解这三种负载均衡算法的实现
iphash算法,对客户端请求的ip进行hash操作,然后根据hash结果将同一个客户端ip的请求分发给同一台服务器进行处理,可以解决session不共享的问题。
3、web缓存
nginx可以对不同的文件做不同的缓存处理,配置灵活,并且支持fastcgi_cache,主要用于对fastcgi的动态程序进行缓存。配合着第三方的ngx_cache_purge,对制定的url缓存内容可以的进行增删管理。
4、nginx相关地址
二、nginx配置文件结构如果你下载好啦,你的安装文件,不妨打开conf文件夹的nginx.conf文件,nginx服务器的基础配置,默认的配置也存放在此。
在nginx.conf的注释符号位#
nginx文件的结构,这个对刚入门的同学,可以多看两眼。
location[pattern]#location块
}
5、location块:配置请求的路由,以及各种页面的处理情况。
下面给大家上一个配置文件,作为理解,同时也配入我搭建的一台测试机中,给大家示例。
配置用户或者组,默认为nobodynobody。
允许生成的进程数,默认为1
指定nginx进程运行文件存放地址
error_loglog/error.logdebug;#制定日志路径,级别。这个设置可以放入全局块,http块,server块,级别以此为:debug|info|notice|warn|error|crit|alert|emerg
accept_mutexon;#设置网路连接序列化,防止惊群现象发生,默认为on
multi_accepton;#设置一个进程是否同时接受多个网络连接,默认为off
事件驱动模型,select|poll|kqueue|epoll|resig|/dev/poll|eventport
worker_connections1024;#最大连接数,默认为512
includemime.types;#文件扩展名与文件类型映射表
default_typeapplication/octet-stream;#默认文件类型,默认为text/plain
log_formatmyformat'$remote_addr–$remote_user[$time_local]$request$status$body_bytes_sent$http_referer$http_user_agent$http_x_forwarded_for';#自定义格式
access_loglog/access.logmyformat;#combined为日志格式的默认值
sendfileon;#允许sendfile方式传输文件,默认为off,可以在http块,server块,location块。
sendfile_max_chunk100k;#每个进程每次调用传输数量不能大于设定的值,默认为0,即不设上限。
keepalive_timeout65;#连接超时时间,默认为75s,可以在http,server,location块。
server192.168.10.121:3333backup;#热备
error_page404https://www.baidu.com;#错误页
keepalive_requests120;#单连接请求上限次数。
server_name127.0.0.1;#监听地址
location~*^.+${#请求的url过滤,正则匹配,~为区分大小写,~*为不区分大小写。
proxy_passhttp://mysvr;#请求转向mysvr定义的服务器列表
allow172.18.5.54;#允许的ip
}
2、惊群现象:一个网路连接到来,多个睡眠的进程被同事叫醒,但只有一个进程能获得链接,这样会影响系统性能。
3、每个指令必须有分号结束。
下面看下其他网友的补充:
在此记录下nginx服务器nginx.conf的配置文件说明,部分注释收集与网络.
#启动进程,通常设置成和cpu的数量相等
error_log/var/log/nginx/error.log;
useepoll;#epoll是多路复用io(i/omultiplexing)中的一种方式,但是仅用于linux2.6以上内核,可以大大提高nginx的性能
worker_connections1024;#单个后台workerprocess进程的最大并发链接数
#设定http服务器,利用它的反向代理功能提供负载均衡支持
#设定mime类型,类型由mime.type文件定义
include/etc/nginx/mime.types;
default_typeapplication/octet-stream;
access_log/var/log/nginx/access.log;
#sendfile指令指定nginx是否调用sendfile函数(zerocopy方式)来输出文件,对于普通应用,
#必须设为on,如果用来进行下载等应用磁盘io重负载应用,可设置为off,以平衡磁盘与网络i/o处理速度,降低系统的uptime.
gzip_disable"msie[1-6]\.(?!.*sv1)";

large_client_header_buffers44k;
include/etc/nginx/conf.d/*.conf;
include/etc/nginx/sites-enabled/*;
#设定负载均衡的服务器列表
#weigth参数表示权值,权值越高被分配到的几率越大
#本机上的squid开启3128端口
server192.168.8.1:3128weight=5;
server192.168.8.2:80weight=1;
server192.168.8.3:80weight=6;
#设定本虚拟主机的访问日志
access_loglogs/www.xx.com.access.logmain;
root/root;#定义服务器的默认网站根目录位置
indexindex.phpindex.htmlindex.htm;#定义首页索引文件的名称
fastcgi_paramscript_filename$document_root/$fastcgi_script_name;
include/etc/nginx/fastcgi_params;
error_page500502503504/50x.html;
location~^/(images|javascript|js|css|flash|media|static)/{
root/var/www/virtual/htdocs;
#过期30天,静态文件不怎么更新,过期可以设大一点,如果频繁更新,则可以设置得小一点。
#php脚本请求全部转发到fastcgi处理.使用fastcgi默认配置.
fastcgi_pass127.0.0.1:9000;
fastcgi_paramscript_filename/home/www/www$fastcgi_script_name;
auth_basic_user_fileconf/htpasswd;
}
#设定http服务器,利用它的反向代理功能提供负载均衡支持
#设定mime类型,类型由mime.type文件定义
include/etc/nginx/mime.types;
default_typeapplication/octet-stream;
access_log/var/log/nginx/access.log;
#省略上文有的一些配置节点
#设定负载均衡的服务器列表
#weigth参数表示权值,权值越高被分配到的几率越大
server192.168.8.1x:3128weight=5;#本机上的squid开启3128端口
server192.168.8.2x:80weight=1;
server192.168.8.3x:80weight=6;
#weigth参数表示权值,权值越高被分配到的几率越大
server192.168.8.x:80weight=1;
server192.168.8.x:80weight=6;
#对aspx后缀的进行负载均衡请求
root/root;#定义服务器的默认网站根目录位置
indexindex.phpindex.htmlindex.htm;#定义首页索引文件的名称
proxy_passhttp://mysvr;#请求转向mysvr定义的服务器列表
#以下是一些反向代理的配置可删除.
#后端的web服务器可以通过x-forwarded-for获取用户真实ip
proxy_set_headerhost$host;
proxy_set_headerx-real-ip$remote_addr;
proxy_set_headerx-forwarded-for$proxy_add_x_forwarded_for;
client_max_body_size10m;#允许客户端请求的最大单文件字节数
client_body_buffer_size128k;#缓冲区代理缓冲用户端请求的最大字节数,
proxy_connect_timeout90;#nginx跟后端服务器连接超时时间(代理连接超时)
proxy_send_timeout90;#后端服务器数据回传时间(代理发送超时)
proxy_read_timeout90;#连接成功后,后端服务器响应时间(代理接收超时)
proxy_buffer_size4k;#设置代理服务器(nginx)保存用户头信息的缓冲区大小
proxy_buffers432k;#proxy_buffers缓冲区,网页平均在32k以下的话,这样设置
proxy_busy_buffers_size64k;#高负荷下缓冲大小(proxy_buffers*2)
proxy_temp_file_write_size64k;#设定缓存文件夹大小,大于这个值,将从upstream服务器传
}
以上就是Nginx配置文件结构的方法的详细内容,更多请关注主机测评网其它相关文章!
本文来源:国外服务器--Nginx配置文件结构的方法(nginx配置文件的后缀)
本文地址:https://www.idcbaba.com/guowai/4407.html
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 1919100645@qq.com 举报,一经查实,本站将立刻删除。



