博客
关于我
[日常] Go语言圣经-基于select的多路复用习题
阅读量:664 次
发布时间:2019-03-15

本文共 2374 字,大约阅读时间需要 7 分钟。

Go 服务器超时处理优化示例

本文将介绍如何利用 Go 语言优化一个简单的 TCP 服务器实现,通过增加客户端连接超时机制,实现客户端 10 秒无响应时自动断开连接的功能。

实现概述

以下是在本次改造中的主要内容和目标:

  • 在现有 echo 服务器的基础上增加客户端连接超时处理
  • 当客户端在 10 秒内没有任何交互时,服务器自动断开连接
  • 保持现有功能的同时,优化代码结构和可读性
  • 服务器设计细节

    服务器基于 Go 语言实现,采用标准库 net 包中的 ListenAcceptClose 等函数进行操作。主要代码逻辑包括以下几个部分:

  • 上线监听

    net.Listen("tcp", ":8040") 开启一个 TCP 监听端口 8040

  • 处理连接

    使用 Accept 回调接收新的连接请求,并启动 goroutine 处理每个连接

  • 客户端输入处理

    通过 bufio.Scanner 实现对客户端输入的读取

  • 超时机制实现

    使用 time.After 创建 10 秒超时定时器,实现自动断开连接功能

  • 代码改造解读

    以下是主要改造的代码片段:

    package mainimport (    "bufio"    "fmt"    "log"    "net"    "strings"    "sync"    "time")func main() {    listeners, err := net.Listen("tcp", ":8040")    if err != nil {        log.Fatal("无法绑定监听地址", err)    }    for {        conn, err := listeners.Accept()        if err != nil {            log.Print("连接拒绝:", err) // 例如客户端主动中断连接            continue        }        go handleConn(conn)    }}// 处理每个连接的 goroutinefunc handleConn(c net.Conn) {    input := bufio.NewScanner(c)    wg := sync.WaitGroup    message := make(chan string, 100)    wg.Add(1)    // 定时器退出 goroutine    go func() {        defer wg.Done()        for {            select {            case <-time.After(10 * time.Second):                c.Close() // 10 秒后自动断开连接            case mes := <-message:                // 收到消息后启动新的 goroutine 处理回复                wg.Add(1)                go func(c net.Conn, text string) {                    defer wg.Done()                    // 实现 echo 功能                    fmt.Fprintln(c, "\t", strings.ToUpper(text))                    time.Sleep(1 * time.Second)                    fmt.Fprintln(c, "\t", text)                    time.Sleep(1 * time.Second)                    fmt.Fprintln(c, "\t", strings.ToLower(text))                    // 除非出现错误,否则不使用 Ctrl + w 中断                }(c, mes)            }        }    }()    // 等待 input 中的所有消息处理完成    for input.Scan() {        text := input.Text()        if text != "" {            message <- text        }    }    <-time.After(time.Millisecond) // 确保所有 goroutine 完成等待    c.Close()}

    改造要点总结

  • 定时器与 goroutine 结合使用

    通过 select 语句配合 time.Afterellyً،实现了客户端 10 秒无响应时自动断开连接功能

  • 消息传递与 goroutine 框架

    利用 sync.WaitGroup 进行 goroutine 的同步管理,确保并发操作的顺序性

  • 客户端消息处理

    实现了消息的读取与转发,客户端输入内容将被自动转发给另一 goroutine 进行处理

  • 总结

    本次改造主要通过增加定时器机制,实现了客户端连接的自动断开功能。在代码实现上,主要采用 goroutine 和 select 语句进行并发控制,并通过 sync.WaitGroup 进行 goroutine 的同步。这一设计既保持了原有 echo 服务器的功能,又增加了更加灵活的服务器控制流程,为后续功能扩展提供了很好的基础。

    转载地址:http://stnmz.baihongyu.com/

    你可能感兴趣的文章
    nginx:/usr/src/fastdfs-nginx-module/src/common.c:21:25:致命错误:fdfs_define.h:没有那个文件或目录 #include
    查看>>
    Nginx:NginxConfig可视化配置工具安装
    查看>>
    Nginx:现代Web服务器的瑞士军刀 | 文章末尾送典藏书籍
    查看>>
    ngModelController
    查看>>
    ngrok | 内网穿透,支持 HTTPS、国内访问、静态域名
    查看>>
    ngrok内网穿透可以实现资源共享吗?快解析更加简洁
    查看>>
    ngrok内网穿透可以实现资源共享吗?快解析更加简洁
    查看>>
    NHibernate学习[1]
    查看>>
    NHibernate异常:No persister for的解决办法
    查看>>
    Nhibernate的第一个实例
    查看>>
    nid修改oracle11gR2数据库名
    查看>>
    NIFI1.21.0/NIFI1.22.0/NIFI1.24.0/NIFI1.26.0_2024-06-11最新版本安装_采用HTTP方式_搭建集群_实际操作---大数据之Nifi工作笔记0050
    查看>>
    NIFI1.21.0_java.net.SocketException:_Too many open files 打开的文件太多_实际操作---大数据之Nifi工作笔记0051
    查看>>
    NIFI1.21.0_Mysql到Mysql增量CDC同步中_日期类型_以及null数据同步处理补充---大数据之Nifi工作笔记0057
    查看>>
    NIFI1.21.0_Mysql到Mysql增量CDC同步中_补充_插入时如果目标表中已存在该数据则自动改为更新数据_Postgresql_Hbase也适用---大数据之Nifi工作笔记0058
    查看>>
    NIFI1.21.0_Mysql到Mysql增量CDC同步中_补充_更新时如果目标表中不存在记录就改为插入数据_Postgresql_Hbase也适用---大数据之Nifi工作笔记0059
    查看>>
    NIFI1.21.0_NIFI和hadoop蹦了_200G集群磁盘又满了_Jps看不到进程了_Unable to write in /tmp. Aborting----大数据之Nifi工作笔记0052
    查看>>
    NIFI1.21.0_Postgresql和Mysql同时指定库_指定多表_全量同步到Mysql数据库以及Hbase数据库中---大数据之Nifi工作笔记0060
    查看>>
    NIFI1.21.0最新版本安装_连接phoenix_单机版_Https登录_什么都没改换了最新版本的NIFI可以连接了_气人_实现插入数据到Hbase_实际操作---大数据之Nifi工作笔记0050
    查看>>
    NIFI1.21.0最新版本安装_配置使用HTTP登录_默认是用HTTPS登录的_Https登录需要输入用户名密码_HTTP不需要---大数据之Nifi工作笔记0051
    查看>>