websocket.go 1.4 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162
  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/utils/mysqlx"
  13. "sikey.com/websocket/utils/zlog"
  14. )
  15. var configFile = flag.String("f", "./etc/websocket.toml", "the config file")
  16. func main() {
  17. flag.Parse()
  18. config.MustLoadConfig(*configFile)
  19. // Zaplog init
  20. zlog.WithZapLogger(zlog.NewLogger(config.MustLoadLogger()))
  21. app := newApp()
  22. app.Run(fmt.Sprintf(":%d", config.Config.Port))
  23. }
  24. func newApp() *gin.Engine {
  25. app := gin.Default()
  26. // 创建 Websocket 横向拓展应用
  27. // exc := stackexchange.NewStackExchange(
  28. // config.Kafka.Brokers,
  29. // config.Kafka.Topic,
  30. // config.Kafka.Partition,
  31. // config.Kafka.MaxBytes,
  32. // )
  33. srv := &server.Server{
  34. Upgrader: websocket.Upgrader{
  35. ReadBufferSize: 1024,
  36. WriteBufferSize: 1024,
  37. CheckOrigin: func(r *http.Request) bool {
  38. return true
  39. },
  40. },
  41. WriteWait: 10 * time.Second,
  42. ReadWait: 10 * time.Second,
  43. PingWait: 120 * time.Second,
  44. Hub: server.NewHub(server.HubConfig{
  45. ConnectSize: 1024,
  46. DisconnectSize: 1024,
  47. MessageSize: 125,
  48. }),
  49. Repositories: repositories.NewRepositories(mysqlx.ConnectMysql()),
  50. }
  51. app.GET("/websocket/endpoint", func(ctx *gin.Context) { server.WebsocketHandler(ctx, srv) })
  52. return app
  53. }