config.go 2.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263
  1. package config
  2. const (
  3. // 系统错误号定义,最低号为110,最高127
  4. MIN_SYSTEM_ERROR_CODE = 110 // 系统信息最小值
  5. NEXT_SUBSCRIBE = 111
  6. NEXT_SUBSCRIBE_MSG = "NEXT SUBSCRIBE"
  7. NEXT_MIDDLE = 112
  8. NEXT_MIDDLE_MSG = "NEXT MIDDLE"
  9. FORBIDDEN = 120
  10. FORBIDDEN_MSG = "FORBIDDEN"
  11. SYSTEM_ERROR = 123
  12. SYSTEM_ERROR_MSG = "SYSTEM ERROR"
  13. GET_TIMEOUT = 124
  14. GET_TIMEOUT_MSG = "GET TIMEOUT"
  15. CONNECT_NO_MATCH = 125
  16. CONNECT_NO_MATCH_MSG = "CONNECT NO MATCH"
  17. CONNECT_END = 126
  18. CONNECT_END_MSG = "CONNECT END"
  19. NO_MATCH = 127
  20. NO_MATCH_MSG = "NO MATCH"
  21. MAX_SYSTEM_ERROR_CODE = 127 //系统信息最大值
  22. )
  23. // 定义成功与失败的值
  24. const STATE_OK = 1
  25. const STATE_FAILED = 0
  26. const (
  27. // ID 号最高值,高于这个值的ID号为系统内部使用
  28. ID_MAX = 65500
  29. // 验证ID
  30. ID_AUTH = 65502
  31. )
  32. // 全局配置
  33. type Config struct {
  34. ConnectTimeout int // 没有收到数据包的连接超时时间(ms)
  35. PingInterval int // 发送ping包的时间间隔,前提是没有收到数据包(ms)
  36. WriteWait int // 写入网络数据等待最长时间(ms)
  37. ReadWait int // 获取命令数据超时时间 (ms)
  38. LongReadWait int // 长时间等待读取数据的超时时间(ms)
  39. CleanDeadConnectWait int // 清理异常的连接(ms)
  40. PrintPing bool // 打印连接ping包
  41. PrintMsg bool // 打印数据包
  42. ProxyTimeout int // 代理方式下,连接超过这个时间将进行一次直连尝试,如为0表示不启用
  43. }
  44. // 获取实例好的配置
  45. func NewConfig() *Config {
  46. // 配置基础的数据
  47. return &Config{
  48. ConnectTimeout: 30 * 1000,
  49. PingInterval: 61 * 1000,
  50. WriteWait: 60 * 1000,
  51. ReadWait: 30 * 1000,
  52. LongReadWait: 150 * 1000,
  53. CleanDeadConnectWait: 3600 * 1000,
  54. PrintPing: true,
  55. PrintMsg: true,
  56. ProxyTimeout: 3600 * 1000,
  57. }
  58. }