Skip to main content

What is sitecore exception of "alarm clock event subscriber"

Hi Team,

Today i will share one of the exception we started seeing in one of our CDs, We all like to keep our logs clean right, any exception can be symptoms of something going wrong

With my surprise, i was seeing following which was being continuously logged

Problem

The exception is

"ERROR Exception in alarm clock event subscriber"

It would have not caught my eyes, But because i was troubleshooting something else and anything in the logs looked suspicious to me and i researched it further and what happens is below

Cause

Sitecore documentation has explained very clear working of what goes behind the scene when Tracker is trying to submit a session to xConnect and what if xConnect is down

Refer : Sitecore documentation

"When the tracker submits a session to xConnect, but xConnect is temporarily unavailable, the tracker classifies this as a transient error (meaning it assumes xConnect becomes available later). The tracker adds the session to a submit queue that, by default, serializes the session to disk. The submit queue service later re-submits the session to xConnect at configurable intervals"

So that means if xConnect is unavailable there is some mechanism where the files gets stored on a file system,  which can be later picked up by the system when xConnect becomes available

Now in this process if xConnect becomes unavailable for sometime and it could be possible that those file which were created on file system by tracker might get stale or corrupt and that is from where the above exception takes birth.

Solution

First of all i wanted to check where on the file system the "Submit Queue" is being created and wanted to double check do i have any files there

and where the tracker will create a file on the disk, that path is mentioned in the \App_Config\Sitecore\Marketing.Tracking\Sitecore.Analytics.Tracking.config


and "dataFolder" is "sc:variable" and can be found in sitecore.config file from where you can get the actual path 

It pointed me to App_Data/Submit Queue folder on my CD server, and because i was getting the exception on my CD0, i went to that path and i saw following files there in queue waiting to be processed


i saw files from 2020 and after further research i took back up of those files and removed those file from the queue, because they were just there and not processed due to some reason

after doing this i went to my CD0 log stream, and i was happy to see that there was no exception and it worked !!!

Conclusion : We all want to keep our logs clean, so some exceptions might not be harming from the processing or performance point of view but its good to get it cleaned, you could also set some automation where if there are files older than some months, you can clean that up to keep your logs clean from these exceptions



 



Comments

Popular posts from this blog

Set up leprechaun code generation with Sitecore XM Cloud Starterkit

Hi Sitecorians, It has been amazing learning year so far and with the change in technology and shift of the focus on frontend frameworks and composable products, it has been market demand to keep learning and exploring new things. Reasons behind this blog Today's topic is something that was in my draft from April-May, and I always thought that there is already a good documentation out there for  Leprechaun  and a blog post is not needed, Until I realized that there was so many of us facing same kind of issues and same kind of problems and spending same amount of time, That is where I thought, if I could write something which can reduce that repetitive troubleshooting time, That would really help the community. 1)  In a project environment, if we get into some configuration issues, we resolve them, we make sure we are not blocked and continue, but if you think same issue, same step and same scenario will come to other people, so if we can draft it online, it will help othe...

Why SitecoreAI - Getting into the shoes of the customer how to select right CMS

Hi Team, Lately, I have been talking to lot of our customers / potential customers and having pre-sales demos where one question always comes is "Why Sitecore" ?  Now this question can be for any product which is out for sell. And as a technician I always get into product technical features, but at the same time as a pre-sales guy, it also makes me think, surely all competitive products have same features, so definitely answer to this is not in the technicalities.  If you step back and think, we are also a customer in our daily life and buy lot of things, what is that process we go through? When we buy, how can your customer decide if this is a right fit for you or not, why we select A over B? Is it price? is it service? Is it a brand? Is it about features? Is it about brand loyalty?  When it is a technical product, I am sure it cannot start with the technicalities of the product or selecting product itself, 100% not, I feel decision is always business strategy first and ...

Hell of sitecore aliases pipeline breaking the site with 500 error

Hello Friends, I belive this blog post is very important for everyone because, It has some very serious effect on working of your headless website, i will share my experience what we faced and how we resolved it Issue we started facing Our site started giving "Key cannot be null or empty" with YSOD like following  Side affect Because of this 500 error, Our site pages were showing 500 custom error page intermittently and our MAU (Monthly Active User) drop rate increased. Sitecore KB There is already Sitecore KB article talking about this error but the patch which is provided on this link is confusing as well as very huge and it could bring other issues along with it as that upgrade patch also has lot of other things too which i did not want to introduce in our stable CMS. Known Issues - Retrieving the child items of resource items is not thread-safe Observation Though the surfaced exception was looking similar and giving same error and behavior given on this article, We looked...