• nginx配置负载均衡


    前两天在学习负载均衡,然后就看到了nginx,当前做反向代理,负载均衡 nginx用的确实比较大,比如阿里用的Tengine也是基于nginx之后改的。当然,我们的项目中也有在用nginx。

    nginx是一款反向代理的服务器,目的就是转发http请求。这样,可以不知道服务器地址,就可以对请求进行转发。nginx,可以理解为一个中间人,用户操作客户端,通过nginx转发到后端,后端请求处理返回给用户。

    这里贴出下载地址(windows):http://nginx.org/download/nginx-1.14.0.zip  


    linux下安装我使用的docker容器安装的:

       第一步从docker下拉下来nginx实例 docker pull nginx

       第二步运行该实例,用设置端口等(若服务器占用80端口,请设置xx为其他未占用端口)   docker run -p xx:80 --name nginx -v $PWD/www:/www -v $PWD/logs:/wwwlogs -d nginx

      如果安装在linux下,不了解docker,请自行百度,linux下安装docker

    安装完成之后就可以进入实例,并配置nginx的反向代理和负载均衡了;

    (负载均衡:为了减免服务器压力,同过设置权重随机访问server服务器,当一个用户访问该接口,压力很小,但是100万个人访问该接口压力就很大了,负载均衡起的就是酱紫的作用,可配置多台服务器进行http请求)。

    下来,开始配置nginx 反向代理:

    打开conf下的nginx.conf文件,

    其他暂时不看,这里直接看重点,

    #这个是需要转发的目标服务器地址以及端口号
    upstream mynginx{ server localhost:
    8080; #Apache } ## Start www.quancha.cn ## server { listen 80; server_name localhost; index index.html index.htm index.php; ## send request back to apache ## location / {
         #需要转发请求的服务器 负载均衡也是如此配置 proxy_pass http:
    //mynginx; #Proxy Settings proxy_redirect off;#是否跳转 proxy_set_header Host $host; #请求要转发的host proxy_set_header X-Real-IP $remote_addr;#请求的远程地址 这些在浏览器的header都可看,不一一解释 proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; proxy_next_upstream error timeout invalid_header http_500 http_502 http_503 http_504; proxy_max_temp_file_size 0; proxy_connect_timeout 90; #连接前面的服务器超时时间 proxy_send_timeout 90;#请求转发数据报文的超时时间 proxy_read_timeout 90;#读取超时时间 proxy_buffer_size 4k; # 缓冲区的大小 proxy_buffers 4 32k; # proxy_busy_buffers_size 64k; # #proxy_buffers缓冲区,网页平均在32k以下的 proxy_temp_file_write_size 64k; ##高负荷下缓冲大小(proxy_buffers*2) } }

    这样配置就可以起到反向代理的作用

    负载均衡类似,配置多个tomcat地址,这里是伪集群方式

    #配置多台服务器(这里只在一台服务器上的不同端口)
    upstream mysvr {
        #权重比设置为1 : 3 意思为 用户请求四次服务器,平均访问8082端口3次,8081端口一次,以此达到服务器均衡的作用(高并发) server
    127.0.0.1:8081 weight=1; server 127.0.0.1:8082 weight=3; #热备 }
     server {
            listen       80;
            server_name  localhost;
    
            #charset koi8-r;
            #access_log  logs/host.access.log  main;
    
         #静态文件,nginx自己处理
            location ~ ^/(images|javascript|js|css|flash|media|static)/ {
                
                #过期30天,静态文件不怎么更新,过期可以设大一点,
                #如果频繁更新,则可以设置得小一点。
                expires 30d;
            }
        location  ~*^.+$ {       #请求的url过滤,正则匹配,~为区分大小写,~*为不区分大小写。
               #root path;  #根目录
               #index vv.txt;  #设置默认页
               proxy_pass  http://mysvr;  #请求转向mysvr 定义的服务器列表
               #deny 127.0.0.1;  #拒绝的ip
               #allow 172.18.5.54; #允许的ip           
            } 
    
            location / {
                root   html;
                index  index.html index.htm;
            }
    }

    下来配置server{ } ,与反向代理配置类似,这里需要注意,反向代理比较适用于对静态资源的访问(反向到静态资源服务器),负载均衡比较适用于对后端服务器集群

    至此,Nginx简单配置写完,记录自己的学习成果!以上仅为自己的见解,如有异议,可在评论区留言,转载请注明出处。

  • 相关阅读:
    CPU密集型、IO密集型
    打印在一行
    python多线程、线程锁
    WPS--world使用格式刷
    pycharm连接linux版python
    Pycharm连接windows上python
    一台windows主机上运行2个tomcat
    启动django应用报错 “Error: [WinError 10013] 以一种访问权限不允许的方式做了一个访问套接字的尝试。”
    ORA-03206,当表空间不够时,如何以添加数据文件的方式扩展表空间
    利用拷贝data目录文件的方式迁移mysql数据库
  • 原文地址:https://www.cnblogs.com/ChoviWu/p/9004725.html
Copyright © 2020-2023  润新知