现在使用java来做工控系统的几种方式:

知识储备:

一、OPC Server端目前常见的有以下几种协议:

参考博客:
https://www.cnblogs.com/ioufev/articles/9697717.html

https://www.cnblogs.com/ioufev/articles/9697890.html

二、DOCM的配置

可以参考https://www.cnblogs.com/ioufev/p/9365919.html

三、OPCServer服务器属性

java 获取OPCServer的方式有两种,

1、jeasyopc:适用于32位操作系统

2、Utgrad :可跨平台

 
 

可以根据具体情况具体分析,相比较对于初次接触来说jeasyopc相对简单。

四、试验模拟OPC

1、实验用模拟OPCServer(50M):MatrikonOPC

2、实际OPCServer使用(450M,中文):KEPServer V6

Utgard:

官网:http://openscada.org/projects/utgard/

博客参考

https://www.cnblogs.com/ioufev/articles/9894452.html

https://elfasd.iteye.com/blog/2064410

JeasyOPC:

博客参考:

https://blog.csdn.net/qq_33720460/article/details/78478430

https://blog.csdn.net/wangzhi291/article/details/45029799

https://blog.csdn.net/diyu122222/article/details/77645668

五:本人只采用了UtgradUt开发用例

/**

*  OPCServer 客户端连接

*/

public class UtgrandClient {

private final String LOCAL_HOST="10.0.0.17";//OPCServer服务器IP

private final String USER_NAME ="OPCServer";//DOCM配置时OPCServer的用户名

private final String PASS_WORD ="Admin123";//密码

private final String  CLS_ID ="7BC0CC8E-482C-47CA-ABDC-0FE7F9C6E729";//cls_id

private final String  DOMAIN ="";

private  int count;

Server server =null;

public  void utGrandReadData(){

System.out.print("*********************************");

System.out.print("************启动加载配置项*********");

System.out.print("*********************************");

final  ConnectionInformation ci =new ConnectionInformation();

ci.setHost(LOCAL_HOST);

ci.setUser(USER_NAME);

ci.setPassword(PASS_WORD);

ci.setClsid(CLS_ID);

ci.setDomain(DOMAIN);

if (ci.getClsid() !=null ){

JISession  session = JISession.createSession ( ci.getDomain (),ci.getUser (),ci.getPassword () );

session.setGlobalSocketTimeout ((int) System.currentTimeMillis());

session.useSessionSecurity(true);

server =new Server(ci,Executors.newSingleThreadScheduledExecutor());

}else if (ci.getProgId () !=null){

JISession session = JISession.createSession ( ci.getDomain (), ci.getUser (), ci.getPassword () );

session.setGlobalSocketTimeout ((int) System.currentTimeMillis());

session.useSessionSecurity(true);

server =new Server(ci,Executors.newSingleThreadScheduledExecutor());

}

try {

server.connect();

Group group = server.addGroup("VC");

Item item = group.addItem("k.k.k");

//    Map items = group.addItems("Random.Real1",

//          "Random.Real2", "Random.Real3", "Random.Real4");

dumpItem(item);

//    for (Entry temp : items.entrySet()) {

//      dumpItem(temp.getValue());

//    }

}catch (Exception e) {

e.printStackTrace();

}

}

/**

* 读取监测点

* @param item

* @throws JIException

*/

private  void dumpItem(Item item)throws JIException {

System.out.println("[" + (++count) +"],ItemName:[" + item.getId()

+"],value:" + item.read(true).getValue());

}

}

/**

* 使用线程来控制 opc client连接,优化运行机内存。(48小时测试内存无增长)

*/

public class ThreadUtgrad {

private Date date;//对象锁

private boolean flag =false;//控制唤醒或等待线程

public ThreadUtgrad() {

date =new Date();

}

public ThreadUtgrad(Date date){

this.date = date;

}

public void run() {

while(true){

synchronized(date){

if(flag){

try {

Thread.sleep(500);

}catch (InterruptedException e) {

e.printStackTrace();

}

date.notify();

flag =false;

}

}

}

}

public Date getDate() {

return date;

}

public void setDate(Date date) {

this.date = date;

}

class PrintMessageextends Thread{

@Override

public void run() {

UtgrandClient utgrandClient =new UtgrandClient();

while(true){

synchronized(date){

if(!flag){

try {

flag =true;

date.wait();

}catch (InterruptedException e) {

e.printStackTrace();

}

}

System.out.println("0.5秒的消息");

utgrandClient.utGrandReadData();

}

}

}

}

@PostConstruct

public void startUtgrandClient() {

Date date =new Date();

//打印5秒消息的线程

ThreadUtgrad threadUtgrad =new ThreadUtgrad(date);

PrintMessage printMessage = threadUtgrad.new PrintMessage();

printMessage.start();

threadUtgrad.run();

//        //不影响打印线程的7秒消息线程

//        new Thread(new Runnable(){

//

//            @Override

//            public void run() {

//                while(true){

//                    try {

//                        Thread.sleep(7000);

//                    } catch (InterruptedException e) {

//                        e.printStackTrace();

//                    }

//                    System.out.println("7秒的消息");

//                }

//

//            }

//

//        }).start();

}

作者:MartinX_c56e
链接:https://www.jianshu.com/p/afb45f585731
来源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

opc 带有session的更多相关文章

