コード例 #1
0
        public static void Get_XAGL_WM2000GLT_PowerDiagram_Mock(ModbusRtuOverTcp client, RedisClient redisClient, string messageString)
        {
            var par = messageString.FromJson <ControlRequest>();

            try
            {
                var powerDiagram = new IotDataOilWellPowerDiagram()
                {
                    AlarmCode = 0,
                    AlarmMsg  = "正常"
                };

                powerDiagram.WellId       = par.DeviceId;
                powerDiagram.DeviceTypeId = par.DeviceTypeId;
                powerDiagram.DateTime     = DateTime.Now;
                powerDiagram.Mock         = par.UseMockData;

                redisClient.AddItemToList("YCIOT:IOT_Data_OilWell_PowerDiagram", powerDiagram.ToJson().IndentJson());
                redisClient.Set($"Group:OilWell:{par.DeviceName}-{par.DeviceId}:PowerDiagram", powerDiagram);
                redisClient.Set($"Single:OilWell:PowerDiagram:{par.DeviceName}-{par.DeviceId}", powerDiagram);
            }
            catch (Exception ex)
            {
                Logger.Error(ex.Message);
                Logger.Error(ex.StackTrace);
                Logger.Error(ex.Source);

                if (!par.UserName.IsNullOrEmpty())
                {
                    ServerEventHelper.SendSseMessage(par.UserName, par.SessionId, -1, ex.Message);
                }
            }
        }
コード例 #2
0
        public static async Task Get_XAGL_WM2000GLT_PowerDiagram(ModbusRtuOverTcp client, RedisClient redisClient, string messageString)
        {
            var par = messageString.FromJson <ControlRequest>();

            try
            {
                var powerDiagram = new IotDataOilWellPowerDiagram()
                {
                    AlarmCode = 0,
                    AlarmMsg  = "正常"
                };

                var logIotModbusPoll = par.ConvertTo <LogIotModbusPoll>();

                logIotModbusPoll.State  = 0;
                logIotModbusPoll.Result = "ok";

                var modbusAddress = par.ModbusAddress;
                powerDiagram.DeviceTypeId = par.DeviceTypeId;
                powerDiagram.Mock         = false;

                var flag = true;

                ClientInfo.CurrentModbusPoolAddress = modbusAddress;

                var jo1 = (JObject)JsonConvert.DeserializeObject(par.CommandParameter);
                powerDiagram.Displacement = Convert.ToDouble(jo1["0"].ToString());

                powerDiagram.D = new List <double>(); //位移
                powerDiagram.P = new List <double>(); //功率

                powerDiagram.DateTime = DateTime.Now;
                powerDiagram.WellId   = par.DeviceId;


                #region  判断井状态

                lock (ClientInfo.locker)
                {
                    ClientInfo.RequestTime     = DateTime.Now;
                    ClientInfo.ExpectedType    = 0x03;
                    ClientInfo.ExpectedDataLen = 2;
                }

                var read = await client.ReadAsync($"s={par.ModbusAddress};x=3;4103", 1);

                if (read.IsSuccess)
                {
                    var value = client.ByteTransform.TransInt16(read.Content, 0);

                    if (value == 3)  //1:正转运行;3:变频停机
                    {
                        powerDiagram.NetworkNode = ClientInfo.ManyIpAddress;
                        powerDiagram.AlarmCode   = 3;
                        powerDiagram.AlarmMsg    = "停井";
                    }
                }
                else
                {
                    flag = false;
                    powerDiagram.AlarmCode = -1;
                    powerDiagram.AlarmMsg  = "数据异常";

                    powerDiagram.Mock         = par.UseMockData;
                    logIotModbusPoll.DateTime = DateTime.Now;
                    logIotModbusPoll.State    = -1;
                    logIotModbusPoll.Result   = $"读取功率图井状态数据异常![{read.Message}]";
                    $"GLT:{par.DeviceName}-{par.DeviceId}{logIotModbusPoll.Result}".Info();

                    redisClient.AddItemToList("YCIOT:ERROR:Log_IOT_Modbus_Poll", logIotModbusPoll.ToJson().IndentJson());
                }
                #endregion

                const ushort step = 100;

                //ToDo:确认采样间隔和点数
                powerDiagram.Count = 300;

                if (flag && powerDiagram.Count <= 300 && powerDiagram.Count >= step)
                {
                    const ushort regAddress = 38268; //读取功率数据
                    for (ushort i = 0; i < powerDiagram.Count && flag; i += step)
                    {
                        var itemCount = (i + step > powerDiagram.Count) ? (ushort)(powerDiagram.Count - i) : step;
                        if (isDebug)
                        {
                            Logger.Info($"{i}:{itemCount}:{(ushort)(regAddress + i)}");
                        }

                        lock (ClientInfo.locker)
                        {
                            ClientInfo.RequestTime     = DateTime.Now;
                            ClientInfo.ExpectedType    = 0x03;
                            ClientInfo.ExpectedDataLen = itemCount * 2;
                        }
                        read = await client.ReadAsync($"s={par.ModbusAddress};x=3;{(regAddress + i)}", itemCount);

                        if (!read.IsSuccess)
                        {
                            read = await client.ReadAsync($"s={par.ModbusAddress};x=3;{(regAddress + i)}", itemCount);
                        }

                        if (read.IsSuccess)
                        {
                            for (var j = 0; j < itemCount; j++)
                            {
                                var value = client.ByteTransform.TransInt16(read.Content, j * 2);
                                var P     = Math.Round((value / 4000.0) * 36, 2);
                                powerDiagram.P.Add(P);
                            }
                        }
                        else
                        {
                            flag = false;

                            powerDiagram.AlarmCode = -1;
                            powerDiagram.AlarmMsg  = "数据异常";

                            powerDiagram.Mock         = par.UseMockData;
                            logIotModbusPoll.Type     = "Get_XAGL_WM2000GLT_PowerDiagram";
                            logIotModbusPoll.DateTime = DateTime.Now;
                            logIotModbusPoll.State    = -1;
                            logIotModbusPoll.Result   =
                                "从 " + (regAddress + i).ToString() + " 个开始,读取 " + itemCount.ToString() +
                                $" 个功率图功率数据异常!{read.Message}";

                            redisClient.AddItemToList("YCIOT:ERROR:Log_IOT_Modbus_Poll", logIotModbusPoll.ToJson().IndentJson());
                        }

                        Thread.Sleep(100);
                    }

                    if (powerDiagram.P.Count > 0)
                    {
                        powerDiagram.MaxPower = powerDiagram.P.Max();                    //最大功率
                        powerDiagram.MinPower = powerDiagram.P.Min();                    //最小功率
                        powerDiagram.AvgPower = Math.Round(powerDiagram.P.Average(), 2); //平均功率
                    }
                }
                else
                {
                    flag = false;
                }

                powerDiagram.NetworkNode = ClientInfo.ManyIpAddress;

                //用于将读取的结果写入Redis队列

                if (flag == true || par.UseMockData)
                {
                    $"GLT:{par.DeviceName}-{par.DeviceId}已获取到数据".Info();
                    powerDiagram.Mock = par.UseMockData;

                    if (powerDiagram.Count != null)
                    {
                        if (powerDiagram.Displacement != null)
                        {
                            powerDiagram.D =
                                DisplacementUtils.FitDisplacement((ushort)powerDiagram.Count,
                                                                  (double)powerDiagram.Displacement);
                        }
                    }

                    redisClient.AddItemToList("YCIOT:IOT_Data_OilWell_PowerDiagram", powerDiagram.ToJson().IndentJson());
                    redisClient.Set($"Group:OilWell:{par.DeviceName}-{par.DeviceId}:PowerDiagram", powerDiagram);
                    redisClient.Set($"Single:OilWell:PowerDiagram:{par.DeviceName}-{par.DeviceId}", powerDiagram);
                }

                //用于通过ServerEvent给调用着返回消息
                if (!par.UserName.IsNullOrEmpty())
                {
                    ServerEventHelper.SendSseMessage(par.UserName, par.SessionId, flag ? 0 : -2, powerDiagram.ToJson().IndentJson());
                }
            }
            catch (Exception ex)
            {
                Logger.Error(ex.Message);
                Logger.Error(ex.StackTrace);
                Logger.Error(ex.Source);

                if (!par.UserName.IsNullOrEmpty())
                {
                    ServerEventHelper.SendSseMessage(par.UserName, par.SessionId, -1, ex.Message);
                }
            }
        }
コード例 #3
0
        public static async Task <bool> GetDateTime(ModbusRtuOverTcp client, int modbusAddress, IotDataOilWellPowerDiagram powerDiagram, ushort startAddress, ushort regCount, int tryReadTimes = 3)
        {
            lock (ClientInfo.locker)
            {
                ClientInfo.RequestTime     = DateTime.Now;
                ClientInfo.ExpectedType    = 0x04;
                ClientInfo.ExpectedDataLen = regCount * 2;
            }
            var read = await client.ReadAsync($"s={modbusAddress};x=4;{startAddress}", regCount);

            if (read.IsSuccess)
            {
                var year  = client.ByteTransform.TransByte(read.Content, 0);
                var month = client.ByteTransform.TransByte(read.Content, 1);
                var date  = client.ByteTransform.TransByte(read.Content, 2);
                var h     = client.ByteTransform.TransByte(read.Content, 3);
                var m     = client.ByteTransform.TransByte(read.Content, 4);
                var s     = client.ByteTransform.TransByte(read.Content, 5);

                powerDiagram.DateTime = new DateTime(2000 + year, month, date, h, m, s);
                return(true);
            }
            else
            {
                tryReadTimes--;
                if (tryReadTimes > 0)
                {
                    return(await GetDateTime(client, modbusAddress, powerDiagram, startAddress, regCount, tryReadTimes));
                }
                return(false);
            }
        }
