Skip to main content

Every Sitecore Instance using GQL is prone to this scenario of template not found - Sitecore Component With GQL Queries Broke On Production

Hello Team,

Today, I wanted to share a real scenario and a solution of it about what happened  suddenly to our components and how we identified it and how we resolved it, and most importantly it could happen to your installations too

Scenario

We have one Sitecore 10.2 headless instance and two sites, One site is non-sxa which is legacy site and another site is a new site which uses headless SXA.

Now, non-sxa site is already live and working fine with all components etc. and the new headless site was in development and it has separate development team, So we have same DEV/UAT/PROD environments.

One fine morning they took their code and site on environment but strangely some of the GQL components like header footer of legacy site disappeared. 

Troubleshooting Steps

1) We checked the broken component's GQL query 

2) We took that query and fired it in GQL IDE, and we observed that, Some of the templates references we used were not found, which was working just fine and we have not had any deployment of this site, see below what it was giving 


3) Now, one thing was clear, that the path of this "Link" template the tooltip is showing is not the one we referenced in our query, if you see the tool tip on above screenshot it is showing the path of SXA template which does not have those fields, Our legacy site does not use SXA.

4) Upon further investigation, we found out that, the other team who is sharing Sitecore instance have installed headless-sxa package and it seemed like it somehow now taking that template

5) We double checked and our custom "Link" template which was on another path was also there but it was somehow giving precedence to this SXA template.

6) We knew how GQL schema is generated, If there are templates with the same name exists in the tree, then precedence will be given to the one which has older date and the template which is of later date will be renamed with _GUID format, Read on link

Sitecore GQL Schema 

If you read the paragraph highlighted below from the Sitecore link


7) We were still puzzled because our custom "Link" template was older as we are live from long time and the headless-sxa package was just recently added, so that should have newer date, So we went on to check the date of that template which was generated by installing the package.

8) With our surprise, it has very old date for obvious reasons, because the package is standard package and it comes up with its own date when package was created by Sitecore. See below


We knew the issue now, but what is the solution? Because headless-sxa package is now overriding the behavior because it is having the older dates in its template.

Solution

1) Change your queries to have template name with _GUID, Because that is the correct template, but in this case you will need to change all the places where this template is used.

2) You can modify the <AddIncludePaths> configuration in the GraphQL schema custom configuration, so that you can exclude the SXA path in generating template schema and configure only those templates which you are using in GraphQ like below.

Default Configuration

By default Sitecore uses helix schema and edgeschema to target specific template path depending on helixContentSchema and edgeSchema configuration like below, and if you observer it will create template schemas for all those given on below paths, now all SXA related folders are also inside these folders only, so it also creates schema for those too. 

Now, if you have a different folder or a path which you want to target, You can patch your custom graph GQL schema configurations so it targets only specific path and generates template schemas for those path only like below 

<?xml version="1.0" encoding="utf-8" ?>
<configuration xmlns:patch="http://www.sitecore.net/xmlconfig/" xmlns:role="http://www.sitecore.net/xmlconfig/role/">
<sitecore>
<api>
<GraphQL>
<endpoints>
<customGraphQLEndpoint>
<schema>
<content>
<templates>
<paths>
<patch:delete />
</paths>
<paths hint="list:AddIncludedPath">
<feature>/sitecore/templates/Feature/Content/MyCustomPath</feature>
</paths>
</templates>
</content>
</schema>
</customGraphQLEndpoint>
</endpoints>
</GraphQL>
</api>
</sitecore>
</configuration>

But the limitation here is, We have "AddIncludedPath" tag but we do not have "AddExcludedPath" tag, so if you have so many path to include but if you have only one path you want to exclude, It is not possible right now, instead you will need to have all those custom path registered in "AddIncludePath" for which i raised the feature request and Sitecore has acknowledge it and taken as feature request with reference no. DEVEX-2997

I hope this scenario will save troubleshooting time for you all, Because this could easily exist in your set up too.


Comments

  1. Great insight! This scenario highlights the importance of understanding shared environments and their impact on projects. Thanks for sharing your experience.
    Pickle Distributorship
    centralized dust collector

    ReplyDelete
  2. This was an eye-opener! I wouldn’t have expected a package installation to cause such precedence issues. Great troubleshooting steps!
    Mezzanine floor manufacturer
    Warehouse Rack in Noida

    ReplyDelete
  3. Amazing write-up! It’s always tricky when different teams share the same environment. Your solution will definitely help others.
    Manual Dust Collector Delhi
    cartridge type bag filter manufacturer

    ReplyDelete
  4. Wow, I didn’t realize template precedence in GQL schema could cause such issues. Great to know the logic behind it.
    Evaporative Cooler Manufacturer
    prefabricated-sheds in delhi

    ReplyDelete
  5. This is super helpful! It’s a good reminder to always check the impact of new installations on shared environments.
    modular mezzanine floor in Indore
    Heavy Duty Mezzanine Floor in Delhi

    ReplyDelete
  6. Excellent post! The way you identified and resolved the issue is commendable. I’ll definitely keep this in mind for future projects.
    heavy duty rack in india
    Slotted Angle Rack Faridabad

    ReplyDelete
  7. Really detailed and informative. I appreciate how you broke down each troubleshooting step. Kudos!
    Slotted Angle Rack in Delhi
    Prefabricated Sheds gurgaon

    ReplyDelete
  8. Thanks for this practical example. The insight about how GQL schema handles templates with the same name is very useful.
    cable tray in delhi
    Industrial Storage rack India

    ReplyDelete
  9. Brilliant analysis! This blog post is a must-read for anyone working with Sitecore headless SXA and GQL.
    fabric storage rack manufacturer
    two tier rack delhi

    ReplyDelete
  10. Very relatable! I’ve faced similar issues with shared environments, and this blog would have saved me hours back then.
    industrial mezzanine floor delhi
    long span rack noida

    ReplyDelete
  11. This was such a thorough explanation. Your experience will definitely help avoid similar headaches in the future.
    cantilever rack gurgaon
    multi tier rack rudrapur

    ReplyDelete
  12. Excellent documentation of the problem and solution. The clarity is appreciated. Bookmarking this for reference!
    industrial storage rack in ghaziabad
    office chair in delhi

    ReplyDelete
  13. Hats off to the troubleshooting steps! It’s a reminder to always dig deeper when unexpected issues arise.
    Franchise Expo Delhi
    Franchise

    ReplyDelete
  14. Incredible attention to detail. You’ve turned a complex issue into a learning experience for many.
    Cooking Oil Distributorship
    Saw Palmetto Oil CO2 Manufacturer in Korea

    ReplyDelete
  15. Very useful content! The troubleshooting steps are easy to follow and replicate. Thanks for sharing your expertise.
    Sparsh Bagga
    SEO Agency in India

    ReplyDelete
  16. Thank you for sharing this real-world example. The GQL query debugging tips are especially helpful!
    Warehouse Rack in India
    Manual Dust Collector Delhi

    ReplyDelete
  17. "The twins look so precious in the photo. They’re growing up fast!"
    mezzanine floor in delhi
    Warehouse Racking System in delhi

    ReplyDelete

Post a Comment

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