-
Notifications
You must be signed in to change notification settings - Fork 284
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
Expose some identifier for Worker and a way to query its status #1039
Comments
Hi, So what to do? In general, have an "images" or "conversions" table:
Your polling happens against the "conversions" table. This way lets you: a) switch backens See more in discussions here: https://www.reddit.com/r/rails/comments/naszfk/getting_job_status_in_rails/ Having said that, there are instances where a "job ID" exists, specifically job workflow coordination. We do carry job IDs in each individual implementation, so I'd be more than willing to expose this, because I see no reason not to. |
🤦 Jup makes total sense. I’ll pretty much build a “jobs” table to track them. Thank you for the reminder! (I say this, yet at the moment I am super time-limited) |
To provide the enhancement you originally wanted, it should be feasible.
NOTE: if the Redis provider cannot supply a job ID, then we can return a Result<Option>, and providers which do not support this return |
Hello, I use workers to process my post-production videos and I have some problems when they suddenly shut down and when restarted, the workers with I am using postgres queue |
Hey @anhnmt, You can use admin-jobs for managing admin workers, which also allows you to re-run jobs. Regarding the "suddenly shut down" issue:
|
@kaplanelad Below is the code I am using pub struct ProcessingWorkerInitializer;
#[async_trait]
impl Initializer for ProcessingWorkerInitializer {
fn name(&self) -> String {
"processing-worker".to_string()
}
async fn before_run(&self, ctx: &AppContext) -> Result<()> {
let pool = ctx.db.get_postgres_connection_pool();
sqlx::raw_sql(
r"
update pg_loco_queue
set status = 'queued'
where status = 'processing';
",
)
.execute(pool)
.await?;
Ok(())
}
} |
go it. $ cargo loco jobs --help
Managing jobs queue
Usage: myapp-cli jobs [OPTIONS] <COMMAND>
Commands:
cancel Cancels jobs with the specified names, setting their status to `cancelled`
tidy Deletes jobs that are either completed or cancelled
purge Deletes jobs based on their age in days
dump Saves the details of all jobs to files in the specified folder
import Imports jobs from a file
help Print this message or the help of the given subcommand(s)
Options:
-e, --environment <ENVIRONMENT> Specify the environment [default: development]
-h, --help Print help
-V, --version Print version What do you think? |
I think we should add the feature to update |
I can add a new |
That seems really cool, you should check the status in the enum to see if it is valid or not |
Feature Request
Is your feature request related to a problem? Please describe.
In my app I can upload (large) images. For the frontend I use the
image
crate to resize a much smaller thumbnail, but this can take a few seconds. I would like for this work to be scheduled into the background from the requst.Describe the solution you'd like
Scheduling in the background is possible with a Worker, which is awesome.
Ideally, there would be an identifier generated when I call
let job_id = ImageResizer::perform_later()
.I would then expose that ID to the frontend and let it poll on some endpoint to check when the job is done.
That way I can tell the user that the image has been uploaded, and then pop an extra notification when the background job is done and the image is available to use.
Describe alternatives you've considered
I have considered some kind of ID tracking in the job itself where I track jobs for a given resource (recipe, in my case) in a separate table but that sounds awfully annoying.
The text was updated successfully, but these errors were encountered: