...
Table of Contents |
---|
Warning |
---|
This section describes how to use self-signed certificates for a test environment ONLY. |
TLS use cases
Your users will connect to the Abiquo UI over HTTPS with TLS.
You can run Abiquo over HTTP to communicate between its appliances when its internal connections are inside using HTTP for internal connections between servers within the same infrastructure/datacenter network.
However, your users will usually connect over HTTPS and if you have remote datacenters, then the remote services will usually also connect over HTTPS.
Abiquo UI
The Apache web server (HTTPD) uses the certificate for the Abiquo User Interface on the Abiquo API/UI or UI server.
On the API/UI server, the certificate files would typically be found When users upload or download templates, they need a direct connection to the Appliance Manager remote service, and this connection must be made with TLS.
Tip |
---|
The Abiquo Monolithic Server has a self-signed certificate and the connection to the appliance manager is preconfigured to use TLS |
When the Abiquo remote services will connect to the Abiquo Server over the internet, these communications should also use TLS.
Mermaid | ||||||
---|---|---|---|---|---|---|
| ||||||
{"diagramDefinition":"flowchart LR\nA--HTTP-->P(RemoteServices)\nsubgraph Abiquo Platform \n A\n P\nend\nX(Cloud User)<--HTTPS-->P\nX(Cloud User)--HTTPS-->A(Abiquo Server)\nY(Remote RS)--HTTPS-->A\nX(Cloud User)<--HTTPS-->Y\n style A fill:#ec9032,stroke:#666,stroke-width:2px,color:#fff\n style P fill:#ec9032,stroke:#666,stroke-width:2px,color:#fff\n style Y fill:#ec9032,stroke:#666,stroke-width:2px,color:#fff"} |
...
Create a self-signed certificate for a test environment
The commands to create a self-signed certificate may vary depending on the version of OpenSSL you are using.
Here are some guides:
https://devopscube.com/create-self-signed-certificates-openssl/
The important step to create a wildcard certificate is to add the subjectAltName for DNS as a required extension for your domain, for example, for the domain
example.com
subjectAltName=DNS:*.example.com
...
Abiquo UI certificates
The API server
OVA has a default self-signed certificate called abiquo.crt
that you can find in this folder /etc/pki/tls/certs
.You configure this
The Apache web server (HTTPD) uses the certificate for the Apache Web Server in the /etc/httpd/conf.d/abiquo.conf
file, which contains the configuration for the Abiquo website/VirtualHostAbiquo User Interface (UI) on the Abiquo server. This certificate is in the default cacerts
repository.
To quickly check this the certificate in the cacerts
keystore, use the following command, with the default changeit
password for a test system.
Code Block | |
---|---|
wide | [root@abicloud ~]# keytool -list -keystore /usr/java/default/jre/lib/security/cacerts -alias abicloud.example.com{$SERVER_FQDN} Enter keystore password: abicloud.example.com, Dec 11, 2022, trustedCertEntry, Certificate fingerprint (SHA1): AA:AA:AA:AA:AA:AA:AA:AA:AA:AA:AA:AA:AA:AA:AA:AA:AA:AA:AA:AA |
...
Remote RS
If you have remote datacenters that will communicate over the internet, or require extra security on the application layer, and more secure communications over and above using firewalls at both ends, you can secure connections for the remote services in remote sites (remote RS servers) by implementing TLS over HTTP, and configure the Catalina connector for Tomcat to use TLS/HTTPS.
You will also need to import the remote RS certificate into the Java keystores of the API/UI servers so the API/UI can connect via HTTPS to the RS.
See Configure Abiquo Tomcat with HTTPS for Remote RS.
To quickly check this certificate, for example, on the API server, use the following command.
Code Block | ||
---|---|---|
| ||
[root@abicloud ~]# keytool -list -keystore /usr/java/default/jre/lib/security/cacerts -alias remoters.example.com
Enter keystore password:
remoters.example.com, Dec 12, 2019, trustedCertEntry,
Certificate fingerprint (SHA1): AA:AA:AA:AA:AA:AA:AA:AA:AA:AA:AA:AA:AA:AA:AA:AA:AA:AA:AA:AA |
Adding Remote RS with TLS in Abiquo
Generally, under this configuration, the following remote services should be added to Abiquo:
Appliance manager from the API/UI server on port
443/tcp
with the connector defined on the UI serverBusiness process manager from remote V2V server on port
8010/tcp
Other remote services from the remote RS server on port
8009/tcp
...
To check the certificate for the Apache Web Server:
Log in the Abiquo server (with the Abiquo UI)
Edit the
/etc/httpd/conf.d/abiquo.conf
file, which contains the configuration for the Abiquo websiteVirtualHost
.Check the configuration at the end of this file, which by default should be as follows.
Code Block |
---|
...
SSLCertificateFile /etc/pki/tls/certs/abiquo.crt
SSLCertificateKeyFile /etc/pki/tls/private/abiquo.key
</VirtualHost> |
For a test system, you can use this certificate or you can replace it with your own self-signed certificate, which can be a wildcard certificate for your whole test environment.
...
Configure TLS for remote services
To use TLS between the API and remote services, configure the following certificates:
API server
cacerts
→ RS certificateRS server
.jks
keystore → RS certificate and API certificate
This section describes this configuration.
...
1. Add certificates to the Java keystore on the Remote services server
Add Remote services and Abiquo Server certificates to the Java keystore on the Remote services server.
Log in to the Remote services server
Go to the
/etc/pki/tls/
folderCopy your self-signed certificate(s) to the
certs
folder and your private key to theprivate
folderConvert the remote RS cert to PCKS12 format, using the domain name of your Remote services server.
Code Block openssl pkcs12 -export -in ${DOMAIN}.crt -inkey ${DOMAIN}.key -name ${REMOTE_SERVICES_FQDN} -out import_cert_key_rs
Convert the Abiquo Server cert to PCKS12 format, using the domain name of your Abiquo Server.
Code Block openssl pkcs12 -export -in ${DOMAIN}.crt -inkey ${DOMAIN}.key -name {$ABIQUO_SERVER_FQDN} -out import_cert_key_server
Go the
/opt/abiquo/tomcat/conf
folderCreate a
.jks
keystore using the following command. Replace${REMOTE_SERVICES}
with the hostname of your Remote services serverCode Block keytool -genkey -keyalg RSA -keystore ${REMOTE_SERVICES}.jks -keysize 2048
Import the Remote services certificate into the RS keystore.
Code Block keytool -importkeystore -deststorepass changeit -destkeystore ${REMOTE_SERVICES}.jks -srckeystore /etc/pki/tls/certs/import_cert_key_rs -srcstoretype PKCS12
Import the Server certificate into the RS keystore.
Code Block keytool -importkeystore -deststorepass changeit -destkeystore ${REMOTE_SERVICES}.jks -srckeystore /etc/pki/tls/certs/import_cert_key_server -srcstoretype PKCS12
Now you should be able to check these certificates with the list command, for example, for a remote services server with a host name of remoters
:
Code Block |
---|
keytool -v -list -keystore /opt/abiquo/tomcat/conf/remoters.jks |
...
2. Change the Tomcat connector on the Remote services to use TLS
To change the Tomcat connector on the Remote services server to use TLS, do these steps.
Log in to the Remote services server
Edit the Tomcat server configuration file at:
Code Block /opt/abiquo/tomcat/conf/server.xml
Remove the Catalina Connector for port
8009
Replace it with a new Connector like the following one.
This example is a guide only, use the correct file for your version of Tomcat. Abiquo 6.1 uses Tomcat 9.Code Block <Service name="Catalina"> <Connector protocol="org.apache.coyote.http11.Http11NioProtocol" port="8009" maxThreads="200" scheme="https" secure="true" SSLEnabled="true" keystoreFile="/opt/abiquo/tomcat/conf/${REMOTE_SERVICES}.jks" keystorePass="changeit" keyAlias="${REMOTE_SERVICES_FQDN}" clientAuth="false" secretrequired="false" sslProtocol="TLS"/>
The important values to change are:
keystoreFile
- e.g. use the host name of your remote RS serverkeystorePass
- use a secure passwordkeyAlias
- you must use the domain name of your remote RS server
Also configure the other parameters according to your environment.
...
3. Add your certificate to cacerts on the Abiquo server
If you are using a separate certificate for the Remote services server, or a wildcard certificate, add it to cacerts on the Abiquo server.
Log in to the Abiquo server as an administrator
Go to the
/etc/pki/tls/
folderCopy the new certificate to the
certs
folder.Copy the new private key to the
private
folderImport the certificate into the default
cacerts
keystore with the name of the Remote services server. For example, for a Remote services server:Code Block keytool -import -trustcacerts -alias ${REMOTE_SERVICES_FQDN} -file /etc/pki/tls/certs/${REMOTE_SERVICES}.crt
If you created a self-signed certificate with your own certificate authority, also import the CA certificate into
cacerts
...
4. Replace the Abiquo certificate for the UI on the Abiquo server - optional
To use a wildcard certificate for Abiquo server and Remote services server, or a different self-signed certificate on Abiquo server, then you should replace the default Abiquo certificate.
To replace the Abiquo certificate with your own certificate:
Delete the default Abiquo certificate from
cacerts
Code Block keytool -delete -alias ${ABIQUO_FQDN} -cacerts
Edit the
/etc/httpd/conf.d/abiquo.conf
file, which contains the configuration for the Abiquo websiteVirtualHost
.Change the configuration at the end of this file to point to your new certificate and key. For example, for a key file called
mycert.key
Code Block ... SSLCertificateFile /etc/pki/tls/certs/mycert.crt SSLCertificateKeyFile /etc/pki/tls/private/mycert.key </VirtualHost>
Tip |
---|
Before you save the file, add the Apache SSL proxy options from the next step too! |
...
5. Enable SSL proxy for Apache
For AM connections from users to Remote services to work with TLS (for template upload and download), enable SSL proxy for Apache.
Log in to the Abiquo server as an administrator.
Edit the Apache configuration at
/etc/httpd/conf.d/abiquo.conf
In the Apache virtual host configuration, add the following.
Code Block ####APACHE SSL PROXY########## SSLProxyEngine On SSLProxyVerify none SSLProxyCheckPeerCN off SSLProxyCheckPeerName off SSLProxyCheckPeerExpire off ##############################
Save the file
...
6. Apply and verify your configuration
Now that you have finished the configuration of your certificates
On the Abiquo Server and the Remote Services servers, restart the Tomcat service.
Code Block systemctld restart abiquo-tomcat.service
If you are using a self-signed certificate in a test environment, accept the remote RS certificates with these steps.
In your browser, open a connection to the remote RS server using the port. In our example, this would be:
https://remoters.bcn.abiquo.com:8009/
On the certificate warning, go to Advanced and accept the risk.
...
V2V server
You can repeat the TLS configuration for your V2V server. Optionally, change the port to 8010
.
...
Next steps
Now you can go back and continue with the next steps of https://abiquo.atlassian.net/wiki/spaces/doc/pages/546308109/Deploy+distributed+scalable+remote+services#Validating-the-remote-services-and-V2V-services-install, which includes following the Quick tutorial to add a datacenter and launch a VM.
Tip |
---|
For this configuration, when you create a datacenter in Abiquo, add the remote services with |
.