myData.go 6.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269
  1. package initialize
  2. import (
  3. "encoding/hex"
  4. "log"
  5. "net"
  6. "os"
  7. "runtime"
  8. "runtime/debug"
  9. "server/dao"
  10. "server/logger"
  11. "server/modbus"
  12. "server/model"
  13. "server/service"
  14. "server/utils"
  15. "strconv"
  16. "strings"
  17. "sync"
  18. "syscall"
  19. "time"
  20. )
  21. type ModbusHandler struct {
  22. queue *modbus.MlQueue
  23. }
  24. var _handlerOnce sync.Once
  25. var _handlerSingle *ModbusHandler
  26. func GetHandler() *ModbusHandler {
  27. _handlerOnce.Do(func() {
  28. _handlerSingle = &ModbusHandler{
  29. queue: modbus.NewQueue(10000),
  30. }
  31. })
  32. return _handlerSingle
  33. }
  34. func InitInductanceTCP() {
  35. lis, err := net.Listen("tcp", ":60001")
  36. if err != nil {
  37. logger.Get().Println(err)
  38. } else {
  39. logger.Get().Println(lis)
  40. model.InductanceTCP = lis
  41. logger.Get().Println("inductanceTCP启动成功")
  42. }
  43. go StartInductanceTCP()
  44. }
  45. func StartInductanceTCP() {
  46. logger.Get().Println("进入StartInductanceTCP")
  47. handler := GetHandler()
  48. for {
  49. logger.Get().Println("进入InductanceTCP循环")
  50. conn, err := model.InductanceTCP.Accept()
  51. if err != nil {
  52. log.Println(err)
  53. }
  54. remoteAddr := conn.RemoteAddr().String()
  55. logger.Get().Printf("lis Accept conn = %s\n", remoteAddr)
  56. model.Mutex.Lock()
  57. if _, exists := model.ConnectionMap[remoteAddr]; exists {
  58. log.Printf("Connection from %s already exists, closing new connection\n", remoteAddr)
  59. conn.Close()
  60. model.Mutex.Unlock()
  61. continue
  62. }
  63. deviceId, err := GetDeviceId(conn)
  64. if err != nil {
  65. log.Println("Error getting device ID:", err)
  66. conn.Close()
  67. model.Mutex.Unlock()
  68. continue
  69. }
  70. model.ConnectionMap[deviceId] = conn
  71. model.Mutex.Unlock()
  72. //用新的协程处理新的连接
  73. go handler.ReadAndHandle(conn, deviceId)
  74. go handler.Handler()
  75. }
  76. }
  77. func GetDeviceId(conn net.Conn) (id string, err error) {
  78. // 发送 Modbus RTU 帧
  79. //FE 04 03 EE 00 08 85 B2
  80. data, err := utils.WriteAndReadDevice(modbus.ReadDeviceId, conn, 9, 2)
  81. if err != nil {
  82. return
  83. }
  84. return string(data), err
  85. }
  86. func (o *ModbusHandler) ReadAndHandle(conn net.Conn, deviceId string) {
  87. for {
  88. buffer := make([]byte, 1024)
  89. n, err := conn.Read(buffer)
  90. if err != nil {
  91. if isConnReset(err) {
  92. logger.Get().Error("连接被远程主机强制关闭")
  93. } else if os.IsTimeout(err) {
  94. logger.Get().Error("读取操作超时")
  95. } else {
  96. // 处理其他类型的错误
  97. logger.Get().Errorf("读取错误: %s\n", err)
  98. }
  99. return
  100. }
  101. queueData := model.QueueData{
  102. Id: deviceId,
  103. Value: buffer[:n],
  104. }
  105. ok, cnt := o.queue.Put(&queueData)
  106. if ok {
  107. continue
  108. } else {
  109. logger.Get().Errorf("HandlerData:查询队列失败,队列消息数量:%d", cnt)
  110. runtime.Gosched()
  111. }
  112. }
  113. }
  114. func isConnReset(err error) bool {
  115. if opErr, ok := err.(*net.OpError); ok {
  116. if opErr.Err == syscall.ECONNRESET {
  117. return true // Unix-like 系统上的 ECONNRESET
  118. } else if runtime.GOOS == "windows" {
  119. // Windows 上的 WSAECONNRESET 通常是通过错误消息识别的
  120. if se, ok := opErr.Err.(*os.SyscallError); ok {
  121. if errno, ok := se.Err.(syscall.Errno); ok {
  122. if errno == 10054 { // 10054 对应 WSAECONNRESET
  123. return true
  124. }
  125. }
  126. } else if strings.Contains(opErr.Err.Error(), "WSAECONNRESET") {
  127. // 如果错误消息包含 WSAECONNRESET,也认为是连接被重置
  128. return true
  129. }
  130. }
  131. }
  132. return false
  133. }
  134. func (o *ModbusHandler) Handler() interface{} {
  135. defer func() {
  136. if err := recover(); err != nil {
  137. go GetHandler().Handler()
  138. logger.Get().Errorf("MqttHandler.Handler:发生异常:%s", string(debug.Stack()))
  139. }
  140. }()
  141. for {
  142. msg, ok, quantity := o.queue.Get()
  143. if !ok {
  144. time.Sleep(10 * time.Millisecond)
  145. continue
  146. } else if quantity > 1000 {
  147. logger.Get().Errorf("数据队列累积过多,请注意优化,当前队列条数:%d", quantity)
  148. }
  149. queueData, ok := msg.(*model.QueueData)
  150. if !ok {
  151. logger.Get().Errorln("Type assertion failed: msg is not of type model.QueueDat")
  152. return nil
  153. }
  154. // 信息处理返回
  155. parseData(queueData)
  156. // 对数据进行修改
  157. }
  158. }
  159. func parseData(data *model.QueueData) {
  160. reg, dev, err := utils.GetDataByDeviceId(data.Id)
  161. if err != nil {
  162. logger.Get().Errorln("Error getting register and device:", err)
  163. return
  164. }
  165. toString := hex.EncodeToString(data.Value)
  166. logger.Get().Println("Modbus Data: " + toString)
  167. switch toString[0:2] {
  168. case "fe":
  169. switch toString[4:8] { // 开关灯
  170. case "0000", "0001", "0002", "0003", "0004", "0005", "0006", "0007":
  171. if toString[8:12] == "0000" {
  172. for i, loop := range dev.DeviceLoops {
  173. loop.State = 0
  174. dev.DeviceLoops[i] = loop
  175. }
  176. } else if toString[8:12] == "ff00" {
  177. for i, loop := range dev.DeviceLoops {
  178. loop.State = 1
  179. dev.DeviceLoops[i] = loop
  180. }
  181. }
  182. }
  183. switch toString[2:6] {
  184. case "0101":
  185. for i, device := range reg.Devices {
  186. if device.Sn == data.Id {
  187. reg.Devices[i].State = 1
  188. reg.Devices[i].OnlineTime = time.Now()
  189. }
  190. }
  191. regions, err := utils.SaveRegionOnData(reg)
  192. logger.Get().Println(data.Id + "-----" + toString)
  193. err = service.SaveData(regions)
  194. if err != nil {
  195. logger.Get().Errorln(err)
  196. return
  197. }
  198. }
  199. case "11":
  200. logger.Get().Println("太阳能---" + toString)
  201. switch toString[2:6] {
  202. case "0336":
  203. logger.Get().Println(data.Id + "太阳能" + toString)
  204. batteryVoltage, _ := strconv.ParseInt(toString[6:10], 16, 64)
  205. batteryCurrent, _ := strconv.ParseInt(toString[10:14], 16, 64)
  206. batteryPlateVoltage, _ := strconv.ParseInt(toString[38:42], 16, 64)
  207. sun := dao.Sun{
  208. DeviceId: dev.Sn,
  209. BatteryVoltage: float64(batteryVoltage) / 100,
  210. BatteryCurrent: int(batteryCurrent),
  211. BatteryPlateVoltage: float64(batteryPlateVoltage) / 100,
  212. }
  213. for i, device := range reg.Devices {
  214. if device.Sn == dev.Sn {
  215. reg.Devices[i].Sun = sun
  216. }
  217. }
  218. regions, err := utils.SaveRegionOnData(reg)
  219. err = service.SaveData(regions)
  220. if err != nil {
  221. logger.Get().Println("太阳能数据保存" + err.Error())
  222. return
  223. }
  224. //电池
  225. if float64(batteryVoltage)/100 < 5 {
  226. data1 := modbus.DeviceSwitch(8, 1)
  227. utils.WriteDevice(data1, model.ConnectionMap[data.Id])
  228. } else {
  229. data1 := modbus.DeviceSwitch(8, 0)
  230. utils.WriteDevice(data1, model.ConnectionMap[data.Id])
  231. }
  232. }
  233. }
  234. switch toString[0:4] {
  235. case "4c43":
  236. bytes, err := hex.DecodeString(toString[4:])
  237. if err != nil {
  238. logger.Get().Errorln("Error decoding bytes:", err)
  239. return
  240. }
  241. for i, device := range reg.Devices {
  242. if device.Sn == string(bytes) {
  243. reg.Devices[i].State = 1
  244. reg.Devices[i].OnlineTime = time.Now()
  245. }
  246. }
  247. regions, err := utils.SaveRegionOnData(reg)
  248. err = service.SaveData(regions)
  249. if err != nil {
  250. logger.Get().Errorln("心跳" + err.Error())
  251. return
  252. }
  253. }
  254. }