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

Python: Bug: 404-resource-not-found error when using kernel.invoke from Azure web app #10040

Closed
Shavivek opened this issue Dec 30, 2024 · 7 comments
Assignees
Labels
bug Something isn't working python Pull requests for the Python Semantic Kernel

Comments

@Shavivek
Copy link

Shavivek commented Dec 30, 2024

Describe the bug
I have a Django web app (python stack) that has few features which use Azure OAI models using semantic-kernel. My app works perfectly on local machine but when I deploy it to Azure web service, the Azure OAI capabilities fail with the error: Error code: 404 - {'error': {'code': '404', 'message': 'Resource not found'}}

To Reproduce
Steps to reproduce the behavior:
I am unable to reproduce the issue locally. My app has 2 main files:

  1. To get a kernel configured.
    def getKernel():

    kernel = Kernel()

    if 'WEBSITE_HOSTNAME' not in os.environ:
    config_file = "app_settings.config"
    config_object = ConfigParser()
    config_object.read(config_file)
    deployment = config_object['azureOpenAI']['AZURE_OPENAI_DEPLOYMENT_NAME']
    api_key=config_object['azureOpenAI']['AZURE_OPENAI_API_KEY']
    endpoint=config_object['azureOpenAI']['AZURE_OPENAI_ENDPOINT']

    else:
    deployment = os.environ['AZURE_OPENAI_DEPLOYMENT_NAME']
    api_key=os.environ['AZURE_OPENAI_API_KEY']
    endpoint=os.environ['AZURE_OPENAI_ENDPOINT']

    service_id = "default"

    kernel.add_service(AzureChatCompletion(
    deployment_name=deployment,
    api_key=api_key,
    endpoint=endpoint, # Used to point to your service
    service_id=service_id,
    ))
    return kernel

and 2 - files that call into semantic functions to get response from OpenAI models.
async def getSpendDetailsLLM(mssg):

kernel = sk.getKernel()

# Get entity Semantic function from the plugin directory
getSpendDetails = kernel.add_plugin(parent_directory=plugins_directory, plugin_name="ExpensePlugin")
getSpendDetailsFunc = getSpendDetails["SpendDetails"]

# Get required entities from message
spendDetails = await kernel.invoke(function=getSpendDetailsFunc, arguments=KernelArguments(mssg=mssg))
# print (spendDetails)
spendDetailsJson = json.loads(str(spendDetails))
return spendDetailsJson

The statement above "await kernel.invoke" causes exception when executed from the Azure instance but works as expected when works locally.
Traceback (most recent call last):
File "/tmp/8dd28badf0397ed/antenv/lib/python3.12/site-packages/semantic_kernel/connectors/ai/open_ai/services/open_ai_handler.py", line 51, in _send_request
response = await self.client.chat.completions.create(**request_settings.prepare_settings_dict())
File "/tmp/8dd28badf0397ed/antenv/lib/python3.12/site-packages/openai/resources/chat/completions.py", line 1289, in create
return await self._post(
File "/tmp/8dd28badf0397ed/antenv/lib/python3.12/site-packages/openai/_base_client.py", line 1805, in post
return await self.request(cast_to, opts, stream=stream, stream_cls=stream_cls)
File "/tmp/8dd28badf0397ed/antenv/lib/python3.12/site-packages/openai/_base_client.py", line 1503, in request
return await self._request(
File "/tmp/8dd28badf0397ed/antenv/lib/python3.12/site-packages/openai/_base_client.py", line 1599, in _request
raise self._make_status_error_from_response(err.response) from None

The above exception (Error code: 404 - {'error': {'code': '404', 'message': 'Resource not found'}}) was the direct cause of the following exception:
File "/tmp/8dd28badf0397ed/antenv/lib/python3.12/site-packages/semantic_kernel/functions/kernel_function_from_prompt.py", line 178, in _invoke_internal
chat_message_contents = await prompt_render_result.ai_service.get_chat_message_contents(
File "/tmp/8dd28badf0397ed/antenv/lib/python3.12/site-packages/semantic_kernel/connectors/ai/open_ai/services/open_ai_chat_completion_base.py", line 111, in get_chat_message_contents
return await self._send_chat_request(settings)
File "/tmp/8dd28badf0397ed/antenv/lib/python3.12/site-packages/semantic_kernel/connectors/ai/open_ai/services/open_ai_chat_completion_base.py", line 272, in _send_chat_request
response = await self._send_request(request_settings=settings)
File "/tmp/8dd28badf0397ed/antenv/lib/python3.12/site-packages/semantic_kernel/connectors/ai/open_ai/services/open_ai_handler.py", line 67, in _send_request
raise ServiceResponseException(

The above exception (("<class 'semantic_kernel.connectors.ai.open_ai.services.azure_chat_completion.AzureChatCompletion'> service failed to complete the prompt", NotFoundError("Error code: 404 - {'error': {'code': '404', 'message': 'Resource not found'}}"))) was the direct cause of the following exception:
File "/tmp/8dd28badf0397ed/antenv/lib/python3.12/site-packages/semantic_kernel/kernel.py", line 180, in invoke
return await function.invoke(kernel=self, arguments=arguments, metadata=metadata)
File "/tmp/8dd28badf0397ed/antenv/lib/python3.12/site-packages/semantic_kernel/functions/kernel_function.py", line 211, in invoke
await stack(function_context)
File "/tmp/8dd28badf0397ed/antenv/lib/python3.12/site-packages/semantic_kernel/functions/kernel_function_from_prompt.py", line 184, in _invoke_internal
raise FunctionExecutionException(f"Error occurred while invoking function {self.name}: {exc}") from exc

The above exception (Error occurred while invoking function SpendDetails: ("<class 'semantic_kernel.connectors.ai.open_ai.services.azure_chat_completion.AzureChatCompletion'> service failed to complete the prompt", NotFoundError("Error code: 404 - {'error': {'code': '404', 'message': 'Resource not found'}}"))) was the direct cause of the following exception:
File "/tmp/8dd28badf0397ed/antenv/lib/python3.12/site-packages/django/core/handlers/exception.py", line 47, in inner
response = get_response(request)
File "/tmp/8dd28badf0397ed/antenv/lib/python3.12/site-packages/django/core/handlers/base.py", line 181, in _get_response
response = wrapped_callback(request, *callback_args, **callback_kwargs)
File "/tmp/8dd28badf0397ed/antenv/lib/python3.12/site-packages/django/contrib/auth/decorators.py", line 21, in _wrapped_view
return view_func(request, *args, **kwargs)
File "/tmp/8dd28badf0397ed/antenv/lib/python3.12/site-packages/django/views/generic/base.py", line 69, in view
return self.dispatch(request, *args, **kwargs)
File "/tmp/8dd28badf0397ed/antenv/lib/python3.12/site-packages/django/views/generic/base.py", line 101, in dispatch
return handler(request, *args, **kwargs)
File "/tmp/8dd28badf0397ed/antenv/lib/python3.12/site-packages/django/views/generic/edit.py", line 170, in get
return super().get(request, *args, **kwargs)
File "/tmp/8dd28badf0397ed/antenv/lib/python3.12/site-packages/django/views/generic/edit.py", line 135, in get
return self.render_to_response(self.get_context_data())
File "/tmp/8dd28badf0397ed/spend/viewClasses/smsProcessviews.py", line 295, in get_context_data
context = super(SMSRecordCreateViewLLM, self).get_context_data(**kwargs)
File "/tmp/8dd28badf0397ed/antenv/lib/python3.12/site-packages/django/views/generic/edit.py", line 68, in get_context_data
kwargs['form'] = self.get_form()
File "/tmp/8dd28badf0397ed/antenv/lib/python3.12/site-packages/django/views/generic/edit.py", line 35, in get_form
return form_class(**self.get_form_kwargs())
File "/tmp/8dd28badf0397ed/spend/viewClasses/smsProcessviews.py", line 385, in get_form_kwargs
kwargs = super(SMSRecordCreateViewLLM, self).get_form_kwargs()
File "/tmp/8dd28badf0397ed/antenv/lib/python3.12/site-packages/django/views/generic/edit.py", line 107, in get_form_kwargs
kwargs = super().get_form_kwargs()
File "/tmp/8dd28badf0397ed/antenv/lib/python3.12/site-packages/django/views/generic/edit.py", line 40, in get_form_kwargs
'initial': self.get_initial(),
File "/tmp/8dd28badf0397ed/spend/viewClasses/smsProcessviews.py", line 316, in get_initial
smsDetails = asyncio.run(lu.getSpendDetailsLLM(sms))
File "/opt/python/3.12.2/lib/python3.12/asyncio/runners.py", line 194, in run
return runner.run(main)
File "/opt/python/3.12.2/lib/python3.12/asyncio/runners.py", line 118, in run
return self._loop.run_until_complete(task)
File "/opt/python/3.12.2/lib/python3.12/asyncio/base_events.py", line 685, in run_until_complete
return future.result()
File "/tmp/8dd28badf0397ed/azureOAI/llmExpense.py", line 112, in getSpendDetailsLLM
spendDetails = await kernel.invoke(function=getSpendDetailsFunc, arguments=KernelArguments(mssg=msgg))
File "/tmp/8dd28badf0397ed/antenv/lib/python3.12/site-packages/semantic_kernel/kernel.py", line 189, in invoke
raise KernelInvokeException(

Exception Type: KernelInvokeException at /spend/sms/new/3096
Exception Value: Error occurred while invoking function: 'ExpensePlugin-SpendDetails'

I have ensured that the env variables for API-version, Deployment-name etc. in config on local machine and on azure are same.

Expected behavior
The functions should behave same when executed locally or from Azure instance.

Screenshots
If applicable, add screenshots to help explain your problem.

Platform

  • OS: Localmachine: Windows, Azure: Linux
  • IDE: VSCode
  • Language: Python 3.12 on Linux
  • Source: semantic-kernel==1.1.2
@Shavivek Shavivek added the bug Something isn't working label Dec 30, 2024
@markwallace-microsoft markwallace-microsoft added python Pull requests for the Python Semantic Kernel triage labels Dec 30, 2024
@github-actions github-actions bot changed the title Bug: 404-resource-not-found error when using kernel.invoke from Azure web app Python: Bug: 404-resource-not-found error when using kernel.invoke from Azure web app Dec 30, 2024
@evchaki
Copy link
Contributor

evchaki commented Jan 2, 2025

@moonbox3 / @eavanvalkenburg can you take a look?

@evchaki evchaki removed the triage label Jan 2, 2025
@alliscode
Copy link
Member

Hi @Shavivek, without being able to debug the code, my best guess would be some of the environment variables are not being configured correctly...

deployment = os.environ['AZURE_OPENAI_DEPLOYMENT_NAME']
api_key=os.environ['AZURE_OPENAI_API_KEY']
endpoint=os.environ['AZURE_OPENAI_ENDPOINT']

Could you add logging to verify that these environment variables are being set as expected in your deployment?

@alliscode alliscode removed the python Pull requests for the Python Semantic Kernel label Jan 2, 2025
@moonbox3 moonbox3 self-assigned this Jan 6, 2025
@moonbox3 moonbox3 added the python Pull requests for the Python Semantic Kernel label Jan 6, 2025
@moonbox3
Copy link
Contributor

moonbox3 commented Jan 6, 2025

Hi @Shavivek, is this accurate: Source: semantic-kernel==1.1.2? Can you please try to use our latest package version 1.17.1? If you are indeed using 1.1.2, that is a very old package from about May of 2024. :)

In any case, as @alliscode mentioned, adding some logging can help -- it does look like something may be amiss with the environment variables that are configured in Azure -- if it's working locally, and it's not working in the cloud, then there should be some discrepancy. There very well could be a bug in the old package version (1.1.2) as well, so please do upgrade and let us know if that fixes it.

Thanks!

@Shavivek
Copy link
Author

Shavivek commented Jan 6, 2025

@moonbox3 When I upgrade to semantic-kernel 1.17.1 and had to upgrade open-ai package also to 1.59.3. But even after that, I get the same error message.

This is the POST URL that gets generated:

<Request('POST', 'https://xxxxxx-yyyyyy.openai.azure.com/openai/deployments/gpt-4o-mini/chat/completions?api-version=2024-07-18')>

@moonbox3
Copy link
Contributor

moonbox3 commented Jan 7, 2025

Hello @Shavivek, thanks for your response. I am not seeing the api-version 2024-07-18 listed for Azure OpenAI. Can you please try a valid API version, like 2024-07-01-preview or something newer? Thanks.

@Shavivek
Copy link
Author

Shavivek commented Jan 9, 2025

@moonbox3 thanks for this hint. I updated the API version to 2024-08-01-preview and it started working. However, the code on my local box can still work with the older version...

@moonbox3
Copy link
Contributor

moonbox3 commented Jan 9, 2025

That's interesting. I don't see any 2024-07-18 API version from Azure (maybe I'm missing something). In any case, I'd stick with a known API version as you've done (2024-08-01-preview) and that should work well going forward. You may also need to use 2024-09-01-preview depending upon your scenario.

@moonbox3 moonbox3 closed this as completed Jan 9, 2025
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
bug Something isn't working python Pull requests for the Python Semantic Kernel
Projects
None yet
Development

No branches or pull requests

5 participants