GO语言使用之网络编程(TCP编程)

简介: GO语言使用之网络编程(TCP编程)

一、基本介绍

Golang的主要设计目标之一就是面向大规模后端服务程序,网络通信这块是服务端 程序必不可少也是至关重要的一部分。

1、 网络编程有两种:

1.TCP socket编程,是网络编程的主流。之所以叫Tcp socket编程,是因为底层是基于Tcp/ip协议的. 比如: QQ聊天

2.b/s结构的http编程,我们使用浏览器去访问服务器时,使用的就是http协议,而http底层依旧是用tcp socket实现的。 比如: 京东商城 【这属于go web 开发范畴 】

2、协议(tcp/ip)

CP/IP(Transmission Control Protocol/Internet Protocol)的简写,中文译名为传输控制协议/因特网互联协议,又叫网络通讯协议,这个协议是Internet最基本的协议、Internet国际互联网络的基础,简单地说,就是由网络层的IP协议和传输层的TCP协议组成的。

20180913094117128.png

3、OSI与Tcp/ip参考模型 (推荐tcp/ip协议3卷)

4、ip地址

**概述:**每个internet上的主机和路由器都有一个ip地址,它包括网络号和主机号,ip地址有ipv4(32位)或者ipv6(128位). 可以通过ipconfig 来查看

5、 端口(port)-介绍

我们这里所指的端口不是指物理意义上的端口,而是特指TCP/IP协议中的端口,是

逻辑意义上的端口。

如果把IP地址比作一间房子,端口就是出入这间房子的门。真正的房子只有几个

门,但是一个IP地址的端口 可以有65536(即:256×256)个之多!端口是通过端

口号来标记的,端口号只有整数,范围是从0 到65535(256×256-1)

6、端口(port)-分类

  • 0号是保留端口.
  • 1-1024是固定端口(程序员不要使用)
    又叫有名端口,即被某些程序固定使用,一般程序员不使用.
    22: SSH远程登录协议 23: telnet使用 21: ftp使用
  • 25: smtp服务使用 80: iis使用 7: echo服务
  • 1025-65535是动态端口
    这些端口,程序员可以使用.

7、端口(port)-使用注意

  1. 在计算机(尤其是做服务器)要尽可能的少开端口
  1. 一个端口只能被一个程序监听
  2. 如果使用 netstat –an 可以查看本机有哪些端口在监听
  3. 可以使用 netstat –anb 来查看监听端口的pid,在结合任务管理器关闭不安全的端口

二、 tcp socket编程的客户端和服务器端

下图为Golang socket编程中客户端和服务器的网络分布

三、TCP快速入门案例

1、服务端

服务端的处理流程:

  • 监听端口 8888
  • 接收客户端的tcp链接,建立客户端和服务器端的链接.
  • 创建goroutine,处理该链接的请求(通常客户端会通过链接发送请求包)
    2、客户端

客户端的处理流程:

  • 建立与服务端的链接
  • 发送请求数据[终端],接收服务器端返回的结果数据
  • 关闭链接

3、简单的程序示意图

4、服务器端功能:

  1. 编写一个服务器端程序,在8888端口监听
  2. 可以和多个客户端创建链接
  3. 链接成功后,客户端可以发送数据,服务器端接受数据,并显示在终端上.
  1. 先使用telnet 来测试,然后编写客户端程序来测试

服务端的代码:

