-
Notifications
You must be signed in to change notification settings - Fork 15
/
Copy pathrequest-lb-weight.py
31 lines (23 loc) · 1.04 KB
/
request-lb-weight.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
#!/usr/bin/env python
# Please note the LICENSE file accompanying this script.
# See https://github.com/reincubate/haproxy-dynamic-weight for more information.
import os, socket, site, sys, memcache
# If the calculation of the load AND the weighting/actioning
# of the load data is at the same interval (1 minute) then we
# will see a lot of jerkiness. So we take the 5 minute average.
# This means servers get lowered in priority more slowly.
load = os.getloadavg()[1]
hostname = socket.gethostname()
max_load = 5
if len(sys.argv) < 2:
raise Exception( 'You must pass the hostname and port of your memcached server' )
# Weight must range from 1 - 256
if load < 0.001:
load = 0.001
if load > max_load:
load = max_load
weight = int( ( (255 / max_load) * ( ( max_load + 0.001 ) - load ) ) + 1 )
if len(sys.argv) > 2:
print 'Declaring weight of %s for %s for %ss, given load of %s' % ( weight, hostname, 60 * 2, load )
mc = memcache.Client( [ sys.argv[1] ], )
mc.set( 'server-weight-%s' % hostname, weight, time=60*2 ) # Set a two minute expiry