Outils pour utilisateurs

Outils du site


linux:ssl (lu 52240 fois)

Différences

Ci-dessous, les différences entre deux révisions de la page.

Lien vers cette vue comparative

Les deux révisions précédentes Révision précédente
Prochaine révision
Révision précédente
Prochaine révision Les deux révisions suivantes
linux:ssl [09-01-2020 10:57]
edmc73
linux:ssl [24-06-2021 16:20]
edmc73
Ligne 10: Ligne 10:
  
  
-===== Avec StartSSL ===== 
  
-Aller sur ce site => http://www.startssl.com/ et créez-vous un compte. Il faudra ensuite installer le certificat qu'il vous fournirons pour vous identifier. 
- 
-Vous devrez valider votre email et nom de domaine en cliquant sur **Validations Wizard** 
- 
-Toujours dans **Validations Wizard** vous devez faire vérifier votre nom de domaine en choisissant **Domain Name Validation** 
- 
-Un mail de vérification sera envoyé à l'une (que vous choisissez) des adresses email renseigné pour votre nom de domaine. 
- 
-Ensuite, cliquez sur **Certificates Wizard**, choisissez **Web Server SSL/TLS Certificate** dans la liste et fournissez un mot de passe pour la clé privé. 
- 
-Copier/coller la clé sur votre serveur. Suivez les indications. 
- 
-  openssl rsa -in ssl.key -out ssl.key 
-   
-Cliquez sur **Continue** et choisissez votre nom de domaine. 
- 
-A la fin vous devez avoir 4 fichiers 
-  ca.pem  ssl.crt  ssl.key sub.class1.server.ca.pem 
- 
-Configurer ensuite apache dans ce style 
-<code> 
-<VirtualHost _default_:443> 
-   DocumentRoot /home/httpd/private 
-   ErrorLog /usr/local/apache/logs/error_log 
-   TransferLog /usr/local/apache/logs/access_log 
-   SSLEngine on 
-   SSLProtocol all -SSLv2 
-   SSLCipherSuite ALL:!ADH:!EXPORT:!SSLv2:RC4+RSA:+HIGH:+MEDIUM 
- 
-   SSLCertificateFile /usr/local/apache/conf/ssl.crt 
-   SSLCertificateKeyFile /usr/local/apache/conf/ssl.key 
-   SSLCertificateChainFile /usr/local/apache/conf/sub.class1.server.ca.pem 
-   CustomLog /usr/local/apache/logs/ssl_request_log \ 
-      "%t %h %{SSL_PROTOCOL}x %{SSL_CIPHER}x \"%r\" %b" 
-</VirtualHost> 
-</code> 
  
 ===== Avec Let's Encrypt ===== ===== Avec Let's Encrypt =====
Ligne 146: Ligne 109:
 </code> </code>
  
 +<note warning>Attention, la méthode par DNS a une validation manuel et ne permet pas facilement d'être renouvelé automatiquement
 +
 +Vous devrez retaper la commande suivante pour renouveler le certificat à la main.
 +  # certbot certonly --manual -d *.edmc73.com
 +
 +Voir la doc: https://certbot.eff.org/docs/using.html#pre-and-post-validation-hooks\\
 +Et un tuto pour automatiser avec l'api ovh: https://buzut.net/certbot-challenge-dns-ovh-wildcard/
 +</note>
  
 Tous les fichiers sont dans **/etc/letsencrypt** Tous les fichiers sont dans **/etc/letsencrypt**
Ligne 259: Ligne 230:
  
  
-<note warning>Ce qui suit est obsolète, mais je le garde pour archive</note> 
-Après avoir demandé une invitation pour tester en avant première ce nouveau service de certificat ssl gratuit, j'ai reçu un mail avec quelques commandes à taper. 
  
-1ère chose, récupérer le script 
-  git clone https://github.com/letsencrypt/letsencrypt 
  
-  If you're running Apache on a recent Debian-based OS, you can try the Apache plugin, which automates both obtaining and installing certs: 
-Je me dit, chouette un script tout prêt à l'emploi, c'est parti ! 
-  ./letsencrypt-auto --apache --server https://acme-v01.api.letsencrypt.org/directory --agree-dev-preview 
  