package main
import (
    "fmt"
    "log"
    _"io"
    "net"//做网络socket开发时,net包含有网络相关的方法和函数
)
func Server()  {
        // Listen函数创建的服务端
        //tcp : 网络协议
        //192.168.191.1:8888 / :8888 本机IP和端口
        l, err := net.Listen("tcp", "192.168.20.23:8888")
        if err != nil {
            log.Fatal(err)
        }
        defer l.Close()//延时关闭listen
        循环等待客户端访问
        for {
            conn, err := l.Accept()
            if err != nil {
                log.Fatal(err)
            }
            fmt.Printf("访问客户端信息: con=%v 客户端ip=%v
", conn, conn.RemoteAddr().String())
            go handleConnection(conn)
            // go func(c net.Conn) {
            //  io.Copy(c, c)
            //  c.Close()
            // }(conn)
        }
}
//服务端处理从客户端接受的数据
func handleConnection(c net.Conn){  
    defer c.Close()//关闭conn
    for {
        //1. 等待客户端通过conn发送信息
        //2. 如果客户端没有wrtie[发送],那么协程就阻塞在这里
        fmt.Printf("服务器在等待客户端%s 发送信息
", c.RemoteAddr().String())
        buf := make([]byte, 1024 )
        n, err := c.Read(buf)
        if err != nil {
            log.Fatal(err)
            break
        }
        //3. 显示客户端发送的内容到服务器的终端
        fmt.Print(string(buf[:n]))
    }
}
func main()  {
    Server()
}

5、客户端功能:

1. 编写一个客户端端程序,能链接到 服务器端的8888端口

2. 客户端可以发送单行数据,然后就退出

3. 能通过终端输入数据(输入一行发送一行), 并发送给服务器端 []

4. 在终端输入exit,表示退出程序.

客户端的代码:

package main
import (
    "strings"
    "os"
    "log"
    "bufio"
    "fmt"
    "net"
)
func Client()  {
    conn, err := net.Dial("tcp", "192.168.20.23:8888")
    if err != nil {
        log.Fatal(err)
    }
    //客户端可以发送单行数据,然后就退出
    reader := bufio.NewReader(os.Stdin) //os.Stdin 代表标准输入[终端]
    for {
        //从终端读取一行用户输入,并准备发送给服务器
        line, err := reader.ReadString('
')
        if err != nil {
            log.Fatal(err)
        }
        line = strings.Trim(line,"
")
        if line == "exit" {
            fmt.Println("用户退出客户端")
            break
        }
        //再将line 发送给 服务器
        conent, err := conn.Write([]byte(line + "
"))
        if err != nil {
            log.Fatal(err)
        }
        fmt.Printf("客户端发送了 %d 字节的数据到服务端
", conent)
    }
}
func main()  {
    Client()
}


相关文章
|
1月前
|
存储 监控 算法
员工上网行为监控中的Go语言算法:布隆过滤器的应用
在信息化高速发展的时代,企业上网行为监管至关重要。布隆过滤器作为一种高效、节省空间的概率性数据结构,适用于大规模URL查询与匹配,是实现精准上网行为管理的理想选择。本文探讨了布隆过滤器的原理及其优缺点,并展示了如何使用Go语言实现该算法,以提升企业网络管理效率和安全性。尽管存在误报等局限性,但合理配置下,布隆过滤器为企业提供了经济有效的解决方案。
85 8
员工上网行为监控中的Go语言算法:布隆过滤器的应用
|
1月前
|
Go 开发工具
百炼-千问模型通过openai接口构建assistant 等 go语言
由于阿里百炼平台通义千问大模型没有完善的go语言兼容openapi示例,并且官方答复assistant是不兼容openapi sdk的。 实际使用中发现是能够支持的,所以自己写了一个demo test示例,给大家做一个参考。
|
1月前
|
存储 Go 索引
go语言中的数组(Array)
go语言中的数组(Array)
117 67
|
7天前
|
存储 监控 算法
内网监控系统之 Go 语言布隆过滤器算法深度剖析
在数字化时代,内网监控系统对企业和组织的信息安全至关重要。布隆过滤器(Bloom Filter)作为一种高效的数据结构,能够快速判断元素是否存在于集合中,适用于内网监控中的恶意IP和违规域名筛选。本文介绍其原理、优势及Go语言实现,提升系统性能与响应速度,保障信息安全。
22 5
|
17天前
|
算法 安全 Go
Go语言中的加密和解密是如何实现的?
Go语言通过标准库中的`crypto`包提供丰富的加密和解密功能,包括对称加密(如AES)、非对称加密(如RSA、ECDSA)及散列函数(如SHA256)。`encoding/base64`包则用于Base64编码与解码。开发者可根据需求选择合适的算法和密钥,使用这些包进行加密操作。示例代码展示了如何使用`crypto/aes`包实现对称加密。加密和解密操作涉及敏感数据处理,需格外注意安全性。
38 14
|
17天前
|
Go 数据库
Go语言中的包(package)是如何组织的?
在Go语言中,包是代码组织和管理的基本单元,用于集合相关函数、类型和变量,便于复用和维护。包通过目录结构、文件命名、初始化函数(`init`)及导出规则来管理命名空间和依赖关系。合理的包组织能提高代码的可读性、可维护性和可复用性,减少耦合度。例如,`stringutils`包提供字符串处理函数,主程序导入使用这些函数,使代码结构清晰易懂。
63 11
|
17天前
|
存储 安全 Go
Go语言中的map数据结构是如何实现的?
Go 语言中的 `map` 是基于哈希表实现的键值对数据结构,支持快速查找、插入和删除操作。其原理涉及哈希函数、桶(Bucket)、动态扩容和哈希冲突处理等关键机制,平均时间复杂度为 O(1)。为了确保线程安全,Go 提供了 `sync.Map` 类型,通过分段锁实现并发访问的安全性。示例代码展示了如何使用自定义结构体和切片模拟 `map` 功能,以及如何使用 `sync.Map` 进行线程安全的操作。
|
21天前
|
监控 安全 算法
深度剖析核心科技:Go 语言赋能局域网管理监控软件进阶之旅
在局域网管理监控中,跳表作为一种高效的数据结构,能显著提升流量索引和查询效率。基于Go语言的跳表实现,通过随机化索引层生成、插入和搜索功能,在高并发场景下展现卓越性能。跳表将查询时间复杂度优化至O(log n),助力实时监控异常流量,保障网络安全与稳定。示例代码展示了其在实际应用中的精妙之处。
39 9
|
1月前
|
负载均衡 网络协议 算法
不为人知的网络编程(十九):能Ping通,TCP就一定能连接和通信吗?
这网络层就像搭积木一样,上层协议都是基于下层协议搭出来的。不管是ping(用了ICMP协议)还是tcp本质上都是基于网络层IP协议的数据包,而到了物理层,都是二进制01串,都走网卡发出去了。 如果网络环境没发生变化,目的地又一样,那按道理说他们走的网络路径应该是一样的,什么情况下会不同呢? 我们就从路由这个话题聊起吧。
73 4
不为人知的网络编程(十九):能Ping通,TCP就一定能连接和通信吗?
|
1月前
|
算法 安全 Go
Go 语言中实现 RSA 加解密、签名验证算法
随着互联网的发展,安全需求日益增长。非对称加密算法RSA成为密码学中的重要代表。本文介绍如何使用Go语言和[forgoer/openssl](https://github.com/forgoer/openssl)库简化RSA加解密操作,包括秘钥生成、加解密及签名验证。该库还支持AES、DES等常用算法,安装简便,代码示例清晰易懂。
60 12