Maison développement back-end Golang Programmation socket et écriture côté serveur en langage Go

Programmation socket et écriture côté serveur en langage Go

May 31, 2023 pm 11:40 PM
go语言 socket编程 服务端编写

Avec le développement rapide d'Internet, de plus en plus d'applications nécessitent une communication réseau et la programmation socket est devenue une méthode de programmation importante. Le langage Go est un langage de programmation qui a beaucoup attiré l'attention ces dernières années et qui présente également des avantages uniques dans le domaine de la programmation réseau. Cet article présentera la programmation socket en langage Go et comment écrire un programme serveur simple.

1. Présentation de la programmation socket

Socket est une couche d'abstraction située entre la couche application et la couche transport, qui permet aux applications de communiquer sur le réseau. Pour la plupart des applications, les prises constituent l'entrée et la sortie de la communication réseau. Plus précisément, dans la programmation socket, un socket peut être considéré comme un type spécial de fichier. Le programme peut effectuer une communication réseau en lisant et en écrivant ce « fichier ».

Le contenu principal de la programmation Socket comprend les aspects suivants :

1. Créer un socket

Avant de créer un socket, vous devez clarifier quel protocole est utilisé : TCP ou UDP. Le choix du protocole affectera directement les méthodes de programmation ultérieures. Dans le langage Go, vous pouvez appeler la fonction correspondante dans le package net pour créer un socket.

2. Lier l'adresse et le port

Pour que le client puisse trouver le serveur, le serveur doit lier l'adresse d'écoute et le port. Dans le langage Go, vous pouvez appeler la fonction Listen dans le package net pour terminer la liaison des adresses et des ports.

3. Écoutez les demandes de connexion client

Une fois que le serveur a lié l'adresse et le port, il commencera à écouter les demandes de connexion client. Dans le langage Go, vous pouvez combiner les instructions goroutine et select pour surveiller plusieurs sockets simultanément.

4. Recevoir et traiter les demandes des clients

Lorsque le client demande d'établir une connexion, le serveur doit appeler la fonction Accepter pour recevoir la demande du client et transmettre la demande du client à la sous-coroutine pour traitement.

5. Envoi et réception de données

Une fois que le client et le serveur ont établi une connexion, les deux parties peuvent envoyer et recevoir des données via Socket. Dans le langage Go, vous pouvez appeler les fonctions Write et Read du package net pour envoyer et recevoir des données.

2. Programmation côté serveur en langage Go

Après avoir compris les connaissances de base de la programmation socket, nous pouvons commencer à écrire des programmes côté serveur. Cette section prendra un simple programme d'écho comme exemple pour présenter comment écrire un programme serveur en utilisant le langage Go.

1. Créer un socket

En langage Go, vous pouvez créer un socket en appelant la fonction Listen dans le package net. Le paramètre de la fonction Listen est une chaîne qui représente l'adresse et le numéro de port que nous voulons lier. Si le port est 0, un port libre est alloué. Le code suivant montre comment créer un socket TCP et le lier au port local 8000.

listener, err := net.Listen("tcp", ":8000")
if err != nil {
    fmt.Println("Error listen:", err)
    return
}
defer listener.Close()
Copier après la connexion

2. Surveiller les demandes de connexion client

Après avoir créé le socket, nous devons surveiller en permanence les demandes de connexion client. Dans le langage Go, nous pouvons utiliser une boucle for infinie pour appeler en continu la fonction Accept et attendre la demande de connexion du client. La fonction Accept renvoie un objet Socket conn auquel le client se connecte.

for {
    conn, err := listener.Accept()
    if err != nil {
        fmt.Println("Error accept:", err)
        return
    }
    go handleConnection(conn)
}
Copier après la connexion

3. Traitement des demandes des clients

La méthode de traitement des demandes des clients est placée dans une sous-coroutine, afin que les processeurs multicœurs puissent être pleinement utilisés pour améliorer les capacités de traitement simultané. Cet article prend comme exemple le programme echo, qui renvoie intactes les données envoyées par le client au client.

func handleConnection(conn net.Conn) {
    buf := make([]byte, 1024)
    defer conn.Close()
    for {
        n, err := conn.Read(buf)
        if err != nil {
            fmt.Println("Error reading:", err)
            return
        }
        fmt.Println("Received:", string(buf[:n]))
        _, err = conn.Write(buf[:n])
        if err != nil {
            fmt.Println("Error writing:", err)
            return
        }
    }
}
Copier après la connexion

4. Code complet

Ce qui suit est le code d'un programme de serveur d'écho complet :

package main

import (
    "fmt"
    "net"
)

func main() {
    listener, err := net.Listen("tcp", ":8000")
    if err != nil {
        fmt.Println("Error listen:", err)
        return
    }
    defer listener.Close()

    fmt.Println("Listening on :8000")

    for {
        conn, err := listener.Accept()
        if err != nil {
            fmt.Println("Error accept:", err)
            continue
        }
        fmt.Println("New client connected")
        go handleConnection(conn)
    }
}

