博客
关于我
[日常] 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/

    你可能感兴趣的文章
    NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置数据路由_实现数据插入数据到目标数据库_实际操作03---大数据之Nifi工作笔记0042
    查看>>
    NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置数据路由_生成插入Sql语句_实际操作02---大数据之Nifi工作笔记0041
    查看>>
    NIFI从MySql中离线读取数据再导入到MySql中_03_来吧用NIFI实现_数据分页获取功能---大数据之Nifi工作笔记0038
    查看>>
    NIFI从MySql中离线读取数据再导入到MySql中_不带分页处理_01_QueryDatabaseTable获取数据_原0036---大数据之Nifi工作笔记0064
    查看>>
    NIFI从MySql中离线读取数据再导入到MySql中_无分页功能_02_转换数据_分割数据_提取JSON数据_替换拼接SQL_添加分页---大数据之Nifi工作笔记0037
    查看>>
    NIFI从Oracle11G同步数据到Mysql_亲测可用_解决数据重复_数据跟源表不一致的问题---大数据之Nifi工作笔记0065
    查看>>
    NIFI从PostGresql中离线读取数据再导入到MySql中_带有数据分页获取功能_不带分页不能用_NIFI资料太少了---大数据之Nifi工作笔记0039
    查看>>
    nifi使用过程-常见问题-以及入门总结---大数据之Nifi工作笔记0012
    查看>>
    NIFI分页获取Mysql数据_导入到Hbase中_并可通过phoenix客户端查询_含金量很高的一篇_搞了好久_实际操作05---大数据之Nifi工作笔记0045
    查看>>
    NIFI分页获取Postgresql数据到Hbase中_实际操作---大数据之Nifi工作笔记0049
    查看>>
    NIFI同步MySql数据_到SqlServer_错误_驱动程序无法通过使用安全套接字层(SSL)加密与SQL Server_Navicat连接SqlServer---大数据之Nifi工作笔记0047
    查看>>
    NIFI同步MySql数据源数据_到原始库hbase_同时对数据进行实时分析处理_同步到清洗库_实际操作06---大数据之Nifi工作笔记0046
    查看>>
    Nifi同步过程中报错create_time字段找不到_实际目标表和源表中没有这个字段---大数据之Nifi工作笔记0066
    查看>>
    NIFI大数据进阶_FlowFile拓扑_对FlowFile内容和属性的修改删除添加_介绍和描述_以及实际操作---大数据之Nifi工作笔记0023
    查看>>
    NIFI大数据进阶_FlowFile生成器_GenerateFlowFile处理器_ReplaceText处理器_处理器介绍_处理过程说明---大数据之Nifi工作笔记0019
    查看>>
    NIFI大数据进阶_FlowFile生成器_GenerateFlowFile处理器_ReplaceText处理器_实际操作---大数据之Nifi工作笔记0020
    查看>>
    NIFI大数据进阶_Json内容转换为Hive支持的文本格式_实际操作_02---大数据之Nifi工作笔记0032
    查看>>
    NIFI大数据进阶_Json内容转换为Hive支持的文本格式_操作方法说明_01_EvaluteJsonPath处理器---大数据之Nifi工作笔记0031
    查看>>
    NIFI大数据进阶_Kafka使用相关说明_实际操作Kafka消费者处理器_来消费kafka数据---大数据之Nifi工作笔记0037
    查看>>
    NIFI大数据进阶_Kafka使用相关说明_实际操作Kafka生产者---大数据之Nifi工作笔记0036
    查看>>