コード例 #4
0
        public static async Task Get_LYQH_GLT_PowerDiagram(ModbusRtuOverTcp client, RedisClient redisClient, string messageString)
        {
            var par = messageString.FromJson <ControlRequest>();

            try
            {
                var powerDiagram = new IotDataOilWellPowerDiagram()
                {
                    AlarmCode = 0,
                    AlarmMsg  = "正常"
                };

                var logIotModbusPoll = par.ConvertTo <LogIotModbusPoll>();

                logIotModbusPoll.State  = 0;
                logIotModbusPoll.Result = "ok";

                var modbusAddress = par.ModbusAddress;
                powerDiagram.DeviceTypeId = par.DeviceTypeId;
                powerDiagram.Mock         = false;

                var flag = true;

                ClientInfo.CurrentModbusPoolAddress = modbusAddress;

                var jo1 = (JObject)JsonConvert.DeserializeObject(par.CommandParameter);
                powerDiagram.Displacement = Convert.ToDouble(jo1["0"].ToString());
                var slotId = Convert.ToInt32(jo1["1"].ToString());

                powerDiagram.D = new List <double>();    //位移
                powerDiagram.P = new List <double>();    //功率

                powerDiagram.DateTime = DateTime.Now;
                powerDiagram.WellId   = par.DeviceId;


                var regAddress = (ushort)((slotId * 0x3000) + 256);      //读取功率数据
                var isSuccess  = await GetDateTime(client, modbusAddress, powerDiagram, regAddress, 3, 3);

                if (!isSuccess)
                {
                    FailLog.Write(redisClient, par, powerDiagram, logIotModbusPoll, "Get_LYQH_GLT_PowerDiagram", "读取功率图时间异常");
                }

                ushort step = 100;
                powerDiagram.Count = 200;
                if (powerDiagram.Count <= 300 && powerDiagram.Count >= step)
                {
                    regAddress = (ushort)((slotId * 0x3000) + 1356);       //读取功率数据
                    for (ushort i = 0; i < powerDiagram.Count && flag; i += step)
                    {
                        var itemCount = (i + step > powerDiagram.Count) ? (ushort)(powerDiagram.Count - i) : step;

                        Logger.Info($"{i}:{itemCount}:{(ushort)(regAddress + i)}");

                        isSuccess = await GetPData(client, modbusAddress, powerDiagram, (ushort)(regAddress + i), itemCount, 3);

                        if (!isSuccess)
                        {
                            var message = "从 " + (regAddress + i).ToString() + " 个开始,读取 " + itemCount.ToString() + " 个功率图功率数据异常!";
                            FailLog.Write(redisClient, par, powerDiagram, logIotModbusPoll, "Get_LYQH_GLT_PowerDiagram", message);
                            flag = false;
                            break;
                        }

                        Thread.Sleep(100);
                    }

                    if (powerDiagram.P.Count > 0)
                    {
                        powerDiagram.MaxPower = powerDiagram.P.Max();                    //最大功率
                        powerDiagram.MinPower = powerDiagram.P.Min();                    //最小功率
                        powerDiagram.AvgPower = Math.Round(powerDiagram.P.Average(), 2); //平均功率
                    }
                }
                else
                {
                    flag = false;
                }

                powerDiagram.NetworkNode = ClientInfo.ManyIpAddress;

                //用于将读取的结果写入Redis队列

                if (flag == true || par.UseMockData)
                {
                    powerDiagram.Mock = par.UseMockData;

                    if (powerDiagram.Count != null)
                    {
                        powerDiagram.D =
                            DisplacementUtils.FitDisplacement((ushort)powerDiagram.Count, (double)powerDiagram.Displacement);
                    }
                    redisClient.AddItemToList("YCIOT:IOT_Data_OilWell_PowerDiagram", powerDiagram.ToJson().IndentJson());
                    redisClient.Set($"Group:OilWell:{par.DeviceName}-{par.DeviceId}:PowerDiagram", powerDiagram);
                    redisClient.Set($"Single:OilWell:PowerDiagram:{par.DeviceName}-{par.DeviceId}", powerDiagram);
                }


                //用于通过ServerEvent给调用着返回消息
                if (!par.UserName.IsNullOrEmpty())
                {
                    ServerEventHelper.SendSseMessage(par.UserName, par.SessionId, flag ? 0 : -2, powerDiagram.ToJson().IndentJson());
                }
            }
            catch (Exception ex)
            {
                Logger.Error(ex.Message);
                Logger.Error(ex.StackTrace);
                Logger.Error(ex.Source);

                if (!par.UserName.IsNullOrEmpty())
                {
                    ServerEventHelper.SendSseMessage(par.UserName, par.SessionId, -1, ex.Message);
                }
            }
        }
コード例 #5
0
        public static async Task <bool> GetPData(ModbusRtuOverTcp client, int modbusAddress, IotDataOilWellPowerDiagram powerDiagram, ushort startAddress, ushort regCount, int tryReadTimes)
        {
            lock (ClientInfo.locker)
            {
                ClientInfo.RequestTime     = DateTime.Now;
                ClientInfo.ExpectedType    = 0x04;
                ClientInfo.ExpectedDataLen = regCount * 2;
            }
            var read = await client.ReadAsync($"s={modbusAddress};x=4;{startAddress}", regCount);

            if (read.IsSuccess)
            {
                for (var j = 0; j < regCount; j++)
                {
                    var value = client.ByteTransform.TransInt16(read.Content, j * 2);
                    if (value != 0)
                    {
                        var L = value * 0.01;
                        powerDiagram.P.Add(Math.Round(L, 2));
                    }
                    else
                    {
                        powerDiagram.P.Add(value);
                    }
                }
                return(true);
            }
            else
            {
                tryReadTimes--;
                if (tryReadTimes > 0)
                {
                    return(await GetPData(client, modbusAddress, powerDiagram, startAddress, regCount, tryReadTimes));
                }
                return(false);
            }
        }