We were using the `cpu_count`, which doesn't respect container affinity. Now, we use `cpu_affinity` and also bound to make sure we don't start a million workers Fixes https://jira.coreos.com/browse/QUAY-928
		
			
				
	
	
		
			28 lines
		
	
	
	
		
			751 B
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			28 lines
		
	
	
	
		
			751 B
		
	
	
	
		
			Python
		
	
	
	
	
	
| import sys
 | |
| import os
 | |
| sys.path.append(os.path.join(os.path.dirname(__file__), "../"))
 | |
| 
 | |
| import logging
 | |
| 
 | |
| from Crypto import Random
 | |
| from util.log import logfile_path
 | |
| from util.workers import get_worker_count
 | |
| 
 | |
| 
 | |
| logconfig = logfile_path(debug=False)
 | |
| bind = 'unix:/tmp/gunicorn_secscan.sock'
 | |
| workers = get_worker_count('secscan', 2, minimum=2, maximum=4)
 | |
| worker_class = 'gevent'
 | |
| pythonpath = '.'
 | |
| preload_app = True
 | |
| 
 | |
| 
 | |
| def post_fork(server, worker):
 | |
|   # Reset the Random library to ensure it won't raise the "PID check failed." error after
 | |
|   # gunicorn forks.
 | |
|   Random.atfork()
 | |
| 
 | |
| def when_ready(server):
 | |
|   logger = logging.getLogger(__name__)
 | |
|   logger.debug('Starting secscan gunicorn with %s workers and %s worker class', workers,
 | |
|                worker_class)
 |