Constructing pure voice conversations with AI brokers requires complicated infrastructure and many code from engineering groups. Textual content-based agent interactions observe a turn-based sample: a consumer sends a whole request, waits for the agent to course of it, and receives a full response earlier than persevering with. Bi-directional streaming removes this constraint by establishing a persistent connection that carries information in each instructions concurrently.
Amazon Bedrock AgentCore Runtime helps bi-directional streaming for real-time, two-way communication between customers and AI brokers. With this functionality, brokers can concurrently hearken to consumer enter whereas producing responses, making a extra pure conversational circulate. That is significantly well-suited for multimodal interactions, comparable to voice and imaginative and prescient agent conversations. The agent can start responding whereas nonetheless receiving consumer enter, deal with mid-conversation interruptions, and alter its responses primarily based on real-time suggestions.
A bi-directional voice chat agent can conduct spoken conversations with the fluidity of human dialogue in order that customers can interrupt, make clear, or change matters naturally. These brokers course of streaming audio enter and output concurrently whereas sustaining conversational state. Constructing this infrastructure requires managing persistent low-latency connections, dealing with concurrent audio streams, preserving context throughout exchanges, and scaling a number of conversations. Implementing these capabilities from scratch calls for months of engineering effort and specialised real-time programs experience. Amazon Bedrock AgentCore Runtime addresses these challenges by offering a safe, serverless, and purpose-built internet hosting atmosphere for deploying and working AI brokers, with out requiring builders to construct and keep complicated streaming infrastructure themselves.
On this publish, you’ll study bi-directional streaming on AgentCore Runtime and the stipulations to create a WebSocket implementation. Additionally, you will learn to use Strands Brokers to implement a bi-directional streaming answer for voice brokers.
AgentCore Runtime bi-directional streaming
Bi-directional streaming makes use of the WebSocket protocol. WebSocket gives full-duplex communication over a single TCP connection, establishing a persistent channel the place information flows constantly in each instructions. This protocol has broad consumer assist throughout browsers, cell purposes, and server environments, making it accessible for various implementation situations.
When a connection is established, the agent can obtain consumer enter as a stream whereas concurrently sending response chunks again to the consumer. The AgentCore Runtime manages the underlying infrastructure that handles connection, message ordering, and maintains conversational state throughout the bi-directional alternate. This alleviates the necessity for builders to construct customized streaming infrastructure or handle the complexities of concurrent information flows.Voice conversations differ from text-based interactions of their expectation of pure circulate. When talking with a voice agent, customers anticipate the identical conversational dynamics they expertise with people: the flexibility to interrupt when they should appropriate themselves, to interject clarification mid-response, or to redirect the dialog with out awkward pauses.With bi-directional streaming, it’s attainable for voice brokers to course of incoming audio whereas producing responses, detecting interruptions, and adjusting habits in real-time. The agent maintains conversational context all through these interactions, preserving the thread of dialogue even because the dialog shifts path. This functionality additionally helps voice brokers from turn-based programs right into a responsive conversational accomplice.
Past voice conversations, bi-directional streaming has a number of interplay patterns. Interactive debugging classes permit builders to information brokers via problem-solving in real-time, offering suggestions because the agent explores options. Collaborative brokers can work alongside customers on shared duties, receiving steady enter because the work progresses somewhat than ready for full directions. Multi-modal brokers can course of streaming video or sensor information whereas concurrently offering evaluation and suggestions. Async long-running agent operations can course of duties over minutes or hours whereas streaming incremental outcomes to purchasers.
WebSocket implementation
To create a WebSocket implementation in AgentCore Runtime, it is best to observe just a few patterns. Firstly, your containers should implement WebSocket endpoints on port 8080 on the /ws path, which aligns with customary WebSocket server practices. This WebSocket endpoint will allow a single agent container to serve each the normal InvokeAgentRuntime API and the brand new InvokeAgentRuntimeWithWebsocketStream API. Moreover, clients should present a /ping endpoint for well being checks.
Bi-directional streaming utilizing WebSockets on AgentCore Runtime helps purposes utilizing a WebSocket language library. The consumer should hook up with the service endpoint with a WebSocket protocol connection:
You additionally want to make use of one of many supported authentication strategies (SigV4 headers, SigV4 pre-signed URL, or OAuth 2.0) and to ensure that the agent utility implements the WebSocket service contract as laid out in HTTP protocol contract.
Strands bi-directional agent: Simplified voice agent growth
Amazon Nova Sonic unifies speech understanding and technology right into a single mannequin, delivering human-like conversational AI with low latency, main accuracy, and powerful worth efficiency. Its built-in structure gives expressive speech technology and real-time transcription in a single mannequin, dynamically adapting responses primarily based on enter speech prosody, tempo, and timbre.
With bi-directional streaming now additionally out there in AgentCore Runtime, you’ve gotten a number of methods to point out how one can host a voice agent: one may be the direct implementation the place you could managing WebSocket connections, parsing protocol occasions, dealing with audio chunks, and orchestrating async duties; one other is the strands bi-directional agent implementation that abstracts this complexity and implements these steps by itself.
Instance Implementation
On this publish, it is best to consult with the Amazon Bedrock AgentCore bi-directional code, which implements bi-directional communication with Amazon Bedrock AgentCore. The repository has two implementations: One which makes use of native Amazon Nova Sonic Python implementation deployed on to AgentCore Runtime, and a high-level framework implementation utilizing the Strands bi-directional agent for simplified real-time audio conversations.
The next diagram exhibits the native Amazon Nova Sonic Python WebSocket server on to AgentCore. It gives full management over the Nova Sonic protocol with direct occasion dealing with for full visibility into session administration, audio streaming, and response technology.

