|
@@ -0,0 +1,195 @@
|
|
|
+<!doctype html>
|
|
|
+<html lang="en">
|
|
|
+ <head>
|
|
|
+ <meta charset="utf-8">
|
|
|
+<title>Introduzione alle reti</title>
|
|
|
+
|
|
|
+
|
|
|
+<meta name="apple-mobile-web-app-capable" content="yes">
|
|
|
+<meta name="apple-mobile-web-app-status-bar-style" content="black-translucent">
|
|
|
+<meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0, user-scalable=no">
|
|
|
+ <link rel="stylesheet" href="../reveal-js/css/reset.css">
|
|
|
+<link rel="stylesheet" href="../reveal-js/css/reveal.css"><link rel="stylesheet" href="../reveal-js/css/theme/black.css" id="theme">
|
|
|
+<link rel="stylesheet" href="../highlight-js/solarized-dark.min.css"><link rel="stylesheet" href="../style.css" id="custom_css">
|
|
|
+
|
|
|
+ </head>
|
|
|
+ <body>
|
|
|
+
|
|
|
+ <div class="reveal">
|
|
|
+ <div class="slides">
|
|
|
+
|
|
|
+
|
|
|
+ <section><h3 id="intro-sulle-reti">intro sulle reti</h3>
|
|
|
+<ul>
|
|
|
+<li>Come funziona l’internet?</li>
|
|
|
+</ul>
|
|
|
+</section><section>
|
|
|
+<h3 id="un-po-di-sigle">Un po di sigle</h3>
|
|
|
+<p>Tanto per confonderci meglio, cerchiamo di capire cosa fanno questi diversi
|
|
|
+elementi</p>
|
|
|
+</section><section>
|
|
|
+<ul>
|
|
|
+<li>ISP</li>
|
|
|
+<li>Router</li>
|
|
|
+<li>WAN</li>
|
|
|
+<li>LAN</li>
|
|
|
+<li>Host(s)</li>
|
|
|
+<li>WLAN</li>
|
|
|
+</ul>
|
|
|
+</section><section>
|
|
|
+<h3 id="stack-isoosi">Stack ISO/OSI</h3>
|
|
|
+<p>Possiamo dividere la rete internet, per come viene vista da un pacchetto,
|
|
|
+si puo’ suddividere in sette “strati”.</p>
|
|
|
+<p><img src="../images/stackiso.png" alt="/images/stackiso.png"></p>
|
|
|
+</section><section>
|
|
|
+<h3 id="dallalto-verso-il-basso">Dall’alto verso il basso</h3>
|
|
|
+<p><strong>Application Layer</strong></p>
|
|
|
+<ul>
|
|
|
+<li>HTTP (Hypertext Transfer Protocol)</li>
|
|
|
+<li>SMTP (Simple Mail Transfer Protocol)</li>
|
|
|
+</ul>
|
|
|
+</section><section>
|
|
|
+<h3 id="transport-layer">Transport Layer</h3>
|
|
|
+<p>Come i dati vengono mandati, se controllando o meno gli errori durante la
|
|
|
+connessione.</p>
|
|
|
+<ul>
|
|
|
+<li>TCP (Transmission Control Protocol) - reliable data delivery</li>
|
|
|
+<li>UDP (User Datagram Protocol) - unreliable data delivery</li>
|
|
|
+</ul>
|
|
|
+</section><section>
|
|
|
+<h3 id="network-layer">Network Layer</h3>
|
|
|
+<p>Qui per permettere agli host, piu propriamente al sistema operativo,</p>
|
|
|
+<p>This layer uses:</p>
|
|
|
+<ul>
|
|
|
+<li>IP (Internet Protocol) - Permette di instradare pacchetti da una host
|
|
|
+all’altro</li>
|
|
|
+<li>ICMP (Internet Control Message Protocol) - Errori, debug, che succede.</li>
|
|
|
+</ul>
|
|
|
+</section><section>
|
|
|
+<h3 id="link-layer">Link Layer</h3>
|
|
|
+<p>Come vengono mandati fisicamente i dati nella ferraglia</p>
|
|
|
+</section><section>
|
|
|
+<h3 id="paccheti-che-si-instradano">Paccheti che si instradano?</h3>
|
|
|
+<p>Abbiamo trovato un modo molto criptico di dire “dati che si muovono”, ma
|
|
|
+avviene cio'?</p>
|
|
|
+<ul>
|
|
|
+<li>MAC: 8 byte OUI (Organizational unique identifier) 8 univoci per scheda
|
|
|
+fisica</li>
|
|
|
+<li>IP</li>
|
|
|
+<li>Hostname</li>
|
|
|
+</ul>
|
|
|
+</section><section>
|
|
|
+<h3 id="quindi-per-esempio-se-mando-una-mail-che-giro-fa">Quindi per esempio, se mando una mail che giro fa?</h3>
|
|
|
+</section><section>
|
|
|
+<h3 id="layer-di-trasporto">Layer di trasporto</h3>
|
|
|
+<pre><code>- Porte
|
|
|
+- UDP
|
|
|
+- TCP
|
|
|
+</code></pre>
|
|
|
+</section><section>
|
|
|
+<h3 id="layer-di-rete">Layer di Rete</h3>
|
|
|
+<pre><code>- IP: destinazione e sorgente
|
|
|
+</code></pre>
|
|
|
+</section><section>
|
|
|
+<h3 id="layer-fisico">Layer Fisico</h3>
|
|
|
+<pre><code>- Incapsula il pacchetto TCP/IP dentro un frame
|
|
|
+- ARP (Address Resolution Protocol)
|
|
|
+</code></pre>
|
|
|
+</section><section>
|
|
|
+<h3 id="quindi-che-giro-fa-la-mail">Quindi che giro fa la mail?</h3>
|
|
|
+<pre><code>![Esempio stack ISO/OSI](./static/images/stackiso.png)
|
|
|
+</code></pre>
|
|
|
+</section><section>
|
|
|
+<h3 id="dhcp">DHCP</h3>
|
|
|
+<pre><code>E' interessante cercare di capire come fa il router a farci collegare
|
|
|
+in automatico.
|
|
|
+ - DHCP
|
|
|
+ - DHCP DISCOVER
|
|
|
+ - DHCP OFFER
|
|
|
+ - DHCP REQUEST
|
|
|
+ - DHCP ACK
|
|
|
+ - Riusciamo a vederlo con wireshark?
|
|
|
+</code></pre>
|
|
|
+</section><section>
|
|
|
+<h3 id="route-netmask-e-altre-cose-orribili">ROUTE, NETMASK, E ALTRE COSE ORRIBILI</h3>
|
|
|
+<pre><code>- Ovvero, di cosa ha bisogno il mio computer per attaccarsi al router?
|
|
|
+- IP, lo abbiamo visto
|
|
|
+- GATEWAY, "da dove passare", quindi l'IP del gateway
|
|
|
+- NETMASK, il mio PC sa di essere in una sottorete, ma quanto e'
|
|
|
+ grande?
|
|
|
+
|
|
|
+Con questi ingredienti posso creare una route!
|
|
|
+</code></pre>
|
|
|
+</section>
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+</div>
|
|
|
+
|
|
|
+
|
|
|
+ </div>
|
|
|
+<script type="text/javascript" src=../reveal-hugo/object-assign.js></script>
|
|
|
+
|
|
|
+<a href="../reveal-js/css/print/" id="print-location" style="display: none;"></a>
|
|
|
+<script type="text/javascript">
|
|
|
+ var printLocationElement = document.getElementById('print-location');
|
|
|
+ var link = document.createElement('link');
|
|
|
+ link.rel = 'stylesheet';
|
|
|
+ link.type = 'text/css';
|
|
|
+ link.href = printLocationElement.href + (window.location.search.match(/print-pdf/gi) ? 'pdf.css' : 'paper.css');
|
|
|
+ document.getElementsByTagName('head')[0].appendChild(link);
|
|
|
+</script>
|
|
|
+
|
|
|
+<script type="application/json" id="reveal-hugo-site-params">{"custom_css":"style.css","highlight_theme":"solarized-dark"}</script>
|
|
|
+<script type="application/json" id="reveal-hugo-page-params">null</script>
|
|
|
+
|
|
|
+<script src="../reveal-js/js/reveal.js"></script>
|
|
|
+
|
|
|
+<script type="text/javascript">
|
|
|
+
|
|
|
+
|
|
|
+ function camelize(map) {
|
|
|
+ if (map) {
|
|
|
+ Object.keys(map).forEach(function(k) {
|
|
|
+ newK = k.replace(/(\_\w)/g, function(m) { return m[1].toUpperCase() });
|
|
|
+ if (newK != k) {
|
|
|
+ map[newK] = map[k];
|
|
|
+ delete map[k];
|
|
|
+ }
|
|
|
+ });
|
|
|
+ }
|
|
|
+ return map;
|
|
|
+ }
|
|
|
+
|
|
|
+ var revealHugoDefaults = { center: true, controls: true, history: true, progress: true, transition: "slide" };
|
|
|
+ var revealHugoSiteParams = JSON.parse(document.getElementById('reveal-hugo-site-params').innerHTML);
|
|
|
+ var revealHugoPageParams = JSON.parse(document.getElementById('reveal-hugo-page-params').innerHTML);
|
|
|
+
|
|
|
+ var options = Object.assign({},
|
|
|
+ camelize(revealHugoDefaults),
|
|
|
+ camelize(revealHugoSiteParams),
|
|
|
+ camelize(revealHugoPageParams));
|
|
|
+ Reveal.initialize(options);
|
|
|
+</script>
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+ <script type="text/javascript" src="../reveal-js/plugin/markdown/marked.js"></script>
|
|
|
+
|
|
|
+ <script type="text/javascript" src="../reveal-js/plugin/markdown/markdown.js"></script>
|
|
|
+
|
|
|
+ <script type="text/javascript" src="../reveal-js/plugin/highlight/highlight.js"></script>
|
|
|
+
|
|
|
+ <script type="text/javascript" src="../reveal-js/plugin/zoom-js/zoom.js"></script>
|
|
|
+
|
|
|
+
|
|
|
+ <script type="text/javascript" src="../reveal-js/plugin/notes/notes.js"></script>
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+ </body>
|
|
|
+</html>
|