Believe it,do it!

          Ideal is the beacon. Without ideal, there is no secure direction; without direction ,there is no life.
          理想是指路明燈。沒(méi)有理想,就沒(méi)有堅(jiān)定的方向;沒(méi)有方向,就沒(méi)有生活。
          CTRL+T eclipse
          posts - 35, comments - 3, trackbacks - 0, articles - 0
            BlogJava :: 首頁(yè) :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理

          Nginx+tomcat 做負(fù)載均衡

          Posted on 2009-11-30 09:23 三羽 閱讀(3288) 評(píng)論(0)  編輯  收藏

          一、

          1、將tomcat 的server.xml文件中所有端口號(hào)都改為不同。
          2、Nginx 的nginx.conf文件中
              http {}增加如下內(nèi)容

               upstream sp.imichat.com{
                 server 127.0.0.1:8080 weight=2;
                 server 127.0.0.1:8088 weight=2;
                 ip_hash;
               }

          server {} 修改信息:


          listen 80;
          server_name sp.imichat.com;

          #charset koi8-r;

          #access_log logs/host_access_log main;

                  location /{
                    proxy_redirect          off;
                    proxy_set_header        Host $host;
                    proxy_set_header        X-Real-IP $remote_addr;
                    proxy_set_header        X-Forwarded-For $proxy_add_x_forwarded_for;
                    proxy_pass http://sp.imichat.com;
                  }

          例:
          #user  nobody;
          worker_processes  1;

          events {
              worker_connections  51024;
          }
          http {
              include       mime.types;
              default_type  application/octet-stream;

               upstream localhost {
                 server 127.0.0.1:8080 weight=2;
                 server 127.0.0.1:8088 weight=2;
                 ip_hash;
               }

              sendfile        on;

              keepalive_timeout  65;

              server {
                  listen       80;
                  server_name  localhost;

                  location /{
                                  proxy_redirect          off;
                                  proxy_set_header        Host $host;
                                  proxy_set_header        X-Real-IP $remote_addr;
                                  proxy_set_header        X-Forwarded-For $proxy_add_x_forwarded_for;
             proxy_pass http://localhost;
                  }

                  error_page   500 502 503 504  /50x.html;
                  location = /50x.html {
                      root   html;
                  }

              }}


          二、

          參數(shù)描述

          檢測(cè)nginx配置文件是否正確
          /usr/local/nginx/sbin/nginx -t -c nginx.conf
          -c 配置文件路徑

          -g Set global directives. (version >=0.7.4)

          -t 檢測(cè)文件是否正確不執(zhí)行

          -v Print version.

          -V Print nginx version, compiler version and configure parameters.

          編譯時(shí)如果使用了–with-debug編譯,還可以使用error_log file [ debug_core| debug_http | debug_event …] 來(lái)獲得debug信息

          通過(guò)信號(hào)對(duì) Nginx 進(jìn)行控制

          Nginx 支持下表中的信號(hào):

          信號(hào)名 作用描述
          TERM, INT 快速關(guān)閉程序,中止當(dāng)前正在處理的請(qǐng)求
          QUIT 處理完當(dāng)前請(qǐng)求后,關(guān)閉程序
          HUP 重新加載配置,并開(kāi)啟新的工作進(jìn)程,關(guān)閉就的進(jìn)程,此操作不會(huì)中斷請(qǐng)求
          USR1 重新打開(kāi)日志文件,用于切換日志,例如每天生成一個(gè)新的日志文件
          USR2 平滑升級(jí)可執(zhí)行程序
          WINCH 從容關(guān)閉工作進(jìn)程

          有兩種方式來(lái)通過(guò)這些信號(hào)去控制 Nginx,第一是通過(guò) logs 目錄下的 nginx.pid 查看當(dāng)前運(yùn)行的 Nginx 的進(jìn)程 ID,通過(guò) kill – XXX <pid> 來(lái)控制 Nginx,其中 XXX 就是上表中列出的信號(hào)名。如果您的系統(tǒng)中只有一個(gè) Nginx 進(jìn)程,那您也可以通過(guò) killall 命令來(lái)完成,例如運(yùn)行 killall – s HUP nginx 來(lái)讓 Nginx 重新加載配置。

          配置:

          use [ kqueue | rtsig | epoll | /dev/poll | select | poll ];FreeBSD使用kqueue,Linux選epoll.
          worker_connections number    每個(gè)worker的最大連接數(shù)
          Maxclient = work_processes * worker_connections

          nginx的upstream目前支持4種方式的分配

          1、輪詢(默認(rèn))

          每個(gè)請(qǐng)求按時(shí)間順序逐一分配到不同的后端服務(wù)器,如果后端服務(wù)器down掉,能自動(dòng)剔除。

          2、weight

          指定輪詢幾率,weight和訪問(wèn)比率成正比,用于后端服務(wù)器性能不均的情況。

          2、ip_hash

          每個(gè)請(qǐng)求按訪問(wèn)ip的hash結(jié)果分配,這樣每個(gè)訪客固定訪問(wèn)一個(gè)后端服務(wù)器,可以解決session的問(wèn)題。

          3、fair(第三方)

          按后端服務(wù)器的響應(yīng)時(shí)間來(lái)分配請(qǐng)求,響應(yīng)時(shí)間短的優(yōu)先分配。

          4、url_hash(第三方)

          按訪問(wèn)url的hash結(jié)果來(lái)分配請(qǐng)求,使每個(gè)url定向到同一個(gè)后端服務(wù)器,后端服務(wù)器為緩存時(shí)比較有效。

          代理
          只需要在nginx的配置文件中增加虛擬主機(jī),然后加入
          \proxy_pass http://localhost:8000;

          負(fù)載均衡:
          只需要在http中增加
          upstream tgcluster {#定義負(fù)載均衡設(shè)備的Ip及設(shè)備狀態(tài)
          ip_hash;
          server 127.0.0.1:9090 down;
          server 127.0.0.1:8080 weight=2;
          server 127.0.0.1:6060;
          server 127.0.0.1:7070 backup;
          }
          在需要使用負(fù)載均衡的server中增加
          proxy_pass http://tgcluster/;

          每個(gè)設(shè)備的狀態(tài)設(shè)置為:
          1.down 表示單前的server暫時(shí)不參與負(fù)載
          2.weight 默認(rèn)為1.weight越大,負(fù)載的權(quán)重就越大。
          3.max_fails :允許請(qǐng)求失敗的次數(shù)默認(rèn)為1.當(dāng)超過(guò)最大次數(shù)時(shí),返回proxy_next_upstream 模塊定義的錯(cuò)誤
          4.fail_timeout:max_fails次失敗后,暫停的時(shí)間。
          5.backup: 其它所有的非backup機(jī)器down或者忙的時(shí)候,請(qǐng)求backup機(jī)器。所以這臺(tái)機(jī)器壓力會(huì)最輕。

          nginx支持同時(shí)設(shè)置多組的負(fù)載均衡,用來(lái)給不用的server來(lái)使用。

          client_body_in_file_only 設(shè)置為On 可以講client post過(guò)來(lái)的數(shù)據(jù)記錄到文件中用來(lái)做debug
          client_body_temp_path 設(shè)置記錄文件的目錄 可以設(shè)置最多3層目錄

          location 對(duì)URL進(jìn)行匹配.可以進(jìn)行重定向或者進(jìn)行新的代理 負(fù)載均衡

          FASTCGI配置:

          請(qǐng)將以下內(nèi)容保存為fastcgi_params文件,保存于/usr/local/nginx/conf下(Ubuntu可保存于/etc/nginx下),他為我們的FastCGI模塊設(shè)置了基本的環(huán)境變量:

          #fastcgi_params
          fastcgi_param GATEWAY_INTERFACE CGI/1.1;
          fastcgi_param SERVER_SOFTWARE    nginx;
          fastcgi_param QUERY_STRING       $query_string;
          fastcgi_param REQUEST_METHOD     $request_method;
          fastcgi_param CONTENT_TYPE       $content_type;
          fastcgi_param CONTENT_LENGTH     $content_length;
          fastcgi_param SCRIPT_FILENAME    $document_root$fastcgi_script_name;
          fastcgi_param SCRIPT_NAME        $fastcgi_script_name;
          fastcgi_param REQUEST_URI        $request_uri;
          fastcgi_param DOCUMENT_URI       $document_uri;
          fastcgi_param DOCUMENT_ROOT      $document_root;
          fastcgi_param SERVER_PROTOCOL    $server_protocol;
          fastcgi_param REMOTE_ADDR        $remote_addr;
          fastcgi_param REMOTE_PORT        $remote_port;
          fastcgi_param SERVER_ADDR        $server_addr;
          fastcgi_param SERVER_PORT        $server_port;
          fastcgi_param SERVER_NAME        $server_name;
          # PHP only, required if PHP was built with –enable-force-cgi-redirect
          fastcgi_param REDIRECT_STATUS    200;請(qǐng)?zhí)貏e注意加粗的一行,PHP-CGI特別需要此行信息來(lái)確定PHP文件的位置。

          另外需要在PHP-CGI的配置文件(Ubuntu 上此配置文件位于/etc/php5/cgi/php.ini)中,打開(kāi)cgi.fix_pathinfo選項(xiàng):

          cgi.fix_pathinfo=1;這樣php-cgi方能正常使用SCRIPT_FILENAME這個(gè)變量。

          接下來(lái)在nginx的配置中針對(duì)php文件配置其利用FastCGI進(jìn)程來(lái)執(zhí)行:

          server {
          index index.php;
          root /usr/local/nginx/html;

              location ~ .*.php$ {
          include /usr/local/nginx/conf/fastcgi_params; #請(qǐng)根據(jù)自己保存的路徑進(jìn)行設(shè)置
          fastcgi_index index.php;
          fastcgi_pass 127.0.0.1:9000; #請(qǐng)根據(jù)自己的FastCGI綁定的地址和端口進(jìn)行配置
          }
          }通知Nginx重新載入配置:

          kill -HUP `cat /usr/local/nginx/logs/nginx.pid`Ubuntu用戶可以使用init腳本:sudo /etc/init.d/nginx reload

          然后啟動(dòng)php-cgi -b 127.0.0.1:9000

          如果出現(xiàn)No input file specified表示SCRIPT_FILENAME設(shè)置的有問(wèn)題。
          使用lighttpd的 spawn-fcgi

          get http://www.lighttpd.net/download/lighttpd-1.4.18.tar.bz2 #獲取Lighttpd的源碼包
          tar -xvjf lighttpd-1.4.18.tar.bz2
          cd lighttpd-1.4.18
          ./configure #編譯
          make
          cp src/spawn-fcgi /usr/local/bin/spawn-fcgi #取出spawn-fcgi的程序下面我們就可以使用 spawn-fcgi 來(lái)控制php-cgi的FastCGI進(jìn)程了

          /usr/local/bin/spawn-fcgi -a 127.0.0.1 -p 9000 -C 5 -u www-data -g www-data -f /usr/bin/php-cgi參數(shù)含義如下

          -f <fcgiapp> 指定調(diào)用FastCGI的進(jìn)程的執(zhí)行程序位置,根據(jù)系統(tǒng)上所裝的PHP的情況具體設(shè)置
          -a <addr> 綁定到地址addr
          -p <port> 綁定到端口port
          -s <path> 綁定到unix socket的路徑path
          -C <childs> 指定產(chǎn)生的FastCGI的進(jìn)程數(shù),默認(rèn)為5(僅用于PHP)
          -P <path> 指定產(chǎn)生的進(jìn)程的PID文件路徑
          -u和-g FastCGI使用什么身份(-u 用戶 -g 用戶組)運(yùn)行,Ubuntu下可以使用www-data,其他的根據(jù)情況配置,如nobody、apache等

          #運(yùn)行用戶
          user   nobody nobody;
          #啟動(dòng)進(jìn)程
          worker_processes   2;
          #全局錯(cuò)誤日志及PID文件
          error_log   logs/error.log notice;
          pid        logs/nginx.pid;
          #工作模式及連接數(shù)上限
          events {
          use epoll;
          worker_connections    1024;
          }
          #設(shè)定http服務(wù)器,利用它的反向代理功能提供負(fù)載均衡支持
          http {
          #設(shè)定mime類型
          include    conf/mime.types;
          default_type   application/octet-stream;
          #設(shè)定日志格式
          log_format main        '$remote_addr - $remote_user [$time_local] '
          '"$request" $status $bytes_sent '
          '"$http_referer" "$http_user_agent" '
          '"$gzip_ratio"';
          log_format download '$remote_addr - $remote_user [$time_local] '
          '"$request" $status $bytes_sent '
          '"$http_referer" "$http_user_agent" '
          '"$http_range" "$sent_http_content_range"';
          #設(shè)定請(qǐng)求緩沖
          client_header_buffer_size 1k;
          large_client_header_buffers   4 4k;
          #開(kāi)啟gzip模塊
          gzip on;
          gzip_min_length   1100;
          gzip_buffers 4 8k;
          gzip_types    text/plain;
          output_buffers   1 32k;
          postpone_output   1460;
          #設(shè)定access log
          access_log   logs/access.log   main;
          client_header_timeout   3m;
          client_body_timeout 3m;
          send_timeout       3m;
          sendfile             on;
          tcp_nopush              on;
          tcp_nodelay          on;
          keepalive_timeout   65;
          #設(shè)定負(fù)載均衡的服務(wù)器列表
          upstream mysvr {
          #weigth參數(shù)表示權(quán)值,權(quán)值越高被分配到的幾率越大
          #本機(jī)上的Squid開(kāi)啟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;
          }
          #設(shè)定虛擬主機(jī)
          server {
          listen       80;
          server_name 192.168.8.1 www.yejr.com;
          charset gb2312;
          #設(shè)定本虛擬主機(jī)的訪問(wèn)日志
          access_log   logs/www.yejr.com.access.log   main;
          #如果訪問(wèn) /img/*, /js/*, /css/* 資源,則直接取本地文件,不通過(guò)squid
          #如果這些文件較多,不推薦這種方式,因?yàn)橥ㄟ^(guò)squid的緩存效果更好
          location ~ ^/(img|js|css)/   {
          root /data3/Html;
          expires 24h;
          }

          只有注冊(cè)用戶登錄后才能發(fā)表評(píng)論。


          網(wǎng)站導(dǎo)航:
           
          主站蜘蛛池模板: 楚雄市| 凤山县| 白水县| 芦溪县| 广水市| 信丰县| 成都市| 三原县| 阳新县| 商都县| 民县| 河东区| 齐齐哈尔市| 东至县| 灵台县| 钦州市| 汕头市| 远安县| 新丰县| 富阳市| 平湖市| 出国| 宜兰县| 阿尔山市| 彰武县| 麦盖提县| 兴海县| 柘城县| 临江市| 西吉县| 耿马| 卢氏县| 聂荣县| 合肥市| 静海县| 德化县| 都江堰市| 临沂市| 仁化县| 罗甸县| 西贡区|