0

0

如何使用 asyncua 检查 OPC UA 节点是否存在并按需创建

碧海醫心

碧海醫心

发布时间:2026-03-10 22:17:08

|

809人浏览过

|

来源于php中文网

原创

本文介绍如何在 python 中借助 asyncua 库安全、可靠地检查指定 nodeid 的 opc ua 节点是否已存在于服务器上;若存在则复用,若不存在则可触发创建逻辑,适用于客户端重启后与服务端节点状态同步的典型工业场景。

本文介绍如何在 python 中借助 asyncua 库安全、可靠地检查指定 nodeid 的 opc ua 节点是否已存在于服务器上;若存在则复用,若不存在则可触发创建逻辑,适用于客户端重启后与服务端节点状态同步的典型工业场景。

在基于 OPC UA 的工业物联网应用中,客户端常需动态管理服务器地址空间(如创建变量、对象或方法节点)。但服务器可能持久化节点(如使用 UaServer 或自定义持久化配置),也可能在重启后清空地址空间。因此,客户端每次重连后必须幂等地校验目标节点是否存在,避免重复创建(引发 BadNodeIdExists 错误)或读写失败(因 BadNodeIdUnknown)。

asyncua 并未提供直接的 node.exists() 接口,但可通过“试探性读取一个轻量级属性”来实现存在性判断。最推荐的方式是调用 read_browse_name() —— 它仅访问节点的浏览名(BrowseName),不涉及值、时间戳或权限等复杂属性,响应快、开销低,且对几乎所有合规节点都有效(包括对象、变量、方法等)。

以下是一个健壮的异步检查函数示例:

OneAI
OneAI

将生成式AI技术打包为API,整合到企业产品和服务中

下载
from asyncua import Client
from asyncua.ua import StatusCodes

async def node_exists(client: Client, node_id: str) -> bool:
    """
    检查指定 NodeId 的节点是否存在于 OPC UA 服务器上。

    Args:
        client: 已连接的 asyncua.Client 实例
        node_id: 合法的 NodeId 字符串,例如 "ns=4;s=MyVariable" 或 "i=2253"

    Returns:
        bool: True 表示节点存在且可访问;False 表示节点不存在(或无权限)
    """
    node = client.get_node(node_id)
    try:
        await node.read_browse_name()  # 成功即表明节点存在且可浏览
        return True
    except Exception as e:
        # 精确捕获更佳:from asyncua.ua.errors import BadNodeIdUnknown
        if hasattr(e, 'code') and e.code == StatusCodes.BadNodeIdUnknown:
            return False
        # 其他异常(如权限不足 BadNotReadable)不视为“不存在”,按需处理
        raise e

# 使用示例
async def main():
    client = Client("opc.tcp://localhost:4840")
    try:
        await client.connect()

        target_node_id = "ns=4;s=Production/CurrentTemperature"

        if await node_exists(client, target_node_id):
            print(f"✅ 节点 {target_node_id} 已存在,直接使用")
            node = client.get_node(target_node_id)
            # 后续操作:读值、写值、订阅等
        else:
            print(f"⚠️  节点 {target_node_id} 不存在,开始创建...")
            # 示例:在 Objects 文件夹下创建新变量(需根据实际地址空间结构调整)
            objects = await client.nodes.objects.get_children()
            parent = objects[0]  # 假设第一个子节点为父容器
            await parent.add_variable(2, "CurrentTemperature", 25.6, varianttype="Double")

    finally:
        await client.disconnect()

? 关键注意事项:

  • 优先使用 read_browse_name():相比 read_value() 或 read_attribute(),它不依赖节点是否可读/是否有值,兼容性更高;
  • ⚠️ 异常处理要精准:仅当 StatusCodes.BadNodeIdUnknown 时判定为“不存在”;其他错误(如 BadNotReadable、BadTimeout)需单独处理,不可一概而论;
  • ? 权限与会话状态:确保 client 已成功 connect() 且会话有效;若服务端启用了访问控制,还需确认当前用户拥有 Browse 权限;
  • ? 命名空间一致性:node_id 必须严格匹配服务端注册的命名空间索引(ns=)和标识符(s= 字符串 / i= 数字),建议从服务端地址空间浏览器中复制验证;
  • ? 幂等性保障:该检查应作为节点创建流程的前置步骤,配合 try/except 创建逻辑,确保多次执行不会破坏服务端结构。

通过上述方法,您可构建高鲁棒性的 OPC UA 客户端,在动态环境(如边缘设备断连重连、服务端版本升级或配置重置)中自动适配服务端状态,显著提升系统可靠性与可维护性。

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
mysql标识符无效错误怎么解决
mysql标识符无效错误怎么解决

mysql标识符无效错误的解决办法:1、检查标识符是否被其他表或数据库使用;2、检查标识符是否包含特殊字符;3、使用引号包裹标识符;4、使用反引号包裹标识符;5、检查MySQL的配置文件等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

209

2023.12.04

Python标识符有哪些
Python标识符有哪些

Python标识符有变量标识符、函数标识符、类标识符、模块标识符、下划线开头的标识符、双下划线开头、双下划线结尾的标识符、整型标识符、浮点型标识符等等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

322

2024.02.23

java标识符合集
java标识符合集

本专题整合了java标识符相关内容,想了解更多详细内容,请阅读下面的文章。

292

2025.06.11

c++标识符介绍
c++标识符介绍

本专题整合了c++标识符相关内容,阅读专题下面的文章了解更多详细内容。

177

2025.08.07

js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

760

2023.08.03

js截取字符串的方法
js截取字符串的方法

js截取字符串的方法有substring()方法、substr()方法、slice()方法、split()方法和slice()方法。本专题为大家提供字符串相关的文章、下载、课程内容,供大家免费下载体验。

220

2023.09.04

java基础知识汇总
java基础知识汇总

java基础知识有Java的历史和特点、Java的开发环境、Java的基本数据类型、变量和常量、运算符和表达式、控制语句、数组和字符串等等知识点。想要知道更多关于java基础知识的朋友,请阅读本专题下面的的有关文章,欢迎大家来php中文网学习。

1564

2023.10.24

字符串介绍
字符串介绍

字符串是一种数据类型,它可以是任何文本,包括字母、数字、符号等。字符串可以由不同的字符组成,例如空格、标点符号、数字等。在编程中,字符串通常用引号括起来,如单引号、双引号或反引号。想了解更多字符串的相关内容,可以阅读本专题下面的文章。

649

2023.11.24

Go高并发任务调度与Goroutine池化实践
Go高并发任务调度与Goroutine池化实践

本专题围绕 Go 语言在高并发任务处理场景中的实践展开,系统讲解 Goroutine 调度模型、Channel 通信机制以及并发控制策略。内容包括任务队列设计、Goroutine 池化管理、资源限制控制以及并发任务的性能优化方法。通过实际案例演示,帮助开发者构建稳定高效的 Go 并发任务处理系统,提高系统在高负载环境下的处理能力与稳定性。

4

2026.03.10

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号