-Cette commande lance l'installation de package python et autre... J'aime pas vraiment ce genre de script qui se permet d'installer des trucs sans te demander ton avis. 
-Tout ça pour lancer un script dans un environnement virtuel de python qui se résume par un échec. 
-<code> 
-Running with virtualenv: sudo /home/user/.local/share/letsencrypt/bin/letsencrypt --apache --server https://acme-v01.api.letsencrypt.org/directory --agree-dev-preview 
-The apache plugin is not working; there may be problems with your existing configuration. 
-The error was: PluginError('Unable to parse runtime variables',) 
-</code> 
- 
-Bien que tous les efforts ont été fait pour nous simplifier la vie, je n'aime pas vraiment ça, surtout pour installer un certificat ssl qui ne demande qu'à copier 3-4 fichiers et écrire quelques lignes de config dans apache. 
- 
-J'ai l'impression de perdre plus de temps à comprendre leur système de plugins. Bref, après plusieurs minutes de lecture de la doc ( https://letsencrypt.readthedocs.org/en/latest/using.html#installation ) je fini par utiliser le plugins **manual** 
- 
-  ./letsencrypt-auto certonly -a manual -d forum.p2pfr.com \ 
-  --server https://acme-v01.api.letsencrypt.org/directory --agree-dev-preview 
- 
-Ce qui nous sort toutes les commandes à taper en root sur le serveur web 
-<code> 
-Make sure your web server displays the following content at 
-http://forum.p2pfr.com/.well-known/acme-challenge/xxxxxxxxxxxxxxxxxxxxxxxxxxx before continuing: 
- 
-xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx 
- 
-Content-Type header MUST be set to text/plain. 
- 
-If you don't have HTTP server configured, you can run the following 
-command on the target server (as root): 
- 
-mkdir -p /tmp/letsencrypt/public_html/.well-known/acme-challenge 
-cd /tmp/letsencrypt/public_html 
-printf "%s" xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx > .well-known/acme-challenge/xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx 
-# run only once per server: 
-$(command -v python2 || command -v python2.7 || command -v python2.6) -c \ 
-"import BaseHTTPServer, SimpleHTTPServer; \ 
-SimpleHTTPServer.SimpleHTTPRequestHandler.extensions_map = {'': 'text/plain'}; \ 
-s = BaseHTTPServer.HTTPServer(('', 80), SimpleHTTPServer.SimpleHTTPRequestHandler); \ 
-s.serve_forever()" 
-</code> 
- 
-Alors ok, on voit mieux ce qui se passe, mais ça me parait encore trop lourd, je décide de tester la méthode **webroot** où l'on définit sur le serveur web où se trouve le site que l'on veut mettre en https et il gère le reste 
- 
-  ./letsencrypt-auto certonly -a webroot --webroot-path /home/public_html/forum.p2pfr.com -d forum.p2pfr.com \ 
-  --server https://acme-v01.api.letsencrypt.org/directory --agree-dev-preview 
- 
-et la magie opère 
-<code> 
-Updating letsencrypt and virtual environment dependencies....... 
-Running with virtualenv: sudo /home/user/.local/share/letsencrypt/bin/letsencrypt certonly -a webroot --webroot-path /home/public_html/forum.p2pfr.com/ -d forum.p2pfr.com --server https://acme-v01.api.letsencrypt.org/directory --agree-dev-preview 
- 
-IMPORTANT NOTES: 
- - Congratulations! Your certificate and chain have been saved at 
-   /etc/letsencrypt/live/forum.p2pfr.com/fullchain.pem. Your cert will 
-   expire on 2016-02-15. To obtain a new version of the certificate in 
-   the future, simply run Let's Encrypt again. 
-</code> 
- 
-Maintenant nous avons 4 fichiers prêt à l'emploi pour configurer notre Apache 
-<code> 
- <IfModule mod_ssl.c> 
-                SSLEngine on 
-                SSLProtocol all -SSLv2 
-                SSLCipherSuite ALL:!ADH:!EXPORT:!SSLv2:RC4+RSA:+HIGH:+MEDIUM 
-                SSLCertificateFile      /etc/letsencrypt/live/forum.p2pfr.com/cert.pem 
-                SSLCertificateKeyFile   /etc/letsencrypt/live/forum.p2pfr.com/privkey.pem 
-                SSLCertificateChainFile /etc/letsencrypt/live/forum.p2pfr.com/chain.pem 
-                SSLCACertificateFile    /etc/letsencrypt/live/forum.p2pfr.com/fullchain.pem 
-                SetEnvIf User-Agent “.*MSIE.*” nokeepalive ssl-unclean-shutdown 
- </IfModule> 
-</code> 
- 
-On reload apache 
-  service apache2 reload 
- 
-et voici le résultat 
-{{:linux:ssl_forum.p2pfr.com.jpg?nolink|}} 
- 
-Pour renouveler le certificat, il suffit de relancer la même dernière commande. 
- 
-Le certificat est valide 90 jours, donc on peut lancer cette commande en automatique tous les 88 jours par exemple via le cron. 
- 
-Le cron ne permet pas d’exécuter un script tous les 88 jours, je propose donc un petit script que vous exécuterez tous les jours par le cron et qui fera un test sur la date du certificat pour savoir si il est plus vieux que 88 jours, et dans ce cas il exécutera le script letsencrypt pour renouveler le certificat. 
- 
-N'oubliez pas d'ajouter l'option ''--renew-by-default'' 
-<code bash> 
-#!/bin/bash 
- 
-if test `find /etc/letsencrypt/live/forum.p2pfr.com/cert.pem -mtime +88` 
-then 
-  /home/user/letsencrypt/letsencrypt-auto certonly -a webroot --webroot-path /home/public_html/p2pfr.com/forum/ -d forum.p2pfr.com --server https://acme-v01.api.letsencrypt.org/directory --renew-by-default 
-fi 
-</code> 
- 
-Pour avoir un peu d'aide 
-  ./letsencrypt-auto --help all 
- 
- 
-====== Retour d'expérience ====== 
-Après 90 jours, c'est donc le moment fatidique de mettre à jour le certificat. Pour info nous recevons un mail de notification d'expiration 20 jours avant, 9 jours avant et le jour J. 
-En lançant la commande 
-  /home/user/letsencrypt/letsencrypt-auto certonly -a webroot --webroot-path /home/public_html/p2pfr.com/forum/ -d forum.p2pfr.com --server https://acme-v01.api.letsencrypt.org/directory --agree-dev-preview --renew-by-default 
- 
-J'obtiens un joli 
-  Updating letsencrypt and virtual environment dependencies...You are using pip version 7.1.2, however version 8.0.2 is available. 
-  You should consider upgrading via the 'pip install --upgrade pip' command. 
-  ..Could not open requirements file: [Errno 2] No such file or directory: 'py26reqs.txt' 
- 
- 
-Je lance le script tout seul 
-  ./letsencrypt-auto 
-  Updating letsencrypt and virtual environment dependencies....... 
-  Running with virtualenv: /root/.local/share/letsencrypt/bin/letsencrypt 
-  No installers seem to be present and working on your system; fix that or try running letsencrypt with the "certonly" command 
- 
-Je lance avec le "certonly" comme il me le suggère et bon bref, je décide de relancer notre commande du début et bingo :) 
-<code> 
-Updating letsencrypt and virtual environment dependencies....... 
-Running with virtualenv: /root/.local/share/letsencrypt/bin/letsencrypt certonly -a webroot --webroot-path /home/public_html/p2pfr.com/forum/ -d forum.p2pfr.com --server https://acme-v01.api.letsencrypt.org/directory --agree-dev-preview 
-Use of --agree-dev-preview is deprecated. 
- 
-IMPORTANT NOTES: 
- - Congratulations! Your certificate and chain have been saved at 
-   /etc/letsencrypt/live/forum.p2pfr.com/fullchain.pem. Your cert will 
-   expire on 2016-05-15. To obtain a new version of the certificate in 
-   the future, simply run Let's Encrypt again. 
- - If you like Let's Encrypt, please consider supporting our work by: 
- 
-   Donating to ISRG / Let's Encrypt:   https://letsencrypt.org/donate 
-   Donating to EFF:                    https://eff.org/donate-le 
-</code> 
- 
-Par contre il faut quand même recharger apache 
-  service apache2 reload 
-Sinon le nouveau certificat n'est pas disponible 
- 
-===== 2ème retour ===== 
- 
-let's encrypt a changé de script. 
- 
-Après avoir réinstallé leur nouveau script **certbot**, la nouvelle commande est un peu plus simple 
-<code> 
-# ./certbot-auto certonly --webroot -w /home/public_html/p2pfr.com/forum -d forum.p2pfr.com 
-Checking for new version... 
-Requesting root privileges to run certbot... 
-   /root/.local/share/letsencrypt/bin/letsencrypt certonly --webroot -w /home/public_html/p2pfr.com/forum -d forum.p2pfr.com 
- 
-IMPORTANT NOTES: 
- - Congratulations! Your certificate and chain have been saved at 
-   /etc/letsencrypt/live/forum.p2pfr.com/fullchain.pem. Your cert will 
-   expire on 2016-08-11. To obtain a new version of the certificate in 
-   the future, simply run Certbot again. 
- - If you like Certbot, please consider supporting our work by: 
- 
-   Donating to ISRG / Let's Encrypt:   https://letsencrypt.org/donate 
-   Donating to EFF:                    https://eff.org/donate-le 
- 
-</code> 
  
