博客
关于我
高并发C/S的TCP版本golang实现
阅读量:267 次
发布时间:2019-03-01

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

前面一篇文章写到的实现服务器只能连接一个客户端,没有发挥出go语言的协程特性,所以又可用如下方法实现高并发,多个客户端连接来完成:

package mainimport (	"fmt"	"net"	"strings")// 服务器Read读客户端,返回0 说明对端关闭func main() {   	// 创建监听套接字	listener, err := net.Listen("tcp", "127.0.0.1:8001")	if err != nil {   		fmt.Println("listen err", err)		return	}	defer listener.Close()	for {   		// 监听客户端连接请求		fmt.Println("服务器等待客户端连接")		conn, err := listener.Accept()		if err != nil {   			fmt.Println("listener.Accept err", err)			return		}		// 具体完成服务器和客户端的数据通信		go HandlerConnect(conn)	}}func HandlerConnect(conn net.Conn) {   	defer conn.Close()	// 获取连接的客户端Addr	addr := conn.RemoteAddr()	fmt.Println(addr, "客户端成功连接---")	// 循环读取客户端发送数据	buf := make([]byte, 4096)	for {   		n, err := conn.Read(buf)		if n == 0 {   			fmt.Println("服务器检测到客户端已关闭,断开连接")			// 这里关闭的只是go线程,main线程还是在for循环的			return		}		if err != nil {   			fmt.Println("conn Read err", err)			return		}		fmt.Println("服务器读到数据:", string(buf[:n]))		// 小写转大写回发		conn.Write([]byte(strings.ToUpper(string(buf[:n]))))	}}

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

你可能感兴趣的文章
Node.js之async_hooks
查看>>
Node.js也分裂了-开源社区动态
查看>>
Node.js创建第一个应用
查看>>
Node.js初体验
查看>>
Node.js升级工具n
查看>>
Node.js卸载超详细步骤(附图文讲解)
查看>>
Node.js卸载超详细步骤(附图文讲解)
查看>>
Node.js基于Express框架搭建一个简单的注册登录Web功能
查看>>
node.js学习之npm 入门 —8.《怎样创建,发布,升级你的npm,node模块》
查看>>
Node.js安装与配置指南:轻松启航您的JavaScript服务器之旅
查看>>
Node.js安装及环境配置之Windows篇
查看>>
Node.js安装和入门 - 2行代码让你能够启动一个Server
查看>>
node.js安装方法
查看>>
Node.js官网无法正常访问时安装NodeJS的方法
查看>>
node.js模块、包
查看>>
node.js模拟qq漂流瓶
查看>>
node.js的express框架用法(一)
查看>>
Node.js的交互式解释器(REPL)
查看>>
Node.js的循环与异步问题
查看>>
Node.js高级编程:用Javascript构建可伸缩应用(1)1.1 介绍和安装-安装Node
查看>>