mirror of
https://github.com/open-webui/open-webui.git
synced 2026-05-06 19:08:59 -05:00
[PR #22107] [MERGED] perf: async DB calls, skip intermediate status writes, elif chain in event emitter #49538
Reference in New Issue
Block a user
Delete Branch "%!s()"
Deleting a branch is permanent. Although the deleted branch may continue to exist for a short time before it actually gets removed, it CANNOT be undone in most cases. Continue?
📋 Pull Request Information
Original PR: https://github.com/open-webui/open-webui/pull/22107
Author: @Classic298
Created: 3/1/2026
Status: ✅ Merged
Merged: 3/1/2026
Merged by: @tjbck
Base:
dev← Head:perf/async-event-emitter-db📝 Commits (1)
f52480fperf: async DB calls, skip intermediate status writes, elif chain in event emitter📊 Changes
1 file changed (+37 additions, -21 deletions)
View changed files
📝
backend/open_webui/socket/main.py(+37 -21)📄 Description
Three improvements to the socket event emitter hot path (when realtime chat save is enabled):
Wrap all synchronous Chats.* DB calls in asyncio.to_thread() to avoid blocking the event loop during streaming. With N concurrent users, sync DB calls serialize all writes and block socket event delivery.
Only persist final (done=True) status events to DB. Intermediate statuses (tool calling progress, web search progress, etc.) are ephemeral UI-only data already delivered via socket — writing every one to DB is unnecessary I/O.
Convert if/if/if chain to if/elif since event types are mutually exclusive, avoiding unnecessary string comparisons after a match.
Contributor License Agreement
By submitting this pull request, I confirm that I have read and fully agree to the Contributor License Agreement (CLA), and I am providing my contributions under its terms.
🔄 This issue represents a GitHub Pull Request. It cannot be merged through Gitea due to API limitations.