go学习之网络编程

news2024/9/21 0:39:00

文章目录

    • 网络编程
      • 1、网络编程的基本介绍
      • 2.网络编程的基础知识
        • 1)协议(tcp/ip)
        • 2)OSI与TCP/ip参考模型
        • 3)ip地址
        • 4)端口(port)介绍
        • 5)tcp socket编程的客户端和服务器端
      • 3.socket编程快速入门
      • 4.经典项目-海量用户即时通讯系统
        • 1)项目开发流程
        • 2)需求分析
        • 3)界面设计

网络编程

1、网络编程的基本介绍

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

网络编程有两种

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

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

2.网络编程的基础知识

1)协议(tcp/ip)

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

协议的抽象理解图

在这里插入图片描述

2)OSI与TCP/ip参考模型

在这里插入图片描述

详细结构(模拟qq好友发送数据经过的网络协议层)

在这里插入图片描述

3)ip地址

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

4)端口(port)介绍

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

如果把ip地址比作一个房子,端口就是出入这间房子的门。真正的房子只有几个门,但是一个ip地址的端口可以有65536(256256)个之多!端口是通过端口号来标记的,端口号只有整数,范围是0到65535(256256-1)

端口–分类

  • 0是保留端口
  • 1-1024是固定端口 又叫有名端口,即被某些程序固定使用,一般程序员不使用, 22:SSH远程登录协议 23:telnet使用 21:Ftp使用 25:smtp服务使用 80:iis使用 7:echo服务
  • 1025-65535是动态端口这些端口,程序员是可以使用的(尽量使用40000以上的端口,这样不易冲突,更好地进行监听操作)

在这里插入图片描述

端口(port)-使用注意

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

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

在这里插入图片描述

3.socket编程快速入门

项目示意图

在这里插入图片描述

1)服务端的处理流程

-1.监听端口

-2.创建客户端的tcp连接,建立客户端和服务端的连接

-3.创建goroutine,处理该连接的请求(通常客户端会通过连接来发送请求包)

server.go

package main
import (
	"fmt"
	"net" //做网络socket开发时。net包含有我们需要所有的方法和函数
	// "io"
)

func process(conn net.Conn) {
	//这里我们循环的接收客户端发送的数据
	defer conn.Close() //关闭conn

	for {
		//创建一个新的切片
		buf := make([]byte,1024)
		//1.等待客户端通过conn发送信息
		//2.如果客户端没有write[发送],那么协程就阻塞在这里
		fmt.Printf("服务器在等待客户端%s 发送信息"+ conn.RemoteAddr().String())
		n,err :=conn.Read(buf) //从conn读取
		if err != nil {
			fmt.Printf("客户端退出 err=%v\n",err)
			return // !!!
		}
		//3.显示客户端发送的内容到服务器的终端
		fmt.Println(string(buf[:n]))
		
	}
}
func main() {
	fmt.Println("服务器开始监听")
	//net.Listen("tcp","0.0.0.0:8888")
	//1.tcp表示使用网络协议是tcp
	//2.0.0.0.0:8888 表示在本地监听8888端口
	listen, err :=net.Listen("tcp","0.0.0.0:8888")
	if err != nil {
		fmt.Println("listen err")
		return
	}
	defer listen.Close()  //延时关闭listen

	//循环等待客户端连接我
	for {
		//等待客户端连接诶
	    fmt.Println("等待客户端连接...")
		conn, err := listen.Accept()
		if err != nil {
			fmt.Println("Accept() err=",err)
		}else {
			fmt.Println("Accept() suc conn=%v 客户端ip为=%v\n",conn,conn.RemoteAddr().String())
		}
		//这里准备启动一个协程为客户端服务

		go process(conn)
	}
	// fmt.Printf("Listen successfully=%v\n",listen)
}

2)客户端的处理流程

-1.建立与服务端的链接

-2.发送请求数据,接收服务器端返回的结果数据

-3.关闭连接

3)客户端功能

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

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

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

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

client.go

package main
import (
	"fmt"
	"net"
	"bufio"
	"os"
	"strings"
)

