版权声明:本文为博主原创文章,未经博主允许不得转载。

第一次跑到互联网公司实习 。。感觉自己进步飞快啊~第一周刚写了个HTTP服务器用于微信公共号的点餐系统~ 第二周就直接开始一边自学Go语言一边写用于Socket的服务器了。。。

因为发现Golang这一块资料挺少的,接下来我会在Blog里把整个Server的Coding,还有遇到的坑都记录下来~

在golang中,网络协议已经被封装的非常完好了,想要写一个Socket的Server,我们并不用像其他语言那样需要为socket、bind、listen、receive等一系列操作头疼,只要使用Golang中自带的net包即可很方便的完成连接等操作~

在这里,给出一个最最基础的基于Socket的Server的写法:

  1. package main
  2. import (
  3. "fmt"
  4. "net"
  5. "log"
  6. "os"
  7. )
  8. func main() {
  9. //建立socket,监听端口
  10. netListen, err := net.Listen("tcp", "localhost:1024")
  11. CheckError(err)
  12. defer netListen.Close()
  13. Log("Waiting for clients")
  14. for {
  15. conn, err := netListen.Accept()
  16. if err != nil {
  17. continue
  18. }
  19. Log(conn.RemoteAddr().String(), " tcp connect success")
  20. handleConnection(conn)
  21. }
  22. }
  23. //处理连接
  24. func handleConnection(conn net.Conn) {
  25. buffer := make([]byte, 2048)
  26. for {
  27. n, err := conn.Read(buffer)
  28. if err != nil {
  29. Log(conn.RemoteAddr().String(), " connection error: ", err)
  30. return
  31. }
  32. Log(conn.RemoteAddr().String(), "receive data string:\n", string(buffer[:n]))
  33. }
  34. }
  35. func Log(v ...interface{}) {
  36. log.Println(v...)
  37. }
  38. func CheckError(err error) {
  39. if err != nil {
  40. fmt.Fprintf(os.Stderr, "Fatal error: %s", err.Error())
  41. os.Exit(1)
  42. }
  43. }

唔,抛除go语言里面10行代码有5行error的蛋疼之处,你可以看到,Server想要建立并接受一个Socket,其核心流程就是

  1. netListen, err := net.Listen("tcp", "localhost:1024")
  1. conn, err := netListen.Accept()
  1. n, err := conn.Read(buffer)

这三步,通过Listen、Accept 和Read,我们就成功的绑定了一个端口,并能够读取从该端口传来的内容~

Server写好之后,接下来就是Client方面啦,我手写一个HelloWorld给大家:

  1. package main
  2. import (
  3. "fmt"
  4. "net"
  5. "os"
  6. )
  7. func sender(conn net.Conn) {
  8. words := "hello world!"
  9. conn.Write([]byte(words))
  10. fmt.Println("send over")
  11. }
  12. func main() {
  13. server := "127.0.0.1:1024"
  14. tcpAddr, err := net.ResolveTCPAddr("tcp4", server)
  15. if err != nil {
  16. fmt.Fprintf(os.Stderr, "Fatal error: %s", err.Error())
  17. os.Exit(1)
  18. }
  19. conn, err := net.DialTCP("tcp", nil, tcpAddr)
  20. if err != nil {
  21. fmt.Fprintf(os.Stderr, "Fatal error: %s", err.Error())
  22. os.Exit(1)
  23. }
  24. fmt.Println("connect success")
  25. sender(conn)
  26. }

可以看到,Client这里的关键在于

  1. tcpAddr, err := net.ResolveTCPAddr("tcp4", server)
  1. conn, err := net.DialTCP("tcp", nil, tcpAddr)

这两步,主要是负责解析端口和连接~

写好Server和Client之后,让我们运行一下看看:~~

成功运行,Console出现Server等待连接的提示:

然后我们运行Client:

成功连接Server啦,让我们看看Server那边的成果:

Server端成功的收到了我们的Hello-World啦,至于后面的那行红字,则是断开连接的提示~

到这里,一个最基础的使用Socket的Server-Client框架就出来啦~

如果想要让Server能够响应来自不同Client的请求,我们只要在Server端的代码的main入口中,

在 handleConnection(conn net.Conn) 这句代码的前面加上一个 go,就可以让服务器并发处理不同的Client发来的请求啦

关于Golang的并发处理,可以参考这里 Golang并行计算

下一篇,我会写一下如何在Server和Client中设计一个通讯协议,从而达到自己的一些特殊要求~

