acme.sh

acme.shopen in new window

Issue

~/.acme.sh/acme.sh --issue -d example.com -d *.example.com -w /var/www/example.com

Renew

crontab -e
22 0 * * * "~/.acme.sh"/acme.sh --cron --home "~/.acme.sh" > /dev/null

Install cert to Nginx

mkdir /etc/nginx/ssl/
mkdir /etc/nginx/ssl/example.com/
~/.acme.sh/acme.sh --install-cert -d example.com \
--key-file       /etc/nginx/ssl/example.com/privkey.pem  \
--fullchain-file /etc/nginx/ssl/example.com/chain.pem \
--reloadcmd     "service nginx force-reload"

Show installed certificate information

~/.acme.sh/acme.sh --info -d example.com

Nginx config

server {
    listen 80;
    listen [::]:80;
    listen 443 ssl http2;
    listen [::]:443 ssl http2;

    server_name example.com *.example.com;
    root /var/www/example.com/public;
    index index.html index.php;
    
    ssl_certificate /etc/nginx/ssl/example.com/chain.pem;
    ssl_certificate_key /etc/nginx/ssl/example.com/privkey.pem;
    ssl_protocols TLSv1.1 TLSv1.2 TLSv1.3;
    ssl_ciphers EECDH+CHACHA20:EECDH+CHACHA20-draft:EECDH+AES128:RSA+AES128:EECDH+AES256:RSA+AES256:EECDH+3DES:RSA+3DES:!MD5;
    ssl_prefer_server_ciphers on;
    ssl_session_cache shared:SSL:10m;
    ssl_session_timeout 10m;
    
    location / {
        try_files $uri $uri/ /index.php?$query_string;
    }
    
    location ~ \.php$ {
        try_files $fastcgi_script_name =404;
        fastcgi_index index.php;
        fastcgi_pass unix:/var/run/php/php8.2-fpm.sock;
        include fastcgi_params;
        fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
    }

    location ~ /\.ht {
        deny all;
    }
}
Last Updated:
Contributors: kelude