func main() {
	conn, err :=net.Dial("tcp","192.168.31.102:8888")
	if err != nil {
		fmt.Println("client dial err=",err)
		return
	}
	//功能1.客户端可以发送单行数据,然后就退出
	reader:= bufio.NewReader(os.Stdin) //os.Stdin 代表标准输入【终端】
    for {
	//从终端读取一行用户输入,并准备发送给服务器
	line, err :=reader.ReadString('\n')
	if err != nil {
		fmt.Println("readerString err=",err)
	}
	//如果用户输入的是exit就退出
	line = strings.Trim(line, "\r\n") 
	if line == "exit"{
		fmt.Println("客户端退出..")
		break
	}

	//再将line发送给服务器
	_, err =conn.Write([]byte(line+ "\n"))
	if err != nil {
		fmt.Println("conn.Write err=",err)
	}
	//fmt.Printf("客户端发送了%d字节的数据,并退出",n)
   }


}

运行效果图

在这里插入图片描述

4.经典项目-海量用户即时通讯系统

1)项目开发流程

需求分析 -->设计阶段–>编码实现–>测试阶段—>实施

2)需求分析

-1 用户注册

-2 用户登录

-3 显示在线用户列表

-4 群聊(广播)

-5 点对点聊天(私聊)

-6 离线留言

3)界面设计

在这里插入图片描述

项目开发前技术准备

项目要保存用户信息和消息数据,因此我们需要学习数据库(Redis和mysql),这里我们选择redis,先学习如何在golang中使用redis

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1312178.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

什么是POM设计模式?

为什么要用POM设计模式 前期,我们学会了使用PythonSelenium编写Web UI自动化测试线性脚本 线性脚本(以快递100网站登录举栗): import timefrom selenium import webdriver from selenium.webdriver.common.by import Bydriver …

【媒体开发】利用FFMPEG进行推拉流

目录 1. 下载并启动媒体服务 2. 使用 FFMPEG 拉流并推送到指定服务地址 3. 客户端拉流 1. 下载并启动媒体服务 MediaMTX,也即之前的rtsp-simple-server,是一个即用型、零依赖的实时媒体服务器和媒体代理,允许发布、读取、代理和记录视频和…

react经验8:使用antd的checkbox实现全选与半选控制

预期实现的效果 列表项部分选中时,checkall处于半选状态,点击checkall要么全选,要么全不选。 实现步骤 列表项类型 declare type TableRow {key: Keytitle: stringisSelected?: boolean }示范数据 const [tabledata, setTabledata] u…

HarmonyOS4.0从零开始的开发教程16数据管理

HarmonyOS(十四)数据管理 1 概述 在移动互联网蓬勃发展的今天,移动应用给我们生活带来了极大的便利,这些便利的本质在于数据的互联互通。因此在应用的开发中数据存储占据了非常重要的位置,HarmonyOS应用开发也不例外…

低功耗蓝牙模块常见天线输出方式及选型建议

随着互联网技术的飞速发展,物联网(IoT)已经渗透到了我们生活的方方面面。作为物联网的关键技术之一,BLE(低功耗蓝牙)技术在汽车电子、智能家居、穿戴设备、工业自动化等领域发挥着举足轻重的作用。深圳市信…

一入二出热电阻温度信号隔离变送器

一入二出热电阻温度信号隔离变送器 用于测量铂热电阻Pt10,Pt100,Pt1000,Cu50,Cu100的热电阻传感器的小型仪器设备。广泛应用于工业测量温度系统,是降低成本且有效的测量方式。 型号:JSD TARZ-1002系列 我们来看下有什么特点: ◆小体积&#x…

ShenYu网关注册中心之Zookeeper注册原理

文章目录 1、客户端注册流程1.1、读取配置1.1.1、用于注册的 ZookeeperClientRegisterRepository1.1.2、用于扫描构建 元数据 和 URI 的 SpringMvcClientEventListener 1.2、扫描注解,注册元数据和URI1.2.1、构建URI并写入Disruptor1.2.2、构建元数据并写入Disrupto…

今天最新早上好问候语,清晨阳光暖心的早安问候语录

1、花以芳香而美,人以真诚而贵。心以善良而德,缘以相识而聚。彼此保重,相约美好。每一个清晨,都是快乐的开始。早安吉祥! ​ 2、拿起手机想到你,我把祝福送给你,虽然天天在重复,证明…

算法 - 无重复字符的最长子串(03)

