-
Notifications
You must be signed in to change notification settings - Fork 5.4k
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
[Feature Request]: Add proper async support #10590
Comments
🤖 It's great to see your interest in adding proper async support to the repository! Your insights into the current implementation and the Pythonic way of handling async are valuable. If you're willing to contribute a solution or propose a fix for this feature, it would be a fantastic addition to the repository. Your expertise in async frameworks could really benefit the community. Keep up the good work!
|
The error about nested asyncio can be resolved with
The error about uvloop is solved by telling fastapi to set the loop-type to asyncio I agree, a proper |
As a workaround, the ingestion pipeline has async support which works nicely https://docs.llamaindex.ai/en/stable/module_guides/loading/ingestion_pipeline/root.html |
I'd actually like to chime in and say this issue could be expanded to the replacement of from what I can tell, I'm not quite sure on the perfect setup, but requiring nest_asyncio is breaking erdewit/nest_asyncio#90 I made an issue there, I'd like to see what's causing it. |
Just to add to this, there's definitely some funky crap going on with Python's async implementation. If you'd like to experience it, make a discord bot, make it async (using discord.py for instance which runs off of asyncio) and then make a bunch of calls, it'll eventually start to do this weird lagging thing where it's doing things, and not erroring, but it's like it's spawning a bunch of child processes it's not finishing |
Feature Description
Async doesn't seem to be supported. Calling
VectorStoreIndex.from_documents(documents, storage_context, use_async=True)
results in an error about using asyncio.run in a nested context. If you use nest_asyncio you get an error about the coroutine that actually does the work not being awaited. Or maybe you get an error about how uvloop isn't patchable.If you muck around with things, you eventually find that it does all this in a sync session, so now you have to maintain logic for both sync and async sessions, which is needed if you need to, for example, provide the cert of the server you're connecting to.
Reason
In general, the Pythonic way to do async support is to create an async version of something, either a class or method. Keyword arguments are not standard practice and are counter-productive to static typing when it works correctly (which it does not here). The issue is that for some reason its using asyncio as an implementation detail rather than approaching the problem as "I'm running in an async context".
Value of Feature
I use an async framework.
The text was updated successfully, but these errors were encountered: