zoukankan      html  css  js  c++  java
  • tcp.go

    package nsqlookupd

    import (
        "io"
        "net"

        "github.com/nsqio/nsq/internal/protocol"
    )

    type tcpServer struct {
        ctx *Context
    }

    func (p *tcpServer) Handle(clientConn net.Conn) {
        p.ctx.nsqlookupd.logf("TCP: new client(%s)", clientConn.RemoteAddr())

        // The client should initialize itself by sending a 4 byte sequence indicating
        // the version of the protocol that it intends to communicate, this will allow us
        // to gracefully upgrade the protocol away from text/line oriented to whatever...
        buf := make([]byte, 4)
        _, err := io.ReadFull(clientConn, buf)
        if err != nil {
            p.ctx.nsqlookupd.logf("ERROR: failed to read protocol version - %s", err)
            return
        }
        protocolMagic := string(buf)

        p.ctx.nsqlookupd.logf("CLIENT(%s): desired protocol magic '%s'",
            clientConn.RemoteAddr(), protocolMagic)

        var prot protocol.Protocol
        switch protocolMagic {
        case "  V1":
            prot = &LookupProtocolV1{ctx: p.ctx}
        default:
            protocol.SendResponse(clientConn, []byte("E_BAD_PROTOCOL"))
            clientConn.Close()
            p.ctx.nsqlookupd.logf("ERROR: client(%s) bad protocol magic '%s'",
                clientConn.RemoteAddr(), protocolMagic)
            return
        }

        err = prot.IOLoop(clientConn)
        if err != nil {
            p.ctx.nsqlookupd.logf("ERROR: client(%s) - %s", clientConn.RemoteAddr(), err)
            return
        }
    }

  • 相关阅读:
    spark-2.0.0与hive-1.2.1整合
    kafka_2.11-0.10.0.0安装步骤
    hive-1.2.1安装步骤
    linux时间编程
    gdb与coredump
    linux下静态库、动态库的创建与使用
    linux常用工具
    js数组、内置对象、自定义对象
    JS学习五(js中的事件)
    JS学习四(BOM DOM)
  • 原文地址:https://www.cnblogs.com/zhangboyu/p/7457142.html
Copyright © 2011-2022 走看看