Maison >développement back-end >Golang >Fondamentaux du réseau
Dans le monde de la conception de systèmes, les réseaux sont le ciment qui lie les différents composants entre eux. Que vous construisiez une application Web, un système distribué ou même un simple service backend, comprendre le fonctionnement des réseaux est essentiel pour garantir une communication, une sécurité et des performances fluides. Dans ce chapitre, nous aborderons certains aspects fondamentaux de la mise en réseau qui sont cruciaux pour créer des systèmes évolutifs et fiables.
Commençons par la fondation. Un réseau informatique est un ensemble d'appareils interconnectés (ordinateurs, serveurs, routeurs, etc.) qui communiquent entre eux. C'est comme le système postal pour les données : il permet à différents appareils d'envoyer et de recevoir des informations sous forme de paquets. Lorsqu'un utilisateur interagit avec un service en ligne (par exemple, votre application de livraison de nourriture), ces paquets sont constamment envoyés entre son appareil et les serveurs qui alimentent l'application.
Exemple : Dans un bureau typique, les ordinateurs des employés sont connectés à des imprimantes, des serveurs de fichiers et parfois même des téléphones via un réseau local. Cette configuration permet un partage rapide des ressources.
Exemple : Imaginez une grande entreprise avec des bureaux à New York, Londres et Tokyo. Les bureaux disposent de réseaux locaux en interne, mais pour communiquer entre eux, ils utilisent un WAN, tirant probablement parti d'Internet ou de connexions privées.
Pour comprendre le fonctionnement des réseaux, nous utilisons le Modèle OSI, qui divise le réseau en sept couches :
La plupart du temps, dans la conception de systèmes, nous nous concentrons sur les couches 3 à 7, en particulier lorsqu'il s'agit des protocoles de communication, de la sécurité et du flux de données.
HTTP (Hypertext Transfer Protocol) et HTTPS (HTTP Secure) sont les principaux protocoles utilisés pour la communication sur le Web. Ils définissent la manière dont les messages sont formatés et transmis entre les clients (comme les navigateurs) et les serveurs.
Exemple : Vous tapez "www.fooddelivery.com" dans votre navigateur, et il envoie une requête HTTP pour récupérer la page d'accueil.
Exemple : Lorsqu'un utilisateur passe une commande sur votre application de livraison de nourriture, HTTPS garantit que ses informations de paiement sont cryptées et sécurisées lorsqu'il voyage de son appareil vers vos serveurs.
TCP (Transmission Control Protocol) et IP (Internet Protocol) sont deux des protocoles fondamentaux qui alimentent Internet.
Exemple : Si votre application de livraison de nourriture envoie les informations du client au serveur, TCP garantit que l'intégralité du message est livrée sans manquer aucune partie.
Exemple : Lorsque vous effectuez une demande depuis votre téléphone, celui-ci utilise votre adresse IP pour acheminer les données vers le serveur. Le serveur possède sa propre adresse IP, permettant aux paquets de vous revenir correctement.
TCP/IP forment ensemble l’épine dorsale de la communication Internet. C'est comme un service postal fiable : TCP garantit que le contenu du colis est intact et IP garantit qu'il arrive au bon endroit.
DNS est comme l'annuaire téléphonique d'Internet. Au lieu de mémoriser les adresses IP (qui sont comme des numéros de téléphone pour les serveurs), nous utilisons des noms de domaine comme « www.example.com ». DNS résout ces noms en adresses IP afin que votre appareil sache où envoyer la demande.
Un équilibreur de charge est crucial lors d'une mise à l'échelle horizontale. Il s'agit d'un outil qui répartit le trafic entrant sur plusieurs serveurs pour garantir qu'aucun serveur n'est submergé. Cela rend votre système plus évolutif et plus tolérant aux pannes.
CDN sont un excellent moyen de réduire la latence et d'améliorer les performances pour les utilisateurs répartis sur différents emplacements. Un CDN est un réseau distribué de serveurs répartis dans le monde entier qui stockent les versions mises en cache de votre contenu. Lorsqu'un utilisateur demande quelque chose à votre site Web, le CDN diffuse ce contenu depuis le serveur le plus proche de lui plutôt que depuis votre serveur principal, réduisant ainsi le temps de chargement.
Exemple : Disons que votre application de livraison de nourriture a des clients en Inde et aux États-Unis, mais que vos serveurs principaux sont situés en Europe. Sans CDN, les utilisateurs en Inde pourraient connaître des temps de chargement lents car leurs demandes doivent voyager jusqu'en Europe. Mais avec un CDN, un serveur en Inde peut diffuser des images en cache, des détails sur les restaurants et du contenu statique, ce qui rend l'application plus rapide.
La sécurité est une préoccupation majeure dans tout système, et les principales technologies permettant de garantir une communication sécurisée sur les réseaux sont SSL (Secure Sockets Layer) et TLS (Transport Layer Security). Ces protocoles cryptent les données envoyées entre les clients et les serveurs, garantissant ainsi que les informations sensibles, telles que les mots de passe et les détails de paiement, sont protégées contre les écoutes indiscrètes.
Exemple : Dans votre application de livraison de nourriture, lorsqu'un utilisateur soumet ses informations de carte de crédit pour effectuer un paiement, les données sont cryptées à l'aide de TLS avant d'être envoyées au serveur. Cela garantit que même si quelqu’un intercepte les données, il ne pourra pas les lire car elles sont cryptées.
Exemple : lorsqu'un utilisateur ouvre votre application, son appareil et vos serveurs passent par cette poignée de main pour se mettre d'accord sur la façon de chiffrer les données avant que des informations sensibles, telles que les informations de connexion ou de paiement, ne soient transmises.
Dans tout système où les données circulent sur les réseaux, la sécurité est primordiale. Voici quelques pratiques de sécurité clés pour garantir un système sécurisé :
Exemple : Supposons qu'un acteur malveillant tente de submerger votre application de livraison de nourriture en envoyant des millions de fausses demandes. La limitation du débit de l'API peut limiter ces requêtes et empêcher le système de planter.
IDS)** peut vous alerter en cas de tentative de violation de votre réseau.
Pour activer SSL/TLS, vous avez besoin d'un certificat SSL, qui vérifie l'identité de votre site Web ou de votre serveur. Les certificats sont délivrés par des entités de confiance appelées Autorités de certification (CA), qui garantissent la légitimité de votre site Web.
Exemple : Lorsque vous achetez un certificat SSL pour le domaine de votre application de livraison de nourriture, il est émis par une autorité de certification comme Let's Encrypt ou DigiCert. Cela indique aux utilisateurs que leurs données sont en sécurité et qu'ils interagissent réellement avec votre application, et non avec un imposteur.
La mise en œuvre du 2FA est une couche de sécurité supplémentaire, obligeant les utilisateurs à fournir deux formes d'identification (généralement quelque chose qu'ils connaissent, comme un mot de passe, et quelque chose qu'ils possèdent, comme un appareil mobile). Cela rend beaucoup plus difficile pour les attaquants de compromettre les comptes.
Exemple : Dans votre application de livraison de nourriture, l'activation de la 2FA pour les utilisateurs peut aider à empêcher tout accès non autorisé, même si leur mot de passe est volé.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!