websocket.go 1.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768
  1. package main
  2. import (
  3. "flag"
  4. "fmt"
  5. "net/http"
  6. "time"
  7. "github.com/gin-gonic/gin"
  8. "github.com/gorilla/websocket"
  9. "sikey.com/websocket/config"
  10. "sikey.com/websocket/repositories"
  11. "sikey.com/websocket/server"
  12. "sikey.com/websocket/stackexchange"
  13. "sikey.com/websocket/utils/mysqlx"
  14. "sikey.com/websocket/utils/zlog"
  15. )
  16. var configFile = flag.String("f", "./etc/websocket.toml", "the config file")
  17. func main() {
  18. flag.Parse()
  19. config.MustLoadConfig(*configFile)
  20. // Zaplog init
  21. zlog.WithZapLogger(zlog.NewLogger(config.MustLoadLogger()))
  22. app := newApp()
  23. app.Run(fmt.Sprintf(":%d", config.Config.Port))
  24. }
  25. func newApp() *gin.Engine {
  26. app := gin.Default()
  27. // 创建 Websocket 横向拓展应用
  28. exc := stackexchange.NewStackExchange(
  29. config.Kafka.Brokers,
  30. config.Kafka.Topic,
  31. config.Kafka.Partition,
  32. config.Kafka.MaxBytes,
  33. )
  34. srv := &server.Server{
  35. Upgrader: websocket.Upgrader{
  36. ReadBufferSize: 1024,
  37. WriteBufferSize: 1024,
  38. CheckOrigin: func(r *http.Request) bool {
  39. return true
  40. },
  41. },
  42. WriteWait: 10 * time.Second,
  43. ReadWait: 10 * time.Second,
  44. PongWait: 20 * time.Second,
  45. // 写 ping 帧周期(必须小于 pongWait), 54s
  46. // PingWait: (600 * time.Second) * 9 / 10,
  47. // (pongWait * 9) / 10
  48. PingWait: 13 * time.Second,
  49. Hub: server.NewHub(server.HubConfig{
  50. ConnectSize: 1024,
  51. DisconnectSize: 1024,
  52. MessageSize: 125,
  53. StackExchange: exc,
  54. }),
  55. Repositories: repositories.NewRepositories(mysqlx.ConnectMysql()),
  56. }
  57. app.GET("/websocket/endpoint", func(ctx *gin.Context) { server.WebsocketHandler(ctx, srv) })
  58. return app
  59. }