Importing self-signed cert into Docker's JRE cacert is not recognized by the service

  • A Java Service is running inside the Docker container, which access the external HTTPS url and its self-sign certificate is unavailable to the service/ JRE cacert keystore and therefore connection fails.
  • Hence imported the self-signed certificate of HTTPS external URL into Docker container’s JRE cacert keystore. (after checking the $JAVA_HOME env. variable)
  • Restarted the Docker container (using “docker restart” command), hoping that the service is also get restarted and pick the changes from JRE cacert. But this didn’t happen, the Java service still fails to access external HTTPS URL.

Any idea how a Java service running inside the Docker container pick the JRE cacert changes with new certificate import?

  • Docker images with visual(X) support? Or should I use VBox instead in this case?
  • Docker swarm on 'dind' images and networking problems
  • How to build docker images on AWS EC2 Windows Server instance?
  • Pulling Docker Images from Private Repository using REGISTRY REST API
  • Unable to connect to Jupyter Notebook served by Docker
  • How to use docker-compose on ovh hosting
  • How to properly start Docker inside Jenkins that is also running in Docker
  • How to get infos about ourself in a compose cluster
  • Docker maven and jenkins, mvn install failed requesting junit:junit:jar:3.x
  • Dockerizing a gradle build on a Mac
  • Getting SequelizeConnectionRefusedError: when running docker with sequelize
  • push updates to gcloud containers/pods
  • One Solution collect form web for “Importing self-signed cert into Docker's JRE cacert is not recognized by the service”

    Hence imported the self-signed certificate of HTTPS external URL into Docker container’s JRE cacert keystore.

    No: you need to import it into the Docker image from which you run your container.

    Importing it into the container would only create a temporary writable data layer, which will be discarded when you restart your container.

    Something like this answer:

    USER root
    COPY ldap.cer $JAVA_HOME/jre/lib/security
    RUN \
        cd $JAVA_HOME/jre/lib/security \
        && keytool -keystore cacerts -storepass changeit -noprompt -trustcacerts -importcert -alias ldapcert -file ldap.cer
    
    Docker will be the best open platform for developers and sysadmins to build, ship, and run distributed applications.