Home  >  Article  >  Backend Development  >  nginx+keepalived high availability load balancing

nginx+keepalived high availability load balancing

WBOY
WBOYOriginal
2016-08-08 09:27:521148browse

Not much to say, nginx installation and configuration, as well as load balancing, you can read another article I wrote "nginx Load Balancing in Practice", and about load balancing, you can read another article I wrote Two articles, one is "lvs+keepalived load balancing" and the other is "haproxy+keepalived load balancing". For the difference between the three load balancing, you can take a look at an article I reprinted "Software Level Load Balancer (LVS)" /HAProxy/Nginx), let’s go directly to the configuration steps:

1. System environment

[plain] view plaincopy

  1. System version: CentOS release 5.9 (Final) x86 32-bit
  2. nginx version: 1.2.8
  3. keepalived version: 1.2 .4
  4. main keepalived: 192.168.207.130
  5. from keepalived:192.168.207.131
  6. VIP: 192.168.207.140
  7. WEB_1:192.168.207.129 Port 80
  8. WEB_2 :192.168.207.130 8080 port
  9. WEB_3:192.168.207.131 8080 port

2. Custom nginx configuration file


at 192.168.207 Operating on .130 and 192.168.207.131

[plain] view plaincopy

  1. useradd nginx
  2. vi /usr/local/nginx/conf/nginx.conf

The content is as follows:

