What is difference between grpc and websocket? Which one is more suitable for bidirectional streaming connection?

RestWebsocketRpcGrpcHttp2

Rest Problem Overview


I want to develop a client-server application in a bi-directional streaming manner.

what is more suitable technology for this, grpc or websocket?

Rest Solutions


Solution 1 - Rest

gRPC is not really the relevant part for comparison, it's that gRPC uses HTTP/2 which can certainly be compared to WebSockets.

https://www.infoq.com/articles/websocket-and-http2-coexist

This article outlines them quite well. Essentially, HTTP/2 is Client/Server with Server Push on the background, so you can make your request and simply stay on that connection listening for updates without the need for polling, for example.

Whilst WebSockets are not going away because of HTTP/2, they might not be considered necessary for use cases that center around "let me know when updates happen related to the thing I just did".

Solution 2 - Rest

gRPC is an API/Protocol on top of HTTP/2, so it is more relevant to compare HTTP/2 and Websockets.

Note: HTTP/2 Server Push is not relevant here either. That is a website optimization technique for cacheable (GET) resources.

Websocket and HTTP/2 support binary data frames with low overhead (a few bytes), however frames (whole payload) in Websocket is masked at sender and then unmasked at receiver. See What is the mask in a WebSocket frame?.

With HTTP/2 you can have multiple streams multiplexed over the same connection. This need to be handled by application developer or a library when using Websocket - if desired.

If your client is a browser, the answer to HTTP/2 or Websockets for low latency client to server messages may be relevant.

Attributions

All content for this solution is sourced from the original question on Stackoverflow.

The content on this page is licensed under the Attribution-ShareAlike 4.0 International (CC BY-SA 4.0) license.

Content TypeOriginal AuthorOriginal Content on Stackoverflow
Questionprashant sindhuView Question on Stackoverflow
Solution 1 - RestPhil SturgeonView Answer on Stackoverflow
Solution 2 - RestJonasView Answer on Stackoverflow