func handleConnection(conn net.Conn) {
    buf := make([]byte, 1024)
    defer conn.Close()
    for {
        n, err := conn.Read(buf)
        if err != nil {
            fmt.Println("Error reading:", err)
            return
        }
        fmt.Println("Received:", string(buf[:n]))
        _, err = conn.Write(buf[:n])
        if err != nil {
            fmt.Println("Error writing:", err)
            return
        }
    }
}
Copier après la connexion

Grâce au code ci-dessus, nous pouvons voir qu'il est très facile d'implémenter un simple programme de serveur d'écho en langage Go .

3. Résumé

Cet article présente principalement les concepts de base de la programmation socket et comment écrire le programme de serveur d'écho le plus simple en langage Go. Le langage Go fournit une interface de programmation réseau très simple et facile à utiliser, qui peut réduire considérablement les coûts d'apprentissage et les difficultés de programmation des programmeurs, et améliorer l'efficacité de la programmation et de l'exploitation. Pour les applications nécessitant une communication réseau, le langage Go est sans aucun doute un très bon choix.

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!

Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

AI Hentai Generator

AI Hentai Generator

Générez AI Hentai gratuitement.

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Quel est le problème avec le fil de file d'attente dans GO's Crawler Colly? Quel est le problème avec le fil de file d'attente dans GO's Crawler Colly? Apr 02, 2025 pm 02:09 PM

Problème de threading de file d'attente dans Go Crawler Colly explore le problème de l'utilisation de la bibliothèque Crawler Crawler dans le langage Go, les développeurs rencontrent souvent des problèmes avec les threads et les files d'attente de demande. � ...

Quelles bibliothèques sont utilisées pour les opérations du numéro de point flottantes en Go? Quelles bibliothèques sont utilisées pour les opérations du numéro de point flottantes en Go? Apr 02, 2025 pm 02:06 PM

La bibliothèque utilisée pour le fonctionnement du numéro de point flottante dans le langage go présente comment s'assurer que la précision est ...

Comment résoudre le problème de conversion de type user_id lors de l'utilisation du flux redis pour implémenter les files d'attente de messages dans le langage Go? Comment résoudre le problème de conversion de type user_id lors de l'utilisation du flux redis pour implémenter les files d'attente de messages dans le langage Go? Apr 02, 2025 pm 04:54 PM

Le problème de l'utilisation de Redessstream pour implémenter les files d'attente de messages dans le langage GO consiste à utiliser le langage GO et redis ...

Dans Go, pourquoi les chaînes d'impression avec println et string () ont-elles des effets différents? Dans Go, pourquoi les chaînes d'impression avec println et string () ont-elles des effets différents? Apr 02, 2025 pm 02:03 PM

La différence entre l'impression de chaîne dans le langage go: la différence dans l'effet de l'utilisation de fonctions println et string () est en Go ...

Que dois-je faire si les étiquettes de structure personnalisées à Goland ne sont pas affichées? Que dois-je faire si les étiquettes de structure personnalisées à Goland ne sont pas affichées? Apr 02, 2025 pm 05:09 PM

Que dois-je faire si les étiquettes de structure personnalisées à Goland ne sont pas affichées? Lorsque vous utilisez Goland pour le développement du langage GO, de nombreux développeurs rencontreront des balises de structure personnalisées ...

Quelles bibliothèques de GO sont développées par de grandes entreprises ou fournies par des projets open source bien connus? Quelles bibliothèques de GO sont développées par de grandes entreprises ou fournies par des projets open source bien connus? Apr 02, 2025 pm 04:12 PM

Quelles bibliothèques de GO sont développées par de grandes entreprises ou des projets open source bien connus? Lors de la programmation en Go, les développeurs rencontrent souvent des besoins communs, ...

Quelle est la différence entre la structure de définition des mots clés `var` et« type »dans le langage Go? Quelle est la différence entre la structure de définition des mots clés `var` et« type »dans le langage Go? Apr 02, 2025 pm 12:57 PM

Deux façons de définir les structures dans le langage GO: la différence entre les mots clés VAR et le type. Lorsque vous définissez des structures, GO Language voit souvent deux façons d'écrire différentes: d'abord ...

Pourquoi est-il nécessaire de passer des pointeurs lors de l'utilisation de bibliothèques Go et Viper? Pourquoi est-il nécessaire de passer des pointeurs lors de l'utilisation de bibliothèques Go et Viper? Apr 02, 2025 pm 04:00 PM

GO POINTER SYNTAXE ET ATTENDRE DES PROBLÈMES DANS LA BIBLIOTHÈQUE VIPER Lors de la programmation en langage Go, il est crucial de comprendre la syntaxe et l'utilisation des pointeurs, en particulier dans ...

See all articles