Ce contenu n'est pas disponible dans la langue sélectionnée.
Chapter 3. Securing the Undertow HTTP Server
Abstract
You can configure the built-in Undertow HTTP server to use SSL/TLS security by editing the contents of the etc/undertow.xml configuration file. In particular, you can add SSL/TLS security to the Fuse Console in this way.
3.1. Undertow server Copier lienLien copié sur presse-papiers!
The Fuse container is pre-configured with an Undertow server, which acts as a general-purpose HTTP server and HTTP servlet container. Through a single HTTP port (by default, http://localhost:8181), the Undertow container can host multiple services, for example:
-
Fuse Console (by default,
http://localhost:8181/hawtio) - Apache CXF Web services endpoints (if the host and port are left unspecified in the endpoint configuration)
- Some Apache Camel endpoints
If you use the default Undertow server for all of your HTTP endpoints, you can conveniently add SSL/TLS security to these HTTP endpoints by following the steps described here.
3.2. Create X.509 certificate and private key Copier lienLien copié sur presse-papiers!
Before you can enable SSL/TLS on the Undertow server, you must create an X.509 certificate and private key, where the certificate and private key must be in Java keystore format (JKS format). For details of how to create a signed certificate and private key, see Appendix A, Managing Certificates.
3.3. Enabling SSL/TLS for Undertow in an Apache Karaf container Copier lienLien copié sur presse-papiers!
For the following procedure, it is assumed that you have already created a signed X.509 certificate and private key pair in the keystore file, alice.ks, with keystore password, StorePass, and key password, KeyPass.
To enable SSL/TLS for Undertow in a Karaf container:
Make sure that the Pax Web server is configured to take its configuration from the
etc/undertow.xmlfile. When you look at the contents of theetc/org.ops4j.pax.web.cfgfile, you should see the following setting:org.ops4j.pax.web.config.file=${karaf.etc}/undertow.xmlorg.ops4j.pax.web.config.file=${karaf.etc}/undertow.xmlCopy to Clipboard Copied! Toggle word wrap Toggle overflow Open the file,
etc/org.ops4j.pax.web.cfg, in a text editor and add the following line:org.osgi.service.http.port.secure=8443
org.osgi.service.http.port.secure=8443Copy to Clipboard Copied! Toggle word wrap Toggle overflow Save and close the file,
etc/org.ops4j.pax.web.cfg.-
Open the file,
etc/undertow.xml, in a text editor. The next steps assume you are working with the defaultundertow.xmlfile, unchanged since installation time. Search for the XML elements,
http-listenerandhttps-listener. Comment out thehttp-listenerelement (by enclosing it between<!--and-->) and uncomment thehttps-listenerelement (spread over two lines). The edited fragment of XML should now look something like this:<!-- HTTP(S) Listener references Socket Binding (and indirectly - Interfaces) --> <!-- http-listener name="http" socket-binding="http" /> --> <!-- verify-client: org.xnio.SslClientAuthMode.NOT_REQUESTED, org.xnio.SslClientAuthMode.REQUESTED, org.xnio.SslClientAuthMode.REQUIRED --> <https-listener name="https" socket-binding="https" security-realm="https" verify-client="NOT_REQUESTED" /><!-- HTTP(S) Listener references Socket Binding (and indirectly - Interfaces) --> <!-- http-listener name="http" socket-binding="http" /> --> <!-- verify-client: org.xnio.SslClientAuthMode.NOT_REQUESTED, org.xnio.SslClientAuthMode.REQUESTED, org.xnio.SslClientAuthMode.REQUIRED --> <https-listener name="https" socket-binding="https" security-realm="https" verify-client="NOT_REQUESTED" />Copy to Clipboard Copied! Toggle word wrap Toggle overflow Search for the
w:keystoreelement. By default, thew:keystoreelement is configured as follows:<w:keystore path="${karaf.etc}/certs/server.keystore" provider="JKS" alias="server" keystore-password="secret" key-password="secret" generate-self-signed-certificate-host="localhost" /><w:keystore path="${karaf.etc}/certs/server.keystore" provider="JKS" alias="server" keystore-password="secret" key-password="secret" generate-self-signed-certificate-host="localhost" />Copy to Clipboard Copied! Toggle word wrap Toggle overflow To install the
alicecertificate as the Undertow server’s certificate, modify thew:keystoreelement attributes as follows:-
Set
pathto the absolute location of thealice.ksfile on the file system. -
Set
providertoJKS. -
Set
aliasto thealicecertificate alias in the keystore. -
Set
keystore-passwordto the value of the password that unlocks the key store. -
Set
key-passwordto the value of the password that encrypts thealiceprivate key. -
Delete the
generate-self-signed-certificate-hostattribute setting.
-
Set
For example, after installing the
alice.kskeystore, the modifiedw:keystoreelement would look something like this:<w:keystore path="${karaf.etc}/certs/alice.ks" provider="JKS" alias="alice" keystore-password="StorePass" key-password="KeyPass" /><w:keystore path="${karaf.etc}/certs/alice.ks" provider="JKS" alias="alice" keystore-password="StorePass" key-password="KeyPass" />Copy to Clipboard Copied! Toggle word wrap Toggle overflow Search for the
<interface name="secure">tag, which is used to specify the IP addresses the secure HTTPS port binds to. By default, this element is commented out, as follows:<!--<interface name="secure">--> <!--<w:inet-address value="127.0.0.1" />--> <!--</interface>--><!--<interface name="secure">--> <!--<w:inet-address value="127.0.0.1" />--> <!--</interface>-->Copy to Clipboard Copied! Toggle word wrap Toggle overflow Uncomment the element and customize the
valueattribute to specify the IP address which the HTTPS port binds to. For example, the wildcard value,0.0.0.0, configures HTTPS to bind to all available IP addresses:<interface name="secure"> <w:inet-address value="0.0.0.0" /> </interface><interface name="secure"> <w:inet-address value="0.0.0.0" /> </interface>Copy to Clipboard Copied! Toggle word wrap Toggle overflow Search for and uncomment the
<socket-binding name="https"tag. When this tag is uncommented, it should look something like this:<socket-binding name="https" interface="secure" port="${org.osgi.service.http.port.secure}" /><socket-binding name="https" interface="secure" port="${org.osgi.service.http.port.secure}" />Copy to Clipboard Copied! Toggle word wrap Toggle overflow -
Save and close the file,
etc/undertow.xml. - Restart the Fuse container, in order for the configuration changes to take effect.
3.4. Customizing allowed TLS protocols and cipher suites Copier lienLien copié sur presse-papiers!
You can customize the allowed TLS protocols and cipher suites by modifying the following attributes of the w:engine element in the etc/undertow.xml file:
enabled-cipher-suites- Specifies the list of allowed TLS/SSL cipher suites.
enabled-protocolsSpecifies the list of allowed TLS/SSL protocols.
WarningDo not enable
SSLprotocol versions, as they are vulnerable to attack. Use onlyTLSprotocol versions.
For full details of the available protocols and cipher suites, consult the appropriate JVM documentation and security provider documentation. For example, for Java 8, see Java Cryptography Architecture Oracle Providers Documentation for JDK 8.
3.5. Connect to the secure console Copier lienLien copié sur presse-papiers!
After configuring SSL security for the Undertow server in the Pax Web configuration file, you should be able to open the Fuse Console by browsing to the following URL:
https://localhost:8443/hawtio
https://localhost:8443/hawtio
Remember to type the https: scheme, instead of http:, in this URL.
Initially, the browser will warn you that you are using an untrusted certificate. Skip this warning and you will be presented with the login screen for the Fuse Console.
3.6. Advanced Undertow configuration Copier lienLien copié sur presse-papiers!
3.6.1. IO configuration Copier lienLien copié sur presse-papiers!
Since PAXWEB-1255 the configuration of the XNIO worker and buffer pool used by the listeners can be altered. In undertow.xml template there is a section that specifies default values of some IO-related parameters:
The following buffer-pool parameters may be specified:
buffer-size- Specifies size of the buffer used for IO operations. When not specified, size is calculated depending on available memory.
direct-buffers- Determines whether java.nio.ByteBuffer#allocateDirect or java.nio.ByteBuffer#allocate should be used.
The following worker parameters may be specified:
io-threads- The number of I/O threads to create for the worker. If not specified, the number of threads is set to the number of CPUs × 2.
task-core-threads- The number of threads for the core task thread pool.
task-max-threads- The maximum number of threads for the worker task thread pool. If not specified, the maximum number of threads is set to the number of CPUs × 16.