| | |
| | | "fmt" |
| | | "github.com/spf13/cast" |
| | | "sync" |
| | | "sync/atomic" |
| | | ) |
| | | |
| | | // 串口不支持并行读写,所以需要加个锁,防止timeout和资源不可用报错 |
| | |
| | | var ( |
| | | ipAddr string |
| | | ) |
| | | defer dealErr(err) |
| | | defer func() { |
| | | dealErr(err) |
| | | }() |
| | | if plcConfig.Method == constvar.PlcMethodModbusTCP { |
| | | ipAddr = fmt.Sprintf("%s:%v", plcConfig.Address, plcConfig.Port) |
| | | err = WriteByModbusTCP(ipAddr, address, value) |
| | |
| | | var ( |
| | | ipAddr string |
| | | ) |
| | | defer dealErr(err) |
| | | defer func() { |
| | | dealErr(err) |
| | | }() |
| | | if plcConfig.Method == constvar.PlcMethodModbusTCP || plcConfig.Method == constvar.PlcMethodModbusRTU { |
| | | var value []byte |
| | | if plcConfig.Method == constvar.PlcMethodModbusTCP { |
| | |
| | | } |
| | | |
| | | func dealErr(err error) { |
| | | logx.Infof("deal err: %v", err) |
| | | if err != nil { |
| | | FailureRemainingOpportunitiesDecr() //减少失败剩余机会 |
| | | } else { |
| | |
| | | } |
| | | } |
| | | |
| | | var connectionStatus atomic.Bool |
| | | |
| | | var failureRemainingOpportunities atomic.Int64 |
| | | var connectionStatus sync.Map |
| | | |
| | | const ( |
| | | defaultFailureRemainingOpportunities = 20 |
| | | ) |
| | | |
| | | func IsConnect() bool { |
| | | return connectionStatus.Load() |
| | | val, ok := connectionStatus.Load(conf.Conf.CurrentDeviceID) |
| | | if !ok { |
| | | return false |
| | | } |
| | | failureRemainingOpportunities := val.(int) |
| | | return failureRemainingOpportunities > 0 |
| | | } |
| | | |
| | | func FailureRemainingOpportunitiesDecr() { |
| | | newValue := failureRemainingOpportunities.Add(-1) |
| | | if newValue <= 0 { |
| | | connectionStatus.Store(false) |
| | | val, ok := connectionStatus.Load(conf.Conf.CurrentDeviceID) |
| | | if !ok { |
| | | return |
| | | } |
| | | failureRemainingOpportunities := val.(int) |
| | | if failureRemainingOpportunities > 0 { |
| | | failureRemainingOpportunities-- |
| | | } |
| | | connectionStatus.Store(conf.Conf.CurrentDeviceID, failureRemainingOpportunities) |
| | | return |
| | | } |
| | | |
| | | func FailureRemainingOpportunitiesReset() { |
| | | if failureRemainingOpportunities.Load() < defaultFailureRemainingOpportunities { |
| | | failureRemainingOpportunities.Store(defaultFailureRemainingOpportunities) |
| | | } |
| | | if connectionStatus.Load() == false { |
| | | connectionStatus.Store(true) |
| | | val, ok := connectionStatus.Load(conf.Conf.CurrentDeviceID) |
| | | if !ok || val.(int) < defaultFailureRemainingOpportunities { |
| | | connectionStatus.Store(conf.Conf.CurrentDeviceID, defaultFailureRemainingOpportunities) |
| | | return |
| | | } |
| | | return |
| | | } |