Avatar

Please consider registering
guest

sp_LogInOut Log In sp_Registration Register

Register | Lost password?
Advanced Search

— Forum Scope —




— Match —





— Forum Options —





Minimum search word length is 3 characters - maximum search word length is 84 characters

sp_Feed Topic RSS sp_TopicIcon
NodeManagerUaNode / NodeManagerRoot loading Opc.Ua.NodeSet2.xml very slow on specific hardware platform
April 2, 2025
8:56, EEST
Avatar
Hendrik Ulbrich
Member
Members
Forum Posts: 15
Member Since:
June 27, 2018
sp_UserOfflineSmall Offline

Hello!

In our OPC UA server Implementation, we have implemented our own “TandemNodeManager” which is extended by the NodeManagerUaNode.

In the constructor, we only have the super() call.
In the @Override method init(), there is a super.init() followed by createAddressSpace(), which then contains our own code.

In the OPC UA server, the certificates are loaded last in initialize(), and then the custom NodeManager is instantiated.
That’s all from your code examples.

We didn’t notice anything unusual under Windows during development.
However, when we run the implementation on our hardware platform, I see the following log entries:

07:32:20.091 INFO [main] c.prosysopc.ua.ApplicationIdentity | Reading application certificate from /usr/local/***_2048.der
07:32:20.103 INFO [main] c.prosysopc.ua.ApplicationIdentity | Reading private key from keystore /usr/local/***_2048.pem
07:32:25.836 INFO [main] c.p.ua.server.NodeManagerRoot | Loading information model jar:file:/var/lib/***/prosys-opc-ua-sdk-client-server-5.2.2-139.jar!/com/prosysopc/ua/types/opcua/server/Opc.Ua.NodeSet2.xml
07:32:51.498 INFO [main] c.p.ua.server.NodeManagerRoot | Loaded: ModelInfo [namespace=http://opcfoundation.org/UA/, version=1.05.03, publicationDate=12/15/23 00:00:00.0000000 GMT, dependencies=[]]

After that, the first log entry from the createAddressSpace() follows:
07:33:16.217 INFO [main] c.m.h.o.opcserver.TandemNodeManager | [..] createAddressSpace

So we need > 50 seconds for this section. Of that, ~26 seconds are for loading the Opc.Ua.NodeSet2.xml.
It is known that our hardware platform is inefficient when processing XML files.

Is there a way to speed this up?
And what else is done after the XML has been loaded, which explains the remaining ~25 seconds?

Thank you for your help!

April 2, 2025
10:55, EEST
Avatar
Bjarne Boström
Moderator
Moderators
Forum Posts: 1041
Member Since:
April 3, 2012
sp_UserOfflineSmall Offline

Hi,

After loading SDK does set some initial values related to the ‘Server’ node. Shouldn’t take long, though normally the loading part also takes few seconds.

There is a background thread named “StandardOPCUANodeSetMemoryCompress” that starts as the last step of the core/standard model loading. It creates an internal representation of the model that avoids loading the XML, if it ever would need to happen again on the same JVM run. Generally speaking, I wouldn’t expect it to matter performance-wise, but maybe on your platform it does?

Note that there is also the part for the loading that creates the UaNodes that represent the address space for the core model. Normally that part takes more than the XML loading itself.

Can you run a profiler tool to show which methods take up time?

Forum Timezone: Europe/Helsinki

Most Users Ever Online: 1919

Currently Online:
28 Guest(s)

Currently Browsing this Page:
1 Guest(s)

Top Posters:

Heikki Tahvanainen: 402

hbrackel: 144

rocket science: 90

pramanj: 86

Francesco Zambon: 83

Ibrahim: 78

Sabari: 62

kapsl: 57

gjevremovic: 49

Xavier: 43

Member Stats:

Guest Posters: 0

Members: 784

Moderators: 8

Admins: 1

Forum Stats:

Groups: 3

Forums: 15

Topics: 1543

Posts: 6508

Newest Members:

anglea06o05589, matsa, Jameshax, Jeffreyfledy, lilliefalconer, Olpsom, shastaappleton, hildred39i, Adam, tammara49z

Moderators: Jouni Aro: 1029, Pyry: 1, Petri: 0, Bjarne Boström: 1041, Jimmy Ni: 26, Matti Siponen: 353, Lusetti: 0, Elias: 0

Administrators: admin: 1