基于Java的OPCDA采集中间件

1.软件功能及技术特点简介:

软件功能及技术特点简介:

OPCDA是基于Java语言开发的OPC client(OPC客户端)跨平台中间件软件,他支持OPC SERVER的OPC DA1.0/2.0/3.0。OPCDA实时采集数据(包括实时数据、报警数据、历史变化数据等),同时提供MQTT发布订阅功能,为工业大数据平台提供现场基础数据支撑,且适用于所有的工业控制行业。

1、支持读取OPC DA1.0、2.0、3.0;

2、支持MQTT物联网功能,发布内容包括实时值、报警等内容;

3、支持操作系统(Windows);

4、适用于工业互联进程中的车间-车间、车间-厂集控中心、厂集控中心-地区集控中

心。

5.采集频率在5s以上,支持5000点位采集。

2.程序配置


1.jre opcdaclient.exe运行所需的java环境

2.lib opcda采集需要的dll文件

3.config.properties 配置文件,程序会默认读取同级目录下的配置文件

4.pointconfig.xlsx文件是点位表,程序会读取同级目录下的pointconfig.xlsx

3.程序界面

双击opcdaclient.exe

OPC服务设置:

输入OPC服务器地址点击游览,查找opcDA服务,点击连接。

点击同步指标,将pointconfig.xlsx文件的点位信息同步显示出来。

采集频率自定义设置不能低于1000ms

MQTT服务设置

输入服务地址,端口 ,用户名和密码。点击连接,如果成功日志会显示MQTT连接成功。

会自动按照采集频率去发送MQTT。

4.部分代码

java 复制代码
```java
// 主面板使用BorderLayout
        JPanel mainPanel = new JPanel(new BorderLayout(10, 10));
        mainPanel.setBorder(BorderFactory.createEmptyBorder(10, 10, 10, 10));

        // 左侧面板(使用BorderLayout垂直排列)
        JPanel leftPanel = new JPanel(new BorderLayout(5, 5));

        // 顶部面板 - OPC和MQTT设置
        JPanel settingsPanel = new JPanel(new GridLayout(2, 1, 5, 5));
        settingsPanel.add(createOpcPanel());
        settingsPanel.add(createMqttPanel());
        leftPanel.add(settingsPanel, BorderLayout.NORTH);

        // 中间表格
        dataTable = new JTable(new DefaultTableModel(
                new String[]{"ItemID", "类型", "值", "质量"}, 0));
        JScrollPane tableScroll = new JScrollPane(dataTable);
        tableScroll.setBorder(BorderFactory.createTitledBorder("数据表格"));
        leftPanel.add(tableScroll, BorderLayout.CENTER);

        // 右侧日志面板(使用JPanel包装确保正确布局)
        JPanel rightPanel = new JPanel(new BorderLayout());
        rightPanel.setPreferredSize(new Dimension(350, 0));
java 复制代码
// 新增方法:更新采集频率
    private void updateCollectFrequency() {
        try {
            int newInterval = Integer.parseInt(collectFrequencyField.getText());
            if (newInterval < 999) {
                logMessage("警告: 采集频率不能低于999ms");
                return;
            }

            if (newInterval != collectInterval) {
                collectInterval = newInterval;
                logMessage("采集频率已设置为: " + collectInterval + "ms");

                // 如果正在采集,则重新启动定时器
                if (collectTimer != null && collectTimer.isRunning() &&
                        jopc != null && jopc.ping()) {
                    //startDataCollection(); // 这会自动停止旧的定时器并创建新的
                    readAllIndicatorValues();
                }
            }
        } catch (NumberFormatException e) {
            logMessage("错误: 请输入有效的数字");
        }
    }

如有需要请私聊。

相关推荐
SunnyRivers4 天前
LangChain中间件详解
中间件·langchain
金刚猿4 天前
06_虚拟机中间件部署_xxl-job 部署
中间件·xxl-job·xxl-job-admin
Loo国昌5 天前
【AI应用开发实战】Guardrail风险控制中间件:Agent系统的安全防线
人工智能·python·安全·自然语言处理·中间件·prompt
键盘鼓手苏苏6 天前
Flutter for OpenHarmony: Flutter 三方库 ntp 精准同步鸿蒙设备系统时间(分布式协同授时利器)
android·分布式·算法·flutter·华为·中间件·harmonyos
Coder_Boy_6 天前
Java后端核心技术体系全解析(个人总结)
java·开发语言·spring boot·分布式·spring cloud·中间件
CN-David6 天前
CentOS搭建Mycat中间件
linux·mysql·中间件·centos·mariadb
三水不滴7 天前
消息队列消费性能优化:批量消费 + 手动 ACK 提升吞吐量
经验分享·笔记·中间件·性能优化
nix.gnehc7 天前
Go进阶攻坚+专家深耕级学习清单|聚焦高并发、高性能中间件/底层框架开发(Java开发者专属)
学习·中间件·golang
金刚猿8 天前
05_虚拟机中间件部署_ubuntu 系统 安装 Redis 7.0.15
redis·ubuntu·中间件
GEM的左耳返8 天前
Java面试深度剖析:从JVM到云原生的技术演进
jvm·spring boot·云原生·中间件·java面试·分布式架构·ai技术