I use Namecheap.com as a registrar, and they resale SSL Certs from a number of other companies, including Comodo.
These are the steps I went through to set up an SSL cert.
Prior to purchasing a cert, you need to generate a private key, and a CSR file (Certificate Signing Request). You'll be asked for the content of the CSR file when ordering the certificate.
openssl req -nodes -newkey rsa:2048 -keyout example_com.key -out example_com.csr
This gives you two files:
example_com.key
-- your Private key. You'll need this later to configure ngxin.example_com.csr
-- Your CSR file.
Now, purchase the certificate [1], wait forever for them to review your purchase. You'll eventually get an email with your PositiveSSL Certificate. It contains a zip file with the following:
- Root CA Certificate - AddTrustExternalCARoot.crt
- Intermediate CA Certificate - PositiveSSLCA2.crt
- Your PositiveSSL Certificate - example_com.crt
Combine everything for nxinx [2]:
Combine the above crt files into a bundle (the order matters, here):
cat example_com.crt PositiveSSLCA2.crt AddTrustExternalCARoot.crt >> ssl-bundle.crt
Store the bundle wherever nginx expects to find it:
mkdir -p /etc/nginx/ssl/example_com/ mv ssl-bundle.crt /etc/nginx/ssl/example_com/
Make sure your nginx config points to the right cert file and to the private key you generated earlier:
server { listen 443; ssl on; ssl_certificate /etc/nginx/ssl/example_com/ssl-bundle.crt; ssl_certificate_key /etc/nginx/ssl/example_com/example_com.key; # ... }
Restart nginx.
[1] | I purchased mine through the Namecheap.com website. |
[2] | Based on these instructions: http://goo.gl/4zJc8 |
[3] | Optimizing HTTPS on Nginx https://bjornjohansen.no/optimizing-https-nginx |
- RSA: openssl req -nodes -newkey rsa:<bytes> -keyout server1-key.pem -out server1.csr
- DSA: openssl req -nodes -newkey dsa:blogCA-cert.pem -keyout server1-key.pem -out server1.csr
- ECDSA: openssl req -nodes -newkey ec:blogCA-cert.pem -keyout server1-key.pem -out server1.csr
---
- [How do I create an ECDSA certificate with the OpenSSL command-line](http://stackoverflow.com/a/11999641/2126990)
- [Stop Paying For SSL Certificates You Don't Need](https://www.tinfoilsecurity.com/blog/stop-paying-for-ssl-certificates-you-dont-need-openssl-ca-tutorial-guide-how-to)
- [Generate ECDSA key with OpenSSL](http://gagor.pl/2013/12/generate-ecdsa-key-with-openssl/)