• nginx反向代理,实现负载均衡


    一,先启动nginx和php-cgi

    #启动 php-cgi
    /usr/local/bin/spawn-fcgi -a 127.0.0.1 -p 8000 -C 5 -f /usr/bin/php-cgi

    #启动 nginx
    ulimit -SHn 65535
    /usr/local/nginx/sbin/nginx

     

    二,修改配置nginx.conf

    1 upstream myselfx {
    2 server 127.0.0.1:10002;
    3   server 127.0.0.1:10001 weight=5;
    4 }
    5
    6 server
    7 {
    8 listen 10000;
    9 server_name localhost;
    10
    11 log_format access '$remote_addr - $remote_user [$time_local] "$request" '
    12 '$status $body_bytes_sent "$http_referer" '
    13 '"$http_user_agent" $http_x_forwarded_for';
    14 access_log /var/log/apps.log access;
    15
    16 location /
    17 {
    18 # fastcgi_pass 127.0.0.1:8000;
    19 # fastcgi_index index.php;
    20 proxy_pass http://myselfx;
    21 proxy_redirect off;
    22 proxy_set_header Host $host;
    23 proxy_set_header X-Real-IP $remote_addr;
    24 proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
    25 client_max_body_size 100m;
    26 client_body_buffer_size 256k;
    27 proxy_connect_timeout 60;
    28 proxy_send_timeout 30;
    29 proxy_read_timeout 30;
    30 proxy_buffer_size 8k;
    31 proxy_buffers 8 64k;
    32 proxy_busy_buffers_size 64k;
    33 proxy_temp_file_write_size 64k;
    34 }
    35
    36 location /NginxStatus
    37 {
    38 stub_status on;
    39 auth_basic "NginxStatus";
    40 auth_basic_user_file /usr/local/nginx/conf/authfile;
    41 }
    42 }
    说明:

    1,我用一台电脑实现这个负载均衡的,用10000反向代理10001,10002

    2,反向代理不要php-cgi支持,所以在上面的配置中没有index和root这类的东西

    3,proxy_pass http://myselfx;这里的http://一定要有不然报错,upstream myselfx这前面一定不要有http://,不然也会报错,不知道为什么非要这样配置

    4,开始的时候 proxy_pass http://127.0.0.1:10000; upstream 127.0.0.1:10000;我这样配置的,nginx不报错,但是我只要一访问http://localhost:10000/这个url时,log文件很快就达到147.7M,好大。里面全部是127.0.0.1这样的数字。这一点根apache,haproxy的思想不太一样。这个也浪费我了好多时间。

    5,proxy_pass http://myselfx;里面的myselfx没有任何意义,在这里只是起个标识作用,在访问页面的时候,是http://localhost:10000/,而不是http://myselfx

    6,你要看清楚你用的是proxy_pass而不是fastcgi_pass,开始老是报错,就是因为我用的是fastcgi_pass

    7,access_log的位置要放在proxy_pass所在location的前面,不然不会启作用

    8, location /NginxStatus 这一块是查看nginx的状态 ,htpasswd -cbd /usr/local/nginx/conf/authfile 用户名  密码

    9,stub_status on;这个要开启,表示允许查看nginx的状态,如果不开启,你输入了authfile里面的用户名和密码了,也看不到东西,会报403错误

    10,weight=5,表示分配的权重,是一种算法,还有其他的如ip_hash,url_hash等

    转:http://blog.51yip.com/apachenginx/944.html

  • 相关阅读:
    HTTP 的学习
    标量方程求解
    限制器
    差分格式
    Archlinux的基本配置
    布拉休斯方程数值求解
    GNU大型项目构建和覆盖率生成(第一篇)
    plot3d网格读取写入与可视化
    abaqus中的约束
    向量范数和矩阵范数
  • 原文地址:https://www.cnblogs.com/shuaixf/p/2036047.html
Copyright © 2020-2023  润新知