Hello AJITH KRISHNA MANKENA,
Welcome to the Microsoft Q&A and thank you for posting your questions here.
I understand that you are having issue of unexpected termination without exceptions.
My first advice is to verify the API key, endpoint configurations and simplify the index creation code.
To address the root cause of silent termination comprehensively, follow the below steps:
- Attach a debugger and step through the code to observe where it terminates. Pay close attention to the
CreateOrUpdateIndexAsync
method.
This enables detailed logs from Azure SDK to identify potential internal errors.AzureEventSourceListener listener = new AzureEventSourceListener((eventData, text) => { Console.WriteLine($"{eventData.Level}: {text}"); }, System.Diagnostics.Tracing.EventLevel.LogAlways);
- Then, add a global exception handler to catch unhandled exceptions:
AppDomain.CurrentDomain.UnhandledException += (sender, args) => { Console.WriteLine($"Unhandled exception: {args.ExceptionObject}"); };
- Confirm the validity of
searchServiceEndpoint
andsearchApiKey
by running a simple API call like listing indexes:
Ensure the API key hasvar response = await indexClient.GetIndexAsync(indexName); Console.WriteLine(response.Value.Name);
Index Administrator
permissions in Azure AI Search. - Start with minimal schema:
SearchIndex searchIndex = new(indexName) { Fields = new[] { new SimpleField("id", SearchFieldDataType.String) { IsKey = true } } }; await indexClient.CreateOrUpdateIndexAsync(searchIndex);
- Run the program locally and in a different environment (e.g., another machine or Azure Function) to rule out environment-specific issues like insufficient memory or runtime incompatibility.
- Use a tool like
ProcDump
(for Windows) orgcore
(for Linux) to capture crash dumps if the application exits unexpectedly using bash or CMD:procdump -e -ma YourApp.exe
- Check Azure AI Search’s diagnostic logs for any failed operations.
The below is a revised code snippet for you:
public static async Task SetUpIndex()
{
const string indexName = "my-demo-index-dummyindex";
try
{
Console.WriteLine("Initializing Azure Search Service");
SearchIndexClient indexClient = new SearchIndexClient(new Uri(searchServiceEndpoint), new AzureKeyCredential(searchApiKey));
Console.WriteLine("Connected to Azure AI Search");
// Minimal schema for testing
SearchIndex searchIndex = new(indexName)
{
Fields = new[]
{
new SimpleField("id", SearchFieldDataType.String) { IsKey = true }
}
};
Console.WriteLine("Creating Index");
await indexClient.CreateOrUpdateIndexAsync(searchIndex);
Console.WriteLine($"Index created successfully: {indexName}");
}
catch (RequestFailedException ex)
{
Console.WriteLine($"Error creating index: {ex.Message}");
}
catch (Exception ex)
{
Console.WriteLine($"Unexpected error: {ex.Message}");
}
}
I hope this is helpful! Do not hesitate to let me know if you have any other questions.
Please don't forget to close up the thread here by upvoting and accept it as an answer if it is helpful.