-La première fois, un email vous sera demandé ainsi qu'une validation de la licence, des infos seront stocké dans /etc/letsencrypt 
  
 ==== Commandes ==== ==== Commandes ====
Ligne 444: Ligne 252:
 Si vous changer le path dans votre config apache, vous pouvez modifier la config letsencrypt à la main dans **/etc/letsencrypt/renewal/xxxx.conf** ensuite, tester si tout se passe bien avec la commande Si vous changer le path dans votre config apache, vous pouvez modifier la config letsencrypt à la main dans **/etc/letsencrypt/renewal/xxxx.conf** ensuite, tester si tout se passe bien avec la commande
   certbot renew --dry-run   certbot renew --dry-run
 +  
 ===== Avec certbot de debian ===== ===== Avec certbot de debian =====
  
Ligne 489: Ligne 298:
   certbot certonly --webroot -w /var/www/letsencrypt/ -d edmc73.com   certbot certonly --webroot -w /var/www/letsencrypt/ -d edmc73.com
 Ce sera le même répertoire pour tous les domaines de votre serveur. Ce sera le même répertoire pour tous les domaines de votre serveur.
 +
 +Si vous utilisez un proxy pass, attention à exclure le chemin de letsencrypt comme ceci
 +
 +<code apache>
 +  ProxyPass /.well-known/acme-challenge !
 +  ProxyPass / http://127.0.0.1:6000/
 +  ProxyPassReverse / http://127.0.0.1:6000/
 +</code>
 +
 +
 ===== Alternative à certbot ===== ===== Alternative à certbot =====
  
