-
-
Notifications
You must be signed in to change notification settings - Fork 751
Streaming websockets's message with WebSocketStreamingProtocol
Jonathan Paugh edited this page Feb 3, 2016
·
3 revisions
By default, Atmosphere's WebSocket implementation will buffer websocket message of size up to 2 Mb. If your application is planning to send messages of larger size, it is recommended to stream those bytes instead of letting Atmosphere to read them in memory. The first task is to add, in web.xml
<init-param>
<param-name>org.atmosphere.websocket.WebSocketProtocol</param-name>
<param-value>org.atmosphere.websocket.protocol.StreamingHttpProtocol</param-value>
</init-param>
Note that this Protocol is only available with Atmosphere 2.1. If you are using a lower version, just write your own Protocol by copying this class.
Next, instead of writing a WebSocketHandler, write an WebSocketProtocolStream so you can manipulate the stream directly, without any buffering from Atmosphere.
- Understanding Atmosphere
- Understanding @ManagedService
- Using javax.inject.Inject and javax.inject.PostConstruct annotation
- Understanding Atmosphere's Annotation
- Understanding AtmosphereResource
- Understanding AtmosphereHandler
- Understanding WebSocketHandler
- Understanding Broadcaster
- Understanding BroadcasterCache
- Understanding Meteor
- Understanding BroadcastFilter
- Understanding Atmosphere's Events Listeners
- Understanding AtmosphereInterceptor
- Configuring Atmosphere for Performance
- Understanding JavaScript functions
- Understanding AtmosphereResourceSession
- Improving Performance by using the PoolableBroadcasterFactory
- Using Atmosphere Jersey API
- Using Meteor API
- Using AtmosphereHandler API
- Using Socket.IO
- Using GWT
- Writing HTML5 Server-Sent Events
- Using STOMP protocol
- Streaming WebSocket messages
- Configuring Atmosphere's Classes Creation and Injection
- Using AtmosphereInterceptor to customize Atmosphere Framework
- Writing WebSocket sub protocol
- Configuring Atmosphere for the Cloud
- Injecting Atmosphere's Components in Jersey
- Sharing connection between Browser's windows and tabs
- Understanding AtmosphereResourceSession
- Manage installed services
- Server Side: javadoc API
- Server Side: atmosphere.xml and web.xml configuration
- Client Side: atmosphere.js API