OpenResty Nginx负载均衡配置和虚拟服务器路由配置详解
2016-08-18 10:09:25 By: shinyuu
新段时间把自己的博客搬到了云服务器上、那么搭建环境就是必须的了、在搭建好环境之后、需要对Nginx进行配置、其实是对OpenResty进行配置、因为我部署的是OpenResty的服务器、OpenResty是一个基于Nginx与Lua的高性能Web平台、最终其实还是在对Nginx进行配置
毕竟我是将我的DD博客、DD记账下载页和一个App开发页以及DD记账的App接口都放到同一个服务器的、在此记录下Nginx服务器nginx.conf的配置文件说明、希望对大家有用
#运行用户 user dwtedx.com; #启动进程、通常设置成和cpu的数量相等 worker_processes 1; #全局错误日志及PID文件 error_log logs/error.log; error_log logs/error.log notice; error_log logs/error.log info; pid logs/nginx.pid; #工作模式及连接数上限 events { #epoll是多路复用IO(I/O Multiplexing)中的一种方式 #但是仅用于linux2.6以上内核、可以大大提高nginx的性能 use epoll; #单个后台worker process进程的最大并发链接数 worker_connections 1024; # multi_accept on; } #设定http服务器、利用它的反向代理功能提供负载均衡支持 http { #设定mime类型、类型由mime.type文件定义 include mime.types; default_type application/octet-stream; #设定日志格式 access_log logs/access.log; #sendfile 指令指定 nginx 是否调用 sendfile 函数(zero copy 方式)来输出文件、对于普通应用 #必须设为 on、如果用来进行下载等应用磁盘IO重负载应用、可设置为 off #以平衡磁盘与网络I/O处理速度、降低系统的uptime sendfile on; #tcp_nopush on; #连接超时时间 #keepalive_timeout 0; keepalive_timeout 65; tcp_nodelay on; #开启gzip压缩 gzip on; gzip_disable "MSIE [1-6].(?!.*SV1)"; #设定请求缓冲 client_header_buffer_size 1k; large_client_header_buffers 4 4k; include /etc/nginx/conf.d/*.conf; include /etc/nginx/sites-enabled/*; #设定负载均衡的服务器列表 upstream mysvr { #weigth参数表示权值,权值越高被分配到的几率越大 #本机上的Squid开启3128端口 server 192.168.8.1:3128 weight=5; server 192.168.8.2:80 weight=1; server 192.168.8.3:80 weight=6; } server { #侦听80端口 listen 80; #定义使用www.dwtedx.com dwtedx.com访问 server_name dwtedx.com www.dwtedx.com; #设定本虚拟主机的访问日志 access_log logs/www.xx.com.access.log main; #默认请求 location / { root /root/workspace; #定义服务器的默认网站根目录位置 index index.php index.html index.htm; #定义首页索引文件的名称 fastcgi_pass dwtedx.com; fastcgi_param SCRIPT_FILENAME $document_root/$fastcgi_script_name; } # 定义错误提示页面 error_page 500 502 503 504 /50x.html; location = /50x.html { root /root/workspace; } #静态文件,nginx自己处理 location ~ ^/(images|javascript|js|css|flash|media|static)/ { root /var/www/virtual/htdocs; #过期30天,静态文件不怎么更新,过期可以设大一点,如果频繁更新,则可以设置得小一点。 expires 30d; } #PHP 脚本请求全部转发到 FastCGI处理. 使用FastCGI默认配置. location ~ .php$ { root /root/workspace; 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; } } }
以上是一些基本的配置、使用OpenResty最大的好处就是负载均衡、这也是Nginx的特性、如果要使用负载均衡的话、可以修改配置http节点如下
#设定http服务器,利用它的反向代理功能提供负载均衡支持 http { #设定mime类型,类型由mime.type文件定义 include /etc/nginx/mime.types; default_type application/octet-stream; #设定日志格式 access_log /root/workspace/access.log; #省略上文有的一些配置节点 #设定负载均衡的服务器列表 upstream mysvr { #weigth参数表示权值,权值越高被分配到的几率越大 server 192.168.8.1x:3128 weight=5;#本机上的Squid开启3128端口 server 192.168.8.2x:80 weight=1; server 192.168.8.3x:80 weight=6; } upstream mysvr2 { #weigth参数表示权值,权值越高被分配到的几率越大 server 192.168.8.x:80 weight=1; server 192.168.8.x:80 weight=6; } }
另外、OpenResty同样也继承了Nginx的优点、就是配置虚拟服务器、可以让80端口同时处理多个网站、非常实用
server { listen 80; server_name diapp.dwtedx.com; location / { #转发Tomcat8080端口 proxy_pass http://127.0.0.1:8080; } } server { listen 80; server_name app.dwtedx.com; location / { #到app目录 root /root/workspace/app; index index.html index.htm; } error_page 404 /404.html; } server { listen 80; server_name income.dwtedx.com; location / { #到income目录 root /root/workspace/income; index index.html index.htm; } error_page 404 /404.html; } # another virtual host using mix of IP-, name-, and port-based configuration # #server { # listen 8000; # listen somename:8080; # server_name somename alias another.alias; # location / { # root html; # index index.html index.htm; # } #} }
上面的配置代码可以直接复制到项目中使用、修改一下域名和端口号之类的就好了
若资源对你有帮助、浏览后有很大收获、不妨小额打赏我一下、你的鼓励是维持我不断写博客最大动力
想获取DD博客最新代码、你可以扫描下方的二维码、关注DD博客微信公众号(ddblogs)
或者你也可以关注我的新浪微博、了解DD博客的最新动态:DD博客官方微博(dwtedx的微博)
如对资源有任何疑问或觉得仍然有很大的改善空间、可以对该博文进行评论、希望不吝赐教
为保证及时回复、可以使用博客留言板给我留言: DD博客留言板(dwtedx的留言板)
感谢你的访问、祝你生活愉快、工作顺心、欢迎常来逛逛
cheung 2016-08-20 02:13:55 1 评 | 回复