job_queues

20
Job Queues Web is more than request and response

Upload: abhinav-lal

Post on 24-May-2015

1.688 views

Category:

Technology


0 download

TRANSCRIPT

Page 1: Job_Queues

Job Queues

Web is more than request and response

Page 2: Job_Queues

Who am I

• Co Founder / CTO Practo.com• Practo.com - simple software for doctors• 2000+ clinics, 10,000+ doctors, 1M+ patients • Cooking PHP for 5 years

Page 3: Job_Queues

Job Queues

Any long running work which does not require user feedback should be done in background.

Page 4: Job_Queues

Order Processing

Page 5: Job_Queues

Order Processing

Page 6: Job_Queues

Jobs to run in background

• Sending email• Fetching RSS feed periodically• Interacting with other application API• Complex report generation• Log analysis• cleaning file system• periodically or after certain action.

Page 7: Job_Queues

Options out there

Page 8: Job_Queues

Beanstalkd

• Open source C daemon• Fast• Persistence – bin log file• Distributed• PHP library – pheanstalk, beanstalk• Simple protocol

Page 9: Job_Queues

Beanstalkd ~ Memcached

• Beanstalkd design based on Memcache Philosophy• Simple protocol• In Memory Queue• Distributed servers handled by client

Page 10: Job_Queues

Beanstalkd Architecture

Page 11: Job_Queues

Beanstalkd client

Page 12: Job_Queues

Beanstalkd Worker

Page 13: Job_Queues

Beanstalkd Goodness

• Named Tubes• Priority• Delayed job• Bury• Kick

Page 14: Job_Queues

How we use it

• SMS System• Image Re sizing• PDF Generation• Real Time Analytics• And a lot more

Page 15: Job_Queues

ONE PROCESS TO RULE THEM ALL

Page 16: Job_Queues

Supervisord

• Python Application• Manages foreground process• Easy to configure - .ini format• Robust and Reliable

Page 17: Job_Queues

The configuration

Page 18: Job_Queues

Load Balance your workers

• Measure average time taken to complete a job• Define threshold of average time• Change num_process in supervisor config• Reload to launch new workers

Page 19: Job_Queues

Practo is Hiring

•  Hacker• Love building stuff• Solve difficult problems• Change the world

[email protected]

Page 20: Job_Queues

Questions

@abhinavlalabhinavlal.inSildeshare.net/abhinavlal