  1. php中session原理及安全性问题

    有一点我们必须承认,大多数web应用程序都离不开session的使用.这篇文章将会结合php以及http协议来分析如何建立一个安全的会话管理机制   我们先简单的了解一些http的知识,从而理解该协议 ...

  2. ASP.NET中的Session怎么正确使用

    Session对象用于存储从一个用户开始访问某个特定的aspx的页面起,到用户离开为止,特定的用户会话所需要的信息.用户在应用程序的页面切换时,Session对象的变量不会被清除. 对于一个Web应用 ...

  3. session 安全相关

    有一点我们必须承认,大多数web应用程序都离不开session的使用.这篇文章将会结合php以及http协议来分析如何建立一个安全的会话管理机制.我们先简单的了解一些http的知识,从而理解该协议的无 ...

  4. php中session机制的详解

    [补充]session_start()要放在php最前面,header()函数也要放在session_start()之后. [读了下面的文章转载的文章后自己的理解]: 1,通过phpinfo()函数可 ...

  5. ASP.NET中的Session怎么正确使用[转]

    Session对象用于存储从一个用户开始访问某个特定的aspx的页面起,到用户离开为止,特定的用户会话所需要的信息.用户在应用程序的页面切换时,Session对象的变量不会被清除. 对于一个Web应用 ...

  6. Session的工作机制详解和安全性问题(PHP实例讲解)

    我们先简单的了解一些http的知识,从而理解该协议的无状态特性.然后,学习一些关于cookie的基本操作.最后,我会一步步阐述如何使用一些简单,高效的方法来提高你的php应用程序的安全性以及稳定行. ...

  7. 集群session的一致性

    一. 何为session 用户使用网站的服务,基本上需要浏览器和web服务器进行多次交互,web服务器如何知道哪些请求是来自哪个会话的? 具体方式为:在会话开始时,分配一个唯一的会话标识(sessio ...

  8. 【译文】漫谈ASP.NET中的Session

    最近这两天被一个Web Farm环境下的Session处理问题虐得很痛苦,网上到处找解决方案,在无意中翻看到这篇文章,感觉很不错,顺手查了一下,貌似没有现成的译文,于是一咬牙一跺脚把这篇文章翻译出来了 ...

  9. 【转】你必须了解的Session的本质

    有一点我们必须承认,大多数web应用程序都离不开session的使用.这篇文章将会结合php以及http协议来分析如何建立一个安全的会话管理机制.我们先简单的了解一些http的知识,从而理解该协议的无 ...

随机推荐

  1. 字符串的新方法——includes() padStart() padEnd()

    ES6为字符串提供了一个新方法,叫做String.prototype.includes('要包含的字符串'),如果包含,则返回字符串,否则返回false 使用ES6中的字符串新方法String.pro ...

  2. investigate issues of real time interrupted

    Issues: customer report that real time will interrupted frequently as below: Root Cause: some storm ...

  3. flutter布局-1-column

    1.mainAxisAlignment:主轴布局方式,column主轴方向是垂直的方向   mainaxis.png 默认值:MainAxisAlignment.start: start ,沿着主轴方 ...

  4. 数据库学习之一--DBMS种类

    一.定义 数据库(DB):数据库是将大量数据保存尔来,通过计算机加工而成的可以进行高效访问的数据集合: 数据库管理系统(DBMS):是一种操纵和管理数据库信息的大型管理软件,用于建立,使用和维护数据库 ...

  5. 提交项目到Github

    create a new repository on the command line git init git add README.md git commit -m "first com ...

  6. sick 激光

    sick10:TiM561-2050101https://www.sick.com/cn/zh/detection-and-ranging-solutions/2d-lidar-/tim5xx/tim ...

  7. springboot+mybatis+druid+sqlite/mysql/oracle

    搭建springboot+mybatis+druid+sqlite/mysql/oracle附带测试 1.版本 springboot2.1.6 jdk1.8 2.最简springboot环境 http ...

  8. XMLHttpRequest Level2 新功能

    XMLHttpRequest是浏览器的接口,使得javascript可以进行HTTP(S)通信: 2008年2月,就提出了XMLHttpRequest Level 2 草案. 这个XMLHttpReq ...

  9. ArcGIS超级工具SPTOOLS-按属性裁剪,矢量数据批量裁剪,矢量数据批量合库

    1.1  按属性裁剪 操作视频: https://weibo.com/tv/v/HwaZRoosq?fid=1034:4376687438183117 按属性裁剪:可以图形表,也可以是非图形表,字段值 ...

  10. 安装Mysql-5.7.13脚本

    安装Mysql-5.7.13,此脚本最后会查找到临时密码,后面登进数据库中更改密码 [root@ZHONG-LONG javascripts]# vim -mysql.sh #!/bin/bash # ...