How to configure spring boot application to use SSL/TLS over MySQL?

后端 未结 2 1411
野性不改
野性不改 2021-02-02 04:30

I set up SSL on my MySQL server.

I generated few certicates for CA (ca.pem, ca-key.pem), for client (client-cert.pem, client-key.pem) and server (server-cert.pem and se

相关标签:
2条回答
  • 2021-02-02 04:53

    You need to add the "*.pem" files (cert and key) in a keystore and the CA in a "truststore".

    This link explains well how to create your own keystore and truststore [link] http://roopindersingh.com/programming/converting-pem-certificates-and-private-keys-to-jks/

    After you have to add in JVM paramaters

    -Djavax.net.ssl.keyStore=/path/to/keystore/keystore.jks
    -Djavax.net.ssl.keyStorePassword=password
    -Djavax.net.ssl.trustStore=/path/to/keystore/truststore.jks
    -Djavax.net.ssl.trustStorePassword=password
    
    0 讨论(0)
  • 2021-02-02 04:54

    Check my answer: https://stackoverflow.com/a/51879119/173149

    I don't like to pollute java options or system properties, which are useless in application containers in any case...

    You can set SSL certificate for MySQL connection programmically with:

    jdbc:mysql://example.com:3306/MYDB?verifyServerCertificate=true&useSSL=true&requireSSL=true&clientCertificateKeyStoreUrl=file:cert/keystore.jks&clientCertificateKeyStorePassword=123456&trustCertificateKeyStoreUrl=file:cert/truststore.jks&trustCertificateKeyStorePassword=123456

    It is documented:

    • https://dev.mysql.com/doc/connector-j/5.1/en/connector-j-reference-configuration-properties.html
    • https://dev.mysql.com/doc/connector-j/5.1/en/connector-j-reference-using-ssl.html
    0 讨论(0)
提交回复
热议问题