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

URL slug queue is stucked forever when some errors occur #38

Open
martinfbluesoftcz opened this issue Dec 2, 2020 · 3 comments
Open

Comments

@martinfbluesoftcz
Copy link
Contributor

Hello, we have problem when some error occurs in URL slug queue processing queue is stucked forever.
Setting Queue Error Behavior is set to Halt queue, I am afraid to change it. But I would expect scheduled task re-run all queue even when some old error is logged. But I am looking to GetNextRunnableQueueItem SQL query which is used by scheduled task to read queue items and clearly there is not change to re-run queue again and only way is to run it manually which is really bad.

Is this some intention or bug?

@KenticoDevTrev
Copy link
Owner

It can depend, you can force it to go, but if it's Halt and it has a legitamate error you should try to correct.

In the Dynamic Routing module UI, there should be a way to see the Queue and view the error, what does it say? What happens when you try to manually "play" the first item?

@KenticoDevTrev
Copy link
Owner

But yeah, i've noticed that if it gets stuck you often have to manually kick it off with the halt and wait thing.

@martinfbluesoftcz
Copy link
Contributor Author

Error need not be related to Dynamic routing, for example we had issue with StackOverflowException in other part of application and this also caused Slug queue processing failed. Next week I noticed it's stucked and ran it manually.

Maybe this change in DynamicRouteInternalHelper.CheckUrlSlugGenerationQueue could help this problem, what do you think?:

public static void CheckUrlSlugGenerationQueue(bool runFromScheduledTask = false)
        {            
            // Clear any stuck tasks
            ClearStuckUrlGenerationTasks();

            if (runFromScheduledTask)
            {
                //@TODO - clear errors to ensure at least one task will be processed
            }

            //....
        }

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

No branches or pull requests

2 participants