[Golang] 从零开始写Socket Server(1): Socket-Client框架的更多相关文章

  1. 从零开始写一个武侠冒险游戏-0-开发框架Codea简介

    从零开始写一个武侠冒险游戏-0-开发框架Codea简介 作者:FreeBlues 修订记录 2016.06.21 初稿完成. 2016.08.03 增加对 XCode 项目文件的说明. 概述 本游戏全 ...

  2. 教你写个简单到的 Redis Client 框架 - .NET Core

    目录 1,关于 Redis RESP 定义数据类型 2,定义异步消息状态机 3,定义命令发送模板 4,定义 Redis Client 5,实现简单的 RESP 解析 6,实现命令发送客户端 7,如何使 ...

  3. 从零开始写一个武侠冒险游戏-8-用GPU提升性能(3)

    从零开始写一个武侠冒险游戏-8-用GPU提升性能(3) ----解决因绘制雷达图导致的帧速下降问题 作者:FreeBlues 修订记录 2016.06.23 初稿完成. 2016.08.07 增加对 ...

  4. 从零开始写一个武侠冒险游戏-7-用GPU提升性能(2)

    从零开始写一个武侠冒险游戏-7-用GPU提升性能(2) ----把地图处理放在GPU上 作者:FreeBlues 修订记录 2016.06.21 初稿完成. 2016.08.06 增加对 XCode ...

  5. 从零开始写一个武侠冒险游戏-6-用GPU提升性能(1)

    从零开始写一个武侠冒险游戏-6-用GPU提升性能(1) ----把帧动画的实现放在GPU上 作者:FreeBlues 修订记录 2016.06.19 初稿完成. 2016.08.05 增加对 XCod ...

  6. [Golang] 从零開始写Socket Server(2): 自己定义通讯协议

    在上一章我们做出来一个最基础的demo后,已经能够初步实现Server和Client之间的信息交流了~ 这一章我会介绍一下怎么在Server和Client之间实现一个简单的通讯协议.从而增强整个信息交 ...

  7. [Golang] 从零開始写Socket Server(3): 对长、短连接的处理策略(模拟心跳)

    通过前两章,我们成功是写出了一套凑合能用的Server和Client,并在二者之间实现了通过协议交流.这么一来,一个简易的socket通讯框架已经初具雏形了,那么我们接下来做的.就是想办法让这个框架更 ...

  8. 在socket的server端处理client端发来的数据

    一.楔子 最近做了一个需求遇到一个坑,归结成一个小问题,其实就是在socket的server端处理client端发来的数据的问题,现将这个问题总结一下,本文将数据在server端以字典的形式存储. 另 ...

  9. C语言写了一个socket server端,适合windows和linux,用GCC编译运行通过

    ////////////////////////////////////////////////////////////////////////////////* gcc -Wall -o s1 s1 ...

随机推荐

  1. Shiro整合springboot,freemaker,redis(含权限系统完整源码)

    区块链技术联盟 2018-02-08 17:06:40 目录 一.导语 二.shiro功能介绍 三.shiro详解 四.shiro实战案例分享 五.系统配置 六.其他 一.导语 今天推荐给大家一个非常 ...

  2. Maven依赖传递、依赖传递排除、依赖冲突

    转载请注明原文地址:http://www.cnblogs.com/ygj0930/p/6628429.html  一:Maven依赖传递 假如有Maven项目A,项目B依赖A,项目C依赖B.那么我们可 ...

  3. MyEclipse 本地安装插件

    安装subeclipse插件 打开之前下载的site-1.6.12.zip文件可以看到里面有features.plugins两个文件夹 用之前我讲过的Myeclipse安装插件的方法安装就可以了 参考 ...

  4. Android开发之欢迎界面标准

    import java.util.ArrayList; import android.app.Activity; import android.content.SharedPreferences; i ...

  5. Windows下VS2017编译OpenCV 3.4.0-rc

    简述 很久没有用过OpenCV了,这次需要做一点图像处理相关的工作,又需要用起来,这里记录一下编译的过程.之前介绍过使用vs2015编译opencv2.4的帖子在这里. 编译好的文件在这里https: ...

  6. Spring Cloud Edgware Release Notes

    Spring Cloud Edgware builds on Spring Boot 1.5.x. Renamed starters A number of starters did not foll ...

  7. Ubuntu16.04, Gqrx通过RTL-SDR的Q通道收听中短波

    硬件准备 天线: 一根悬垂的3~4米长线天线, 如果只是临时使用, 直接用普通的0.75平方的聚氯乙烯多股软电线就可以了. 巴伦: 9:1巴伦 接收器: Q通道增加低频输入的RTL-SDR接收器 以及 ...

  8. spring aop实现日志收集

    概述 使用spring aop 来实现日志的统一收集功能 详细 代码下载:http://www.demodashi.com/demo/10185.html 使用spring aop 来实现日志的统一收 ...

  9. ios中MKHorizMenu用法

    下载地址 https://github.com/MugunthKumar/MKHorizMenuDemo直接 加入MKHorizMenu目录即可 下载包地址 http://pan.baidu.com/ ...

  10. How to use, monitor, and disable transparent hugepages in Red Hat Enterprise Linux 6

    Resolution Note: Transparent Huge Pages are not available on the 32-bit version of RHEL 6. Transpare ...