Movatterモバイル変換


[0]ホーム

URL:


Skip to content

Navigation Menu

Sign in
Appearance settings

Search code, repositories, users, issues, pull requests...

Provide feedback

We read every piece of feedback, and take your input very seriously.

Saved searches

Use saved searches to filter your results more quickly

Sign up
Appearance settings

Minimal and idiomatic WebSocket library for Go

License

NotificationsYou must be signed in to change notification settings

coder/websocket

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Go ReferenceGo Coverage

websocket is a minimal and idiomatic WebSocket library for Go.

Install

go get github.com/coder/websocket

Note

Coder now maintains this project as explained inthis blog post.We're grateful tonhooyr for authoring and maintaining this project from2019 to 2024.

Highlights

Roadmap

See GitHub issues for minor issues but the major future enhancements are:

  • Perfect examples#217
  • wstest.Pipe for in memory testing#340
  • Ping pong heartbeat helper#267
  • Ping pong instrumentation callbacks#246
  • Graceful shutdown helpers#209
  • Assembly for WebSocket masking#16
    • WIP at#326, about 3x faster
  • HTTP/2#4
  • The holy grail#402

Examples

For a production quality example that demonstrates the complete API, see theecho example.

For a full stack example, see thechat example.

Server

http.HandlerFunc(func (w http.ResponseWriter,r*http.Request) {c,err:=websocket.Accept(w,r,nil)iferr!=nil {// ...}deferc.CloseNow()// Set the context as needed. Use of r.Context() is not recommended// to avoid surprising behavior (see http.Hijacker).ctx,cancel:=context.WithTimeout(context.Background(),time.Second*10)defercancel()varvinterface{}err=wsjson.Read(ctx,c,&v)iferr!=nil {// ...}log.Printf("received: %v",v)c.Close(websocket.StatusNormalClosure,"")})

Client

ctx,cancel:=context.WithTimeout(context.Background(),time.Minute)defercancel()c,_,err:=websocket.Dial(ctx,"ws://localhost:8080",nil)iferr!=nil {// ...}deferc.CloseNow()err=wsjson.Write(ctx,c,"hi")iferr!=nil {// ...}c.Close(websocket.StatusNormalClosure,"")

Comparison

gorilla/websocket

Advantages ofgorilla/websocket:

  • Mature and widely used
  • Prepared writes
  • Configurablebuffer sizes
  • No extra goroutine per connection to support cancellation with context.Context. This costs github.com/coder/websocket 2 KB of memory per connection.

Advantages of github.com/coder/websocket:

golang.org/x/net/websocket

golang.org/x/net/websocket is deprecated.Seegolang/go/issues/18152.

Thenet.Conn can help in transitioningto github.com/coder/websocket.

gobwas/ws

gobwas/ws has an extremely flexible API that allows it to be usedin an event driven style for performance. See the author'sblog post.

However it is quite bloated. Seehttps://pkg.go.dev/github.com/gobwas/ws

When writing idiomatic Go, github.com/coder/websocket will be faster and easier to use.

lesismal/nbio

lesismal/nbio is similar to gobwas/ws in that the API isevent driven for performance reasons.

However it is quite bloated. Seehttps://pkg.go.dev/github.com/lesismal/nbio

When writing idiomatic Go, github.com/coder/websocket will be faster and easier to use.


[8]ページ先頭

©2009-2025 Movatter.jp