index.html 18 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460
  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. <p></p>
  147. <h2 id="configuration-du-reseau">Configuration du réseau</h2>
  148. <p>Nous avons utilisé la configuration automatique du réseau (DHCP).</p>
  149. <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>
  150. <h3 id="configuration-de-lipv4">Configuration de l'IPV4</h3>
  151. <p>Les éléments suivants ont été configurés dans l'interface de configuration de ma box (Freebox dans mon cas)</p>
  152. <p>Mon réseau domestique est: <strong>192.168.111.0</strong>
  153. Ma passerelle est: <strong>192.168.111.254</strong></p>
  154. <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>
  155. <p>La configuration se fait dans le fichier: <strong>/etc/network/interfaces</strong></p>
  156. <p>Nous avons ceci:</p>
  157. <pre><code>source /etc/network/interfaces.d/*
  158. # The loopback network interface
  159. auto lo
  160. iface lo inet loopback
  161. # The primary network interface
  162. allow-hotplug enp4s0
  163. iface enp4s0 inet dhcp
  164. # This is an autoconfigured IPv6 interface
  165. iface enp4s0 inet6 auto
  166. </code></pre>
  167. <p>Vous noterez que le nom des interfaces a changé ...</p>
  168. <p>Modification de l'interface réseau IPV4:</p>
  169. <p>Les lignes concernées sont:</p>
  170. <pre><code># The primary network interface
  171. allow-hotplug enp4s0
  172. iface enp4s0 inet dhcp
  173. </code></pre>
  174. <p>Modifiez ces lignes pour obtenir:</p>
  175. <pre><code># The primary network interface
  176. allow-hotplug enp4s0
  177. # iface enp4s0 inet dhcp (ligne à commenter)
  178. # lignes à ajouter
  179. iface enp4s0 inet static
  180. # IP address
  181. address 192.168.111.160
  182. # network address
  183. network 192.168.111.0
  184. # subnet mask
  185. netmask 255.255.255.0
  186. # broadcast address
  187. broadcast 192.168.111.255
  188. # default gateway
  189. gateway 192.168.111.254
  190. # name server
  191. dns-nameservers 8.8.8.8 8.8.4.4
  192. </code></pre>
  193. <p>Explications:</p>
  194. <ul>
  195. <li>enp4s0: c'est le nom donné par Debian à mon interface réseau</li>
  196. <li>l'adresse IP est l'adresse que j'ai choisie dans mon réseau local pour mon serveur</li>
  197. <li>nous avons ensuite l'adresse réseau</li>
  198. <li>puis le masque</li>
  199. <li>l'adresse de broadcast</li>
  200. <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>
  201. <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>
  202. </ul>
  203. <p>Sauvegarde du fichier et redémarrage du serveur.</p>
  204. <p>Vous noterez que la connexion par <strong>ssh</strong> échoue, car l'empreinte du serveur a changé.</p>
  205. <pre><code>@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
  206. @ WARNING: REMOTE HOST IDENTIFICATION HAS CHANGED! @
  207. @@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
  208. IT IS POSSIBLE THAT SOMEONE IS DOING SOMETHING NASTY!
  209. Someone could be eavesdropping on you right now (man-in-the-middle attack)!
  210. It is also possible that a host key has just been changed.
  211. The fingerprint for the ECDSA key sent by the remote host is
  212. SHA256:w0HKVAyxVFC2t50O6hte6PioCIAjcwxus7Mm8/Q+NBo.
  213. Please contact your system administrator.
  214. Add correct host key in /home/eric/.ssh/known_hosts to get rid of this message.
  215. Offending ECDSA key in /home/eric/.ssh/known_hosts:14
  216. remove with:
  217. ssh-keygen -f &quot;/home/eric/.ssh/known_hosts&quot; -R atom
  218. ECDSA host key for atom has changed and you have requested strict checking.
  219. Host key verification failed.
  220. </code></pre>
  221. <p>Suivez les instructions données par le message de <strong>ssh</strong> et reconnectez-vous.</p>
  222. <pre><code>eric@aldebaran:~$ ssh ericadmin@atom
  223. The authenticity of host 'atom (192.168.111.160)' can't be established.
  224. ECDSA key fingerprint is SHA256:w0HKVAyxVFC2t50O6hte6PioCIAjcwxus7Mm8/Q+NBo.
  225. Are you sure you want to continue connecting (yes/no)? yes
  226. Warning: Permanently added 'atom,192.168.111.160' (ECDSA) to the list of known hosts.
  227. Last login: Mon Dec 25 10:57:50 2017 from 192.168.111.150
  228. ericadmin@atom:~$
  229. </code></pre>
  230. <p>Test de l'adresse IPV4 (mode super-utilisateur)</p>
  231. <pre><code>root@atom:/home/ericadmin# ifconfig
  232. enp4s0: flags=4163&lt;UP,BROADCAST,RUNNING,MULTICAST&gt; mtu 1500
  233. inet 192.168.111.160 netmask 255.255.255.0 broadcast 192.168.111.255
  234. inet6 2a01:e0a:54:c220:223:54ff:fec6:a07 prefixlen 64 scopeid 0x0&lt;global&gt;
  235. inet6 fe80::223:54ff:fec6:a07 prefixlen 64 scopeid 0x20&lt;link&gt;
  236. ether 00:23:54:c6:0a:07 txqueuelen 1000 (Ethernet)
  237. RX packets 1666 bytes 134780 (131.6 KiB)
  238. RX errors 0 dropped 2 overruns 0 frame 0
  239. TX packets 432 bytes 39182 (38.2 KiB)
  240. TX errors 0 dropped 0 overruns 0 carrier 0 collisions 0
  241. lo: flags=73&lt;UP,LOOPBACK,RUNNING&gt; mtu 65536
  242. inet 127.0.0.1 netmask 255.0.0.0
  243. inet6 ::1 prefixlen 128 scopeid 0x10&lt;host&gt;
  244. loop txqueuelen 1 (Boucle locale)
  245. RX packets 0 bytes 0 (0.0 B)
  246. RX errors 0 dropped 0 overruns 0 frame 0
  247. TX packets 0 bytes 0 (0.0 B)
  248. TX errors 0 dropped 0 overruns 0 carrier 0 collisions 0
  249. root@atom:/home/ericadmin#
  250. </code></pre>
  251. <p>Mon adresse IPV4 est la bonne: <strong>192.168.111.160</strong></p>
  252. <h3 id="configuration-de-lipv6">Configuration de l'IPV6</h3>
  253. <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>
  254. <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>
  255. <p>En configuration manuelle, nous pouvons attribuer l'adresse de notre choix, comprise bien sûr dans le pool d'adresses.</p>
  256. <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>
  257. <blockquote>
  258. <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 ...
  259. 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>
  260. </blockquote>
  261. <pre><code>#This is an autoconfigured IPv6 interface
  262. iface enp2s0 inet6 auto
  263. privext 2
  264. </code></pre>
  265. <p>Le résultat est le suivant:</p>
  266. <pre><code>enp2s0: flags=4163&lt;UP,BROADCAST,RUNNING,MULTICAST&gt; mtu 1500
  267. inet 192.168.111.240 netmask 255.255.255.0 broadcast 192.168.111.255
  268. inet6 2a01:e0a:54:c220:e128:ec57:4b1a:b078 prefixlen 64 scopeid 0x0&lt;global&gt;
  269. inet6 fe80::3aea:a7ff:fea6:cf93 prefixlen 64 scopeid 0x20&lt;link&gt;
  270. inet6 2a01:e0a:54:c220:3aea:a7ff:fea6:cf93 prefixlen 64 scopeid 0x0&lt;global&gt;
  271. ether 38:ea:a7:a6:cf:93 txqueuelen 1000 (Ethernet)
  272. RX packets 7753 bytes 551016 (538.1 KiB)
  273. RX errors 0 dropped 0 overruns 0 frame 0
  274. TX packets 1579 bytes 152907 (149.3 KiB)
  275. TX errors 0 dropped 0 overruns 0 carrier 0 collisions 0
  276. device interrupt 18
  277. </code></pre>
  278. <p>Vous noterez la présence de 3 adresses ipv6.</p>
  279. <ul>
  280. <li>
  281. <p>Une adresse commençant par inet6 fe80:
  282. 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>
  283. </li>
  284. <li>
  285. <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>
  286. </li>
  287. </ul>
  288. <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>
  289. <h3 id="tester-la-configuration-reseau">Tester la configuration réseau</h3>
  290. <p>Je teste la connexion IPV6 à partir de ma machine de bureau.</p>
  291. <p>Première adresse ipv6:</p>
  292. <pre><code>eric@aldebaran:~$ ping6 2a01:e0a:54:c220:e128:ec57:4b1a:b078
  293. PING 2a01:e0a:54:c220:e128:ec57:4b1a:b078(2a01:e0a:54:c220:e128:ec57:4b1a:b078) 56 data bytes
  294. 64 bytes from 2a01:e0a:54:c220:e128:ec57:4b1a:b078: icmp_seq=1 ttl=64 time=0.487 ms
  295. 64 bytes from 2a01:e0a:54:c220:e128:ec57:4b1a:b078: icmp_seq=2 ttl=64 time=0.339 ms
  296. 64 bytes from 2a01:e0a:54:c220:e128:ec57:4b1a:b078: icmp_seq=3 ttl=64 time=0.322 ms
  297. ^C
  298. 2a01:e0a:54:c220:e128:ec57:4b1a:b078 ping statistics
  299. 3 packets transmitted, 3 received, 0% packet loss, time 2046ms
  300. rtt min/avg/max/mdev = 0.322/0.382/0.487/0.077 ms
  301. eric@aldebaran:~$
  302. </code></pre>
  303. <p>2ème adresse ipv6:</p>
  304. <pre><code>eric@aldebaran:~$ ping6 2a01:e0a:54:c220:3aea:a7ff:fea6:cf93
  305. PING 2a01:e0a:54:c220:3aea:a7ff:fea6:cf93(2a01:e0a:54:c220:3aea:a7ff:fea6:cf93) 56 data bytes
  306. 64 bytes from 2a01:e0a:54:c220:3aea:a7ff:fea6:cf93: icmp_seq=1 ttl=64 time=0.571 ms
  307. 64 bytes from 2a01:e0a:54:c220:3aea:a7ff:fea6:cf93: icmp_seq=2 ttl=64 time=0.424 ms
  308. ^C
  309. 2a01:e0a:54:c220:3aea:a7ff:fea6:cf93 ping statistics
  310. 2 packets transmitted, 2 received, 0% packet loss, time 1020ms
  311. rtt min/avg/max/mdev = 0.424/0.497/0.571/0.076 ms
  312. </code></pre>
  313. <p>3ème adresse ipv6:</p>
  314. <pre><code>root@aldebaran:/home/eric# ping6 -I enp4s0 fe80:0:0:0:3aea:a7ff:fea6:cf93
  315. 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
  316. 64 bytes from fe80::3aea:a7ff:fea6:cf93%enp4s0: icmp_seq=1 ttl=64 time=0.336 ms
  317. 64 bytes from fe80::3aea:a7ff:fea6:cf93%enp4s0: icmp_seq=2 ttl=64 time=0.357 ms
  318. ^C
  319. fe80:0:0:0:3aea:a7ff:fea6:cf93 ping statistics
  320. 2 packets transmitted, 2 received, 0% packet loss, time 1026ms
  321. rtt min/avg/max/mdev = 0.336/0.346/0.357/0.021 ms
  322. </code></pre>
  323. <p>Vous noterez que pour l'adresse «link» commençant par Fe80::, il faut spécifier l'interface réseau. (-i enp4s0 )</p>
  324. <p>Vous pouvez constater que tout marche comme il se doit.</p>
  325. <p>Il faut bien sûr tester la connectivité dans les 2 sens: serveur -&gt; autre machine <strong>ET</strong>
  326. autre machine -&gt; serveur.</p>
  327. <p>Quelques liens:</p>
  328. <ul>
  329. <li><a href="http://www.linux-france.org/~openingault/gulliveripv6/theorie/addr.html#umacast">Linux France en français</a></li>
  330. <li><a href="https://www.cyberciti.biz/faq/howto-test-ipv6-network-with-ping6-command/">Cyberciti IPV6 Howto en anglais</a></li>
  331. </ul>
  332. </div>
  333. </div>
  334. <footer>
  335. <div class="rst-footer-buttons" role="navigation" aria-label="footer navigation">
  336. <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>
  337. <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>
  338. </div>
  339. <hr/>
  340. <div role="contentinfo">
  341. <!-- Copyright etc -->
  342. </div>
  343. 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>.
  344. </footer>
  345. </div>
  346. </div>
  347. </section>
  348. </div>
  349. <div class="rst-versions" role="note" style="cursor: pointer">
  350. <span class="rst-current-version" data-toggle="rst-current-version">
  351. <span><a href="../2-deux/" style="color: #fcfcfc;">&laquo; Previous</a></span>
  352. <span style="margin-left: 15px"><a href="../4-quatre/" style="color: #fcfcfc">Next &raquo;</a></span>
  353. </span>
  354. </div>
  355. </body>
  356. </html>