docker容器间的负载均衡

2018-11-26  本文已影响0人  李喂马

场景

在最近一次开发过程中遇见这个这样的问题:在面临突发性大量用户涌进系统的时候,服务器的资源使用并不高,cpu使用率28%左右,内存的使用率40%左右但是依然会造成系统卡顿,请求超时等问题。百思不得其解头发都快抓掉完了~。系统也未发现sql慢查询等操作,修改php的最大链接数,进程数等配置依然不见得到改善。思来想去大概确定问题应该出现在php代码的身上,由于php处理任务时间过长一直占据着进程得不到释放,在大量请求的请求的情况下后面的一直处于等待状态,等待时候过长就会出现504,系统卡顿的情况。目前可以确定不是硬件问题,sql瓶颈问题,所以问题在于php瓶颈大概会有以下几个地方:

思来想去既然服务的资源使用不多还不到50%,处理不过来的是php,如果使用多个php去执行这些任务就会得到改善,这个时候直觉就是负载均衡。在以往的负载均衡里都是多台服务器搭建一样的运行环境然配置nginx的proxy_pass反向代理到http请求上,但是现在问题在于服务器资源使用只有三分钟一,再购买服务器会有点浪费,也不是最根本的办法,想到docker-compose scale的参数可以设置启动容器的数量,唉~我可以启动多个容器然后使用nginx负载聚合每次访问不用的phpfpm容器处理任务的啊,提起袖子说干就干。。。

实现思路

启动多个phpfpm容器,利用nginx负载均衡分配处理任务的容器

具体配置

 nginx:
    image: nginx:stable
    ports:
      - 80:80
      - 443:443
    volumes:
      - ./vhost:/etc/nginx/conf.d
      - ../Code:/var/www/html
    links:
      - phpfpm
      - phpfpm2

  //第一个phpfpm
  phpfpm:
    image: php:v7.2
    volumes:
      - ../Code:/var/www/html
      - ./php-fpm7.2/queue:/etc/supervisor/conf.d
#    ports:
#      - "9000"
#      - "9501:9501"

 
 //第二个phpfpm
  phpfpm2:
    image: php:v7.2
    volumes:
      - ../Code:/var/www/html
      - ./php-fpm7.2/queue:/etc/supervisor/conf.d
#    ports:
#      - "9000"
#      - "9501:9501"

upstream webs {
    server phpfpm:9000;
    server phpfpm2:9000;
}


server {
        listen       80 ;
        server_name test.xx;
        root         /var/www/html/test;

        location = /favicon.ico {
          log_not_found off;
          access_log off;
        }


        location ^~ /web/  {
            if (!-e $request_filename) {
                rewrite  ^(.*)$ /web/index.html break;
            }
        }

        location / {
            index index.php index.html index.htm;
                if (!-e $request_filename) {
                    rewrite  ^(.*)$  /index.php?s=$1  last;
                    break;
                }
        }

        location ~ \.php(.*)$ {
            fastcgi_pass   webs;        //注意这里
            fastcgi_index  index.php;
            fastcgi_split_path_info  ^(.+\.php)(.*)$;
            fastcgi_param  SCRIPT_FILENAME  $document_root$fastcgi_script_name;
            fastcgi_param  PATH_INFO  $fastcgi_path_info;
            fastcgi_param  PATH_TRANSLATED  $document_root$fastcgi_path_info;
            include        fastcgi_params;
        }

    }

缺陷

上一篇 下一篇

猜你喜欢

热点阅读