Ligne 545: Ligne 364:
 </code> </code>
  
 +
 +===== Avec StartSSL =====
 +
 +Aller sur ce site => http://www.startssl.com/ et créez-vous un compte. Il faudra ensuite installer le certificat qu'il vous fournirons pour vous identifier.
 +
 +Vous devrez valider votre email et nom de domaine en cliquant sur **Validations Wizard**
 +
 +Toujours dans **Validations Wizard** vous devez faire vérifier votre nom de domaine en choisissant **Domain Name Validation**
 +
 +Un mail de vérification sera envoyé à l'une (que vous choisissez) des adresses email renseigné pour votre nom de domaine.
 +
 +Ensuite, cliquez sur **Certificates Wizard**, choisissez **Web Server SSL/TLS Certificate** dans la liste et fournissez un mot de passe pour la clé privé.
 +
 +Copier/coller la clé sur votre serveur. Suivez les indications.
 +
 +  openssl rsa -in ssl.key -out ssl.key
 +  
 +Cliquez sur **Continue** et choisissez votre nom de domaine.
 +
 +A la fin vous devez avoir 4 fichiers
 +  ca.pem  ssl.crt  ssl.key sub.class1.server.ca.pem
 +
 +Configurer ensuite apache dans ce style
 +<code>
 +<VirtualHost _default_:443>
 +   DocumentRoot /home/httpd/private
 +   ErrorLog /usr/local/apache/logs/error_log
 +   TransferLog /usr/local/apache/logs/access_log
 +   SSLEngine on
 +   SSLProtocol all -SSLv2
 +   SSLCipherSuite ALL:!ADH:!EXPORT:!SSLv2:RC4+RSA:+HIGH:+MEDIUM
 +
 +   SSLCertificateFile /usr/local/apache/conf/ssl.crt
 +   SSLCertificateKeyFile /usr/local/apache/conf/ssl.key
 +   SSLCertificateChainFile /usr/local/apache/conf/sub.class1.server.ca.pem
 +   CustomLog /usr/local/apache/logs/ssl_request_log \
 +      "%t %h %{SSL_PROTOCOL}x %{SSL_CIPHER}x \"%r\" %b"
 +</VirtualHost>
 +</code>
linux/ssl.txt · Dernière modification: 17-12-2023 10:35 de edmc73