KB 95 - Splunk – Create Self-signed SSL Certificate V2
KB 95 (Splunk): Splunk – Create Self-signed SSL Certificate V2
Category: Information
Platform: Splunk
Priority: Normal
Version: 1 from 23.03.2021
Description
The purpose of this document is to show the process to generate a self-signed SLL certificate for Splunk that matches the fully qualified domain name of the Splunk server. By default Splunk is delivered with a certificate called SplunkServerDefautCert – however for SAP to connect to Splunk the certificate much match the hostname of the server. Please follow the steps below for additional information on how to create the Self-signed SSL certificate.
Verify the Current Certificate Name
Connect to port 8089 of your Splunk server through a web browsers using the following format:
https://<Fully Qualified Domain Name:8089
Accept to continue to the website
data:image/s3,"s3://crabby-images/084b7/084b706014fd210538c2a8c3a3beda2d7fdf2f6c" alt=""
Click on the “Certificate (invalid)” message and then select “View Certificate”
data:image/s3,"s3://crabby-images/d5314/d5314f7246abd575b2beb5030a39feffe078c12e" alt=""
data:image/s3,"s3://crabby-images/edd90/edd90b53d956364447fefae5094a70a7c3bbf3c2" alt=""
You can see the certificate does not match the FQDN of the server.
Initial Steps
Logon through RDP to the Splunk server and start a DOS command window. Change directory to the $SPLUNK_HOME\etc\auth directory of the Splunk installation.
data:image/s3,"s3://crabby-images/47e0f/47e0fc3841152756e7a5c9164157f6c2f5321e1d" alt=""
Make a directory call my “myCerts” using the command “mkdir myCerts”
data:image/s3,"s3://crabby-images/3e01e/3e01ea0d761e8f01509d6d7d01e506285bb3dc24" alt=""
Change to the myCerts directory
data:image/s3,"s3://crabby-images/ebe2c/ebe2cdde082b20a76bf335ee7bd03e030f67f25b" alt=""
Create Root Certificate Authority/Create a Certificate Authority Private Key
“C:\Program Files\Splunk\bin\openssl.exe” genrsa -aes256 -passout pass:1234 -out myCAPrivateKey.key 2048 -config “C:\Program Files\Splun \openssl.cnf
Remove the Key Phrase from the Private Key
“C:\Program Files\Splunk\bin\openssl.exe” rsa -passin pass:1234 -in myCAPrivateKey.key -out myCAPrivateKey.key
Create Root Certificate Request
Use the following command to generate a request for the root certificate – in the example below I called my RootCA – SplunkCA.bnwconsulting.com.au
“C:\Program Files\Splunk\bin\openssl.exe” req -new -key myCAPrivateKey.key -out myCACertificate.csr -config “C:\Program Files\Splunk\openssl.cnf
data:image/s3,"s3://crabby-images/2f24d/2f24d1d44f542491a8c5f0279209bd590bc6f274" alt=""
Sign Root Certificate Request
Sign the certificate request with the Root CA private key.
“C:\Program Files\Splunk\bin\openssl.exe” x509 -req -in myCACertificate.csr -sha512 -signkey myCAPrivateKey.key -CAcreateserial -out myCACertificate.pem -days 1095
Create Server Certificate/Create Server Private Key
Create a private key for the server certificate
“C:\Program Files\Splunk\bin\openssl.exe” genrsa -aes256 -passout pass:1234 -out myServerPrivateKey.key 2048 -config “C:\Program Files\Splunk\openssl.cnf”
Remove Key phrase from private key
“C:\Program Files\Splunk\bin\openssl.exe” rsa -passin pass:1234 -in myServerPrivateKey.key -out myServerPrivateKey.key
Create Server Certificate request
Use the following command to generate a Certificate request that will be signed by the RootCA you have created. The name uses must match the FQDN of your Splunk server. In the example below I am generating a request for Splunk66x.bnwconsulting.com.au
“C:\Program Files\Splunk\bin\openssl.exe” req -new -key myServerPrivateKey.key -out myServerCertificate.csr -config “C:\Program Files\Splunk\openssl.cnf”
data:image/s3,"s3://crabby-images/c14ae/c14aeaaa0b1830b01536eaa0a6ac3cc9c78aa820" alt=""
Sign Server Certificate Request
Use the following command to generate a response for the Server Certificate request from the Root CA Certificate.
“C:\Program Files\Splunk\bin\openssl.exe” x509 -req -in myServerCertificate.csr -sha256 -CA myCACertificate.pem -CAkey myCAPrivateKey.key-CAcreateserial -out myServerCertificate.pem -days 1095
data:image/s3,"s3://crabby-images/16e5d/16e5d23f9ad0e9bf231f6223f902707e66cf661c" alt=""
Import Response
Import the Certificate response into the Splunk Server Certificate
copy myServerCertificate.pem+myServerPrivateKey.key+myCACertificate.pem mySplukServerCertificate.pem
data:image/s3,"s3://crabby-images/8ac15/8ac150982afbf75be915464edcdc0cb7efde6117" alt=""
mySplukServerCertificate.pem is now the SSL Certificate for your server.
Update Splunk Configuration/Certificate Files
The following files will now exist in the “myCerts” directory
Root CA Files
myCACertificate.csr
myCACertificate.pem
myCACertificate.srl
myCAPrivateKey.key
Server Certificate Files
myServerCertificate.csr
myServerCertificate.pem
myServerPrivateKey.key
mySplukServerCertificate.pem
data:image/s3,"s3://crabby-images/27e42/27e42384e78e15aae6e6804aecc05e54f96ae141" alt=""
Update Splunk SSL settings
Navigate to the $SPLUNK_HOME\etc\system\local directory
data:image/s3,"s3://crabby-images/7ea90/7ea90a1b3bf9bac03783fc84d18fb9a54884fe1e" alt=""
Open server.conf and search [sslConfig]
data:image/s3,"s3://crabby-images/3bab4/3bab44657aaaf929c851ec1f3b555cb5f3e16e8c" alt=""
[sslConfig]
sslPassword = xxxxxxxxxxxx
Replace the information under [sslConfig] with the following information
[sslConfig]
caCertFile = myCACertificate.pem
caPath = $SPLUNK_HOME\etc\auth\mycerts
sslKeysfile = mySplukServerCertificate.pem
sslKeysfilePassword = 1234
data:image/s3,"s3://crabby-images/2ec1e/2ec1e6ed88862f08393d0319763be5f47424f145" alt=""
Save and close
Restart Splukd Windows service
data:image/s3,"s3://crabby-images/987d7/987d7ec60b8ef5a0cb0275a435319b07643ae74f" alt=""
Test new certificate
Connect to port 8089 of your Splunk server through a web browsers using the following format:
https://<Fully Qualified Domain Name:8089
data:image/s3,"s3://crabby-images/ee8bf/ee8bfecfe2ccd99b3d3857210b3023957cf4c126" alt=""
Accept to continue to the website
data:image/s3,"s3://crabby-images/d58ce/d58ce8a0ec9d19051bdef51e4e76e222b32e2603" alt=""
Click on the “Certificate error” message and then select “View Certificate”
data:image/s3,"s3://crabby-images/2d2b3/2d2b32ba1ead681514c01871ac09d7d0c1c88b09" alt=""
data:image/s3,"s3://crabby-images/0ce71/0ce711848991ea1addc3b292310d9ebbd4c32c77" alt=""
Verify the “Issued to” name of the certificate matches the browser name.
Product version
Product | From | To |
PowerConnect [NW,S4HANA,S4HANA Cloud] | [Affected version from] | [Affected version to] |