The Strands bi-directional agent framework for real-time audio conversations with Amazon Nova Sonic gives a high-level abstraction that simplifies bi-directional streaming, computerized session administration, and power integration. The code snippet under is an instance of this simplification.
This implementation demonstrates the simplicity of Strands: instantiate a mannequin, create an agent with instruments and a system immediate, and run it with enter/output streams. The framework handles protocol complexity internally.
The next is the agent declaration part within the code:
Instruments are handed on to the agent’s constructor, and Strands handles perform calling orchestration robotically. In abstract, a local WebSocket implementation of the identical performance requires roughly 150 traces of code, whereas Strands implementation reduces this to roughly 20 traces targeted on enterprise logic. Builders can deal with defining agent habits, integrating instruments, and crafting system prompts somewhat than managing WebSocket connections, parsing occasions, dealing with audio chunks, or orchestrating async duties. This makes bi-directional streaming accessible to builders with out specialised real-time programs experience whereas sustaining full entry to the audio dialog capabilities of Nova Sonic. The Strands bi-directional function is presently solely supported for the Python SDK. If you’re searching for flexibility within the implementation of your voice agent, the native Amazon Nova Sonic implementation may help you. Additionally, this may be vital for the circumstances the place you’ve gotten a number of totally different patterns of communication from agent to mannequin. With Amazon Nova Sonic implementation it is possible for you to to manage each step of the method with full management. The framework method can present higher management of dependencies, as a result of it’s finished by the SDK, and gives consistency throughout programs. The identical Strands bi-directional agent code construction works with Nova Sonic, OpenAI Realtime API, and Google Gemini Dwell builders merely swap the mannequin implementation whereas retaining the remainder of their code unchanged.
Conclusion
The bi-directional streaming functionality of Amazon Bedrock AgentCore Runtime transforms how builders can construct conversational AI brokers. By offering WebSocket-based real-time communication infrastructure, AgentCore removes months of engineering effort required to implement streaming programs from scratch. The framework runtime permits builders to deploy a number of varieties of voice brokers—from native protocol implementations utilizing Amazon Nova Sonic to high-level frameworks just like the Strands bi-directional agent—inside the identical safe, serverless atmosphere.
Concerning the authors
Lana Zhang is a Senior Specialist Options Architect for Generative AI at AWS inside the Worldwide Specialist Group. She makes a speciality of AI/ML, with a deal with use circumstances comparable to AI voice assistants and multimodal understanding. She works intently with clients throughout various industries, together with media and leisure, gaming, sports activities, promoting, monetary companies, and healthcare, to assist them rework their enterprise options via AI.
Phelipe Fabres is a Senior Specialist Options Architect for Generative AI at AWS for Startups. He makes a speciality of AI/ML with a deal with Agentic programs and the complete course of of coaching/inference. He has greater than 10 years of working with software program growth, from monolith to event-driven architectures with a Ph.D. in Graph Concept.
Evandro Franco is an Sr. Knowledge Scientist engaged on Amazon Net Providers. He’s a part of the International GTM staff that helps AWS clients overcome enterprise challenges associated to AI/ML on prime of AWS, primarily on Amazon Bedrock AgentCore and Strands Brokers. He has greater than 18 years of expertise working with expertise, from software program growth, infrastructure, serverless, to machine studying. In his free time, Evandro enjoys taking part in together with his son, primarily constructing some humorous Lego bricks.


