This guide explains how to install and configure acme.sh for SSL certificate management using Let's Encrypt, integrate it with Nginx, set up automatic renewal with cron
, and perform manual renewal if needed.
1️⃣ Install acme.sh
acme.sh is a pure shell script for managing SSL certificates.
curl https://get.acme.sh | sh
Add it to your shell environment:
source ~/.bashrc
Verify installation:
acme.sh --version
2️⃣ Issue an SSL Certificate
Using Webroot Mode (Recommended for Nginx)
Replace yourdomain.com with your actual domain:
acme.sh --issue -d yourdomain.com -d www.yourdomain.com -w /var/www/html
Certificates are stored in:
~/.acme.sh/yourdomain.com/
3️⃣ Install the Certificate to Nginx
sudo mkdir -p /etc/nginx/ssl/yourdomain.com acme.sh --install-cert -d yourdomain.com \ --key-file /etc/nginx/ssl/yourdomain.com/key.pem \ --fullchain-file /etc/nginx/ssl/yourdomain.com/fullchain.pem \ --reloadcmd "systemctl reload nginx"
4️⃣ Configure Nginx to Use SSL
Edit your Nginx config file (e.g., /etc/nginx/sites-available/yourdomain.conf):
server { listen 80; server_name yourdomain.com www.yourdomain.com; # Redirect HTTP to HTTPS return 301 https://$host$request_uri; } server { listen 443 ssl; server_name yourdomain.com www.yourdomain.com; ssl_certificate /etc/nginx/ssl/yourdomain.com/fullchain.pem; ssl_certificate_key /etc/nginx/ssl/yourdomain.com/key.pem; location / { root /var/www/html; index index.html; } }
Test and reload Nginx:
sudo nginx -t sudo systemctl reload nginx
5️⃣ Set Up Auto-Renewal with crontab
acme.sh usually sets this up automatically. Check:
crontab -l
Expected output:
0 0 * * * "~/.acme.sh"/acme.sh --cron --home "~/.acme.sh" > /dev/null
If not present, add manually:
crontab -e
Insert:
0 0 * * * ~/.acme.sh/acme.sh --cron --home ~/.acme.sh > /dev/null
6️⃣ Manually Renew Certificates
Renew a Single Domain
Force renewal before expiration:
acme.sh --renew -d yourdomain.com --force
Reload Nginx:
sudo systemctl reload nginx
Renew All Certificates
To renew all certificates managed by acme.sh at once:
acme.sh --renew-all --force
Reload Nginx after renewal:
sudo systemctl reload nginx
7️⃣ Useful Commands
- List all issued certificates:
acme.sh --list
- Revoke a certificate:
acme.sh --revoke -d yourdomain.com
- Remove a certificate from acme.sh:
acme.sh --remove -d yourdomain.com
8️⃣ Troubleshooting
- Open required ports:
sudo ufw allow 80 sudo ufw allow 443
- Check Nginx logs:
sudo tail -f /var/log/nginx/error.log
- Verify DNS points to your server.
✅ With this setup, SSL will be automatically renewed via cron, integrated with Nginx, and can be manually renewed anytime — either for one domain or all at once.
Top comments (0)