From 20c24a392374f9d083e048bdd2a0469b352d2203 Mon Sep 17 00:00:00 2001 From: shreyas Date: Thu, 28 Jul 2016 12:58:37 +0530 Subject: [PATCH 1/3] [Minor] Add limit_conn_zone to bench nginx config --- bench/config/nginx.py | 8 ++++++-- bench/config/templates/nginx.conf | 2 ++ playbooks/install.py | 16 ++++++++++++++++ 3 files changed, 24 insertions(+), 2 deletions(-) diff --git a/bench/config/nginx.py b/bench/config/nginx.py index a8516370..13d01b94 100644 --- a/bench/config/nginx.py +++ b/bench/config/nginx.py @@ -1,4 +1,4 @@ -import os, json, click, random, string +import os, json, click, random, string, hashlib from bench.utils import get_sites, get_bench_name, exec_cmd def make_nginx_conf(bench_path, yes=False): @@ -12,13 +12,17 @@ def make_nginx_conf(bench_path, yes=False): config = get_config(bench_path) sites = prepare_sites(config, bench_path) + bench_name = get_bench_name(bench_path) + bench_name_hash = hashlib.sha256('bench_name').hexdigest()[:16] + nginx_conf = template.render(**{ "sites_path": sites_path, "http_timeout": config.get("http_timeout"), "sites": sites, "webserver_port": config.get('webserver_port'), "socketio_port": config.get('socketio_port'), - "bench_name": get_bench_name(bench_path), + "bench_name": bench_name, + "bench_name_hash": bench_name_hash, "error_pages": get_error_pages(), # for nginx map variable diff --git a/bench/config/templates/nginx.conf b/bench/config/templates/nginx.conf index a086a250..ebcae666 100644 --- a/bench/config/templates/nginx.conf +++ b/bench/config/templates/nginx.conf @@ -139,6 +139,8 @@ upstream {{ bench_name}}-socketio-server { server 127.0.0.1:{{ socketio_port or 3000 }} fail_timeout=0; } +limit_conn_zone $host zone=per_host_{{ bench_name_hash }}:3000m; + # setup maps {%- set site_name_variable="$host" %} {% if sites.domain_map -%} diff --git a/playbooks/install.py b/playbooks/install.py index d337c7bb..7167c3df 100755 --- a/playbooks/install.py +++ b/playbooks/install.py @@ -5,6 +5,8 @@ from distutils.spawn import find_executable tmp_bench_repo = '/tmp/.bench' def install_bench(args): + check_brew_installed() + # pre-requisites for bench repo cloning install_package('curl') install_package('wget') @@ -139,6 +141,20 @@ def install_package(package): if not success: could_not_install(package) +def check_brew_installed(): + if 'Darwin' not in os.uname(): + return + + brew_exec = find_executable('brew') + + if not brew_exec: + raise Exception(''' + Please install brew package manager before proceeding with bench setup. Please run following + to install brew package manager on your machine, + + /usr/bin/ruby -e "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/master/install)" + ''') + def clone_bench_repo(args): '''Clones the bench repository in the user folder''' if os.path.exists(tmp_bench_repo): From f9067f3d7af4990b694dda2b598dae6674965a97 Mon Sep 17 00:00:00 2001 From: shreyas Date: Thu, 28 Jul 2016 16:17:48 +0530 Subject: [PATCH 2/3] [Minor] Add rate limiting for bench --- bench/config/nginx.py | 8 ++++++++ bench/config/production_setup.py | 6 +++++- bench/config/templates/nginx.conf | 4 +++- requirements.txt | 1 + 4 files changed, 17 insertions(+), 2 deletions(-) diff --git a/bench/config/nginx.py b/bench/config/nginx.py index 13d01b94..3c8fbc38 100644 --- a/bench/config/nginx.py +++ b/bench/config/nginx.py @@ -23,6 +23,7 @@ def make_nginx_conf(bench_path, yes=False): "socketio_port": config.get('socketio_port'), "bench_name": bench_name, "bench_name_hash": bench_name_hash, + "limit_conn_shared_memory": get_limit_conn_shared_memory(), "error_pages": get_error_pages(), # for nginx map variable @@ -160,3 +161,10 @@ def get_error_pages(): return { 502: os.path.join(templates, '502.html') } + +def get_limit_conn_shared_memory(): + """Allocate 2 percent of total virtual memory as shared memory for nginx limit_conn_zone""" + import psutil + total_vm = (psutil.virtual_memory().total) / (1024 * 1024) # in MB + + return int(0.02 * total_vm) diff --git a/bench/config/production_setup.py b/bench/config/production_setup.py index df19398e..e7e6c94a 100755 --- a/bench/config/production_setup.py +++ b/bench/config/production_setup.py @@ -127,5 +127,9 @@ def reload_supervisor(): pass def reload_nginx(): - subprocess.check_output(['sudo', find_executable('nginx'), '-t']) + try: + subprocess.check_output(['sudo', find_executable('nginx'), '-t']) + except: + raise + service('nginx', 'reload') diff --git a/bench/config/templates/nginx.conf b/bench/config/templates/nginx.conf index ebcae666..008987d7 100644 --- a/bench/config/templates/nginx.conf +++ b/bench/config/templates/nginx.conf @@ -21,6 +21,8 @@ server { root {{ sites_path }}; + limit_conn per_host_{{ bench_name_hash }} 8; + {% if ssl_certificate and ssl_certificate_key %} ssl on; ssl_certificate {{ ssl_certificate }}; @@ -139,7 +141,7 @@ upstream {{ bench_name}}-socketio-server { server 127.0.0.1:{{ socketio_port or 3000 }} fail_timeout=0; } -limit_conn_zone $host zone=per_host_{{ bench_name_hash }}:3000m; +limit_conn_zone $host zone=per_host_{{ bench_name_hash }}:{{ limit_conn_shared_memory }}m; # setup maps {%- set site_name_variable="$host" %} diff --git a/requirements.txt b/requirements.txt index f5a239a6..57eb2683 100644 --- a/requirements.txt +++ b/requirements.txt @@ -3,6 +3,7 @@ jinja2 virtualenv requests honcho +psutil python-crontab semantic_version GitPython==0.3.2.rc1 From 0c95b6a564baa1b80501f263001773823e349925 Mon Sep 17 00:00:00 2001 From: shreyas Date: Fri, 29 Jul 2016 11:54:46 +0530 Subject: [PATCH 3/3] [Fix] Travis CI failure fixes --- bench/config/nginx.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/bench/config/nginx.py b/bench/config/nginx.py index 3c8fbc38..66aedd10 100644 --- a/bench/config/nginx.py +++ b/bench/config/nginx.py @@ -13,7 +13,7 @@ def make_nginx_conf(bench_path, yes=False): sites = prepare_sites(config, bench_path) bench_name = get_bench_name(bench_path) - bench_name_hash = hashlib.sha256('bench_name').hexdigest()[:16] + bench_name_hash = hashlib.sha256(bench_name).hexdigest()[:16] nginx_conf = template.render(**{ "sites_path": sites_path,