server.go 2.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151
  1. package main
  2. import (
  3. "fmt"
  4. "os"
  5. "path/filepath"
  6. "sync"
  7. "gopkg.in/ini.v1"
  8. "hnyfkj.com.cn/rtu/linux/baseapp"
  9. "hnyfkj.com.cn/rtu/linux/sshd"
  10. )
  11. const MODULE_NAME = sshd.MODULE_NAME
  12. type MQTTBroker struct {
  13. Address string `ini:"BrokerAddress"` // 地址端口
  14. Username string `ini:"Username"` // 用户名称
  15. Password string `ini:"Password"` // 接入密码
  16. }
  17. type Config struct {
  18. MQTTSrv MQTTBroker `ini:"MQTTSrv"`
  19. }
  20. var (
  21. CfgServers = &Config{}
  22. Version = "1.0.0.2"
  23. )
  24. func loadCfgServers() error {
  25. cfgFile := filepath.Join(baseapp.CFG_DIR, "sshd_cfg.ini")
  26. cfgIni, err := ini.Load(cfgFile)
  27. if err != nil {
  28. return err
  29. }
  30. if cfgIni.HasSection("MQTTSrv") {
  31. if err := cfgIni.Section("MQTTSrv").MapTo(&CfgServers.MQTTSrv); err != nil {
  32. return err
  33. }
  34. } else {
  35. return fmt.Errorf("配置文件\"%s\"缺少\"[MQTTSrv]\"节", cfgFile)
  36. }
  37. return nil
  38. }
  39. func main() {
  40. baseapp.InitPath()
  41. if err := EnsureSSHDConfig(); err != nil {
  42. fmt.Printf("[YFKJ_SSHD] ensure config failed: %v\n", err)
  43. os.Exit(1)
  44. }
  45. cfgFile := filepath.Join(baseapp.CFG_DIR, "sshd_cfg.ini")
  46. baseapp.InitLogger(cfgFile)
  47. baseapp.SingleInstanceRun() // 异步非阻塞
  48. baseapp.Logger.Infof("程序版本: %s 构建时间: %s\n程序开始运行...",
  49. Version, baseapp.BuildTime)
  50. if err := loadCfgServers(); err != nil {
  51. baseapp.Logger.Errorf("[%s] 加载服务器配置项失败: %v!!", MODULE_NAME, err)
  52. return
  53. }
  54. success := sshd.ModuleInit(CfgServers.MQTTSrv.Address, CfgServers.MQTTSrv.Username, CfgServers.MQTTSrv.Password)
  55. if !success {
  56. return
  57. }
  58. <-baseapp.IsExit2()
  59. sshd.ModuleExit()
  60. baseapp.Logger.Info("程序退出")
  61. baseapp.ExitLogger() // 安全的关闭日志模块
  62. baseapp.SafeExit() // 安全的关闭退出程序
  63. }
  64. const defaultSSHDCfg = `[Log]
  65. ; 日志级别: trace、debug、info、warn、error、fatal、panic
  66. Level = info
  67. ; 输出目标: console(控制台)、file(文件)、all(控制台+文件)
  68. Target = file
  69. ; 每个日志文件的最大大下, 以"MB"为单位
  70. MaxFileSize = 5
  71. ; 保留的最大备份文件数量
  72. MaxBackupFileCnts = 1
  73. [MQTTSrv]
  74. ; 地址端口
  75. BrokerAddress = tcp://8.136.98.49:61883
  76. ; 用户名称
  77. Username = user
  78. ; 接入密码
  79. Password = f335bf402c655ee5fd2b5300905124e
  80. `
  81. var (
  82. initCfgOnce sync.Once
  83. initCfgErr error
  84. )
  85. func EnsureSSHDConfig() error {
  86. initCfgOnce.Do(func() {
  87. initCfgErr = ensureSSHDConfig()
  88. })
  89. return initCfgErr
  90. }
  91. func ensureSSHDConfig() error {
  92. cfgFile := filepath.Join(
  93. baseapp.CFG_DIR,
  94. "sshd_cfg.ini",
  95. )
  96. if err := os.MkdirAll(
  97. baseapp.CFG_DIR,
  98. 0755,
  99. ); err != nil {
  100. return err
  101. }
  102. f, err := os.OpenFile(
  103. cfgFile,
  104. os.O_CREATE|os.O_EXCL|os.O_WRONLY,
  105. 0644,
  106. )
  107. if err != nil {
  108. if os.IsExist(err) {
  109. return nil
  110. }
  111. return err
  112. }
  113. defer func() {
  114. _ = f.Close()
  115. }()
  116. if _, err = f.WriteString(defaultSSHDCfg); err != nil {
  117. _ = os.Remove(cfgFile)
  118. return err
  119. }
  120. if err = f.Close(); err != nil {
  121. _ = os.Remove(cfgFile)
  122. return err
  123. }
  124. return nil
  125. }