[plain] view plaincopy

  1. #Run user                                                                                                                                                                              
  2. #Global error log and PID file
  3. error_log logs/error. log notification; epoll;
  4. worker_connections 1024; #So The total number of connections supported by nginx is equal to worker_processes * worker_connections
  5. }
  6. #Set the http server and use its reverse proxy function to provide load balancing support
  7. http {
  8. #Set the mime type
  9. include mime.types ; #This is about nginx Which multimedia types are supported? You can go to conf/mime.types to check which multimedia are supported.
  10. default_type application/octet-stream; #Default data type
  11. #Set log format
  12. Log_format main '$remote_addr - $remote_user [$time_local] ' '"$request" $status $bytes_sent ' '"$http_referer" "$http_user_agent" '​
  13. ​ '"$gzip_ratio"' ; ; ent ' '
  14. '"$http_referer" "$http_user_agent" '
  15. '"$http_range" "$sent_http_content_range"';
  16. large_client_header_buffers 4 4k;
  17. #Enable gzip module
  18.       #gzip on;                                                  gzip_types text/plain;
  19. #output_buffers 1 32k;
  20. #postpone_output 1460;
  21. #Setting access log
  22. access_log logs/access.log main;
  23. client_header_timeout 3m;
  24. client_body_timeout 3m;
  25. send_timeout 3m;
  26. sendfile on;
  27. tcp_nopush on;
  28. tcp_nodelay on;
  29. keepalive_timeout 65;
  30. #Set the load balancing server list
  31. upstream mysvr {
  32. #weigth parameter representation Weight, the higher the weight, the greater the chance of being assigned                                                                                                                                                                            weight=5; . Server 192.168.207.131:8080 weight = 5;
  33. }
  34. server {#This is set to set web service, monitor port 8080
  35. Listen 8080;
  36. server_name 192.168.207.131; #This changes according to the system ip
  37.                                                   ‐ ’ s ‐ ‐ ‐ ‐ ‐ ‐ ‐ ‐              page 500 502 503 504 /50x.html;
  38. # location = /50x.html {
  39. html;
  40.         #Set up virtual host                                                              A Server_name 192.168.207.140;#Here is VIP
  41. #Charset GB2312;
  42. #Set the visits log of this virtual host
  43. access_log Logs/Threeb.access.log Main;
  44.           #If you access /img/*, /js/*, /css/* resources, fetch local files directly, not through squid                                                   The cache effect is better l #Location ~^/(IMG | JS | CSS)/{
  45. #root/data3/html;
  46. #Expires 24h;
  47. #}#"/" Enable load balancing
  48. local/{
  49. proxy_pass http:// mysvr;#
  50.               proxy_set_header Host $host;                                             proxy_set_header                  proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; client_max_body_size 10m; client_body_buffer_ size 128k;
  51.            proxy_connect_timeout 90;                 proxy_read_timeout 90;                        proxy_buffer_size                             proxy_busy_buffers_size 64k;
  52.                                                                                                                                                  
  53. stub_status on;
  54. access_log on;
  55.                  auth_basic "NginxStatus";                                                                                                                                                             auth_basic    "NginxStatus";                                                                                                                                                                .Customize keepalived configuration file
  56. [plain] view plaincopy
  57. vi /etc/keepalived/keepalived.conf
  58. The content is as follows:
  59. [plain] view plaincopy
    1. global_defs {
    2. notification_email {
    3. root@localhost.localdomain }
    4. notification_email_from notify@keepalived.com
    5. smtp_server 127.0.0.1
    6. smtp_connect_timeout 30
    7. router_id LVS_DEVEL
    8. }
    9. vrrp_script chk_http_port {
    10.                script "/etc/keepalived/check_nginx.sh"                                                                                                                                        ##Monitoring time
    11.                                                                                                                                                                                                          Monitoring time VI_1 {
    12.                                                                                                     ,                    ### Monitoring network card
    13.                                                                     ’ s ‐         ‐   ‐ ‐ out of 101                                      The weight value MASTRE must be higher than BAUCKUP
    14. Auth_pass 1111}}
    15. track_script {
    16. chK_HTTP_PORT ###}}}
    17. virtual_ipaddress {
    18. 192.168.207.140 ### vip address
    19. View plaincopy
      1. vi /etc/keepalived/check_nginx.sh

      The content is as follows:

      [plain] view plaincopy

      1. !/bin/bash
      2. A = `ps -C nginx --no-header |wc -l`
      3. if [ $A -eq 0 ];then /usr/local/nginx/sbin/nginx
      4. if no process is worth zero
      5.                                                                                                                                                                                    sleep                                                                                 sleep                              -no-header |wc -l` -eq 0 ];then
      6.                                                                                                                                                                                                    
      7.                                                                                        Here is to check whether nginx has started. If it has not started, start nginx first. If it has not started after 3 seconds, the keepalived process will also be closed, so that keepalived can take over and provide high availability. Here, The keepalived service provides high availability, while nginx provides load balancing of back-end web servers.
      8. You also need to add execution permissions to the script, as follows
      9. [plain] view plaincopy
      10. chmod +x /etc/keepalived/check_nginx.sh
      5. Start the service and test
      Let me talk about it first. On WEB_1, I use the system auto I brought the apache web server last night, which is more trouble-free. In this case, I only need to start the master-slave keepalived, because it will use the check_nginx.sh script to automatically start nginx. Everything is started.
      Visit http://192.168.207.140 to access the content of the three back-end web servers in rotationHere we turn off the main keepalived service to test high availabilityThen it will be in /var/log/ on the slave keepalived server messages saw a log like this

      [plain] view plaincopy
      1. Apr 19 17:42:44 localhost Keepalived_vrrp: VRRP_Instance(VI_1) Transition to MASTER STATE

      Apr 19 17:42:45 localhost Keepalived_vrrp : VRRP_Instance(VI_1) Entering MASTER STATE



      Apr 19 17:42:45 localhost Keepalived_vrrp: VRRP_Instance(VI_1) setting protocol VIPs.



      Apr 19 17:42:45 localhost Keepalived_vrrp: VRRP_Instance(VI_1) Sending gratuitous ARPs on eth0 for 192.168.207.140

      Apr 19 17:42:45 localhost Keepalived_vrrp: Netlink reflector reports IP 192.168.207.140 added

      1. Apr 19 17:42:45 localhost Keepalived_healthcheckers: Netlink reflector reports IP 192.168. 207.140 added Apr 19 17:42:45 localhost avahi-daemon[4204]: Registering new address record for 192.168.207.140 on eth0.

      2. Continue to visit http://192.168.207.140, you can still access the three back-end web servers
        Then open the original owner keepalived, you can observe the log display of the original slave keepalived server

        [plain] view plaincopy

        1. Apr 19 17:42:50 localhost Keepalived_vrrp: VRRP_Instance(VI_1) Sending gratuitous ARPs on eth0 for 192.168.207.140
        2. Apr 1 9 17:44:06 localhost Keepalived_vrrp: VRRP_Instance(VI_1) Received higher prio advert
        3. Apr 19 17:44:06 localhost Keepalived_vrrp: VRRP_Instance(VI_1) Entering BACKUP STATE
        4. Apr 19 17:44:06 localhost Keepalived_vrrp: VRRP_Instance (VI_1) removing protocol VIPs.
        5. Apr 19 17:44:06 localhost Keepalived_vrrp: Netlink reflector reports IP 192.168.207.140 removed
        6. Apr 19 17:44:06 localhost Keepalived_healthcheckers: Netlink reflector reports IP 192.168 .207.140 removed
        7. Apr 19 17:44:06 localhost avahi-daemon[4204]: Withdrawing address record for 192.168.207.140 on eth0.

        It means that the original master-slave result has been restored.
        In the production environment, the back-end machine may also hang up, but you don’t have to worry about it, nginx will automatically allocate the session to a good back-end web server

        ok, here you go It's all over, practice personal testing, I wish you success

        From: http://blog.csdn.net/zmj_88888888/article/details/8825471

        The above has introduced nginx+keepalived high-availability load balancing, including aspects of it. I hope it will be helpful to friends who are interested in PHP tutorials.

Statement:
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn