Read machine from appsettings.json
This commit is contained in:
@@ -1,10 +1,6 @@
|
||||
using Modbus.Net;
|
||||
using Modbus.Net.Modbus;
|
||||
using Modbus.Net.Siemens;
|
||||
using DataReturnDef = Modbus.Net.DataReturnDef<string, double>;
|
||||
using ModbusMachine = Modbus.Net.Modbus.ModbusMachine<string, string>;
|
||||
using MultipleMachinesJobScheduler = Modbus.Net.MultipleMachinesJobScheduler<Modbus.Net.IMachineMethodDatas, string, double>;
|
||||
using SiemensMachine = Modbus.Net.Siemens.SiemensMachine<string, string>;
|
||||
|
||||
namespace MachineJob.Service
|
||||
{
|
||||
@@ -19,39 +15,7 @@ namespace MachineJob.Service
|
||||
|
||||
protected override Task ExecuteAsync(CancellationToken stoppingToken)
|
||||
{
|
||||
|
||||
List<AddressUnit> _addresses = new List<AddressUnit>
|
||||
{
|
||||
new AddressUnit() { Area = "4X", Address = 1, DataType = typeof(short), Id = "1", Name = "Test1" },
|
||||
new AddressUnit() { Area = "4X", Address = 2, DataType = typeof(short), Id = "2", Name = "Test2" },
|
||||
new AddressUnit() { Area = "4X", Address = 3, DataType = typeof(short), Id = "3", Name = "Test3" },
|
||||
new AddressUnit() { Area = "4X", Address = 4, DataType = typeof(short), Id = "4", Name = "Test4" },
|
||||
new AddressUnit() { Area = "4X", Address = 5, DataType = typeof(short), Id = "5", Name = "Test5" },
|
||||
new AddressUnit() { Area = "4X", Address = 6, DataType = typeof(short), Id = "6", Name = "Test6" },
|
||||
new AddressUnit() { Area = "4X", Address = 7, DataType = typeof(short), Id = "7", Name = "Test7" },
|
||||
new AddressUnit() { Area = "4X", Address = 8, DataType = typeof(short), Id = "8", Name = "Test8" },
|
||||
new AddressUnit() { Area = "4X", Address = 9, DataType = typeof(short), Id = "9", Name = "Test9" },
|
||||
new AddressUnit() { Area = "4X", Address = 10, DataType = typeof(short), Id = "10", Name = "Test10" }
|
||||
};
|
||||
|
||||
List<AddressUnit> _addresses2 = new List<AddressUnit>
|
||||
{
|
||||
new AddressUnit() { Area = "DB1", Address = 0, DataType = typeof(short), Id = "1", Name = "Test1" },
|
||||
new AddressUnit() { Area = "DB1", Address = 2, DataType = typeof(short), Id = "2", Name = "Test2" },
|
||||
new AddressUnit() { Area = "DB1", Address = 4, DataType = typeof(short), Id = "3", Name = "Test3" },
|
||||
new AddressUnit() { Area = "DB1", Address = 6, DataType = typeof(short), Id = "4", Name = "Test4" },
|
||||
new AddressUnit() { Area = "DB1", Address = 8, DataType = typeof(short), Id = "5", Name = "Test5" },
|
||||
new AddressUnit() { Area = "DB1", Address = 10, DataType = typeof(short), Id = "6", Name = "Test6" },
|
||||
new AddressUnit() { Area = "DB1", Address = 12, DataType = typeof(short), Id = "7", Name = "Test7" },
|
||||
new AddressUnit() { Area = "DB1", Address = 14, DataType = typeof(short), Id = "8", Name = "Test8" },
|
||||
new AddressUnit() { Area = "DB1", Address = 16, DataType = typeof(short), Id = "9", Name = "Test9" },
|
||||
new AddressUnit() { Area = "DB1", Address = 18, DataType = typeof(short), Id = "10", Name = "Test10" }
|
||||
};
|
||||
|
||||
IMachine<string> machine = new ModbusMachine("ModbusMachine1", ModbusType.Tcp, null, _addresses, true, 1, 2, Endian.BigEndianLsb);
|
||||
IMachine<string> machine2 = new SiemensMachine("SiemensMachine1", SiemensType.Tcp, null, SiemensMachineModel.S7_1200, _addresses2, true, 1, 2);
|
||||
IMachine<string> machine3 = new ModbusMachine("ModbusMachine2", ModbusType.Rtu, "COM1", _addresses, true, 3, 2);
|
||||
var machines = new List<IMachine<string>>() { machine, machine2, machine3 };
|
||||
var machines = MachineReader.ReadMachines();
|
||||
return Task.Run(() => MultipleMachinesJobScheduler.RunScheduler(machines, async (machine, scheduler) =>
|
||||
{
|
||||
await scheduler.From(machine.Id, machine, MachineDataType.Name).Result.Query(machine.Id + ".ConsoleQuery", QueryConsole).Result.To(machine.Id + ".To", machine).Result.Deal(machine.Id + ".Deal", OnSuccess, OnFailure).Result.Run();
|
||||
|
||||
@@ -13,13 +13,188 @@
|
||||
},
|
||||
|
||||
"Modbus.Net": {
|
||||
"TCP": {
|
||||
"Modbus": {
|
||||
"IP": "192.168.8.210"
|
||||
"Machine": [
|
||||
{
|
||||
"a:id": "ModbusMachine1",
|
||||
"b:protocol": "Modbus",
|
||||
"c:type": "Tcp",
|
||||
"d:connectionString": "192.168.8.210",
|
||||
"e:addressMap": "AddressMapModbus",
|
||||
"f:keepConnect": true,
|
||||
"g:slaveAddress": 1,
|
||||
"h:masterAddress": 2,
|
||||
"i:endian": "BigEndianLsb"
|
||||
},
|
||||
"Siemens": {
|
||||
"IP": "192.168.8.210"
|
||||
{
|
||||
"a:id": "SiemensMachine1",
|
||||
"b:protocol": "Siemens",
|
||||
"c:type": "Tcp",
|
||||
"d:connectionString": "192.168.8.210",
|
||||
"e:model": "S7_1200",
|
||||
"f:addressMap": "AddressMapSiemens",
|
||||
"g:keepConnect": true,
|
||||
"h:slaveAddress": 1,
|
||||
"i:masterAddress": 2,
|
||||
"j:src": 1,
|
||||
"k:dst": 0
|
||||
},
|
||||
{
|
||||
"a:id": "ModbusMachine2",
|
||||
"b:protocol": "Modbus",
|
||||
"c:type": "Rtu",
|
||||
"d:connectionString": "COM1",
|
||||
"e:addressMap": "AddressMapModbus",
|
||||
"f:keepConnect": true,
|
||||
"g:slaveAddress": 3,
|
||||
"h:masterAddress": 2,
|
||||
"i:endian": "BigEndianLsb"
|
||||
}
|
||||
],
|
||||
"addressMap": {
|
||||
"AddressMapModbus": [
|
||||
{
|
||||
"Area": "4X",
|
||||
"Address": 1,
|
||||
"DataType": "Int16",
|
||||
"Id": "1",
|
||||
"Name": "Test1"
|
||||
},
|
||||
{
|
||||
"Area": "4X",
|
||||
"Address": 2,
|
||||
"DataType": "Int16",
|
||||
"Id": "2",
|
||||
"Name": "Test2"
|
||||
},
|
||||
{
|
||||
"Area": "4X",
|
||||
"Address": 3,
|
||||
"DataType": "Int16",
|
||||
"Id": "3",
|
||||
"Name": "Test3"
|
||||
},
|
||||
{
|
||||
"Area": "4X",
|
||||
"Address": 4,
|
||||
"DataType": "Int16",
|
||||
"Id": "4",
|
||||
"Name": "Test4"
|
||||
},
|
||||
{
|
||||
"Area": "4X",
|
||||
"Address": 5,
|
||||
"DataType": "Int16",
|
||||
"Id": "5",
|
||||
"Name": "Test5"
|
||||
},
|
||||
{
|
||||
"Area": "4X",
|
||||
"Address": 6,
|
||||
"DataType": "Int16",
|
||||
"Id": "6",
|
||||
"Name": "Test6"
|
||||
},
|
||||
{
|
||||
"Area": "4X",
|
||||
"Address": 7,
|
||||
"DataType": "Int16",
|
||||
"Id": "7",
|
||||
"Name": "Test7"
|
||||
},
|
||||
{
|
||||
"Area": "4X",
|
||||
"Address": 8,
|
||||
"DataType": "Int16",
|
||||
"Id": "8",
|
||||
"Name": "Test8"
|
||||
},
|
||||
{
|
||||
"Area": "4X",
|
||||
"Address": 9,
|
||||
"DataType": "Int16",
|
||||
"Id": "9",
|
||||
"Name": "Test9"
|
||||
},
|
||||
{
|
||||
"Area": "4X",
|
||||
"Address": 10,
|
||||
"DataType": "Int16",
|
||||
"Id": "10",
|
||||
"Name": "Test10"
|
||||
}
|
||||
],
|
||||
"AddressMapSiemens": [
|
||||
{
|
||||
"Area": "DB1",
|
||||
"Address": 0,
|
||||
"DataType": "Int16",
|
||||
"Id": "1",
|
||||
"Name": "Test1"
|
||||
},
|
||||
{
|
||||
"Area": "DB1",
|
||||
"Address": 2,
|
||||
"DataType": "Int16",
|
||||
"Id": "2",
|
||||
"Name": "Test2"
|
||||
},
|
||||
{
|
||||
"Area": "DB1",
|
||||
"Address": 4,
|
||||
"DataType": "Int16",
|
||||
"Id": "3",
|
||||
"Name": "Test3"
|
||||
},
|
||||
{
|
||||
"Area": "DB1",
|
||||
"Address": 6,
|
||||
"DataType": "Int16",
|
||||
"Id": "4",
|
||||
"Name": "Test4"
|
||||
},
|
||||
{
|
||||
"Area": "DB1",
|
||||
"Address": 8,
|
||||
"DataType": "Int16",
|
||||
"Id": "5",
|
||||
"Name": "Test5"
|
||||
},
|
||||
{
|
||||
"Area": "DB1",
|
||||
"Address": 10,
|
||||
"DataType": "Int16",
|
||||
"Id": "6",
|
||||
"Name": "Test6"
|
||||
},
|
||||
{
|
||||
"Area": "DB1",
|
||||
"Address": 12,
|
||||
"DataType": "Int16",
|
||||
"Id": "7",
|
||||
"Name": "Test7"
|
||||
},
|
||||
{
|
||||
"Area": "DB1",
|
||||
"Address": 14,
|
||||
"DataType": "Int16",
|
||||
"Id": "8",
|
||||
"Name": "Test8"
|
||||
},
|
||||
{
|
||||
"Area": "DB1",
|
||||
"Address": 16,
|
||||
"DataType": "Int16",
|
||||
"Id": "9",
|
||||
"Name": "Test9"
|
||||
},
|
||||
{
|
||||
"Area": "DB1",
|
||||
"Address": 18,
|
||||
"DataType": "Int16",
|
||||
"Id": "10",
|
||||
"Name": "Test10"
|
||||
}
|
||||
]
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user