index.html 18 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459
  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. <title>Configuration du réseau - The Yojik Server Installation Guide</title>
  9. <link rel="shortcut icon" href="../img/favicon.ico">
  10. <link href='https://fonts.googleapis.com/css?family=Lato:400,700|Roboto+Slab:400,700|Inconsolata:400,700' rel='stylesheet' type='text/css'>
  11. <link rel="stylesheet" href="../css/theme.css" type="text/css" />
  12. <link rel="stylesheet" href="../css/theme_extra.css" type="text/css" />
  13. <link rel="stylesheet" href="../css/highlight.css">
  14. <script>
  15. // Current page data
  16. var mkdocs_page_name = "Configuration du réseau";
  17. var mkdocs_page_input_path = "3-trois.md";
  18. var mkdocs_page_url = "/3-trois/";
  19. </script>
  20. <script src="../js/jquery-2.1.1.min.js"></script>
  21. <script src="../js/modernizr-2.8.3.min.js"></script>
  22. <script type="text/javascript" src="../js/highlight.pack.js"></script>
  23. <script src="../js/theme.js"></script>
  24. </head>
  25. <body class="wy-body-for-nav" role="document">
  26. <div class="wy-grid-for-nav">
  27. <nav data-toggle="wy-nav-shift" class="wy-nav-side stickynav">
  28. <div class="wy-side-nav-search">
  29. <a href=".." class="icon icon-home"> The Yojik Server Installation Guide</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" />
  33. </form>
  34. </div>
  35. </div>
  36. <div class="wy-menu wy-menu-vertical" data-spy="affix" role="navigation" aria-label="main navigation">
  37. <ul class="current">
  38. <li>
  39. <li class="toctree-l1 ">
  40. <a class="" href="..">Home</a>
  41. </li>
  42. <li>
  43. <li>
  44. <li class="toctree-l1 ">
  45. <a class="" href="../1-un/">Installation d'un serveur Debian/Stretch sécurisé</a>
  46. </li>
  47. <li>
  48. <li>
  49. <li class="toctree-l1 ">
  50. <a class="" href="../2-deux/">Premières étapes de sécurisation du serveur</a>
  51. </li>
  52. <li>
  53. <li>
  54. <li class="toctree-l1 current">
  55. <a class="current" href="./">Configuration du réseau</a>
  56. <ul>
  57. <li class="toctree-l3"><a href="#configuration-du-reseau">Configuration du réseau</a></li>
  58. <li><a class="toctree-l4" href="#configuration-de-lipv4">Configuration de l'IPV4</a></li>
  59. <li><a class="toctree-l4" href="#configuration-de-lipv6">Configuration de l'IPV6</a></li>
  60. <li><a class="toctree-l4" href="#tester-la-configuration-reseau">Tester la configuration réseau</a></li>
  61. </ul>
  62. </li>
  63. <li>
  64. <li>
  65. <li class="toctree-l1 ">
  66. <a class="" href="../4-quatre/">Installation d'un serveur de temps</a>
  67. </li>
  68. <li>
  69. <li>
  70. <li class="toctree-l1 ">
  71. <a class="" href="../5-cinq/">Installation d'un pare-feu</a>
  72. </li>
  73. <li>
  74. <li>
  75. <li class="toctree-l1 ">
  76. <a class="" href="../6-six/">Contrer les attaques de brute-force avec fail2ban</a>
  77. </li>
  78. <li>
  79. <li>
  80. <li class="toctree-l1 ">
  81. <a class="" href="../7-sept/">Installation d'un serveur de courrier basique</a>
  82. </li>
  83. <li>
  84. <li>
  85. <li class="toctree-l1 ">
  86. <a class="" href="../8-huit/">Installation du serveur DNS</a>
  87. </li>
  88. <li>
  89. <li>
  90. <li class="toctree-l1 ">
  91. <a class="" href="../9-neuf/">Installation d'un serveur web</a>
  92. </li>
  93. <li>
  94. <li>
  95. <li class="toctree-l1 ">
  96. <a class="" href="../10-dix/">Installation de dovecot et de l'authentification</a>
  97. </li>
  98. <li>
  99. <li>
  100. <li class="toctree-l1 ">
  101. <a class="" href="../11-onze/">Installation des certificats letsencrypt</a>
  102. </li>
  103. <li>
  104. <li>
  105. <li class="toctree-l1 ">
  106. <a class="" href="../12-douze/">Ajout des enregistrements SPF et DKIM au fichier de zone DNS</a>
  107. </li>
  108. <li>
  109. <li>
  110. <li class="toctree-l1 ">
  111. <a class="" href="../17-dixsept/">Installation de programmes de surveillance du serveur</a>
  112. </li>
  113. <li>
  114. <li>
  115. <li class="toctree-l1 ">
  116. <a class="" href="../18-dixhuit/">Installation d'un webmail</a>
  117. </li>
  118. <li>
  119. <li>
  120. <li class="toctree-l1 ">
  121. <a class="" href="../19-dixneuf/">Installation de git et de gogs</a>
  122. </li>
  123. <li>
  124. </ul>
  125. </div>
  126. &nbsp;
  127. </nav>
  128. <section data-toggle="wy-nav-shift" class="wy-nav-content-wrap">
  129. <nav class="wy-nav-top" role="navigation" aria-label="top navigation">
  130. <i data-toggle="wy-nav-top" class="fa fa-bars"></i>
  131. <a href="..">The Yojik Server Installation Guide</a>
  132. </nav>
  133. <div class="wy-nav-content">
  134. <div class="rst-content">
  135. <div role="navigation" aria-label="breadcrumbs navigation">
  136. <ul class="wy-breadcrumbs">
  137. <li><a href="..">Docs</a> &raquo;</li>
  138. <li>Configuration du réseau</li>
  139. <li class="wy-breadcrumbs-aside">
  140. </li>
  141. </ul>
  142. <hr/>
  143. </div>
  144. <div role="main">
  145. <div class="section">
  146. <h2 id="configuration-du-reseau">Configuration du réseau</h2>
  147. <p>Nous avons utilisé la configuration automatique du réseau (DHCP).</p>
  148. <p>Il est temps de configurer manuellement les adresses IP pour avoir des adresses fixes dans le temps (faisable aussi avec DHCP si on a un serveur DHCP configurable)</p>
  149. <h3 id="configuration-de-lipv4">Configuration de l'IPV4</h3>
  150. <p>Les éléments suivants ont été configurés dans l'interface de configuration de ma box (Freebox dans mon cas)</p>
  151. <p>Mon réseau domestique est: <strong>192.168.111.0</strong>
  152. Ma passerelle est: <strong>192.168.111.254</strong></p>
  153. <p>J'ai choisi l'adresse suivante pour mon serveur: <strong>192.168.111.160</strong> et j'ai configuré cette adresse comme zone “DMZ” sur ma Freebox (zone démilitarisée, accessible de l'extérieur)</p>
  154. <p>La configuration se fait dans le fichier: <strong>/etc/network/interfaces</strong></p>
  155. <p>Nous avons ceci:</p>
  156. <pre><code class="shell">source /etc/network/interfaces.d/*
  157. # The loopback network interface
  158. auto lo
  159. iface lo inet loopback
  160. # The primary network interface
  161. allow-hotplug enp4s0
  162. iface enp4s0 inet dhcp
  163. # This is an autoconfigured IPv6 interface
  164. iface enp4s0 inet6 auto
  165. </code></pre>
  166. <p>Vous noterez que le nom des interfaces a changé ...</p>
  167. <p>Modification de l'interface réseau IPV4:</p>
  168. <p>Les lignes concernées sont:</p>
  169. <pre><code class="shell"># The primary network interface
  170. allow-hotplug enp4s0
  171. iface enp4s0 inet dhcp
  172. </code></pre>
  173. <p>Modifiez ces lignes pour obtenir:</p>
  174. <pre><code class="shell"># The primary network interface
  175. allow-hotplug enp4s0
  176. # iface enp4s0 inet dhcp (ligne à commenter)
  177. # lignes à ajouter
  178. iface enp4s0 inet static
  179. # IP address
  180. address 192.168.111.160
  181. # network address
  182. network 192.168.111.0
  183. # subnet mask
  184. netmask 255.255.255.0
  185. # broadcast address
  186. broadcast 192.168.111.255
  187. # default gateway
  188. gateway 192.168.111.254
  189. # name server
  190. dns-nameservers 8.8.8.8 8.8.4.4
  191. </code></pre>
  192. <p>Explications:</p>
  193. <ul>
  194. <li>enp4s0: c'est le nom donné par Debian à mon interface réseau</li>
  195. <li>l'adresse IP est l'adresse que j'ai choisie dans mon réseau local pour mon serveur</li>
  196. <li>nous avons ensuite l'adresse réseau</li>
  197. <li>puis le masque</li>
  198. <li>l'adresse de broadcast</li>
  199. <li>et l'adresse de sortie de notre réseau (en fait l'adresse est fixée par notre routeur: la mienne est: 254)</li>
  200. <li>les serveurs de nom: nous allons mettre un serveur de nom <strong>provisoire</strong> avant d'installer notre propre serveur de noms. J'ai pris ici les serveurs de Google.</li>
  201. </ul>
  202. <p>Sauvegarde du fichier et redémarrage du serveur.</p>
  203. <p>Vous noterez que la connexion par <strong>ssh</strong> échoue, car l'empreinte du serveur a changé.</p>
  204. <pre><code class="shell">@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
  205. @ WARNING: REMOTE HOST IDENTIFICATION HAS CHANGED! @
  206. @@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
  207. IT IS POSSIBLE THAT SOMEONE IS DOING SOMETHING NASTY!
  208. Someone could be eavesdropping on you right now (man-in-the-middle attack)!
  209. It is also possible that a host key has just been changed.
  210. The fingerprint for the ECDSA key sent by the remote host is
  211. SHA256:w0HKVAyxVFC2t50O6hte6PioCIAjcwxus7Mm8/Q+NBo.
  212. Please contact your system administrator.
  213. Add correct host key in /home/eric/.ssh/known_hosts to get rid of this message.
  214. Offending ECDSA key in /home/eric/.ssh/known_hosts:14
  215. remove with:
  216. ssh-keygen -f &quot;/home/eric/.ssh/known_hosts&quot; -R atom
  217. ECDSA host key for atom has changed and you have requested strict checking.
  218. Host key verification failed.
  219. </code></pre>
  220. <p>Suivez les instructions données par le message de <strong>ssh</strong> et reconnectez-vous.</p>
  221. <pre><code class="shell">eric@aldebaran:~$ ssh ericadmin@atom
  222. The authenticity of host 'atom (192.168.111.160)' can't be established.
  223. ECDSA key fingerprint is SHA256:w0HKVAyxVFC2t50O6hte6PioCIAjcwxus7Mm8/Q+NBo.
  224. Are you sure you want to continue connecting (yes/no)? yes
  225. Warning: Permanently added 'atom,192.168.111.160' (ECDSA) to the list of known hosts.
  226. Last login: Mon Dec 25 10:57:50 2017 from 192.168.111.150
  227. ericadmin@atom:~$
  228. </code></pre>
  229. <p>Test de l'adresse IPV4 (mode super-utilisateur)</p>
  230. <pre><code class="shell">root@atom:/home/ericadmin# ifconfig
  231. enp4s0: flags=4163&lt;UP,BROADCAST,RUNNING,MULTICAST&gt; mtu 1500
  232. inet 192.168.111.160 netmask 255.255.255.0 broadcast 192.168.111.255
  233. inet6 2a01:e0a:54:c220:223:54ff:fec6:a07 prefixlen 64 scopeid 0x0&lt;global&gt;
  234. inet6 fe80::223:54ff:fec6:a07 prefixlen 64 scopeid 0x20&lt;link&gt;
  235. ether 00:23:54:c6:0a:07 txqueuelen 1000 (Ethernet)
  236. RX packets 1666 bytes 134780 (131.6 KiB)
  237. RX errors 0 dropped 2 overruns 0 frame 0
  238. TX packets 432 bytes 39182 (38.2 KiB)
  239. TX errors 0 dropped 0 overruns 0 carrier 0 collisions 0
  240. lo: flags=73&lt;UP,LOOPBACK,RUNNING&gt; mtu 65536
  241. inet 127.0.0.1 netmask 255.0.0.0
  242. inet6 ::1 prefixlen 128 scopeid 0x10&lt;host&gt;
  243. loop txqueuelen 1 (Boucle locale)
  244. RX packets 0 bytes 0 (0.0 B)
  245. RX errors 0 dropped 0 overruns 0 frame 0
  246. TX packets 0 bytes 0 (0.0 B)
  247. TX errors 0 dropped 0 overruns 0 carrier 0 collisions 0
  248. root@atom:/home/ericadmin#
  249. </code></pre>
  250. <p>Mon adresse IPV4 est la bonne: <strong>192.168.111.160</strong></p>
  251. <h3 id="configuration-de-lipv6">Configuration de l'IPV6</h3>
  252. <p>Nous allons utiliser la configuration automatique. Un préfixe IPV6 nous est attribué par notre fournisseur d'accès. Nous disposons d'un pool gigantesque d'adresses IPV6 utilisables comme bon nous semble.</p>
  253. <p>Avec la configuration automatique, une adresse ipv6 est fabriquée à partir de l'adresse mac de notre interface réseau. C'est une adresse fixe qui ne changera pas tant que nous ne changerons pas le matériel réseau du serveur.</p>
  254. <p>En configuration manuelle, nous pouvons attribuer l'adresse de notre choix, comprise bien sûr dans le pool d'adresses.</p>
  255. <p>Nous allons ajouter une option qui permet d'augmenter la protection de la vie privée. Du fait du pool d'adresses disponibles, il est possible de demander au système de changer régulièrement d'adresses pour les requêtes extérieures. L'interface réseau de notre serveur peut être dotée de plusieurs adresses IPV6 simultanément. L'option à rajouter est: <strong>privext 2</strong>.</p>
  256. <blockquote>
  257. <p>Note: nous devrons changer cette configuration ensuite car il faut que l'adresse unique renvoyée par le serveur DNS soit la même que l'adresse d'émission ...
  258. L'adresse d'émission change avec le paramètre <strong>privext 2</strong> et cette adresse ne correspond pas avec celle renvoyée par le serveur DNS. Il nous faudra employer une adresse statique, et unique pour notre serveur (en IPV4 et IPV6.)</p>
  259. </blockquote>
  260. <pre><code class="shell">#This is an autoconfigured IPv6 interface
  261. iface enp2s0 inet6 auto
  262. privext 2
  263. </code></pre>
  264. <p>Le résultat est le suivant:</p>
  265. <pre><code class="shell">enp2s0: flags=4163&lt;UP,BROADCAST,RUNNING,MULTICAST&gt; mtu 1500
  266. inet 192.168.111.240 netmask 255.255.255.0 broadcast 192.168.111.255
  267. inet6 2a01:e0a:54:c220:e128:ec57:4b1a:b078 prefixlen 64 scopeid 0x0&lt;global&gt;
  268. inet6 fe80::3aea:a7ff:fea6:cf93 prefixlen 64 scopeid 0x20&lt;link&gt;
  269. inet6 2a01:e0a:54:c220:3aea:a7ff:fea6:cf93 prefixlen 64 scopeid 0x0&lt;global&gt;
  270. ether 38:ea:a7:a6:cf:93 txqueuelen 1000 (Ethernet)
  271. RX packets 7753 bytes 551016 (538.1 KiB)
  272. RX errors 0 dropped 0 overruns 0 frame 0
  273. TX packets 1579 bytes 152907 (149.3 KiB)
  274. TX errors 0 dropped 0 overruns 0 carrier 0 collisions 0
  275. device interrupt 18
  276. </code></pre>
  277. <p>Vous noterez la présence de 3 adresses ipv6.</p>
  278. <ul>
  279. <li>
  280. <p>Une adresse commençant par inet6 fe80:
  281. Cette adresse n'est pas routée sur le réseau internet. Elle ne sert que pour le réseau local. Elle est marquée: «link».</p>
  282. </li>
  283. <li>
  284. <p>2 autres adresses ipv6 marquées «global»: l'une d'elle est l'adresse basée sur l'adresse mac de la carte réseau, l'autre a été générée par le système.</p>
  285. </li>
  286. </ul>
  287. <p>Ces 3 adresses sont dans le pool d'adresses attribué par le FAI, et donc, les 64 premiers bits de l'adresse constituent le préfixe ipv6. Le pool d'adresses peu être de 64 bits ou 56 suivant les fournisseurs, ou moins encore.</p>
  288. <h3 id="tester-la-configuration-reseau">Tester la configuration réseau</h3>
  289. <p>Je teste la connexion IPV6 à partir de ma machine de bureau.</p>
  290. <p>Première adresse ipv6:</p>
  291. <pre><code class="shell">eric@aldebaran:~$ ping6 2a01:e0a:54:c220:e128:ec57:4b1a:b078
  292. PING 2a01:e0a:54:c220:e128:ec57:4b1a:b078(2a01:e0a:54:c220:e128:ec57:4b1a:b078) 56 data bytes
  293. 64 bytes from 2a01:e0a:54:c220:e128:ec57:4b1a:b078: icmp_seq=1 ttl=64 time=0.487 ms
  294. 64 bytes from 2a01:e0a:54:c220:e128:ec57:4b1a:b078: icmp_seq=2 ttl=64 time=0.339 ms
  295. 64 bytes from 2a01:e0a:54:c220:e128:ec57:4b1a:b078: icmp_seq=3 ttl=64 time=0.322 ms
  296. ^C
  297. 2a01:e0a:54:c220:e128:ec57:4b1a:b078 ping statistics
  298. 3 packets transmitted, 3 received, 0% packet loss, time 2046ms
  299. rtt min/avg/max/mdev = 0.322/0.382/0.487/0.077 ms
  300. eric@aldebaran:~$
  301. </code></pre>
  302. <p>2ème adresse ipv6:</p>
  303. <pre><code class="shell">eric@aldebaran:~$ ping6 2a01:e0a:54:c220:3aea:a7ff:fea6:cf93
  304. PING 2a01:e0a:54:c220:3aea:a7ff:fea6:cf93(2a01:e0a:54:c220:3aea:a7ff:fea6:cf93) 56 data bytes
  305. 64 bytes from 2a01:e0a:54:c220:3aea:a7ff:fea6:cf93: icmp_seq=1 ttl=64 time=0.571 ms
  306. 64 bytes from 2a01:e0a:54:c220:3aea:a7ff:fea6:cf93: icmp_seq=2 ttl=64 time=0.424 ms
  307. ^C
  308. 2a01:e0a:54:c220:3aea:a7ff:fea6:cf93 ping statistics
  309. 2 packets transmitted, 2 received, 0% packet loss, time 1020ms
  310. rtt min/avg/max/mdev = 0.424/0.497/0.571/0.076 ms
  311. </code></pre>
  312. <p>3ème adresse ipv6:</p>
  313. <pre><code class="shell">root@aldebaran:/home/eric# ping6 -I enp4s0 fe80:0:0:0:3aea:a7ff:fea6:cf93
  314. PING fe80:0:0:0:3aea:a7ff:fea6:cf93(fe80::3aea:a7ff:fea6:cf93) from fe80::1e6f:65ff:fe92:dd1f%enp4s0 enp4s0: 56 data bytes
  315. 64 bytes from fe80::3aea:a7ff:fea6:cf93%enp4s0: icmp_seq=1 ttl=64 time=0.336 ms
  316. 64 bytes from fe80::3aea:a7ff:fea6:cf93%enp4s0: icmp_seq=2 ttl=64 time=0.357 ms
  317. ^C
  318. fe80:0:0:0:3aea:a7ff:fea6:cf93 ping statistics
  319. 2 packets transmitted, 2 received, 0% packet loss, time 1026ms
  320. rtt min/avg/max/mdev = 0.336/0.346/0.357/0.021 ms
  321. </code></pre>
  322. <p>Vous noterez que pour l'adresse «link» commençant par Fe80::, il faut spécifier l'interface réseau. (-i enp4s0 )</p>
  323. <p>Vous pouvez constater que tout marche comme il se doit.</p>
  324. <p>Il faut bien sûr tester la connectivité dans les 2 sens: serveur -&gt; autre machine <strong>ET</strong>
  325. autre machine -&gt; serveur.</p>
  326. <p>Quelques liens:</p>
  327. <ul>
  328. <li><a href="http://www.linux-france.org/~openingault/gulliveripv6/theorie/addr.html#umacast">Linux France en français</a></li>
  329. <li><a href="https://www.cyberciti.biz/faq/howto-test-ipv6-network-with-ping6-command/">Cyberciti IPV6 Howto en anglais</a></li>
  330. </ul>
  331. </div>
  332. </div>
  333. <footer>
  334. <div class="rst-footer-buttons" role="navigation" aria-label="footer navigation">
  335. <a href="../4-quatre/" class="btn btn-neutral float-right" title="Installation d'un serveur de temps">Next <span class="icon icon-circle-arrow-right"></span></a>
  336. <a href="../2-deux/" class="btn btn-neutral" title="Premières étapes de sécurisation du serveur"><span class="icon icon-circle-arrow-left"></span> Previous</a>
  337. </div>
  338. <hr/>
  339. <div role="contentinfo">
  340. <!-- Copyright etc -->
  341. </div>
  342. Built with <a href="http://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>.
  343. </footer>
  344. </div>
  345. </div>
  346. </section>
  347. </div>
  348. <div class="rst-versions" role="note" style="cursor: pointer">
  349. <span class="rst-current-version" data-toggle="rst-current-version">
  350. <span><a href="../2-deux/" style="color: #fcfcfc;">&laquo; Previous</a></span>
  351. <span style="margin-left: 15px"><a href="../4-quatre/" style="color: #fcfcfc">Next &raquo;</a></span>
  352. </span>
  353. </div>
  354. </body>
  355. </html>