

8:56, EEST

June 27, 2018

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!
10:55, EEST

April 3, 2012

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?
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, tammara49zModerators: Jouni Aro: 1029, Pyry: 1, Petri: 0, Bjarne Boström: 1041, Jimmy Ni: 26, Matti Siponen: 353, Lusetti: 0, Elias: 0
Administrators: admin: 1