Go语言网络编程的实例

简介: 【10月更文挑战第27天】Go语言网络编程的实例

以下是一些Go语言网络编程的实例:

  1. TCP服务器

    • 代码示例

      package main
      
      import (
          "fmt"
          "io"
          "net"
      )
      
      func handleConnection(conn net.Conn) {
             
          defer conn.Close()
          for {
             
              buf := make([]byte, 1024)
              n, err := conn.Read(buf)
              if err != nil {
             
                  return
              }
              fmt.Printf("Received: %s", string(buf[:n]))
              conn.Write([]byte("Message received."))
          }
      }
      
      func main() {
             
          listener, err := net.Listen("tcp", "localhost:8080")
          if err != nil {
             
              fmt.Println("Error listening:", err)
              return
          }
          defer listener.Close()
          for {
             
              conn, err := listener.Accept()
              if err != nil {
             
                  continue
              }
              go handleConnection(conn)
          }
      }
      
    • 说明:这个示例创建了一个TCP服务器,监听localhost:8080端口。每当有新的客户端连接时,它都会启动一个新的goroutine来处理该连接。服务器读取客户端发送的数据,并将其打印到控制台,然后向客户端发送确认消息[^1^]。
  2. TCP客户端

    • 代码示例

      package main
      
      import (
          "fmt"
          "net"
      )
      
      func main() {
             
          conn, err := net.Dial("tcp", "localhost:8080")
          if err != nil {
             
              fmt.Println("Error dialing:", err)
              return
          }
          defer conn.Close()
          conn.Write([]byte("Hello, server!"))
          buf := make([]byte, 1024)
          n, err := conn.Read(buf)
          if err != nil {
             
              fmt.Println("Error reading:", err)
              return
          }
          fmt.Printf("Received: %s", string(buf[:n]))
      }
      
    • 说明:这个示例是一个TCP客户端,它连接到上面提到的TCP服务器,并发送一条消息。然后,它等待服务器的响应,并将其打印到控制台[^1^]。
  3. HTTP服务器

    • 代码示例

      package main
      
      import (
          "fmt"
          "net/http"
      )
      
      func helloHandler(w http.ResponseWriter, r *http.Request) {
             
          fmt.Fprintf(w, "Hello, World!")
      }
      
      func main() {
             
          http.HandleFunc("/", helloHandler)
          http.ListenAndServe(":8080", nil)
      }
      
    • 说明:这个示例创建了一个简单的HTTP服务器,监听localhost:8080端口。当HTTP请求到达服务器时,它会调用helloHandler函数来处理请求,并向客户端发送“Hello, World!”作为响应[^5^]。
  4. 并发HTTP服务器

    • 代码示例

      package main
      
      import (
          "fmt"
          "log"
          "net/http"
      )
      
      func helloHandler(w http.ResponseWriter, r *http.Request) {
             
          fmt.Fprintf(w, "Hello, %q", r.URL.Path[1:])
      }
      
      func main() {
             
          http.HandleFunc("/", helloHandler)
          log.Fatal(http.ListenAndServe(":8090", nil))
      }
      
    • 说明:这个示例展示了如何创建一个可以处理并发请求的HTTP服务器。它使用了Go语言的并发特性(goroutine),使得每个HTTP请求都在自己的goroutine中处理,从而提高了服务器的性能和响应速度[^5^]。
  5. WebSocket服务器

    • 代码示例

      package main
      
      import (
          "fmt"
          "log"
          "net/http"
          "github.com/gorilla/websocket"
      )
      var upgrader = websocket.Upgrader{
             } // use default options
      
      func echo(w http.ResponseWriter, r *http.Request) {
             
          c, err := upgrader.Upgrade(w, r, nil)
          if err != nil {
             
              log.Print("upgrade:", err)
              return
          }
          defer c.Close()
          for {
             
              mt, message, err := c.ReadMessage()
              if err != nil {
             
                  log.Println("read:", err)
                  break
              }
              log.Printf("recv: %s", message)
              err = c.WriteMessage(mt, message)
              if err != nil {
             
                  log.Println("write:", err)
                  break
              }
          }
      }
      
      func main() {
             
          http.HandleFunc("/echo", echo)
          log.Fatal(http.ListenAndServe("localhost:8080", nil))
      }
      
    • 说明:这个示例使用gorilla/websocket库创建了一个简单的WebSocket服务器。当客户端连接到服务器时,它会将接收到的消息回显给客户端[^1^]。

综上所述,这些实例涵盖了Go语言网络编程中的多种常见场景,包括TCP通信、HTTP服务、并发处理以及WebSocket通信。通过学习和实践这些实例,你可以更好地理解Go语言的网络编程模型,并掌握构建高效、可靠网络应用的技能。

目录
相关文章
|
7月前
|
存储 安全 Java
【Golang】(4)Go里面的指针如何?函数与方法怎么不一样?带你了解Go不同于其他高级语言的语法
结构体可以存储一组不同类型的数据,是一种符合类型。Go抛弃了类与继承,同时也抛弃了构造方法,刻意弱化了面向对象的功能,Go并非是一个传统OOP的语言,但是Go依旧有着OOP的影子,通过结构体和方法也可以模拟出一个类。
374 2
|
8月前
|
网络协议 Java Linux
【App Service】在Azure环境中如何查看App Service实例当前的网络连接情况呢?
在 Azure App Service(Windows 和 Linux)中部署应用时,分析网络连接状态是排查异常、验证端口监听及确认后端连接的关键。本文介绍如何在 Linux 环境中使用 `netstat` 命令查看特定端口(如 443、3306、6380)的连接情况,并解析输出结果。同时说明在 Windows App Service 中 `netstat` 被禁用的情况下,如何通过门户抓包等替代方法进行网络诊断。内容涵盖命令示例、操作步骤及附录说明,帮助开发者快速掌握云环境中的网络分析技巧。
213 11
|
9月前
|
Cloud Native 安全 Java
Go:为云原生而生的高效语言
Go:为云原生而生的高效语言
566 1
|
9月前
|
Cloud Native Go API
Go:为云原生而生的高效语言
Go:为云原生而生的高效语言
575 0
|
9月前
|
Cloud Native Java Go
Go:为云原生而生的高效语言
Go:为云原生而生的高效语言
403 0
|
9月前
|
Cloud Native Java 中间件
Go:为云原生而生的高效语言
Go:为云原生而生的高效语言
452 0
|
9月前
|
Cloud Native Java Go
Go:为云原生而生的高效语言
Go:为云原生而生的高效语言
503 0
|
9月前
|
数据采集 Go API
Go语言实战案例:多协程并发下载网页内容
本文是《Go语言100个实战案例 · 网络与并发篇》第6篇,讲解如何使用 Goroutine 和 Channel 实现多协程并发抓取网页内容,提升网络请求效率。通过实战掌握高并发编程技巧,构建爬虫、内容聚合器等工具,涵盖 WaitGroup、超时控制、错误处理等核心知识点。
|
网络协议 安全 Java
Java中的网络编程:Socket编程详解
Java中的网络编程:Socket编程详解
|
网络协议 安全 Java
Java中的网络编程:Socket编程详解
Java中的网络编程:Socket编程详解

热门文章

最新文章