build queue rate limiting: address PR comments
This commit is contained in:
		
							parent
							
								
									eb69abff8b
								
							
						
					
					
						commit
						c41de8ded6
					
				
					 4 changed files with 12 additions and 7 deletions
				
			
		|  | @ -291,6 +291,7 @@ class RepositoryBuildList(RepositoryParamResource): | |||
|       build_request = start_build(repo, prepared, pull_robot_name=pull_robot_name) | ||||
|     except MaximumBuildsQueuedException: | ||||
|       abort(429, message='Maximum queued build rate exceeded.') | ||||
| 
 | ||||
|     resp = build_status_view(build_request) | ||||
|     repo_string = '%s/%s' % (namespace, repository) | ||||
|     headers = { | ||||
|  |  | |||
|  | @ -16,23 +16,27 @@ from util.morecollections import AttrDict | |||
| 
 | ||||
| logger = logging.getLogger(__name__) | ||||
| 
 | ||||
| MAX_BUILD_QUEUE_ITEMS = app.config.get('MAX_BUILD_QUEUE_ITEMS', -1) | ||||
| MAX_BUILD_QUEUE_SECS = app.config.get('MAX_BUILD_QUEUE_SECS', -1) | ||||
| MAX_BUILD_QUEUE_RATE_ITEMS = app.config.get('MAX_BUILD_QUEUE_RATE_ITEMS', -1) | ||||
| MAX_BUILD_QUEUE_RATE_SECS = app.config.get('MAX_BUILD_QUEUE_RATE_SECS', -1) | ||||
| 
 | ||||
| 
 | ||||
| class MaximumBuildsQueuedException(Exception): | ||||
|   """ | ||||
|   This exception is raised when a build is requested, but the incoming build | ||||
|   would exceed the configured maximum build rate. | ||||
|   """ | ||||
|   pass | ||||
| 
 | ||||
| 
 | ||||
| def start_build(repository, prepared_build, pull_robot_name=None): | ||||
|   queue_item_prefix = '%s/%s' % (repository.namespace_user.username, repository.name) | ||||
|   if MAX_BUILD_QUEUE_ITEMS > 0 and MAX_BUILD_QUEUE_SECS > 0: | ||||
|   if MAX_BUILD_QUEUE_RATE_ITEMS > 0 and MAX_BUILD_QUEUE_RATE_SECS > 0: | ||||
|     now = datetime.utcnow() | ||||
|     available_min = now - timedelta(seconds=MAX_BUILD_QUEUE_SECS) | ||||
|     available_min = now - timedelta(seconds=MAX_BUILD_QUEUE_RATE_SECS) | ||||
|     available_builds = dockerfile_build_queue.num_available_jobs_between(available_min, | ||||
|                                                                          now, | ||||
|                                                                          queue_item_prefix) | ||||
|     if available_builds > MAX_BUILD_QUEUE_ITEMS: | ||||
|     if available_builds >= MAX_BUILD_QUEUE_RATE_ITEMS: | ||||
|       raise MaximumBuildsQueuedException() | ||||
| 
 | ||||
|   host = app.config['SERVER_HOSTNAME'] | ||||
|  |  | |||
|  | @ -107,7 +107,7 @@ def build_trigger_webhook(trigger_uuid, **kwargs): | |||
|     try: | ||||
|       start_build(repo, prepared, pull_robot_name=pull_robot_name) | ||||
|     except MaximumBuildsQueuedException: | ||||
|       abort(429) | ||||
|       abort(429, message='Maximum queued build rate exceeded.') | ||||
| 
 | ||||
|     return make_response('Okay') | ||||
| 
 | ||||
|  |  | |||
		Reference in a new issue