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

High CPU to completely normal CPU - SXA issue, SXA pages not loading in mobile device

  Hi Team, Today i am going to share one of the nightmarish issue with you all, We are having Sitecore 9.1.1 hosted in azure PaaS environment Our site was working just fine and no noise, but we have been working on a feature release where 7-8 months of development needed to be released to production, Big GO LIVE event right?  Also to make the development smoother we also introduced BLUE/GREEN deployment slots in the same release, so we can easily SWAP slots and go live Everything went well, we went live, we even did load and performance testing on our staging and pre-prod and we were confident enough of results Very next day we started getting "SITE DOWN" alerts, and also product owners and clients mentioned that site is very slow for them in US time and in our morning when we were accessing it, it was working lighting fast so we were clue less at start, but we started digging  1) First thing caught our eyes were HIGH CPU spikes, in US time, also without any traffic CPU u...

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...

An error occurred while receiving the HTTP response to This could be due to the service endpoint binding not using the HTTP protocol. This could also be due to an HTTP request context being aborted by the server (possibly due to the service shutting down). See server logs for more details.

You have noticed many times that everything was working fine and suddenly the below error starts coming and you find no way to work it out An error occurred while receiving the HTTP response to This could be due to the service endpoint binding not using the HTTP protocol. This could also be due to an HTTP request context being aborted by the server (possibly due to the service shutting down). See server logs for more details. The reason for this is the receiving size of WCF service is smaller then the data which is coming from service It was working before because it was small,So you will have to try to increase the receiving setting in your end point,Possible settings can be following maxStringContentLength="2147483647" maxReceivedMessageSize="2147483647" maxBufferSize="2147483647" maxArrayLength="2147483647" That would definately help you!!!