User Tools

Site Tools


en:user_advanced:gs3_https
This version is outdated by a newer approved version.DiffThis version (2025/02/12 23:59) is a draft.
Approvals: 0/1
The Previously approved version (2024/09/23 02:39) is available.Diff

This is an old revision of the document!


Running Greenstone3 over HTTPS

There are two main ways of running Greenstone 3 using HTTPS:

  • [Preferred] Running an Apache server configured to support HTTPS, and reverse proxying the Tomcat server
  • Setting up Tomcat to run using HTTPS

Using Apache to reverse proxy Tomcat

Linux: Getting SSL certificates using certbot

A

To have your webserver running under https, you need an SSL certificate. Many hosting platforms have tools to let you use HTTPS. See https://certbot.eff.org/hosting_providers to check your hosting provider.

If yours doesn't, an easy way of getting an SSL certificate, which is free, is to use certbot and LetsEncrypt. Certbot https://certbot.eff.org/ is a free, open source software tool for automatically using Let’s Encrypt certificates on manually-administrated websites to enable HTTPS. LetsEncrypt is a free, automated, and open Certificate Authority. About Certbot

You will need to install certbot - follow the instructions at https://certbot.eff.org/instructions Take note of the "What you need" section. Then, choose your webserver ('apache' or 'other' for Tomcat) and operating system, and it will give you instructions to install certbot, plus also instructions to run it to get certificates.

Once you have certbot installed, if you are using Apache, you can run

  • sudo certbot –apache - this will generate the certificates, plus also setup Apache configuration to use them.
  • sudo certbot certonly - will generate the certificates, but do no configuration in Apache - you will need to do that yourself.

If you are adding https support to Tomcat, you can use the Greenstone ant targets to generate the certificates, plus then convert them and setup Tomcat configuration to use them.

  • ant setup-https-cert - this will obtain the certificates from LetsEncrypt, and put them into Tomcat's conf folder.
  • ant renew-existing-https-cert - to run the renewal command and reinstall them into Tomcat.

The SSL certificates are installed into /etc/letsencrypt/live/<tomcat.server>

Once you use certbot to obtain certificates, it sets up a systemd timer to automatically renew them every 60 days. You shouldn't need to re-run certbot unless your settings have changed. Note, if your port 80 is not open by default, and you opened it just for generating the initial certificates, this renewal won't work. You'll need to open up port 80, and run

  • sudo certbot renew.
en/user_advanced/gs3_https.1739404790.txt.gz · Last modified: 2025/02/12 23:59 by kjdon