四、Node-OPCUA 进阶(2)-OPCUA服务器(一)

1.0 写一个简单的node-opcua服务器

在这个示例中,我们在默认端口上创建了一个空的OPCUA Server。 端点URL是opc.tcp://HOSTNAME:26543,其中HOSTNAME是计算机的名称。

程序结构:

javascript 复制代码
const { OPCUAServer } = require("node-opcua");
(async () => {
try {
_"服务器代码"
}
catch(err) {
}
})();

服务器代码:

javascript 复制代码
const server = new OPCUAServer({ port: 26543 });
await server.start();
const endpointUrl = server.endpoints[0].endpointDescriptions()[0].endpointUrl;
console.log(
"  服务器启动成功,可以通过 url访问端点:  ",
endpointUrl
);
console.log("按 CTRL+C 停止服务");

完整的程序代码 my_ first**_server.js:**

javascript 复制代码
const { OPCUAServer } = require("node-opcua");
(async () => {
    try {
        const server = new OPCUAServer({ port: 26543 });
        await server.start();
        const endpointUrl = server.endpoints[0].endpointDescriptions()[0].endpointUrl;
        console.log(
            " 服务器启动成功,可以通过 url访问端点: ",
            endpointUrl
        );
        console.log("按 CTRL+C 停止服务");
    }
    catch (err) {
    }
})();
2.0 用Typescript创建一个opcua服务器

让我们添加chalk模块,它将允许我们在控制台上生成彩色信息。

javascript 复制代码
npm install chalk

下面是代码,程序的框架如下:

javascript 复制代码
// my_first_server_step-1_typescript.ts
import { OPCUAServer, ServerState, coerceLocalizedText } from "node-opcua";
import * as chalk from "chalk";
(async () => {
try {
_"服务器代码"
_"关闭管理"
}
catch(err) {
console.log("error", err);
process.exit(-1);
}
})();

服务器代码

javascript 复制代码
const server = new OPCUAServer({ port: 26543 });
await server.start();
const endpointUrl = server.endpoints[0].endpointDescriptions()[0].endpointUrl;
console.log(" 服务器已运行在 ", endpointUrl);
console.log("按 CTRL+C 停止服务");

关闭管理

让我们添加一些代码来优雅地关闭服务器。当用户按下CTRL+C启动服务器的关闭过程时,我们将进行拦截。

javascript 复制代码
process.on("SIGINT", () => {
_"防止重新输入"
console.log(" 收到来自用户的服务器中断 ");
console.log(" 关闭 ...");
server.engine.serverStatus.shutdownReason = coerceLocalizedText("被管理员关闭");
server.shutdown(10000, () => {
console.log(" 关闭结束 ");
console.log(" 完成 ");
process.exit(0);
});
});

防止重新输入

用户可能重复按CTRL+C,我们不希望多次调用shutdown。我们可以通过检查服务器状态来防止这种情况。

javascript 复制代码
if (server.engine.serverStatus.state === ServerState.Shutdown) {
console.log(
"服务器关闭已经请求...关闭将发生在 ",
server.engine.serverStatus.secondsTillShutdown,
"秒"
);
return;
}

运行服务器

my_first_server_step-1_typescript.ts

javascript 复制代码
npx ts-node-script my_first_server_step-1_typescript.ts
2.1 指定buildInfo

在这个示例中,我们在一个自定义端口上创建了一个空的OPCUA服务器,我们还在buildInfo中设置了一些额外的参数。

端点URL是opc.tcp://HOSTNAME:26543,其中HOSTNAME是计算机的名称。

my_first_server_step2.ts

javascript 复制代码
//my_first_server_step2.ts
import { OPCUAServer } from "node-opcua";
(async function main() {
try {
const server = new OPCUAServer({
port: 26543,
buildInfo: {
manufacturerName: "公司名",
productName: "我的第一个OPCUA服务器",
softwareVersion: "1.0.0"
},
});
await server.start();
const endpointUrl = server.endpoints[0].endpointDescriptions()[0].endpointUrl!;
console.log(" 服务器已运行在 ", endpointUrl);
console.log("按 CTRL+C 停止服务");
} catch (err) {
console.log("error", err);
process.exit(-1);
}
})();
相关推荐
codingWhat1 天前
整理「祖传」代码,就是在开发脚手架?
前端·javascript·node.js
ServBay1 天前
Node.js、Bun 与 Deno,2026 年后端运行时选择指南
node.js·deno·bun
码路飞2 天前
Node.js 中间层我维护了两年,这周终于摊牌了——成本账单算完我人傻了
node.js
None3213 天前
【NestJs】使用Winston+ELK分布式链路追踪日志采集
javascript·node.js
Dilettante2583 天前
这一招让 Node 后端服务启动速度提升 75%!
typescript·node.js
Mr_li3 天前
NestJS 集成 TypeORM 的最优解
node.js·nestjs
UIUV4 天前
node:child_process spawn 模块学习笔记
javascript·后端·node.js
前端付豪5 天前
Nest 项目小实践之注册登陆
前端·node.js·nestjs
天蓝色的鱼鱼5 天前
Node.js 中间层退潮:从“前端救星”到“成本噩梦”
前端·架构·node.js
codingWhat5 天前
uniapp 多地区、多平台、多环境打包方案
前端·架构·node.js