 ad370a3e55
			
		
	
	ad370a3e55
	
	
	
		
			
			This patch revises examples to use v2 interface which is long-term supported. Change-Id: I66fe67e1a1e81c092b2f37eaa6d2ad11f6166e22
		
			
				
	
	
		
			53 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			53 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
| # Copyright (c) 2014 Rackspace, Inc.
 | |
| #
 | |
| # Licensed under the Apache License, Version 2.0 (the "License");
 | |
| # you may not use this file except in compliance with the License.
 | |
| # You may obtain a copy of the License at
 | |
| #
 | |
| #    http://www.apache.org/licenses/LICENSE-2.0
 | |
| #
 | |
| # Unless required by applicable law or agreed to in writing, software
 | |
| # distributed under the License is distributed on an "AS IS" BASIS,
 | |
| # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
 | |
| # implied.
 | |
| # See the License for the specific language governing permissions and
 | |
| # limitations under the License.
 | |
| 
 | |
| import time
 | |
| 
 | |
| from zaqarclient.queues.v2 import client
 | |
| 
 | |
| URL = 'http://localhost:8888'
 | |
| 
 | |
| # Note: credential information should be provided using `conf`
 | |
| # keyword argument if authentication is enabled at server side.
 | |
| # Please refer to keystone_auth.py for more information.
 | |
| cli = client.Client(URL)
 | |
| queue = cli.queue('worker-jobs')
 | |
| 
 | |
| 
 | |
| def send_jobs():
 | |
|     jobs = [
 | |
|         {'name': 'fluffy'},
 | |
|         {'name': 'scout'},
 | |
|         {'name': 'jo'}
 | |
|     ]
 | |
|     queue.post([{'body': j,
 | |
|                  'ttl': 360}
 | |
|                 for j in jobs])
 | |
| 
 | |
| 
 | |
| def process_jobs():
 | |
|     claim1 = queue.claim(ttl=500, grace=900, limit=2)
 | |
|     for msg in claim1:
 | |
|         claim_id = msg.claim_id
 | |
|         print('{claim_id} =? {id}'.format(claim_id=claim_id, id=claim1.id))
 | |
|         print('processing job %s' % (msg))
 | |
|         msg.delete()
 | |
|         time.sleep(0.5)
 | |
| 
 | |
| if __name__ == '__main__':
 | |
|     while True:
 | |
|         send_jobs()
 | |
|         process_jobs()
 |