Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Redis queue needs to implement job priority #205

Open
farmani opened this issue Feb 6, 2018 · 7 comments
Open

Redis queue needs to implement job priority #205

farmani opened this issue Feb 6, 2018 · 7 comments
Labels
type:enhancement Enhancement

Comments

@farmani
Copy link
Contributor

farmani commented Feb 6, 2018

mysql driver implement job priority but it doesnt support by redis yet. can you please implement it for redis and may be other driver please?

@samdark samdark added the type:enhancement Enhancement label Feb 6, 2018
@farmani
Copy link
Contributor Author

farmani commented Feb 6, 2018

I hope this will be doable before 2.0.14

@kushalhalder
Copy link
Contributor

You can create multiple queues, for example: high priority, medium priority and low priority. Have different redis databases for the queues. Then add 3 workers for the high priority queue, 2 for medium priority and 1 for low priority.

@samdark
Copy link
Member

samdark commented Feb 8, 2018

I hope this will be doable before 2.0.14

doesn't matter, releases of extensions aren't too tied to framework releases

@farmani
Copy link
Contributor Author

farmani commented Feb 8, 2018

@kushalhalder I know but not a good idea when other driver support priority.
@samdark yeah you right. it seems I do not used to extensions yet

@zhuravljov
Copy link
Member

Do you have any ideas to implement this lossless?
Now redis driver works using redis lists. Publisher pushes new message into start of list using LPUSH command (complexity: O(1)), and subscriber waits and receives the message from end of list using BRPOP (complexity: O(1)). Subscriber should be without changes, because this is fastest way to receive messages. Therefore publisher should be modified to insert new message into list according its priority O(n). The changing will complicate publishing, and redis driver will not be so fast.

@Insolita
Copy link

Insolita commented Apr 29, 2018

You can create multiple queues, for example: high priority, medium priority and low priority. Have different redis databases for the queues. Then add 3 workers for the high priority queue, 2 for medium priority and 1 for low priority.

It's good, but it require computing power for parallel execution 6 tasks, it may be sensitive for intensive tasks.

If only high and default priority needs, for high priority possible to make RPUSH
For high/default/low priority - only O(n) complexity is possible.
So i think, that it may be realized as custom, non-default driver, only for cases when queue speed has less significance than number of workers

@Insolita
Copy link

Also is the way - to make 3 Redis lists for high, default and low priorities, it can be faster on redis level, but more complex on queue manager level

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
type:enhancement Enhancement
Projects
None yet
Development

No branches or pull requests

5 participants