原理: 定义左右两个指针,保证两个指针对应的子串中没有重复的字符,寻找并记录最长的子串长度。如果窗口满足条件,右指针向右滑动扩大窗口,更新最优值;如果窗口不满足条件,左指针向右缩小窗口。…

打工人副业变现秘籍,某多/某手变现底层引擎-Stable Diffusion替换背景

在Stable Diffusion软件中,使用ControlNet+模型实现固定物体批量替换背景 出图的流程。 一、准备好图片 1.你需要准备好一些白底图或者透明底图用于训练模型。 2.你需要准备同样角度的其他背景色底图用于ControlNet勾线 3.注意检查你的图片尺寸,是否为1:1,…

L1-041:寻找250

题目描述 对方不想和你说话,并向你扔了一串数…… 而你必须从这一串数字中找到“250”这个高大上的感人数字。 输入格式: 输入在一行中给出不知道多少个绝对值不超过1000的整数,其中保证至少存在一个“250”。 输出格式: 在一行中…

移植Modelsim仿真工程

背景 上班在公司用的PC1生成并完整的进行了仿真,打包成zip,经过微信传输并在家里的PC2上打开想要继续进行仿真,需要如何处理呢? 环境 软件路径公司PC1Quartus II Prime Pro 21.4C:\intelfpga_pro\21.4\quartus\bin64\qpro.exeMo…

Nginx与keepalived高可用节点搭建实验

本文主要介绍了nginxkeepalived的部署实验,并简单说明了nginx的集中负载分担模式 简介: nginx可以通过反向代理功能对后端服务器实现负载均衡功能 keepalived 是一种高可用集群选举软件 keepalived架构 分为三个模块: 1、keepalived core …

基于java的医院住院管理系统的设计与实现论文

摘 要 互联网发展至今,无论是其理论还是技术都已经成熟,而且它广泛参与在社会中的方方面面。它让信息都可以通过网络传播,搭配信息管理工具可以很好地为人们提供服务。针对医院住院信息管理混乱,出错率高,信息安全性差…

SpringIOC之FullyQualifiedAnnotationBeanNameGenerator

博主介绍:✌全网粉丝5W+,全栈开发工程师,从事多年软件开发,在大厂呆过。持有软件中级、六级等证书。可提供微服务项目搭建与毕业项目实战,博主也曾写过优秀论文,查重率极低,在这方面有丰富的经验✌ 博主作品:《Java项目案例》主要基于SpringBoot+MyBatis/MyBatis-plus+…

论文阅读:Lidar Annotation Is All You Need

目录 概要 Motivation 整体架构流程 技术细节 小结 概要 论文重点在探讨利用点云的地面分割任务作为标注,直接训练Camera的精细2D分割。在以往的地面分割任务中,利用Lidar来做地面分割是目前采用激光雷达方案进行自动驾驶的常见手段。来自Evocargo …

LeetCode Hot100 148.排序链表

题目: 给你链表的头结点 head ,请将其按 升序 排列并返回 排序后的链表 。 class Solution {public ListNode sortList(ListNode head) {return sortList(head, null);}private ListNode sortList(ListNode head, ListNode tail) {if (head null)retur…

超详细 | 哈里斯鹰优化算法原理、实现及其改进与利用(Matlab/Python)

测试函数为F9 在MATLAB中执行程序结果如下: 在Python中执行程序结果如下: 哈里斯鹰优化算法(Harris Hawks Optimization , HHO)是 Heidari等[1]于2019年提出的一种新型元启发式算法,设计灵感来源于哈里斯鹰在捕食猎物过程中的合作行为以及突…

智能优化算法应用:基于原子搜索算法3D无线传感器网络(WSN)覆盖优化 - 附代码

智能优化算法应用:基于原子搜索算法3D无线传感器网络(WSN)覆盖优化 - 附代码 文章目录 智能优化算法应用:基于原子搜索算法3D无线传感器网络(WSN)覆盖优化 - 附代码1.无线传感网络节点模型2.覆盖数学模型及分析3.原子搜索算法4.实验参数设定5.算法结果6.…

【算法刷题】Day16

文章目录 1. 不同路径题干:算法原理:代码: 2. 二分查找题干:算法原理:1、暴力解法 O(n)2、二分查找算法 朴素二分模版:代码: 1. 不同路径 原题链接 题干: 机器人只能向下和向右走&a…