OpenResty Nginx负载均衡配置和虚拟服务器路由配置详解

OpenResty Nginx负载均衡配置和虚拟服务器路由配置详解

转自:http://dditblog.com/itshare_566.html


新段时间把自己的博客搬到了云服务器上、那么搭建环境就是必须的了、在搭建好环境之后、需要对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的留言板)

感谢你的访问、祝你生活愉快、工作顺心、欢迎常来逛逛

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值