index.html 30 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601
  1. <!DOCTYPE html>
  2. <!--[if IE 8]><html class="no-js lt-ie9" lang="en" > <![endif]-->
  3. <!--[if gt IE 8]><!--> <html class="no-js" lang="en" > <!--<![endif]-->
  4. <head>
  5. <meta charset="utf-8">
  6. <meta http-equiv="X-UA-Compatible" content="IE=edge">
  7. <meta name="viewport" content="width=device-width, initial-scale=1.0">
  8. <link rel="shortcut icon" href="../../../img/favicon.ico">
  9. <title>Installation d'un serveur de courriers basique - Les Tutoriels du Yojik</title>
  10. <link rel="stylesheet" href="../../../css/theme.css" />
  11. <link rel="stylesheet" href="../../../css/theme_extra.css" />
  12. <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/highlight.js/9.12.0/styles/github.min.css" />
  13. <script>
  14. // Current page data
  15. var mkdocs_page_name = "Installation d'un serveur de courriers basique";
  16. var mkdocs_page_input_path = "Tutoriels/tutoraspi/Installation-courrier-basique.md";
  17. var mkdocs_page_url = null;
  18. </script>
  19. <script src="../../../js/jquery-2.1.1.min.js" defer></script>
  20. <script src="../../../js/modernizr-2.8.3.min.js" defer></script>
  21. <script src="https://cdnjs.cloudflare.com/ajax/libs/highlight.js/9.12.0/highlight.min.js"></script>
  22. <script>hljs.initHighlightingOnLoad();</script>
  23. </head>
  24. <body class="wy-body-for-nav" role="document">
  25. <div class="wy-grid-for-nav">
  26. <nav data-toggle="wy-nav-shift" class="wy-nav-side stickynav">
  27. <div class="wy-side-scroll">
  28. <div class="wy-side-nav-search">
  29. <a href="../../.." class="icon icon-home"> Les Tutoriels du Yojik</a>
  30. <div role="search">
  31. <form id ="rtd-search-form" class="wy-form" action="../../../search.html" method="get">
  32. <input type="text" name="q" placeholder="Search docs" title="Type search term here" />
  33. </form>
  34. </div>
  35. </div>
  36. <div class="wy-menu wy-menu-vertical" data-spy="affix" role="navigation" aria-label="main navigation">
  37. <p class="caption"><span class="caption-text">Home</span></p>
  38. <ul>
  39. <li class="toctree-l1"><a class="reference internal" href="../../..">Page d'accueil</a>
  40. </li>
  41. </ul>
  42. <p class="caption"><span class="caption-text">Tutoriels</span></p>
  43. <ul class="current">
  44. <li class="toctree-l1"><a class="reference internal" href="../../tutos/">Introduction</a>
  45. </li>
  46. <li class="toctree-l1"><a class="reference internal" href="#">Installation d'un serveur sécurisé, version Debian/Stretch (obsolète)</a>
  47. <ul>
  48. <li class="toctree-l2"><a class="reference internal" href="../../tutostretch/tutostretch/">Présentation</a>
  49. </li>
  50. <li class="toctree-l2"><a class="reference internal" href="#">Installation</a>
  51. <ul>
  52. <li class="toctree-l3"><a class="reference internal" href="../../tutostretch/Installation-de-base/">Installation du système de base</a>
  53. </li>
  54. <li class="toctree-l3"><a class="reference internal" href="../../tutostretch/ovh/">Démarrage sur serveur OVH</a>
  55. </li>
  56. <li class="toctree-l3"><a class="reference internal" href="../../tutostretch/Premi%C3%A8re-Etape-S%C3%A9curisation/">Première étapes de sécurisation du serveur</a>
  57. </li>
  58. <li class="toctree-l3"><a class="reference internal" href="../../tutostretch/Configuration-R%C3%A9seau/">Configuration du réseau</a>
  59. </li>
  60. <li class="toctree-l3"><a class="reference internal" href="../../tutostretch/Installation-Serveur-Temps/">Installation d'un serveur de temps</a>
  61. </li>
  62. <li class="toctree-l3"><a class="reference internal" href="../../tutostretch/Installation-Parre-Feu/">Installation d'un pare-feu</a>
  63. </li>
  64. <li class="toctree-l3"><a class="reference internal" href="../../tutostretch/Installation-Fail2ban/">Contrer les attaques de brute-force avec fail2ban</a>
  65. </li>
  66. <li class="toctree-l3"><a class="reference internal" href="../../tutostretch/Installation-Serveur-Courrier-Basique/">Installation d'un serveur de courrier basique</a>
  67. </li>
  68. <li class="toctree-l3"><a class="reference internal" href="../../tutostretch/Installation-Serveur-DNS/">Installation du serveur DNS</a>
  69. </li>
  70. <li class="toctree-l3"><a class="reference internal" href="../../tutostretch/Installation-Serveur-Web/">Installation d'un serveur web</a>
  71. </li>
  72. <li class="toctree-l3"><a class="reference internal" href="../../tutostretch/Installation-Dovecot-Authentification/">Installation de dovecot et de l'authentification</a>
  73. </li>
  74. <li class="toctree-l3"><a class="" href="../../tutostretch/Installation-Certificats-Letsencrypt.md)">Installation des certificats letsencrypt</a>
  75. </li>
  76. <li class="toctree-l3"><a class="" href="../../tutostretch/courrier-SPF-DKIM-OPENDMARC.md">Ajout des enregistrements **spf**, **DKIM**, **DMARC** au fichier de zone DNS</a>
  77. </li>
  78. <li class="toctree-l3"><a class="reference internal" href="../../tutostretch/Courrier-Comptes-Virtuels/">Ajout des comptes émail virtuels</a>
  79. </li>
  80. <li class="toctree-l3"><a class="reference internal" href="../../tutostretch/Surveillance-Serveur/">Installation de programmes de surveillance du serveur</a>
  81. </li>
  82. <li class="toctree-l3"><a class="reference internal" href="../../tutostretch/Installation-Webmail/">Installation d'un webmail (rainloop)</a>
  83. </li>
  84. <li class="toctree-l3"><a class="" href="../../tutostretch/Sécurisation-Serveur-Web">Sécurisation d'un serveur WEB</a>
  85. </li>
  86. </ul>
  87. </li>
  88. </ul>
  89. </li>
  90. <li class="toctree-l1"><a class="reference internal" href="#">Installation d'un serveur sécurisé, version Debian/Buster (en cours d'écriture)</a>
  91. <ul>
  92. <li class="toctree-l2"><a class="reference internal" href="../../tutobuster/1-tutobuster/">Présentation</a>
  93. </li>
  94. <li class="toctree-l2"><a class="reference internal" href="../../tutobuster/2-Installation-de-base/">Installation de base</a>
  95. </li>
  96. <li class="toctree-l2"><a class="reference internal" href="../../tutobuster/3-ovh/">Démarrage sur serveur OVH</a>
  97. </li>
  98. <li class="toctree-l2"><a class="reference internal" href="../../tutobuster/4-Plan/">Plan d'ensemble</a>
  99. </li>
  100. <li class="toctree-l2"><a class="reference internal" href="../../tutobuster/5-Premi%C3%A8re-Etape-S%C3%A9curisation/">Premières étapes de sécurisation du serveur</a>
  101. </li>
  102. </ul>
  103. </li>
  104. <li class="toctree-l1 current"><a class="reference internal current" href="#">Installation d'un serveur sécurisé, version Debian/Buster sur RaspberryPI</a>
  105. <ul class="current">
  106. <li class="toctree-l2"><a class="reference internal" href="../R%C3%A9sum%C3%A9/">Résumé</a>
  107. </li>
  108. <li class="toctree-l2"><a class="reference internal" href="../tutoraspi/">Présentation</a>
  109. </li>
  110. <li class="toctree-l2"><a class="reference internal" href="../Installation-de-base/">Installation de base</a>
  111. </li>
  112. <li class="toctree-l2"><a class="reference internal" href="../Premier-d%C3%A9marrage/">Premier démarrage</a>
  113. </li>
  114. <li class="toctree-l2"><a class="reference internal" href="../Etat-des-lieux/">État des lieux</a>
  115. </li>
  116. <li class="toctree-l2"><a class="reference internal" href="../S%C3%A9curisation-SSH/">Sécurisation SSH</a>
  117. </li>
  118. <li class="toctree-l2"><a class="reference internal" href="../R%C3%A9seau/">Réseau (des IPs fixes)</a>
  119. </li>
  120. <li class="toctree-l2"><a class="reference internal" href="../Knot/">Installation de Knot-resolver</a>
  121. </li>
  122. <li class="toctree-l2"><a class="reference internal" href="../Firewall/">Installation d'un pare-feux</a>
  123. </li>
  124. <li class="toctree-l2"><a class="reference internal" href="../Fail2ban/">Contrer les attaques de force brute</a>
  125. </li>
  126. <li class="toctree-l2"><a class="reference internal" href="../Logwatch/">Surveillance du serveur</a>
  127. </li>
  128. <li class="toctree-l2 current"><a class="reference internal current" href="./">Installation d'un serveur de courriers basique</a>
  129. <ul class="current">
  130. <li class="toctree-l3"><a class="reference internal" href="#installation">Installation</a>
  131. </li>
  132. <li class="toctree-l3"><a class="reference internal" href="#suppression-complete-de-exim4">Suppression complète de exim4</a>
  133. </li>
  134. <li class="toctree-l3"><a class="reference internal" href="#ouverture-des-ports-25">Ouverture des ports 25</a>
  135. <ul>
  136. <li class="toctree-l4"><a class="reference internal" href="#liste-des-services-disponibles">Liste des services disponibles</a>
  137. </li>
  138. <li class="toctree-l4"><a class="reference internal" href="#ajout-du-service-smtp">Ajout du service smtp</a>
  139. </li>
  140. <li class="toctree-l4"><a class="reference internal" href="#verification">Vérification</a>
  141. </li>
  142. </ul>
  143. </li>
  144. <li class="toctree-l3"><a class="reference internal" href="#installation-des-utilitaire-courriers">Installation des utilitaire courriers</a>
  145. </li>
  146. <li class="toctree-l3"><a class="reference internal" href="#test-denvoi-de-courriers-entre-comptes-internes">Test d'envoi de courriers entre comptes internes.</a>
  147. </li>
  148. <li class="toctree-l3"><a class="reference internal" href="#configuration-de-postfix">Configuration de postfix</a>
  149. <ul>
  150. <li class="toctree-l4"><a class="reference internal" href="#courriers-sortants">Courriers sortants</a>
  151. </li>
  152. <li class="toctree-l4"><a class="reference internal" href="#courriers-entrants">Courriers entrants</a>
  153. </li>
  154. </ul>
  155. </li>
  156. <li class="toctree-l3"><a class="reference internal" href="#amelioration-de-la-gestion-du-courrier">Amélioration de la gestion du courrier</a>
  157. </li>
  158. <li class="toctree-l3"><a class="reference internal" href="#protection-par-fail2ban">Protection par Fail2ban</a>
  159. </li>
  160. </ul>
  161. </li>
  162. <li class="toctree-l2"><a class="reference internal" href="../Exemple-d-utilisation-serveur-Web/">Exemple d'utilisation avec un serveur Web</a>
  163. </li>
  164. <li class="toctree-l2"><a class="reference internal" href="../Annexe/">Annexe</a>
  165. </li>
  166. </ul>
  167. </li>
  168. <li class="toctree-l1"><a class="reference internal" href="#">Domotique</a>
  169. <ul>
  170. <li class="toctree-l2"><a class="reference internal" href="../../Domotique/Introduction/">Introduction</a>
  171. </li>
  172. <li class="toctree-l2"><a class="reference internal" href="../../Domotique/Le-mat%C3%A9riel/">Le matériel</a>
  173. </li>
  174. </ul>
  175. </li>
  176. </ul>
  177. </div>
  178. </div>
  179. </nav>
  180. <section data-toggle="wy-nav-shift" class="wy-nav-content-wrap">
  181. <nav class="wy-nav-top" role="navigation" aria-label="top navigation">
  182. <i data-toggle="wy-nav-top" class="fa fa-bars"></i>
  183. <a href="../../..">Les Tutoriels du Yojik</a>
  184. </nav>
  185. <div class="wy-nav-content">
  186. <div class="rst-content">
  187. <div role="navigation" aria-label="breadcrumbs navigation">
  188. <ul class="wy-breadcrumbs">
  189. <li><a href="../../..">Docs</a> &raquo;</li>
  190. <li>Installation d'un serveur sécurisé, version Debian/Buster sur RaspberryPI &raquo;</li>
  191. <li>Tutoriels &raquo;</li>
  192. <li>Installation d'un serveur de courriers basique</li>
  193. <li class="wy-breadcrumbs-aside">
  194. </li>
  195. </ul>
  196. <hr/>
  197. </div>
  198. <div role="main">
  199. <div class="section">
  200. <h1 id="installation-dun-serveur-de-courrier-basique">Installation d'un serveur de courrier basique</h1>
  201. <p>Debian installe par défaut <strong>exim4</strong>. Nous allons le remplacer par postfix (que nous étendrons par la suite pour obtenir un serveur de mail complet)</p>
  202. <p>Il faut penser à ouvrir les ports 25 en IPV4 et IPV6 avec <strong>firewalld</strong>.</p>
  203. <h2 id="installation">Installation</h2>
  204. <pre><code>pi@raspberrypi:~ $ sudo apt install postfix
  205. Lecture des listes de paquets... Fait
  206. Construction de l'arbre des dépendances
  207. Lecture des informations d'état... Fait
  208. Les paquets suivants ont été installés automatiquement et ne sont plus nécessaires :
  209. libgnutls-dane0 libunbound8
  210. Veuillez utiliser « sudo apt autoremove » pour les supprimer.
  211. Les paquets supplémentaires suivants seront installés :
  212. ssl-cert
  213. Paquets suggérés :
  214. procmail postfix-mysql postfix-pgsql postfix-ldap postfix-pcre postfix-lmdb postfix-sqlite sasl2-bin | dovecot-common postfix-cdb ufw
  215. postfix-doc openssl-blacklist
  216. Les paquets suivants seront ENLEVÉS :
  217. exim4-base exim4-config exim4-daemon-light
  218. Les NOUVEAUX paquets suivants seront installés :
  219. postfix ssl-cert
  220. 0 mis à jour, 2 nouvellement installés, 3 à enlever et 0 non mis à jour.
  221. Il est nécessaire de prendre 1 423 ko dans les archives.
  222. Après cette opération, 0 o d'espace disque supplémentaires seront utilisés.
  223. Souhaitez-vous continuer ? [O/n] o
  224. Réception de :1 http://ftp.igh.cnrs.fr/pub/os/linux/raspbian/raspbian buster/main armhf postfix armhf 3.4.14-0+deb10u1 [1 402 kB]
  225. Réception de :2 http://mirrors.ircam.fr/pub/raspbian/raspbian buster/main armhf ssl-cert all 1.0.39 [20,8 kB]
  226. 1 423 ko réceptionnés en 3s (524 ko/s)
  227. Préconfiguration des paquets...
  228. dpkg: exim4-daemon-light : problème de dépendance, mais suppression comme demandé :
  229. logwatch dépend de default-mta | mail-transport-agent ; cependant :
  230. Le paquet default-mta n'est pas installé.
  231. Le paquet exim4-daemon-light qui fournit default-mta doit être supprimé.
  232. Le paquet mail-transport-agent n'est pas installé.
  233. Le paquet exim4-daemon-light qui fournit mail-transport-agent doit être supprimé.
  234. logwatch dépend de default-mta | mail-transport-agent ; cependant :
  235. Le paquet default-mta n'est pas installé.
  236. Le paquet exim4-daemon-light qui fournit default-mta doit être supprimé.
  237. Le paquet mail-transport-agent n'est pas installé.
  238. Le paquet exim4-daemon-light qui fournit mail-transport-agent doit être supprimé.
  239. (Lecture de la base de données... 46982 fichiers et répertoires déjà installés.)
  240. Suppression de exim4-daemon-light (4.92-8+deb10u4) ...
  241. dpkg: exim4-config : problème de dépendance, mais suppression comme demandé :
  242. exim4-base dépend de exim4-config (&gt;= 4.82) | exim4-config-2 ; cependant :
  243. Le paquet exim4-config doit être supprimé.
  244. Le paquet exim4-config-2 n'est pas installé.
  245. Le paquet exim4-config qui fournit exim4-config-2 doit être supprimé.
  246. exim4-base dépend de exim4-config (&gt;= 4.82) | exim4-config-2 ; cependant :
  247. Le paquet exim4-config doit être supprimé.
  248. Le paquet exim4-config-2 n'est pas installé.
  249. Le paquet exim4-config qui fournit exim4-config-2 doit être supprimé.
  250. Suppression de exim4-config (4.92-8+deb10u4) ...
  251. Sélection du paquet postfix précédemment désélectionné.
  252. (Lecture de la base de données... 46922 fichiers et répertoires déjà installés.)
  253. Préparation du dépaquetage de .../postfix_3.4.14-0+deb10u1_armhf.deb ...
  254. Dépaquetage de postfix (3.4.14-0+deb10u1) ...
  255. (Lecture de la base de données... 47112 fichiers et répertoires déjà installés.)
  256. Suppression de exim4-base (4.92-8+deb10u4) ...
  257. Sélection du paquet ssl-cert précédemment désélectionné.
  258. (Lecture de la base de données... 47038 fichiers et répertoires déjà installés.)
  259. Préparation du dépaquetage de .../ssl-cert_1.0.39_all.deb ...
  260. Dépaquetage de ssl-cert (1.0.39) ...
  261. Paramétrage de ssl-cert (1.0.39) ...
  262. Paramétrage de postfix (3.4.14-0+deb10u1) ...
  263. Ajout du groupe « postfix » (GID 118)...
  264. Fait.
  265. Ajout de l'utilisateur système « postfix » (UID 112) ...
  266. Ajout du nouvel utilisateur « postfix » (UID 112) avec pour groupe d'appartenance « postfix » ...
  267. Le répertoire personnel « /var/spool/postfix » n'a pas été créé.
  268. Creating /etc/postfix/dynamicmaps.cf
  269. Ajout du groupe « postdrop » (GID 119)...
  270. Fait.
  271. setting myhostname: raspberrypi
  272. setting alias maps
  273. setting alias database
  274. changing /etc/mailname to yojik.net
  275. setting myorigin
  276. setting destinations: $myhostname, yojik.net, raspberrypi, localhost.localdomain, localhost
  277. setting relayhost:
  278. setting mynetworks: 127.0.0.0/8 [::ffff:127.0.0.0]/104 [::1]/128
  279. setting mailbox_size_limit: 0
  280. setting recipient_delimiter: +
  281. setting inet_interfaces: all
  282. setting inet_protocols: all
  283. WARNING: /etc/aliases exists, but does not have a root alias.
  284. Postfix (main.cf) is now set up with a default configuration. If you need to
  285. make changes, edit /etc/postfix/main.cf (and others) as needed. To view
  286. Postfix configuration values, see postconf(1).
  287. After modifying main.cf, be sure to run 'service postfix reload'.
  288. Running newaliases
  289. Created symlink /etc/systemd/system/multi-user.target.wants/postfix.service → /lib/systemd/system/postfix.service.
  290. Traitement des actions différées (« triggers ») pour systemd (241-7~deb10u6+rpi1) ...
  291. Traitement des actions différées (« triggers ») pour man-db (2.8.5-2) ...
  292. Traitement des actions différées (« triggers ») pour rsyslog (8.1901.0-1) ...
  293. pi@raspberrypi:~ $
  294. </code></pre>
  295. <h2 id="suppression-complete-de-exim4">Suppression complète de <strong>exim4</strong></h2>
  296. <p>On supprime complètement <strong>exim4</strong>, fichiers de configuration inclus.</p>
  297. <pre><code>pi@raspberrypi:~ $ sudo apt remove --purge exim4*
  298. Lecture des listes de paquets... Fait
  299. Construction de l'arbre des dépendances
  300. Lecture des informations d'état... Fait
  301. Note : sélection de exim4-base pour l'expression rationnelle « exim4* »
  302. Note : sélection de exim4-config-2 pour l'expression rationnelle « exim4* »
  303. Note : sélection de exim4-doc-info pour l'expression rationnelle « exim4* »
  304. Note : sélection de exim4-daemon-light pour l'expression rationnelle « exim4* »
  305. Note : sélection de exim4-daemon-heavy pour l'expression rationnelle « exim4* »
  306. Note : sélection de exim4-daemon-custom pour l'expression rationnelle « exim4* »
  307. Note : sélection de exim4-config pour l'expression rationnelle « exim4* »
  308. Note : sélection de exim4-doc-html pour l'expression rationnelle « exim4* »
  309. Note : sélection de exim4-localscanapi-2.0 pour l'expression rationnelle « exim4* »
  310. Note : sélection de exim4-dev pour l'expression rationnelle « exim4* »
  311. Note : sélection de exim4 pour l'expression rationnelle « exim4* »
  312. Le paquet « exim4-daemon-custom » n'est pas installé, et ne peut donc être supprimé
  313. Note : sélection de « exim4-config » au lieu de « exim4-config-2 »
  314. Le paquet « exim4 » n'est pas installé, et ne peut donc être supprimé
  315. Le paquet « exim4-daemon-heavy » n'est pas installé, et ne peut donc être supprimé
  316. Le paquet « exim4-dev » n'est pas installé, et ne peut donc être supprimé
  317. Le paquet « exim4-doc-html » n'est pas installé, et ne peut donc être supprimé
  318. Le paquet « exim4-doc-info » n'est pas installé, et ne peut donc être supprimé
  319. Les paquets suivants ont été installés automatiquement et ne sont plus nécessaires :
  320. libgnutls-dane0 libunbound8
  321. Veuillez utiliser « sudo apt autoremove » pour les supprimer.
  322. Les paquets suivants seront ENLEVÉS :
  323. exim4-base* exim4-config* exim4-daemon-light*
  324. 0 mis à jour, 0 nouvellement installés, 3 à enlever et 0 non mis à jour.
  325. Après cette opération, 0 o d'espace disque supplémentaires seront utilisés.
  326. Souhaitez-vous continuer ? [O/n] o
  327. (Lecture de la base de données... 47047 fichiers et répertoires déjà installés.)
  328. Purge des fichiers de configuration de exim4-base (4.92-8+deb10u4) ...
  329. Purge des fichiers de configuration de exim4-config (4.92-8+deb10u4) ...
  330. dpkg-statoverride: avertissement: pas de dérogation (« override ») présente
  331. Purge des fichiers de configuration de exim4-daemon-light (4.92-8+deb10u4) ...
  332. Traitement des actions différées (« triggers ») pour systemd (241-7~deb10u6+rpi1) ...
  333. pi@raspberrypi:~ $
  334. </code></pre>
  335. <h2 id="ouverture-des-ports-25">Ouverture des ports 25</h2>
  336. <p>Ajout du protocole <strong>smtp</strong> à notre zone.</p>
  337. <h3 id="liste-des-services-disponibles">Liste des services disponibles</h3>
  338. <pre><code>pi@piras:~ $ sudo firewall-cmd --get-services
  339. RH-Satellite-6 amanda-client amanda-k5-client amqp amqps apcupsd audit bacula
  340. bacula-client bgp bitcoin bitcoin-rpc bitcoin-testnet bitcoin-testnet-rpc
  341. ceph ceph-mon cfengine cockpit condor-collector ctdb dhcp dhcpv6
  342. dhcpv6-client distcc dns docker-registry docker-swarm dropbox-lansync
  343. elasticsearch etcd-client etcd-server finger freeipa-ldap freeipa-ldaps
  344. freeipa-replication freeipa-trust ftp ganglia-client ganglia-master
  345. git gre high-availability http https imap imaps ipp ipp-client
  346. ipsec irc ircs iscsi-target isns jenkins kadmin kerberos kibana klogin
  347. kpasswd kprop kshell ldap ldaps libvirt libvirt-tls lightning-network
  348. llmnr managesieve matrix mdns minidlna mongodb mosh mountd mqtt mqtt-tls
  349. ms-wbt mssql murmur mysql nfs nfs3 nmea-0183 nrpe ntp nut openvpn
  350. ovirt-imageio ovirt-storageconsole ovirt-vmconsole plex pmcd pmproxy
  351. pmwebapi pmwebapis pop3 pop3s postgresql privoxy proxy-dhcp ptp
  352. pulseaudio puppetmaster quassel radius redis rpc-bind rsh rsyncd
  353. rtsp salt-master samba samba-client samba-dc sane sip sips slp smtp
  354. smtp-submission smtps snmp snmptrap spideroak-lansync squid ssh
  355. steam-streaming svdrp svn syncthing syncthing-gui synergy syslog syslog-tls
  356. telnet tftp tftp-client tinc tor-socks transmission-client upnp-client vdsm
  357. vnc-server wbem-http wbem-https wsman wsmans xdmcp xmpp-bosh xmpp-client
  358. xmpp-local xmpp-server zabbix-agent zabbix-server
  359. pi@piras:~ $
  360. </code></pre>
  361. <p>Le protocole qui nous intéresse est : <strong>smtp</strong></p>
  362. <h3 id="ajout-du-service-smtp">Ajout du service smtp</h3>
  363. <pre><code>pi@piras:~ $ sudo firewall-cmd --permanent --zone=public --add-service=smtp
  364. success
  365. pi@piras:~ $
  366. </code></pre>
  367. <p>Il faut recharger <strong>firewalld</strong> pour que ce soit pris en compte.</p>
  368. <pre><code>pi@piras:~ $ sudo systemctl restart firewalld
  369. pi@piras:~ $
  370. </code></pre>
  371. <p>Dans mon cas, j'ai été obligé de redémarrer le serveur pour que ce soit pris en compte: pas d'explication ... mais comme ça, ça marche!</p>
  372. <h3 id="verification">Vérification</h3>
  373. <pre><code>pi@piras:~ $ sudo firewall-cmd --list-all
  374. public (active)
  375. target: default
  376. icmp-block-inversion: no
  377. interfaces: eth0
  378. sources:
  379. services: dhcpv6-client smtp ssh
  380. ports:
  381. protocols:
  382. masquerade: no
  383. forward-ports:
  384. source-ports:
  385. icmp-blocks:
  386. rich rules:
  387. pi@piras:~ $
  388. </code></pre>
  389. <h2 id="installation-des-utilitaire-courriers">Installation des utilitaire courriers</h2>
  390. <pre><code>pi@raspberrypi:~ $ sudo apt install mailutils
  391. Lecture des listes de paquets... Fait
  392. Construction de l'arbre des dépendances
  393. Lecture des informations d'état... Fait
  394. mailutils est déjà la version la plus récente (1:3.5-4).
  395. mailutils passé en « installé manuellement ».
  396. Les paquets suivants ont été installés automatiquement et ne sont plus nécessaires :
  397. libgnutls-dane0 libunbound8
  398. Veuillez utiliser « sudo apt autoremove » pour les supprimer.
  399. 0 mis à jour, 0 nouvellement installés, 0 à enlever et 0 non mis à jour.
  400. pi@raspberrypi:~ $
  401. </code></pre>
  402. <p>Ils étaient déjà installés.</p>
  403. <h2 id="test-denvoi-de-courriers-entre-comptes-internes">Test d'envoi de courriers entre comptes internes.</h2>
  404. <ul>
  405. <li>
  406. <p>pi-&gt; root</p>
  407. <p>Les commandes suivantes permettent de :</p>
  408. <ul>
  409. <li>
  410. <p>envoyer un message à <strong>root</strong>(Essai 1)</p>
  411. <pre><code>pi@raspberrypi:~ $ mail root
  412. Cc:
  413. Subject: Essai1
  414. Essai 1
  415. .
  416. pi@raspberrypi:~ $
  417. </code></pre>
  418. </li>
  419. <li>
  420. <p>passer <strong>root</strong></p>
  421. <pre><code>pi@raspberrypi:~ $ sudo /bin/bash
  422. root@raspberrypi:/home/pi#
  423. </code></pre>
  424. </li>
  425. <li>
  426. <p>lancer <strong>mutt</strong></p>
  427. <pre><code>root@raspberrypi:/home/pi# mutt
  428. 1 gardé(s), 0 effacé(s).
  429. root@raspberrypi:/home/pi#
  430. </code></pre>
  431. <p><img alt="image de mutt" src="../../../Images/tutoraspi/Capture%20d%E2%80%99%C3%A9cran%20de%202021-02-14%2019-11-39.png" /></p>
  432. </li>
  433. </ul>
  434. </li>
  435. <li>
  436. <p>root -&gt; pi</p>
  437. <pre><code>root@raspberrypi:/home/pi# mail pi
  438. Cc:
  439. Subject: Essai 2
  440. .
  441. root@raspberrypi:/home/pi# exit
  442. Vous avez du nouveau courrier dans /var/mail/pi
  443. pi@raspberrypi:~ $ mutt
  444. 3 gardé(s), 0 effacé(s).
  445. pi@raspberrypi:~ $
  446. </code></pre>
  447. <p>Nous avions 2 messages avant: le nouveau message est bien arrivé !</p>
  448. </li>
  449. </ul>
  450. <h2 id="configuration-de-postfix">Configuration de <strong>postfix</strong></h2>
  451. <p>Il nous faut configurer <strong>postfix</strong> pour permettre l'envoi de courriers à l'extérieur et en recevoir de l'extérieur.</p>
  452. <p>Pour cela, il nous faut modifier le fichier <strong>/etc/postfix/main.cf</strong></p>
  453. <p>Modifiez la ligne <strong>mydestination</strong> pour qu'elle ressemble à ce qui suit :</p>
  454. <blockquote>
  455. <p>mydestination = $myhostname, yojik.net, atom.yojik.net, localhost.yojik.net, localhost</p>
  456. </blockquote>
  457. <p>et relancez <strong>postfix</strong> avec la commande suivante :</p>
  458. <blockquote>
  459. <p>sudo service postfix restart</p>
  460. </blockquote>
  461. <h3 id="courriers-sortants">Courriers sortants</h3>
  462. <p>Envoi d'un message sur mon compte de messagerie gmail (oui, un envoi sur mon compte normal ne fonctionne pas dû à sa configuration):</p>
  463. <pre><code>pi@piras:~$ echo "Et voilà un petit message" | mail -s "test du courrier sortant" ericounet26200@gmail.com
  464. </code></pre>
  465. <p>Le message est bien reçu et dans les courriers indésirables, bien entendu (pas de dkim, spf, dnnssec, etc.)</p>
  466. <h3 id="courriers-entrants">Courriers entrants</h3>
  467. <p>Envoi d'un message à partir de mon adresse de courrier normale :</p>
  468. <p>Message bien reçu (après mise à jour de mon serveur DNS).</p>
  469. <p><img alt="Mutt" src="../../../Images/tutoraspi/Capture%20d%E2%80%99%C3%A9cran%20de%202021-02-15%2004-59-28.png" /></p>
  470. <h2 id="amelioration-de-la-gestion-du-courrier">Amélioration de la gestion du courrier</h2>
  471. <p>Nous allons transférer les mails destinés à <strong>root</strong> vers l'utilisateur <strong>pi</strong>. Ainsi que d'autres adresses de courrier standards. Pour cela, nous allons modifier le fichier <strong>/etc/aliases</strong>, le compiler pour être digeste par <strong>postfix</strong> et relancer <strong>postfix</strong>.</p>
  472. <p>Ce fichier sert à rediriger toutes les adresses émail comme <strong>abuse</strong>, <strong>webmaster</strong>, <strong>root</strong> vers un utilisateur <strong>administrateur</strong> de la machine, root puis vers moi <strong>ericadmin</strong>.</p>
  473. <pre><code># /etc/aliases
  474. mailer-daemon: postmaster
  475. postmaster: root
  476. nobody: root
  477. hostmaster: root
  478. usenet: root
  479. news: root
  480. webmaster: root
  481. www: root
  482. ftp: root
  483. abuse: root
  484. noc: root
  485. security: root
  486. root: pi
  487. </code></pre>
  488. <p>Il faut lancer la commande <strong>newaliases</strong> pour générer le fichier.db utile à Postfix et on demande à Postfix de recharger ses fichiers.</p>
  489. <pre><code>pi@piras:~ $ sudo newaliases
  490. pi@piras:~ $
  491. </code></pre>
  492. <p>On relance <strong>postfix</strong> :</p>
  493. <pre><code>pi@piras:~ $ sudo systemctl restart postfix
  494. pi@piras:~ $
  495. </code></pre>
  496. <p>Et on teste (envoi d'un courrier à root@piras.yojik.net)</p>
  497. <p><img alt="Transfert" src="../../../Images/tutoraspi/Capture%20d%E2%80%99%C3%A9cran%20de%202021-02-15%2005-07-49.png" /></p>
  498. <p>Et voilà, notre serveur de courrier est fonctionnel.</p>
  499. <h2 id="protection-par-fail2ban">Protection par Fail2ban</h2>
  500. <p>Nous devons ajouter la surveillance du mail par <strong>fail2ban</strong>.</p>
  501. <p>Editons le fichier /etc/fail2ban/jail.d/defaults-debian.conf pour y ajouter la surveillance de postfix (port smtp : 25.)</p>
  502. <p>Nous prenons l'exemple fourni dans <strong>/etc/fail2ban/jail.conf</strong> et ne gardons que le port 25.</p>
  503. <p>Voilà la partie modifiée à ajouter :</p>
  504. <pre><code>[postfix]
  505. mode = more
  506. port = smtp
  507. logpath = %(postfix_log)s
  508. backend = %(postfix_backend)s
  509. </code></pre>
  510. <p>Relançons le service pour que nos modifications soient prises en compte:</p>
  511. <pre><code>pi@piras:~ $ sudo systemctl reload fail2ban
  512. pi@piras:~ $
  513. </code></pre>
  514. </div>
  515. </div>
  516. <footer>
  517. <div class="rst-footer-buttons" role="navigation" aria-label="footer navigation">
  518. <a href="../Exemple-d-utilisation-serveur-Web/" class="btn btn-neutral float-right" title="Exemple d'utilisation avec un serveur Web">Next <span class="icon icon-circle-arrow-right"></span></a>
  519. <a href="../Logwatch/" class="btn btn-neutral" title="Surveillance du serveur"><span class="icon icon-circle-arrow-left"></span> Previous</a>
  520. </div>
  521. <hr/>
  522. <div role="contentinfo">
  523. <!-- Copyright etc -->
  524. </div>
  525. Built with <a href="https://www.mkdocs.org/">MkDocs</a> using a <a href="https://github.com/snide/sphinx_rtd_theme">theme</a> provided by <a href="https://readthedocs.org">Read the Docs</a>.
  526. </footer>
  527. </div>
  528. </div>
  529. </section>
  530. </div>
  531. <div class="rst-versions" role="note" aria-label="versions">
  532. <span class="rst-current-version" data-toggle="rst-current-version">
  533. <span><a href="../Logwatch/" style="color: #fcfcfc;">&laquo; Previous</a></span>
  534. <span style="margin-left: 15px"><a href="../Exemple-d-utilisation-serveur-Web/" style="color: #fcfcfc">Next &raquo;</a></span>
  535. </span>
  536. </div>
  537. <script>var base_url = '../../..';</script>
  538. <script src="../../../js/theme.js" defer></script>
  539. <script src="../../../search/main.js" defer></script>
  540. <script defer>
  541. window.onload = function () {
  542. SphinxRtdTheme.Navigation.enable(true);
  543. };
  544. </script>
  545. </body>
  546. </html>