Note
Access to this page requires authorization. You can try signing in or changing directories.
Access to this page requires authorization. You can try changing directories.
In this article, you learn how to configure the OPC UA certificates infrastructure for the connector for OPC UA. This configuration lets you determine which OPC UA servers you trust to securely establish a session with.
Based on the OPC UA specification, the connector for OPC UA acts as a single OPC UA application when it establishes secure communications with OPC UA servers. The connector for OPC UA uses the same application instance certificate for all secure channels it opens to your OPC UA servers.
The connector for OPC UA must trust the OPC UA servers it connects to. The connector maintains a list of trusted certificates. To learn more, see:
- Manage certificates for your Azure IoT Operations deployment - this article describes how Azure IoT Operations uses Azure Key Vault to manage certificates.
- OPC UA certificates infrastructure for the connector for OPC UA - this article describes the roles of the trusted certificates list and issuer certificates list.
Prerequisites
An Azure IoT Operations instance deployed with secure settings. If you deployed Azure IoT Operations with test settings, you need to first enable secure settings.
Configure a self-signed application instance certificate for the connector for OPC UA
The default deployment of the connector for OPC UA installs all the resources needed by cert-manager to create an OPC UA compliant self-signed certificate. This certificate is stored in the aio-opc-opcuabroker-default-application-cert secret. This secret is mapped into all the connector for OPC UA pods and acts as the OPC UA client application instance certificate. cert-manager handles the automatic renewal of this application instance certificate.
This configuration is typically sufficient for compliant and secure communication between your OPC UA servers and the connector for OPC UA in a demonstration or exploration environment. For a production environment, use enterprise grade application instance certificates in your deployment.
Configure the trusted certificates list
To connect to an OPC UA server, first you need to establish the application authentication mutual trust. To configure the trusted certificates list of the servers you want the connector for OPC UA to connect to:
To use the operations experience web UI to manage the trusted certificates list, complete the following steps:
- Get the OPC UA server application's instance certificate as a file. These files typically have a - .deror- .crtextension. This file contains the public key only.- Tip - Typically, an OPC UA server has an interface that lets you export its application instance certificate. This interface isn't standardized. For servers such as KEPServerEx, there's a Windows-based configuration UI for certificates management. Other servers might have a web interface or use operating system folders to store the certificates. To find out how to export the application instance certificate, refer to the user manual of your server. After you have the certificate, make sure it's either DER or PEM encoded. These certificates are typically stored in files with either the - .deror- .crtextension. If the certificate isn't in one of those file formats, use a tool such as- opensslto transform the certificate into the required format.
- You can add the certificate directly to your Azure Key Vault as a secret and import from there, or you can upload the certificate to the trusted certificates list using the operations experience. - Note - The connector for OPC UA uses a Kubernetes native secret named aio-opc-ua-broker-trust-list to store the trusted certificates list. This secret is created when you deploy Azure IoT Operations. 
- Go to the Devices page in the operations experience web UI. 
- To view the trusted certificates list, select Manage certificates and secrets and then Certificates: 
- You can upload a certificate file from your local machine or add one that you previously added as a secret in your Azure Key Vault: 
- Select Apply to save the changes. The certificate is now added to the trusted certificates list. If you upload the certificate, it's automatically added to your Azure Key Vault as a secret. 
If your OPC UA server uses a certificate issued by a certificate authority (CA), you can trust the CA by adding its public key certificate to the trusted certificates list. The connector for OPC UA now automatically trusts all the servers that use a valid certificate issued by the CA. Therefore, you don't need to explicitly add the OPC UA server's certificate to the connector for OPC UA trusted certificates list. Currently, you can't use the operations experience to add a certificate revocation list to the trusted certificates list.
Tip
To add a new certificate in the operations experience, you must be assigned to the Key Vault Secrets Officer role for your Azure Key Vault.
Important
If you're adding a certificate from Azure Key Vault, it must be stored as a secret and not as a certificate.
Configure the issuer certificates list
If your OPC UA server uses a certificate issued by a CA, but you don't want to trust all certificates issued by the CA, configure the issuer certificates list:
Before you can configure the issuer certificates list with your intermediate certificates, you need to add the CA certificate to the trusted certificates list. The connector for OPC UA uses the CA certificate to validate the issuer chain of the OPC UA server's certificate.
To use the operations experience web UI to manage the issuer certificates list, complete the following steps:
- Get the issuer certificate that was used to sign your server instance certificates as a file. These files typically have a - .deror- .crtextension. This file contains the public key only. You might also have a .crl file (certificate revocation list) for the issuer certificate.
- You can add the issuer certificate directly to your Azure Key Vault as a secret and import from there, or you can upload the certificate and certificate revocation list (.crl file) to the issuer certificates list using the operations experience. - Note - The connector for OPC UA uses a Kubernetes native secret named aio-opc-ua-broker-issuer-list to store the issuer certificates list. This secret is created when you deploy Azure IoT Operations. 
- Go to the Devices page in the operations experience web UI. 
- To view the issuer certificates list, select Manage certificates and secrets and then Certificates. The filter box lets you view the different certificate lists: 
- You can upload an issuer certificate file from your local machine or add one that you previously added as a secret in your Azure Key Vault: 
- Select Apply to save the changes. The certificate is now added to the issuer certificates list. If you upload the certificate, it's automatically added to your Azure Key Vault as a secret. 
You can also use the operations experience to add a certificate revocation list (.crl file) to the trusted certificates list.
Tip
To add a new certificate in the operations experience, you must be assigned to the Key Vault Secrets Officer role for your Azure Key Vault.
Important
If you're adding a certificate from Azure Key Vault, it must be stored as a secret and not as a certificate.
Configure your OPC UA server
To complete the configuration of the application authentication mutual trust, you need to configure your OPC UA server to trust the connector for OPC UA application instance certificate:
- To extract the connector for OPC UA certificate into a - opcuabroker.crtfile, run the following command:- kubectl -n azure-iot-operations get secret aio-opc-opcuabroker-default-application-cert -o jsonpath='{.data.tls\.crt}' | base64 -d > opcuabroker.crt- kubectl -n azure-iot-operations get secret aio-opc-opcuabroker-default-application-cert -o jsonpath='{.data.tls\.crt}' | %{ [Text.Encoding]::UTF8.GetString([Convert]::FromBase64String($_)) } > opcuabroker.crt
- Many OPC UA servers only support certificates in the DER format. If necessary, use the following command to convert the opcuabroker.crt certificate to opcuabroker.der: - openssl x509 -outform der -in opcuabroker.crt -out opcuabroker.der
- Consult the documentation of your OPC UA server to learn how to add the - opcuabroker.crtor- opcuabroker.dercertificate file to the server's trusted certificates list.
Configure an enterprise grade application instance certificate
For production environments, you can configure the connector for OPC UA to use an enterprise grade application instance certificate. Typically, an enterprise CA issues this certificate and you need the CA certificate to your configuration. Often, there's a hierarchy of CAs and you need to add the complete validation chain of CAs to your configuration.
The following example references the following items:
| Item | Description | 
|---|---|
| opcuabroker-certificate.der | File that contains the enterprise grade application instance certificate public key. | 
| opcuabroker-certificate.pem | File that contains the enterprise grade application instance certificate private key. | 
| subjectName | The subject name string embedded in the application instance certificate. | 
| applicationUri | The application instance URI embedded in the application instance. | 
| enterprise-grade-ca-1.der | File that contains the enterprise grade CA certificate public key. | 
| enterprise-grade-ca-1.crl | The CA's CRL file. | 
Like the previous examples, you use a dedicated Kubernetes secret to store the certificates and CRLs. To configure the enterprise grade application instance certificate, complete the following steps:
- Save the certificates and the CRL in the aio-opc-ua-broker-client-certificate secret by using the following command: - # Create aio-opc-ua-broker-client-certificate secret # Upload OPC UA public key certificate as an entry to the secret # Upload OPC UA private key certificate as an entry to the secret az iot ops connector opcua client add \ --instance <your instance name> \ -g <your resource group> \ --public-key-file "./opcuabroker-certificate.der" \ --private-key-file "./opcuabroker-certificate.pem" \ --subject-name <subject name from the public key cert> \ --application-uri <application uri from the public key cert>
- If you use the CA to issue certificates for your OPC UA broker, configure the aio-opc-ua-broker-issuer-list secret. Use a Kubernetes client such as - kubectlto configure the secrets enterprise-grade-ca-1.der and enterprise-grade-ca-1.crl:- # Append CA certificate to the issuer list secret as a new entry az iot ops connector opcua issuer add --instance <your instance name> --resource-group <your resource group> --certificate-file "./enterprise-grade-ca-1.der" # Append the CRL to the issuer list secret as a new entry az iot ops connector opcua issuer add --instance <your instance name> --resource-group <your resource group> --certificate-file "./enterprise-grade-ca-1.crl"
Now that the connector for OPC UA uses the enterprise certificate, don't forget to add the new certificate's public key to the trusted certificate lists of all OPC UA servers it needs to connect to.
 
 
 
