更新 推送新增status + time

This commit is contained in:
caixiang 2021-09-30 17:00:30 +08:00
parent e36ca8ae57
commit 32b5a1fd43
11 changed files with 476 additions and 88 deletions

View File

@ -4,11 +4,14 @@ import com.alibaba.fastjson.JSONArray;
import com.alibaba.fastjson.JSONObject; import com.alibaba.fastjson.JSONObject;
import com.qgs.dc.common.utils.CommonFunction; import com.qgs.dc.common.utils.CommonFunction;
import com.qgs.dc.opcua.constant.PLCConstant; import com.qgs.dc.opcua.constant.PLCConstant;
import com.qgs.dc.opcua.selfunion.entity.SubscribeVarArgEntity;
import com.qgs.dc.opcua.selfunion.entity.SubscribeVarOfConfigEntity;
import org.eclipse.milo.opcua.stack.core.security.SecurityPolicy; import org.eclipse.milo.opcua.stack.core.security.SecurityPolicy;
import java.io.*; import java.io.*;
import java.nio.charset.StandardCharsets; import java.nio.charset.StandardCharsets;
import java.util.HashMap; import java.util.*;
import java.util.stream.Collectors;
public class LocalMulPLCConfig { public class LocalMulPLCConfig {
@ -21,7 +24,7 @@ public class LocalMulPLCConfig {
if (!jsonFile.exists()) { if (!jsonFile.exists()) {
boolean b= jsonFile.createNewFile(); boolean b= jsonFile.createNewFile();
JSONObject json = new JSONObject(); JSONObject json = new JSONObject();
json =JSON.parseObject("{\"config\": []}"); json =JSON.parseObject("{\"config\": [],\"subscribedForVisit\":{}}");
FileWriter fw = new FileWriter(jsonFile.getAbsoluteFile()); FileWriter fw = new FileWriter(jsonFile.getAbsoluteFile());
BufferedWriter bw = new BufferedWriter(fw); BufferedWriter bw = new BufferedWriter(fw);
json.writeJSONString(bw); json.writeJSONString(bw);
@ -45,8 +48,120 @@ public class LocalMulPLCConfig {
} }
} }
public static void main(String[] args) throws IOException {
// SubscribeVarOfConfigEntity subscribeVarOfConfigEntity1 = new SubscribeVarOfConfigEntity(5,"Boolean",3000,"plc2");
// SubscribeVarOfConfigEntity subscribeVarOfConfigEntity2 = new SubscribeVarOfConfigEntity(5,"Byte",2000,"plc2");
// SubscribeVarOfConfigEntity subscribeVarOfConfigEntity3 = new SubscribeVarOfConfigEntity(5,"Double",1000,"plc2");
// SubscribeVarOfConfigEntity subscribeVarOfConfigEntity4 = new SubscribeVarOfConfigEntity(5,"Float",1000,"plc2");
// ArrayList<SubscribeVarOfConfigEntity> objects = new ArrayList<>();
// objects.add(subscribeVarOfConfigEntity1);
// objects.add(subscribeVarOfConfigEntity2);
// objects.add(subscribeVarOfConfigEntity3);
// objects.add(subscribeVarOfConfigEntity4);
// writeIntoFileOfSubscribeVar(objects);
//read
ArrayList<SubscribeVarOfConfigEntity> plc1 = getSubscribedVarOfConfig("plc2");
Map<Integer, List<SubscribeVarOfConfigEntity>> map = plc1.stream().collect(Collectors.groupingBy(t -> t.getPeriod()));
System.out.println("period"+map);
/*然后再对map处理这样就方便取出自己要的数据*/
for(Map.Entry<Integer, List<SubscribeVarOfConfigEntity>> entry : map.entrySet()){
System.out.println("key:"+entry.getKey());
System.out.println("value:"+entry.getValue());
}
System.out.println();
}
//把修改了的变量 全量替换到文件
public static void writeIntoFileOfSubscribeVar(List<SubscribeVarOfConfigEntity> subscribeVars) throws IOException {
String s = "";
String ss = "";
if(CommonFunction.isLinux()){
s = readJsonFile(PLCConstant.localURLForLinux);
ss = PLCConstant.localURLForLinux;
}else if(CommonFunction.isWindows()){
s = readJsonFile(PLCConstant.localURLForWindows);
ss = PLCConstant.localURLForWindows;
}
JSONObject jobj = JSON.parseObject(s);
//JSONArray subscribedForVisits = jobj.getJSONArray("subscribedForVisit");//构建JSONArray数组
JSONObject subscribedForVisit = jobj.getJSONObject("subscribedForVisit");
if(subscribeVars.size() <= 0){
return;
}
String plcName = subscribeVars.get(0).getPlcName();
JSONArray objects = new JSONArray();
for (SubscribeVarOfConfigEntity entity:subscribeVars){
Map<String, Object> newValue = new LinkedHashMap<String, Object>();
newValue.put("plc_name", entity.getPlcName());
newValue.put("ns", entity.getNameSpace());
newValue.put("period", entity.getPeriod());
newValue.put("identity", entity.getIdentifier());
objects.add(newValue);
}
subscribedForVisit.put(plcName,objects);
JSONObject json = jobj;
File file = new File(ss);
if (!file.exists()) {
boolean b= file.createNewFile();
}
FileWriter fw = new FileWriter(file.getAbsoluteFile());
BufferedWriter bw = new BufferedWriter(fw);
json.writeJSONString(bw);
bw.close();
System.out.println("end");
//写入json 结束
}
//todo here 把订阅的信息 存储到本地文件CURD + 比对重复问题
public static ArrayList<SubscribeVarOfConfigEntity> getSubscribedVarOfConfig(String plcName){
//String path = LocalMulPLCConfig.class.getClassLoader().getResource("mulPLCConfig.json").getPath();
String s = "";
if(CommonFunction.isLinux()){
CommonFunction.createDirIfNotExit(PLCConstant.localURLDirForLinux);
s = readJsonFile(PLCConstant.localURLForLinux);
}else if(CommonFunction.isWindows()){
CommonFunction.createDirIfNotExit(PLCConstant.localURLDirForWindows);
s = readJsonFile(PLCConstant.localURLForWindows);
}
JSONObject jobj = JSON.parseObject(s);
JSONObject subscribedForVisit = jobj.getJSONObject("subscribedForVisit");//构建JSONArray数组
JSONArray jsonObject = subscribedForVisit.getJSONArray(plcName);
if(jsonObject == null){
return new ArrayList<>();
}
ArrayList<SubscribeVarOfConfigEntity> res = new ArrayList<>();
for (int i = 0 ; i < jsonObject.size();i++){
JSONObject key = (JSONObject)jsonObject.get(i);
Integer period = (Integer)key.get("period");
Integer ns = (Integer)key.get("ns");
String identity =(String)key.get("identity");
res.add(new SubscribeVarOfConfigEntity(ns,identity,period,plcName));
}
return res;
}
public static HashMap<String,PLCConfig> getPLCConfig(){ public static HashMap<String,PLCConfig> getPLCConfig(){
//String path = LocalMulPLCConfig.class.getClassLoader().getResource("mulPLCConfig.json").getPath(); //String path = LocalMulPLCConfig.class.getClassLoader().getResource("mulPLCConfig.json").getPath();
String s = ""; String s = "";

View File

@ -3,15 +3,16 @@ package com.qgs.dc.opcua.controller;
import com.qgs.dc.opcua.Consumer.EventReceivedCallBack; import com.qgs.dc.opcua.Consumer.EventReceivedCallBack;
import com.qgs.dc.opcua.arg.*; import com.qgs.dc.opcua.arg.*;
import com.qgs.dc.common.utils.CommonFunction; import com.qgs.dc.common.utils.CommonFunction;
import com.qgs.dc.opcua.config.LocalMulPLCConfig;
import com.qgs.dc.opcua.constant.PLCConstant; import com.qgs.dc.opcua.constant.PLCConstant;
import com.qgs.dc.opcua.selfunion.Enum.PLCType; import com.qgs.dc.opcua.selfunion.Enum.PLCType;
import com.qgs.dc.opcua.selfunion.Enum.PLCVar;
import com.qgs.dc.opcua.selfunion.NodeIdKey; import com.qgs.dc.opcua.selfunion.NodeIdKey;
import com.qgs.dc.opcua.selfunion.UAService; import com.qgs.dc.opcua.selfunion.UAService;
import com.qgs.dc.opcua.selfunion.entity.CurrentSubEntity; import com.qgs.dc.opcua.selfunion.entity.*;
import com.qgs.dc.opcua.selfunion.entity.DelSubscribeEntity;
import com.qgs.dc.opcua.selfunion.entity.SubscribeEventArgEntity;
import com.qgs.dc.opcua.selfunion.entity.SubscribeVarArgEntity;
import com.qgs.dc.common.websocket.WebSocketServer; import com.qgs.dc.common.websocket.WebSocketServer;
import com.qgs.dc.opcua.taskPool.MultiWorkRunnable;
import com.qgs.dc.opcua.taskPool.QGSThreadPool;
import org.eclipse.milo.opcua.sdk.client.api.subscriptions.UaMonitoredItem; import org.eclipse.milo.opcua.sdk.client.api.subscriptions.UaMonitoredItem;
import org.eclipse.milo.opcua.stack.core.StatusCodes; import org.eclipse.milo.opcua.stack.core.StatusCodes;
import org.eclipse.milo.opcua.stack.core.types.builtin.DataValue; import org.eclipse.milo.opcua.stack.core.types.builtin.DataValue;
@ -29,6 +30,9 @@ import java.io.IOException;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.Date; import java.util.Date;
import java.util.List; import java.util.List;
import java.util.Map;
import java.util.concurrent.Future;
import java.util.stream.Collectors;
@RestController @RestController
@RequestMapping("/opcua") @RequestMapping("/opcua")
@ -42,22 +46,6 @@ public class OperateController {
@Autowired @Autowired
WebSocketServer webSocketServer; WebSocketServer webSocketServer;
@PostMapping("/testForWeight")
public R testForWeight(){
//压力测试
try {
DataValue dv = uaService.getValue(5,"Boolean", "plc1");
Object value = dv.getValue().getValue();
logger.info(CommonFunction.judgeVarType(value));
return R.ok().put("result", CommonFunction.var(value));
}catch (Exception e){
String s = uaService.extractError(e.getMessage());
s = s+";详细:"+e.getMessage();
return R.error().put("result",s);
}
}
@PostMapping("/addThisPlc") @PostMapping("/addThisPlc")
/** /**
* @Description * @Description
@ -173,7 +161,40 @@ public class OperateController {
return R.error().put("result", e.getMessage()); return R.error().put("result", e.getMessage());
} }
}
// @PostMapping("/readwriteForTest")
// //public R read(Integer nameSpace,String identifier,String plcName) {
// public R readwriteForTest() {
// for(int i = 0;i<50;i++){
// MultiWorkRunnable<Long> multiWorkRunnable1 = new MultiWorkRunnable<>(uaService);
// Future<Long> submit1 = QGSThreadPool.executor.submit(multiWorkRunnable1);
// }
// return R.ok();
// }
//获取这台plc 所有订阅的变量
@PostMapping("getAllSubscribeVarOfPlcNameWithLocal")
public R getAllSubscribeVarOfPlcNameWithLocal(@RequestBody SubscribeVarArgEntity subscribeVarArgEntity) throws Exception {
if(subscribeVarArgEntity.getPlcName()==null){
return R.error("plcName 不能为空");
}
ArrayList<SubscribeVarOfConfigEntity> subscribedVarOfConfig = LocalMulPLCConfig.getSubscribedVarOfConfig(subscribeVarArgEntity.getPlcName());
for(SubscribeVarOfConfigEntity entity: subscribedVarOfConfig){
Object value = uaService.getValue(entity.getNameSpace(), entity.getIdentifier(), entity.getPlcName()).getValue().getValue();
entity.setNowValue(value.toString());
}
Map<Integer, List<SubscribeVarOfConfigEntity>> map = subscribedVarOfConfig.stream().collect(Collectors.groupingBy(t -> t.getPeriod()));
return R.ok().put("result",map);
}
@PostMapping("saveAllSubscribeVarOfPlcNameToLocal")
public R saveAllSubscribeVarOfPlcNameToLocal(@RequestBody List<SubscribeVarOfConfigEntity> subscribeVars) throws Exception {
LocalMulPLCConfig.writeIntoFileOfSubscribeVar(subscribeVars);
return R.ok().put("result","成功");
} }
//todo 1.订阅变量数组...并且把数据类型返还给前端 //todo 1.订阅变量数组...并且把数据类型返还给前端
@ -183,6 +204,7 @@ public class OperateController {
* listNameSpace List<Integer> * listNameSpace List<Integer>
* listIdentifier List<String> * listIdentifier List<String>
* plcName String * plcName String
* period Integer
* 注意 : ns identify 必须位置上相互对应判断是否数组依据就是看几组数据 * 注意 : ns identify 必须位置上相互对应判断是否数组依据就是看几组数据
* 返回 * 返回
* 这边是通过websocket 返回的 是一个字符串 * 这边是通过websocket 返回的 是一个字符串
@ -190,13 +212,13 @@ public class OperateController {
* 第二组 是变量值 * 第二组 是变量值
* 第三组 是变量值 的类型如果是数组 那就是QArray * 第三组 是变量值 的类型如果是数组 那就是QArray
* 第四组 是变量值 的类型如果是数组 那这组就存在代表数组里面变量的数据类型 * 第四组 是变量值 的类型如果是数组 那这组就存在代表数组里面变量的数据类型
* 3,Byte|8,7,7,7,8|QArray|QShort * 3,Byte|8,7,7,7,8|QArray|QShort|status|time
* 3,Byte|0|QUByte * 3,Byte|0|QUByte|status|time
* */ * */
@PostMapping("subscribeVarForFunction") @PostMapping("subscribeVarForFunction")
public R subscribeVarForFunction(@RequestBody SubscribeVarArgEntity subscribeVarArgEntity) throws Exception { public R subscribeVarForFunction(@RequestBody SubscribeVarArgEntity subscribeVarArgEntity) throws Exception {
Integer integer = uaService.subscribeValues(subscribeVarArgEntity.getListNameSpace(), subscribeVarArgEntity.getListIdentifier(), new Double(1000), Integer integer = uaService.subscribeValues(subscribeVarArgEntity.getListNameSpace(), subscribeVarArgEntity.getListIdentifier(), new Double(subscribeVarArgEntity.getPeriod()==null?1000:subscribeVarArgEntity.getPeriod()),
(item, dataValue) -> { (item, dataValue) -> {
System.err.println("(测试是否 每隔intervel 都会执行这个回调方法) subscription value received: item:NodeId : " + System.err.println("(测试是否 每隔intervel 都会执行这个回调方法) subscription value received: item:NodeId : " +
@ -231,6 +253,7 @@ public class OperateController {
* listNameSpace List<Integer> * listNameSpace List<Integer>
* listIdentifier List<String> * listIdentifier List<String>
* plcName String * plcName String
* period Integer
* 注意 : ns identify 必须位置上相互对应判断是否数组依据就是看几组数据 * 注意 : ns identify 必须位置上相互对应判断是否数组依据就是看几组数据
* 返回 * 返回
* 1 <===> 你要订阅的这个Node 订阅成功包括这个变量已存在 然后你再次去订阅 * 1 <===> 你要订阅的这个Node 订阅成功包括这个变量已存在 然后你再次去订阅
@ -243,14 +266,14 @@ public class OperateController {
* 第三组 是变量值 的类型如果是数组 那就是QArray * 第三组 是变量值 的类型如果是数组 那就是QArray
* 第四组 是变量值 的类型如果是数组 那这组就存在代表数组里面变量的数据类型 * 第四组 是变量值 的类型如果是数组 那这组就存在代表数组里面变量的数据类型
* 第五组 是这个变量所属 的plc是哪个plc * 第五组 是这个变量所属 的plc是哪个plc
* 3,Byte|8,7,7,7,8|QArray|QShort|plcName * 3,Byte|8,7,7,7,8|QArray|QShort|plcName|status|time
* 3,Byte|0|QUByte|plcName * 3,Byte|0|QUByte|plcName|status|time
* */ * */
@PostMapping("subscribeVarForVisit") @PostMapping("subscribeVarForVisit")
public R subscribeVarForVisit(@RequestBody SubscribeVarArgEntity subscribeVarArgEntity){ public R subscribeVarForVisit(@RequestBody SubscribeVarArgEntity subscribeVarArgEntity){
try { try {
Integer integer = uaService.subscribeForVisit(subscribeVarArgEntity.getListNameSpace(), subscribeVarArgEntity.getListIdentifier(), new Double(1000), (item, dataValue) -> { Integer integer = uaService.subscribeForVisit(subscribeVarArgEntity.getListNameSpace(), subscribeVarArgEntity.getListIdentifier(), new Double(subscribeVarArgEntity.getPeriod()==null?1000:subscribeVarArgEntity.getPeriod()), (item, dataValue) -> {
UInteger attributeId = item.getReadValueId().getAttributeId(); UInteger attributeId = item.getReadValueId().getAttributeId();
System.err.println("(测试是否 每隔intervel 都会执行这个回调方法) subscription value received: item:NodeId : " + System.err.println("(测试是否 每隔intervel 都会执行这个回调方法) subscription value received: item:NodeId : " +
@ -264,7 +287,7 @@ public class OperateController {
String status = CommonFunction.quality(dataValue.getStatusCode()); String status = CommonFunction.quality(dataValue.getStatusCode());
String time = dataValue.getSourceTime().getJavaDate().toString(); String time = dataValue.getSourceTime().getJavaDate().toString();
String res = namespaceIndex + "," + identifier + "|" + CommonFunction.var2String(value) + "|" + varType+ "|" +subscribeVarArgEntity.getPlcName()+"|"+status+"|"+time; String res = namespaceIndex + "," + identifier + "|" + CommonFunction.var2String(value) + "|" + varType+ "|" +subscribeVarArgEntity.getPlcName()+"|"+status+"|"+time ;
try { try {
webSocketServer.sendtoAll(res); webSocketServer.sendtoAll(res);
@ -288,6 +311,7 @@ public class OperateController {
} }
} }
/** /**
* 状态 暂时还未用到
* 含义 : 订阅一个或者多个事件 * 含义 : 订阅一个或者多个事件
* 参数 : SubscribeArgEntity * 参数 : SubscribeArgEntity
* listNameSpace List<Integer> * listNameSpace List<Integer>
@ -410,6 +434,7 @@ public class OperateController {
//todo 测试 //todo 测试
try { try {
List<CurrentSubEntity> currentSubscribeVarForVisited = uaService.getCurrentSubscribeVarForVisited(currentSubArgEntity.getPlcName()); List<CurrentSubEntity> currentSubscribeVarForVisited = uaService.getCurrentSubscribeVarForVisited(currentSubArgEntity.getPlcName());
if(currentSubscribeVarForVisited == null){ if(currentSubscribeVarForVisited == null){
return R.error().put("result",currentSubArgEntity.getPlcName()+"这台plc不存在 或是 订阅不存在"); return R.error().put("result",currentSubArgEntity.getPlcName()+"这台plc不存在 或是 订阅不存在");
} }

View File

@ -19,6 +19,20 @@ public enum PLCVar implements PLCVarEnum {
Int64_5(3,"Int64"), Int64_5(3,"Int64"),
Int32_5(3,"Int32"), Int32_5(3,"Int32"),
Int16_5(3,"Int16"), Int16_5(3,"Int16"),
Byte(5,"Byte"),
Boolean(5,"Boolean"),
ByteString(5,"ByteString"),
DateTime(5,"DateTime"),
Double(5,"Double"),
Float(5,"Float"),
Int16(5,"Int16"),
Int32(5,"Int32"),
Int64(5,"Int64"),
Integer(5,"Integer"),
String(5,"String"),
Time(5,"Time"),
RealPLC(3,"@LOCALSERVER.db1.0,b"), RealPLC(3,"@LOCALSERVER.db1.0,b"),

View File

@ -4,6 +4,7 @@ import com.alibaba.fastjson.JSON;
import com.alibaba.fastjson.JSONArray; import com.alibaba.fastjson.JSONArray;
import com.alibaba.fastjson.JSONObject; import com.alibaba.fastjson.JSONObject;
import com.google.common.collect.ImmutableList; import com.google.common.collect.ImmutableList;
import com.qgs.dc.common.websocket.WebSocketServer;
import com.qgs.dc.opcua.config.LocalMulPLCConfig; import com.qgs.dc.opcua.config.LocalMulPLCConfig;
import com.qgs.dc.opcua.config.PLCConfig; import com.qgs.dc.opcua.config.PLCConfig;
import com.qgs.dc.common.utils.CommonFunction; import com.qgs.dc.common.utils.CommonFunction;
@ -11,6 +12,7 @@ import com.qgs.dc.opcua.constant.PLCConstant;
import com.qgs.dc.opcua.selfunion.Enum.PLCVar; import com.qgs.dc.opcua.selfunion.Enum.PLCVar;
import com.qgs.dc.opcua.selfunion.entity.CurrentSubEntity; import com.qgs.dc.opcua.selfunion.entity.CurrentSubEntity;
import com.qgs.dc.opcua.selfunion.entity.SubscribeEntity; import com.qgs.dc.opcua.selfunion.entity.SubscribeEntity;
import com.qgs.dc.opcua.selfunion.entity.SubscribeVarOfConfigEntity;
import org.bouncycastle.jce.provider.BouncyCastleProvider; import org.bouncycastle.jce.provider.BouncyCastleProvider;
import org.eclipse.milo.opcua.sdk.client.OpcUaClient; import org.eclipse.milo.opcua.sdk.client.OpcUaClient;
import org.eclipse.milo.opcua.sdk.client.api.config.OpcUaClientConfig; import org.eclipse.milo.opcua.sdk.client.api.config.OpcUaClientConfig;
@ -35,6 +37,7 @@ import org.eclipse.milo.opcua.stack.core.types.enumerated.TimestampsToReturn;
import org.eclipse.milo.opcua.stack.core.types.structured.*; import org.eclipse.milo.opcua.stack.core.types.structured.*;
import org.slf4j.Logger; import org.slf4j.Logger;
import org.slf4j.LoggerFactory; import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Component; import org.springframework.stereotype.Component;
import java.io.BufferedWriter; import java.io.BufferedWriter;
@ -54,6 +57,7 @@ import java.util.function.Predicate;
import static com.qgs.dc.opcua.config.LocalMulPLCConfig.readJsonFile; import static com.qgs.dc.opcua.config.LocalMulPLCConfig.readJsonFile;
import static org.eclipse.milo.opcua.stack.core.types.builtin.unsigned.Unsigned.uint; import static org.eclipse.milo.opcua.stack.core.types.builtin.unsigned.Unsigned.uint;
import static org.eclipse.milo.opcua.stack.core.util.ConversionUtil.l; import static org.eclipse.milo.opcua.stack.core.util.ConversionUtil.l;
import static org.eclipse.milo.opcua.stack.core.util.ConversionUtil.s;
/** /**
* @Author: 蔡翔 * @Author: 蔡翔
@ -100,6 +104,8 @@ public class UAService {
Security.addProvider(new BouncyCastleProvider()); Security.addProvider(new BouncyCastleProvider());
} }
@Autowired
WebSocketServer webSocketServer;
private final Logger logger = LoggerFactory.getLogger(getClass()); private final Logger logger = LoggerFactory.getLogger(getClass());
private boolean flag = true; private boolean flag = true;
@ -727,7 +733,8 @@ public class UAService {
//SubscribeEntity 不存在的时候新建一个SubscribeEntity,并且UaSubscription也要新建一个 //SubscribeEntity 不存在的时候新建一个SubscribeEntity,并且UaSubscription也要新建一个
if(currentNow == null){ if(currentNow == null){
try { try {
subscription = client.getSubscriptionManager().createSubscription(1000.0).get(); Double rquestedPubilshInterval = listenTimeInterval;
subscription = client.getSubscriptionManager().createSubscription(rquestedPubilshInterval).get();
}catch (Exception e){ }catch (Exception e){
throw new Exception("在 subscribeForVisit 的时候出现异常,,具体异常是: "+e.getMessage()); throw new Exception("在 subscribeForVisit 的时候出现异常,,具体异常是: "+e.getMessage());
} }
@ -880,8 +887,8 @@ public class UAService {
//SubscribeEntity 不存在的时候新建一个SubscribeEntity,并且UaSubscription也要新建一个 //SubscribeEntity 不存在的时候新建一个SubscribeEntity,并且UaSubscription也要新建一个
if(currentNow == null){ if(currentNow == null){
try { try {
Double rquestedPubilshInterval = samplingInterval;
subscription = client.getSubscriptionManager().createSubscription(1000.0).get(); subscription = client.getSubscriptionManager().createSubscription(rquestedPubilshInterval).get();
}catch (Exception e){ }catch (Exception e){
throw new Exception("在 subscribeForVisit 的时候出现异常,,具体异常是: "+e.getMessage()); throw new Exception("在 subscribeForVisit 的时候出现异常,,具体异常是: "+e.getMessage());
} }
@ -1704,6 +1711,7 @@ public class UAService {
OpcUaClient op = null; OpcUaClient op = null;
try { try {
op = createClient(hashMap.get(key)); op = createClient(hashMap.get(key));
}catch (Exception e){ }catch (Exception e){
logger.error("采集程序启动的时候,尝试连接 "+key +"失败,,可能是网络问题 或者 OPC SERVER问题"); logger.error("采集程序启动的时候,尝试连接 "+key +"失败,,可能是网络问题 或者 OPC SERVER问题");
continue; continue;

View File

@ -10,8 +10,29 @@ import java.util.List;
public class SubscribeVarArgEntity { public class SubscribeVarArgEntity {
List<Integer> listNameSpace; List<Integer> listNameSpace;
List<String> listIdentifier; List<String> listIdentifier;
//采集频率 单位 ms 2000ms = 2s 采集一次
Integer period;
String plcName; String plcName;
public Integer getPeriod() {
return period;
}
public SubscribeVarArgEntity() {
}
public SubscribeVarArgEntity(List<Integer> listNameSpace, List<String> listIdentifier, Integer period, String plcName) {
this.listNameSpace = listNameSpace;
this.listIdentifier = listIdentifier;
this.period = period;
this.plcName = plcName;
}
public void setPeriod(Integer period) {
this.period = period;
}
public List<Integer> getListNameSpace() { public List<Integer> getListNameSpace() {
return listNameSpace; return listNameSpace;
} }

View File

@ -0,0 +1,66 @@
package com.qgs.dc.opcua.selfunion.entity;
/**
* @Desc: ""
* @Author: caixiang
* @DATE: 2020/7/23 14:51
*/
public class SubscribeVarOfConfigEntity {
Integer nameSpace;
String identifier;
//采集频率 单位 ms 2000ms = 2s 采集一次
Integer period;
String plcName;
String nowValue;
public String getNowValue() {
return nowValue;
}
public void setNowValue(String nowValue) {
this.nowValue = nowValue;
}
public Integer getPeriod() {
return period;
}
public SubscribeVarOfConfigEntity() {
}
public SubscribeVarOfConfigEntity(Integer nameSpace, String identifier, Integer period, String plcName) {
this.nameSpace = nameSpace;
this.identifier = identifier;
this.period = period;
this.plcName = plcName;
}
public void setPeriod(Integer period) {
this.period = period;
}
public Integer getNameSpace() {
return nameSpace;
}
public void setNameSpace(Integer nameSpace) {
this.nameSpace = nameSpace;
}
public String getIdentifier() {
return identifier;
}
public void setIdentifier(String identifier) {
this.identifier = identifier;
}
public String getPlcName() {
return plcName;
}
public void setPlcName(String plcName) {
this.plcName = plcName;
}
}

View File

@ -0,0 +1,58 @@
package com.qgs.dc.opcua.taskPool;
import com.qgs.dc.opcua.selfunion.Enum.PLCVar;
import com.qgs.dc.opcua.selfunion.UAService;
import org.eclipse.milo.opcua.stack.core.types.builtin.DataValue;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import java.util.concurrent.Callable;
/**
* @Author: 蔡翔
* @Date: 2019/10/30 16:23
* @Version 1.0
*/
public class MultiWorkRunnable<T> implements Callable<T> {
private final static Logger logger = LoggerFactory.getLogger(MultiWorkRunnable.class);
private UAService uaService;
public MultiWorkRunnable(UAService uaService){
this.uaService = uaService;
}
public MultiWorkRunnable(){
}
public synchronized void initialMultiWorkRunnable(UAService uaService){
this.uaService = uaService;
}
public static void main(String[] args) {
}
@Override
public T call() throws Exception {
Long start = System.currentTimeMillis();
//10000/200
for (int i = 0; i < 60; i++) {
DataValue Byte = uaService.getValue(PLCVar.Byte, "plc2");
DataValue Boolean = uaService.getValue(PLCVar.Boolean, "plc2");
DataValue ByteString = uaService.getValue(PLCVar.ByteString, "plc2");
DataValue plc11 = uaService.getValue(PLCVar.DateTime, "plc2");
DataValue plc12 = uaService.getValue(PLCVar.Double, "plc2");
DataValue plc13 = uaService.getValue(PLCVar.Float, "plc2");
DataValue plc14 = uaService.getValue(PLCVar.Int16, "plc2");
DataValue plc15 = uaService.getValue(PLCVar.Int32, "plc2");
DataValue plc16 = uaService.getValue(PLCVar.Int64, "plc2");
DataValue plc17 = uaService.getValue(PLCVar.Integer, "plc2");
DataValue plc18 = uaService.getValue(PLCVar.String, "plc2");
DataValue plc19 = uaService.getValue(PLCVar.Time, "plc2");
}
Long end = System.currentTimeMillis();
Long res = end-start;
System.out.println(res);
return (T)res;
//return (T(1));
}
}

View File

@ -0,0 +1,39 @@
package com.qgs.dc.opcua.taskPool;
import java.util.concurrent.*;
import java.util.concurrent.atomic.AtomicInteger;
/**
* @Author: 蔡翔
* @Date: 2019/9/23 9:32
* @Version 1.0
*/
public class QGSThreadPool {
public static AtomicInteger threadCount = new AtomicInteger();
public static ThreadPoolExecutor executor = new ThreadPoolExecutor(
200, //核心线程数
400, //最大线程数
1L, // 空闲线程存活时间 这里是一分钟
TimeUnit.MINUTES, // 空闲线程存货的时间单位
new ArrayBlockingQueue<>(200), //一个指定上限的的阻塞队列这个队列中存放着待执行的任务
new ThreadFactory() {
// 自定义一个线程工厂来给线程池里面的线程取名字
@Override
public Thread newThread(Runnable r) {
return new Thread(r, "threadPool-opc-" + threadCount.incrementAndGet());
}
},
new RejectedExecutionHandler() {
// 自定义一个拒绝处理策略安慰被线程池拒之门外的任务
@Override
public void rejectedExecution(Runnable r, ThreadPoolExecutor executor) {
System.out.println("opc read err"+r);
}
}
);
ExecutorService executorService = Executors.newSingleThreadExecutor();
/*public ExecutorService getExecutor(){
return this.executor;
}*/
}

View File

@ -28,59 +28,12 @@ public class S7Controller {
@PostMapping("/addThisPlc") @PostMapping("/addThisPlc")
public R addThisPlc() throws PlcConnectionException { public R addThisPlc() throws PlcConnectionException {
Integer plc1 = s7Service.addPlc("plc1", "s7://192.168.0.200"); //s7://192.168.1.51?remote-rack=0&remote-slot=3&controller-type=S7_400,如果参数不是默认的 要向这样往url 后面加
return R.ok().put("res",plc1); return R.ok().put("res",s7Service.addPlc("s7://192.168.0.200"));
} }
@PostMapping("/getValue") @PostMapping("/getValue")
public R getValue() throws PlcConnectionException { public R getValue() throws PlcConnectionException {
try(PlcConnection conn = s7Service.getConnection("s7://192.168.0.200")) {
if(conn.isConnected()){
if(conn.getMetadata().canRead()){
try {
PlcReadRequest.Builder builder = conn.readRequestBuilder();
//builder.addItem("INT_1", "%DB10:4:INT");
//builder.addItem("Byte-array", "%DB10:312:BYTE[20]");
builder.addItem("STRING", "%DB10:10.0:STRING(20)");
PlcReadRequest readRequest = builder.build();
//PlcReadResponse response = readRequest.execute().get();
CompletableFuture<? extends PlcReadResponse> execute = readRequest.execute();
PlcReadResponse response = execute.get();
for (String fieldName : response.getFieldNames()) {
if(response.getResponseCode(fieldName) == PlcResponseCode.OK) {
int numValues = response.getNumberOfValues(fieldName);
PlcValue asPlcValue = response.getAsPlcValue();
if(numValues == 1) {
Object obj = response.getObject(fieldName);
logger.info("Value[" + fieldName + "]: " + response.getObject(fieldName));
}
else {
logger.info("Value[" + fieldName + "]:");
for(int i = 0; i < numValues; i++) {
logger.info(" - " + response.getObject(fieldName, i));
}
}
}
else {
logger.error("Error[" + fieldName + "]: " + response.getResponseCode(fieldName).name());
}
}
}catch (Exception e){
logger.error(e.getMessage());
}
}else {
System.out.println("断线后 不能 read");
}
}else {
System.out.println("conn 为 connected");
}
}catch (Exception e){
System.out.println(e.getMessage());
}
return R.ok().put("res",1); return R.ok().put("res",1);

View File

@ -0,0 +1,28 @@
package com.qgs.dc.s7.enums;
import org.apache.plc4x.java.PlcDriverManager;
import org.apache.plc4x.java.api.PlcConnection;
import org.apache.plc4x.java.api.exceptions.PlcConnectionException;
import org.apache.plc4x.java.utils.connectionpool.PooledPlcDriverManager;
/**
* @Author: 蔡翔
* @Date: 2019/12/5 14:53
* @Version 1.0
*/
public enum S7DriveManage {
INSTANCE("driverManagerPool", new PooledPlcDriverManager())
;
PlcDriverManager driverManager;
private String desc;
S7DriveManage(String desc, PooledPlcDriverManager object){
this.driverManager = object;
this.desc = desc;
}
public PlcDriverManager getInstance(){
return this.driverManager;
}
}

View File

@ -1,8 +1,13 @@
package com.qgs.dc.s7.service; package com.qgs.dc.s7.service;
import com.qgs.dc.s7.enums.S7DriveManage;
import org.apache.plc4x.java.PlcDriverManager; import org.apache.plc4x.java.PlcDriverManager;
import org.apache.plc4x.java.api.PlcConnection; import org.apache.plc4x.java.api.PlcConnection;
import org.apache.plc4x.java.api.exceptions.PlcConnectionException; import org.apache.plc4x.java.api.exceptions.PlcConnectionException;
import org.apache.plc4x.java.api.messages.PlcReadRequest;
import org.apache.plc4x.java.api.messages.PlcReadResponse;
import org.apache.plc4x.java.api.types.PlcResponseCode;
import org.apache.plc4x.java.api.value.PlcValue;
import org.apache.plc4x.java.utils.connectionpool.PooledPlcDriverManager; import org.apache.plc4x.java.utils.connectionpool.PooledPlcDriverManager;
import org.apache.plc4x.java.utils.connectionpool2.CachedDriverManager; import org.apache.plc4x.java.utils.connectionpool2.CachedDriverManager;
import org.eclipse.milo.opcua.sdk.client.OpcUaClient; import org.eclipse.milo.opcua.sdk.client.OpcUaClient;
@ -10,7 +15,10 @@ import org.slf4j.Logger;
import org.slf4j.LoggerFactory; import org.slf4j.LoggerFactory;
import org.springframework.stereotype.Component; import org.springframework.stereotype.Component;
import java.util.ArrayList;
import java.util.HashMap; import java.util.HashMap;
import java.util.List;
import java.util.concurrent.CompletableFuture;
/** /**
* @Desc: "" * @Desc: ""
@ -27,17 +35,70 @@ public class S7Service {
public S7Service(){ public S7Service(){
driverManager = new PooledPlcDriverManager(); driverManager = S7DriveManage.INSTANCE.getInstance();
} }
public Integer addPlc(String plcName,String url) throws PlcConnectionException { public boolean addPlc(String url) throws PlcConnectionException {
PlcConnection connection = driverManager.getConnection(url);
return connection.isConnected();
return 1;
} }
public PlcConnection getConnection(String url) throws PlcConnectionException { //url : s7://192.168.0.200
//address : %DB10:10.0:STRING(20)
//get 一个或者多个value
public Object getValue(String url,HashMap<String,String> listAddress) throws PlcConnectionException {
try(PlcConnection conn = driverManager.getConnection(url)) {
if(conn.isConnected()){
if(conn.getMetadata().canRead()){
try {
PlcReadRequest.Builder builder = conn.readRequestBuilder();
for(String key:listAddress.keySet()){
builder.addItem(key, listAddress.get(key));
}
PlcReadRequest readRequest = builder.build();
CompletableFuture<? extends PlcReadResponse> execute = readRequest.execute();
PlcReadResponse response = execute.get();
for (String fieldName : response.getFieldNames()) {
if(response.getResponseCode(fieldName) == PlcResponseCode.OK) {
int numValues = response.getNumberOfValues(fieldName);
PlcValue asPlcValue = response.getAsPlcValue();
if(numValues == 1) {
Object obj = response.getObject(fieldName);
logger.info("Value[" + fieldName + "]: " + response.getObject(fieldName));
return obj;
}
else {
logger.info("Value[" + fieldName + "]:");
List<Object> res = new ArrayList<>();
for(int i = 0; i < numValues; i++) {
logger.info(" - " + response.getObject(fieldName, i));
res.add(response.getObject(fieldName,i));
}
}
}
else {
logger.error("Error[" + fieldName + "]: " + response.getResponseCode(fieldName).name());
}
}
}catch (Exception e){
logger.error(e.getMessage());
}
}else {
System.out.println("can not read");
}
}else {
System.out.println("conn not connected");
}
}catch (Exception e){
System.out.println(e.getMessage());
}
return driverManager.getConnection(url); return driverManager.getConnection(url);
} }
} }