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

Publish blog post 'Cleaning up [orphan] from indexes' #118

Merged
merged 8 commits into from
Oct 30, 2024
53 changes: 53 additions & 0 deletions docs/_posts/2024-10-30-cleaning-up-orphan-from-indexes.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,53 @@
---
title: "Cleaning up [orphan] from indexes"
date: 2024-10-30 12:00:00 +0100
categories:
- Sitecore
tags:
- Sitecore
- Sitecore 10.3
author: tcanyalcin
---
![alt text](../files/2024/10/30/sitecore-orphan.png "Sitecore [orphan]")


Recently on our live website, indexes stopped working while showing data from a particular page type. Also on these pages, most components were missing.
Everything was working fine on the master database. In the logs, we found the following error:

```
Message: Could not map index document field to property "Paths" on type App.Foundation.Search.SearchResultItem : Guid should contain 32 digits with 4 dashes (xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx). Actual value: [orphan]
```

Also, when we visited those pages on the web database and opened presentation details, it was not possible to check the datasource, because the browse button was throwing an error if the component datasource was coming from the local datasource. In the logs, we found the following error:

```
Exception: System.NullReferenceException
Message: Object reference not set to an instance of an object.
Source: Sitecore.XA.Foundation.LocalDatasources
at Sitecore.XA.Foundation.LocalDatasources.RenderingDatasources.DatasourceSettingsProvider.GetSettingsItem(Item contextItem, ID renderingId)
at Sitecore.XA.Foundation.LocalDatasources.RenderingDatasources.DatasourceSettingsProvider.HasSettings(Item contextItem, ID renderingId)
at Sitecore.XA.Foundation.LocalDatasources.Pipelines.GetRenderingDatasource.AddAdditionalTemplates.Process(GetRenderingDatasourceArgs args)
at (Object , Object )
at Sitecore.Pipelines.CorePipeline.Run(PipelineArgs args)
at Sitecore.Pipelines.DefaultCorePipelineManager.Run(String pipelineName, PipelineArgs args, String pipelineDomain, Boolean failIfNotExists)
at Sitecore.Pipelines.DefaultCorePipelineManager.Run(String pipelineName, PipelineArgs args, String pipelineDomain)
at Sitecore.XA.Foundation.LocalDatasources.CustomFields.FieldTypesEx.BucketInternalLink.ShowDialog(ClientPipelineArgs args)
```

So we had 2 different problems that might be connected.

With these clues in hand, we checked indexes for these page types. Then, found out that there were many cases with [orphan] assigned to the *_path* field:

![alt text](../files/2024/10/30/solr_orphan.png "Solr Orphan in Path")

We tried rebuilding databases but it didn't help and [orphan]s stayed. 

Then we tried database cleanup from sitecore/admin/dbcleanup.aspx:

![alt text](../files/2024/10/30/sitecore_database_cleanup.png "Sitecore Database Cleanup")

and rebuild indexes again. All orphans got cleared from indexes.

Once we checked the error we got from local datasources, we also saw that the error was gone.

Indexes worked again, pages were showing components after clearing the caches.
Binary file added docs/files/2024/10/30/sitecore-orphan.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added docs/files/2024/10/30/solr_orphan.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading