17:59, EEST
January 26, 2024
Hi!
We changed to the latest version (5) of the client and also server in our simulator.
We get this error when logging into the simulator from our client after some time, about 45 minutes.
Restarting and it works again.
Caused by: com.prosysopc.ua.stack.common.ServiceResultException: Bad_UnexpectedError (code=0x80010000, description=”The endpoint received from GetEndpoints is not in the endpoints of CreateSessionResponse”)
Stacktrace:
java.lang.RuntimeException: com.prosysopc.ua.client.InvalidServerEndpointException: Failed to create session channel to server: : opc.tcp://plc-two:52530/OPCUA/ServerPOC [http://opcfoundation.org/UA/SecurityPolicy#Basic256Sha256,SignAndEncrypt] ServiceResult=Bad_UnexpectedError (0x80010000) “An unexpected error occurred.”
at se.tf.saap.rest.opcua.FacilityPLCClient.connect(FacilityPLCClient.java:67)
at se.tf.saap.rest.opcua.OPCUASessionService.connectAndSubscribe(OPCUASessionService.java:191)
at java.base/java.util.stream.ForEachOps$ForEachOp$OfRef.accept(ForEachOps.java:184)
at java.base/java.util.stream.ReferencePipeline$2$1.accept(ReferencePipeline.java:179)
at java.base/java.util.concurrent.ConcurrentHashMap$ValueSpliterator.forEachRemaining(ConcurrentHashMap.java:3612)
at java.base/java.util.stream.AbstractPipeline.copyInto(AbstractPipeline.java:509)
at java.base/java.util.stream.AbstractPipeline.wrapAndCopyInto(AbstractPipeline.java:499)
at java.base/java.util.stream.ForEachOps$ForEachOp.evaluateSequential(ForEachOps.java:151)
at java.base/java.util.stream.ForEachOps$ForEachOp$OfRef.evaluateSequential(ForEachOps.java:174)
at java.base/java.util.stream.AbstractPipeline.evaluate(AbstractPipeline.java:234)
at java.base/java.util.stream.ReferencePipeline.forEach(ReferencePipeline.java:596)
at se.tf.saap.rest.opcua.OPCUASessionService.scheduledReconnectionAttempt(OPCUASessionService.java:165)
at java.base/jdk.internal.reflect.DirectMethodHandleAccessor.invoke(DirectMethodHandleAccessor.java:103)
at java.base/java.lang.reflect.Method.invoke(Method.java:580)
at org.springframework.scheduling.support.ScheduledMethodRunnable.runInternal(ScheduledMethodRunnable.java:130)
at org.springframework.scheduling.support.ScheduledMethodRunnable.lambda$run$2(ScheduledMethodRunnable.java:124)
at io.micrometer.observation.Observation.observe(Observation.java:499)
at org.springframework.scheduling.support.ScheduledMethodRunnable.run(ScheduledMethodRunnable.java:124)
at org.springframework.scheduling.support.DelegatingErrorHandlingRunnable.run(DelegatingErrorHandlingRunnable.java:54)
at java.base/java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:572)
at java.base/java.util.concurrent.FutureTask.runAndReset(FutureTask.java:358)
at java.base/java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.run(ScheduledThreadPoolExecutor.java:305)
at java.base/java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1144)
at java.base/java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:642)
at java.base/java.lang.Thread.run(Thread.java:1583)
Caused by: com.prosysopc.ua.client.InvalidServerEndpointException: Failed to create session channel to server: : opc.tcp://plc-two:52530/OPCUA/ServerPOC [http://opcfoundation.org/UA/SecurityPolicy#Basic256Sha256,SignAndEncrypt]
at com.prosysopc.ua.client.UaClient.ciX(SourceFile:5767)
at com.prosysopc.ua.client.UaClient.connect(SourceFile:1066)
at se.tf.saap.rest.opcua.FacilityPLCClient.connect(FacilityPLCClient.java:63)
… 24 common frames omitted
Caused by: com.prosysopc.ua.stack.common.ServiceResultException: Bad_UnexpectedError (code=0x80010000, description=”The endpoint received from GetEndpoints is not in the endpoints of CreateSessionResponse”)
at com.prosysopc.ua.stack.application.Client.a(SourceFile:1091)
at com.prosysopc.ua.stack.application.Client.createSession(SourceFile:647)
at com.prosysopc.ua.client.UaClient.ciX(SourceFile:5714)
… 26 common frames omitted
Haven’t seen this happening locally in development-environment at all.
What could be causing this?
/Mika
13:51, EEST
April 3, 2012
Hi,
Hmm odd..
Can you tell the precise 5.x version used (also from what version did you update from)? And also just to doublecheck, the Server side was also done using our SDK? And did you restart the client, the server or both? Did anything .. odd happen on the server’s machine (such as e.g. changing the computername/hostname)? Did this happen only once or are you able to reproduce this?
The exception itself happens if the check defined in https://reference.opcfoundation.org/Core/Part4/v105/docs/5.6.2 fails:
“
…
The Server returns its EndpointDescriptions in the response. Clients use this information to determine whether the list of EndpointDescriptions returned from the DiscoveryEndpoint matches the Endpoints that the Server has. If there is a difference then the Client shall close the Session and report an error. The Server returns all EndpointDescriptions for the serverUri specified by the Client in the request. The Client only verifies EndpointDescriptions with a transportProfileUri that matches the profileUri specified in the original GetEndpoints request. A Client may skip this check if the EndpointDescriptions were provided by a trusted source such as the Administrator.
…
“
The check can be disabled via UaClient.setValidateDiscoveredEndpoints(false).
There should be the following 3 ERROR level logs in the client side logs:
“The endpoint received from GetEndpoints is not in the endpoints of CreateSessionResponse. Endpoint=…”
“GetEndpoints returned endpoints=…”
“CreateSessionResponse endpoints=…”
That should show the difference, it might provide some insight why did that happen. If not obivious or looks like SDK bug, please (if possible) send that part of the log to uajava-support@prosysopc.com and refer this discussion.
16:26, EEST
January 26, 2024
For the simulation server we use 5.2.2-139 updated from 4.11.0-41
And for client 5.2.0-133 updated from 4.11.0-41
We disabled the ValidateDiscoveredEndpoints and we don’t seem to have the problem any longer but is it safe to do so?
In simulator no problem but I guess we don’t want disabled it later when going to production?
The full log looks like this
java.lang.RuntimeException: com.prosysopc.ua.client.InvalidServerEndpointException: Failed to create session channel to server: : opc.tcp://plc-two:52530/OPCUA/ServerPOC [http://opcfoundation.org/UA/SecurityPolicy#Basic256Sha256,SignAndEncrypt] ServiceResult=Bad_UnexpectedError (0x80010000) “An unexpected error occurred.”
at se.tf.saap.rest.opcua.FacilityPLCClient.connect(FacilityPLCClient.java:67)
at se.tf.saap.rest.opcua.OPCUASessionService.connectAndSubscribe(OPCUASessionService.java:191)
at java.base/java.util.stream.ForEachOps$ForEachOp$OfRef.accept(ForEachOps.java:184)
at java.base/java.util.stream.ReferencePipeline$2$1.accept(ReferencePipeline.java:179)
at java.base/java.util.concurrent.ConcurrentHashMap$ValueSpliterator.forEachRemaining(ConcurrentHashMap.java:3612)
at java.base/java.util.stream.AbstractPipeline.copyInto(AbstractPipeline.java:509)
at java.base/java.util.stream.AbstractPipeline.wrapAndCopyInto(AbstractPipeline.java:499)
at java.base/java.util.stream.ForEachOps$ForEachOp.evaluateSequential(ForEachOps.java:151)
at java.base/java.util.stream.ForEachOps$ForEachOp$OfRef.evaluateSequential(ForEachOps.java:174)
at java.base/java.util.stream.AbstractPipeline.evaluate(AbstractPipeline.java:234)
at java.base/java.util.stream.ReferencePipeline.forEach(ReferencePipeline.java:596)
at se.tf.saap.rest.opcua.OPCUASessionService.scheduledReconnectionAttempt(OPCUASessionService.java:165)
at java.base/jdk.internal.reflect.DirectMethodHandleAccessor.invoke(DirectMethodHandleAccessor.java:103)
at java.base/java.lang.reflect.Method.invoke(Method.java:580)
at org.springframework.scheduling.support.ScheduledMethodRunnable.runInternal(ScheduledMethodRunnable.java:130)
at org.springframework.scheduling.support.ScheduledMethodRunnable.lambda$run$2(ScheduledMethodRunnable.java:124)
at io.micrometer.observation.Observation.observe(Observation.java:499)
at org.springframework.scheduling.support.ScheduledMethodRunnable.run(ScheduledMethodRunnable.java:124)
at org.springframework.scheduling.support.DelegatingErrorHandlingRunnable.run(DelegatingErrorHandlingRunnable.java:54)
at java.base/java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:572)
at java.base/java.util.concurrent.FutureTask.runAndReset(FutureTask.java:358)
at java.base/java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.run(ScheduledThreadPoolExecutor.java:305)
at java.base/java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1144)
at java.base/java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:642)
at java.base/java.lang.Thread.run(Thread.java:1583)
Caused by: com.prosysopc.ua.client.InvalidServerEndpointException: Failed to create session channel to server: : opc.tcp://plc-two:52530/OPCUA/ServerPOC [http://opcfoundation.org/UA/SecurityPolicy#Basic256Sha256,SignAndEncrypt]
at com.prosysopc.ua.client.UaClient.ciX(SourceFile:5767)
at com.prosysopc.ua.client.UaClient.connect(SourceFile:1066)
at se.tf.saap.rest.opcua.FacilityPLCClient.connect(FacilityPLCClient.java:63)
… 24 common frames omitted
Caused by: com.prosysopc.ua.stack.common.ServiceResultException: Bad_UnexpectedError (code=0x80010000, description=”The endpoint received from GetEndpoints is not in the endpoints of CreateSessionResponse”)
at com.prosysopc.ua.stack.application.Client.a(SourceFile:1091)
at com.prosysopc.ua.stack.application.Client.createSession(SourceFile:647)
at com.prosysopc.ua.client.UaClient.ciX(SourceFile:5714)
… 26 common frames omitted
12:38, EEST
April 3, 2012
I was talking about the application log (files), not the stacktrace of the exception. The 3 ERROR logs are logged by com.prosysopc.ua.stack.application.Client (this is used internally by the UaClient). Typically ERROR logs are logged from all packages, but doublecheck your applications logging configuration. Or alternatively if you can deploy the sampleconsoleserver example as-is to the server you could test vs. that to see if it happens with that as well (and that would log it by default on the console, with modifications to logback.xml you could also make it log to files).
Anyway, this is odd, I do not recall anything 4.11.0 -> 5.x that should affect this. There are changes in the encoding system and there is more localization support, but neither should matter. Thus preferably I would need to see the 3 log lines that would show the both service results and the mismatching EndpointDescription.
Explaining the flag is quite long, so I’ll do a separate post for it later if needed.
14:43, EEST
January 26, 2024
Sorry misunderstood what you asked for.
Hope these are what you are looking for.
CreateSessionResponse endpoints=[EndpointDescription [EndpointUrl=”opc.tcp://61f441fa9d5c:52530/OPCUA/ServerPOC”, Server=”null”, ServerCertificate=”null”, SecurityMode=”None”, SecurityPolicyUri=”http://opcfoundation.org/UA/SecurityPolicy#None”, UserIdentityTokens=”[UserTokenPolicy [PolicyId=”username_basic128″, TokenType=”UserName”, IssuedTokenType=”null”, IssuerEndpointUrl=”null”, SecurityPolicyUri=”http://opcfoundation.org/UA/SecurityPolicy#Basic128Rsa15″]]”, TransportProfileUri=”http://opcfoundation.org/UA-Profile/Transport/uatcp-uasc-uabinary”, SecurityLevel=”0″], EndpointDescription [EndpointUrl=”opc.tcp://61f441fa9d5c:52530/OPCUA/ServerPOC”, Server=”null”, ServerCertificate=”null”, SecurityMode=”Sign”, SecurityPolicyUri=”http://opcfoundation.org/UA/SecurityPolicy#Aes256_Sha256_RsaPss”, UserIdentityTokens=”[UserTokenPolicy [PolicyId=”username_basic128″, TokenType=”UserName”, IssuedTokenType=”null”, IssuerEndpointUrl=”null”, SecurityPolicyUri=”http://opcfoundation.org/UA/SecurityPolicy#Basic128Rsa15″]]”, TransportProfileUri=”http://opcfoundation.org/UA-Profile/Transport/uatcp-uasc-uabinary”, SecurityLevel=”1″], EndpointDescription [EndpointUrl=”opc.tcp://61f441fa9d5c:52530/OPCUA/ServerPOC”, Server=”null”, ServerCertificate=”null”, SecurityMode=”SignAndEncrypt”, SecurityPolicyUri=”http://opcfoundation.org/UA/SecurityPolicy#Basic256Sha256″, UserIdentityTokens=”[UserTokenPolicy [PolicyId=”username_basic128″, TokenType=”UserName”, IssuedTokenType=”null”, IssuerEndpointUrl=”null”, SecurityPolicyUri=”http://opcfoundation.org/UA/SecurityPolicy#Basic128Rsa15″]]”, TransportProfileUri=”http://opcfoundation.org/UA-Profile/Transport/uatcp-uasc-uabinary”, SecurityLevel=”2″], EndpointDescription [EndpointUrl=”opc.tcp://61f441fa9d5c:52530/OPCUA/ServerPOC”, Server=”null”, ServerCertificate=”null”, SecurityMode=”SignAndEncrypt”, SecurityPolicyUri=”http://opcfoundation.org/UA/SecurityPolicy#Aes128_Sha256_RsaOaep”, UserIdentityTokens=”[UserTokenPolicy [PolicyId=”username_basic128″, TokenType=”UserName”, IssuedTokenType=”null”, IssuerEndpointUrl=”null”, SecurityPolicyUri=”http://opcfoundation.org/UA/SecurityPolicy#Basic128Rsa15″]]”, TransportProfileUri=”http://opcfoundation.org/UA-Profile/Transport/uatcp-uasc-uabinary”, SecurityLevel=”2″], EndpointDescription [EndpointUrl=”opc.tcp://61f441fa9d5c:52530/OPCUA/ServerPOC”, Server=”null”, ServerCertificate=”null”, SecurityMode=”Sign”, SecurityPolicyUri=”http://opcfoundation.org/UA/SecurityPolicy#Basic256Sha256″, UserIdentityTokens=”[UserTokenPolicy [PolicyId=”username_basic128″, TokenType=”UserName”, IssuedTokenType=”null”, IssuerEndpointUrl=”null”, SecurityPolicyUri=”http://opcfoundation.org/UA/SecurityPolicy#Basic128Rsa15″]]”, TransportProfileUri=”http://opcfoundation.org/UA-Profile/Transport/uatcp-uasc-uabinary”, SecurityLevel=”1″], EndpointDescription [EndpointUrl=”opc.tcp://61f441fa9d5c:52530/OPCUA/ServerPOC”, Server=”null”, ServerCertificate=”null”, SecurityMode=”Sign”, SecurityPolicyUri=”http://opcfoundation.org/UA/SecurityPolicy#Aes128_Sha256_RsaOaep”, UserIdentityTokens=”[UserTokenPolicy [PolicyId=”username_basic128″, TokenType=”UserName”, IssuedTokenType=”null”, IssuerEndpointUrl=”null”, SecurityPolicyUri=”http://opcfoundation.org/UA/SecurityPolicy#Basic128Rsa15″]]”, TransportProfileUri=”http://opcfoundation.org/UA-Profile/Transport/uatcp-uasc-uabinary”, SecurityLevel=”1″], EndpointDescription [EndpointUrl=”opc.tcp://61f441fa9d5c:52530/OPCUA/ServerPOC”, Server=”null”, ServerCertificate=”null”, SecurityMode=”SignAndEncrypt”, SecurityPolicyUri=”http://opcfoundation.org/UA/SecurityPolicy#Aes256_Sha256_RsaPss”, UserIdentityTokens=”[UserTokenPolicy [PolicyId=”username_basic128″, TokenType=”UserName”, IssuedTokenType=”null”, IssuerEndpointUrl=”null”, SecurityPolicyUri=”http://opcfoundation.org/UA/SecurityPolicy#Basic128Rsa15″]]”, TransportProfileUri=”http://opcfoundation.org/UA-Profile/Transport/uatcp-uasc-uabinary”, SecurityLevel=”2″]]
GetEndpoints returned endpoints=[EndpointDescription [EndpointUrl=”opc.tcp://5a55695bc41a:52530/OPCUA/ServerPOC”, Server=”null”, ServerCertificate=”null”, SecurityMode=”None”, SecurityPolicyUri=”http://opcfoundation.org/UA/SecurityPolicy#None”, UserIdentityTokens=”[UserTokenPolicy [PolicyId=”username_basic128″, TokenType=”UserName”, IssuedTokenType=”null”, IssuerEndpointUrl=”null”, SecurityPolicyUri=”http://opcfoundation.org/UA/SecurityPolicy#Basic128Rsa15″]]”, TransportProfileUri=”http://opcfoundation.org/UA-Profile/Transport/uatcp-uasc-uabinary”, SecurityLevel=”0″], EndpointDescription [EndpointUrl=”opc.tcp://5a55695bc41a:52530/OPCUA/ServerPOC”, Server=”null”, ServerCertificate=”null”, SecurityMode=”Sign”, SecurityPolicyUri=”http://opcfoundation.org/UA/SecurityPolicy#Aes256_Sha256_RsaPss”, UserIdentityTokens=”[UserTokenPolicy [PolicyId=”username_basic128″, TokenType=”UserName”, IssuedTokenType=”null”, IssuerEndpointUrl=”null”, SecurityPolicyUri=”http://opcfoundation.org/UA/SecurityPolicy#Basic128Rsa15″]]”, TransportProfileUri=”http://opcfoundation.org/UA-Profile/Transport/uatcp-uasc-uabinary”, SecurityLevel=”1″], EndpointDescription [EndpointUrl=”opc.tcp://5a55695bc41a:52530/OPCUA/ServerPOC”, Server=”null”, ServerCertificate=”null”, SecurityMode=”SignAndEncrypt”, SecurityPolicyUri=”http://opcfoundation.org/UA/SecurityPolicy#Basic256Sha256″, UserIdentityTokens=”[UserTokenPolicy [PolicyId=”username_basic128″, TokenType=”UserName”, IssuedTokenType=”null”, IssuerEndpointUrl=”null”, SecurityPolicyUri=”http://opcfoundation.org/UA/SecurityPolicy#Basic128Rsa15″]]”, TransportProfileUri=”http://opcfoundation.org/UA-Profile/Transport/uatcp-uasc-uabinary”, SecurityLevel=”2″], EndpointDescription [EndpointUrl=”opc.tcp://5a55695bc41a:52530/OPCUA/ServerPOC”, Server=”null”, ServerCertificate=”null”, SecurityMode=”SignAndEncrypt”, SecurityPolicyUri=”http://opcfoundation.org/UA/SecurityPolicy#Aes128_Sha256_RsaOaep”, UserIdentityTokens=”[UserTokenPolicy [PolicyId=”username_basic128″, TokenType=”UserName”, IssuedTokenType=”null”, IssuerEndpointUrl=”null”, SecurityPolicyUri=”http://opcfoundation.org/UA/SecurityPolicy#Basic128Rsa15″]]”, TransportProfileUri=”http://opcfoundation.org/UA-Profile/Transport/uatcp-uasc-uabinary”, SecurityLevel=”2″], EndpointDescription [EndpointUrl=”opc.tcp://5a55695bc41a:52530/OPCUA/ServerPOC”, Server=”null”, ServerCertificate=”null”, SecurityMode=”Sign”, SecurityPolicyUri=”http://opcfoundation.org/UA/SecurityPolicy#Basic256Sha256″, UserIdentityTokens=”[UserTokenPolicy [PolicyId=”username_basic128″, TokenType=”UserName”, IssuedTokenType=”null”, IssuerEndpointUrl=”null”, SecurityPolicyUri=”http://opcfoundation.org/UA/SecurityPolicy#Basic128Rsa15″]]”, TransportProfileUri=”http://opcfoundation.org/UA-Profile/Transport/uatcp-uasc-uabinary”, SecurityLevel=”1″], EndpointDescription [EndpointUrl=”opc.tcp://5a55695bc41a:52530/OPCUA/ServerPOC”, Server=”null”, ServerCertificate=”null”, SecurityMode=”Sign”, SecurityPolicyUri=”http://opcfoundation.org/UA/SecurityPolicy#Aes128_Sha256_RsaOaep”, UserIdentityTokens=”[UserTokenPolicy [PolicyId=”username_basic128″, TokenType=”UserName”, IssuedTokenType=”null”, IssuerEndpointUrl=”null”, SecurityPolicyUri=”http://opcfoundation.org/UA/SecurityPolicy#Basic128Rsa15″]]”, TransportProfileUri=”http://opcfoundation.org/UA-Profile/Transport/uatcp-uasc-uabinary”, SecurityLevel=”1″], EndpointDescription [EndpointUrl=”opc.tcp://5a55695bc41a:52530/OPCUA/ServerPOC”, Server=”null”, ServerCertificate=”null”, SecurityMode=”SignAndEncrypt”, SecurityPolicyUri=”http://opcfoundation.org/UA/SecurityPolicy#Aes256_Sha256_RsaPss”, UserIdentityTokens=”[UserTokenPolicy [PolicyId=”username_basic128″, TokenType=”UserName”, IssuedTokenType=”null”, IssuerEndpointUrl=”null”, SecurityPolicyUri=”http://opcfoundation.org/UA/SecurityPolicy#Basic128Rsa15″]]”, TransportProfileUri=”http://opcfoundation.org/UA-Profile/Transport/uatcp-uasc-uabinary”, SecurityLevel=”2″]]
The endpoint received from GetEndpoints is not in the endpoints of CreateSessionResponse. Endpoint=EndpointDescription [EndpointUrl=”opc.tcp://5a55695bc41a:52530/OPCUA/ServerPOC”, Server=”null”, ServerCertificate=”null”, SecurityMode=”None”, SecurityPolicyUri=”http://opcfoundation.org/UA/SecurityPolicy#None”, UserIdentityTokens=”[UserTokenPolicy [PolicyId=”username_basic128″, TokenType=”UserName”, IssuedTokenType=”null”, IssuerEndpointUrl=”null”, SecurityPolicyUri=”http://opcfoundation.org/UA/SecurityPolicy#Basic128Rsa15″]]”, TransportProfileUri=”http://opcfoundation.org/UA-Profile/Transport/uatcp-uasc-uabinary”, SecurityLevel=”0″
Besides changing versions on opc ua from 4 -> 5 we also changed JDK from 17 -> 21.
We received a license file for the simulator. Haven’t yet found in documentation where to place it. Is it in the rescources folder?
15:56, EEST
April 3, 2012
Do you have some sort of “load-balanced container-environment” for the server side? Is this also new related to this change? Asking because the hostnames do look like ones typically in such environments and thus it might fail due to that i.e. because CreateSessionResponse has references to ‘opc.tcp://61f441fa9d5c:52530…’ which is different from the hostname where the GetEndpoints was made ‘opc.tcp://5a55695bc41a:52530…’. Skipping some details, but the GetEndpoints “query” is done on a separate connection. You must ensure those connections happen to the same instance e.g. based on the connection IP or something on the load balancer.
The SDK doesn’t use a license file, you just swap the evaluation jar with the one from the licensed edition .zips. But seems there might be some confusion so I’ll continue by mail.
17:58, EEST
April 3, 2012
I’ll try to write more details as well tomorrow as this misses some details. I must note that we have limited experience with such environments. But basically as far as I’m aware, 4.x should have been no different than 5.x regarding this, thus that should have failed as well. But it could be just e.g. luck and depending how the load balancer works (e.g. 5.x has more datatypes, we read those on connect, thus 5.x connections would read/browse a bit more than 4.x etc. so maybe that affects … things). Or I could be missing something.
Technically here the failure was that the hostname was different for the instances. In Docker that is basically random if not set (and I think you can only have one per hostname?).
Additionally, if security is being used, if each instance has made their own certificate that could be an additional thing that could fail.
However, IF each instance loads the same certificate (i.e. that is made separately, either with the SDK or some 3rd party tool), there could maybe be a trick via static com.prosysopc.ua.ApplicationIdentity.setActualHostName(String). If you would use that at the “start of main” before other interactions with the SDK, that does override the hostname resolution. Use the FQN version of the hostname, if one exist. Then the endpointurl in the endpointdescriptions should be the same in all instances and it technically shouldn’t matter to which instance the GetEndpoints went. However please note that still I highly recommend to configure the load balancer in a such way that clients would retain the instance they initially connected to because otherwise if a reconnect happens the session must be always redone (and you will also lose any data for Subscriptions that could have collected data during the connection break, though depends one the needs of your case). Also some clients (not ours) do try to use the EndpointUrl for connection purposes after GetEndpoints (matters only if some other SDK clients are used) basically the scenario is equivalent to the server being behind a NAT (thus that is why we keep using the original defined connection address).
Most Users Ever Online: 1919
Currently Online:
122 Guest(s)
Currently Browsing this Page:
1 Guest(s)
Top Posters:
Heikki Tahvanainen: 402
hbrackel: 144
rocket science: 88
pramanj: 86
Francesco Zambon: 83
Ibrahim: 78
Sabari: 62
kapsl: 57
gjevremovic: 49
Xavier: 43
Member Stats:
Guest Posters: 0
Members: 749
Moderators: 7
Admins: 1
Forum Stats:
Groups: 3
Forums: 15
Topics: 1529
Posts: 6471
Newest Members:
scvchad954, misty3446453365, KelsonzFu, Kelsonz, lienbelisario, erick34s63346, Kaitlyntvsl, lonaerskine7, KTP21ideft, GeorgecotagModerators: Jouni Aro: 1026, Pyry: 1, Petri: 0, Bjarne Boström: 1032, Jimmy Ni: 26, Matti Siponen: 349, Lusetti: 0
Administrators: admin: 1