Python学习32天(socket、tcp协议)

Noseparte 2020-03-26

守望了31天,终于等到了网络编程阶段,很多很多的基础原理知识,然后脑子懵了,进入新世界的感觉。

一、客户端\服务器架构

1.硬件C/S架构(打印机) 2.软件C/S架构   

2.互联网中处处是C/S架构   

如黄色网站是服务端,你的浏览器是客户端(B/S架构也是C/S架构的一种)   

腾讯作为服务端为你提供视频,你得下个腾讯视频客户端才能看它的视频) C/S架构与socket的关系:

学习socket就是为了完成C/S架构的开发

二、互联网协议

1.如何基于socket编程,来开发一款自己的C/S架构软件

2.C/S架构的软件(软件属于应用层)是基于网络进行通信的

3.网络的核心即一堆协议,协议即标准,你想开发一款基于网络通信的软件,就必须遵循这些标准。

4.让我们从这些标准开始研究,开启我们的socket编程之旅

Python学习32天(socket、tcp协议)

   然后是我们伟大的socket做了什么呢?请看下图

Python学习32天(socket、tcp协议)

 二、socket到底是一个什么东西呢?

  Socket是应用层与TCP/IP协议族通信的中间软件抽象层,它是一组接口。在设计模式中,Socket其实就是一个门面模式,它把复杂的TCP/IP协议族隐藏在Socket接口后面,对用户来说,一组简单的接口就是全部,让Socket去组织数据,以符合指定的协议。

  所以,我们无需深入理解tcp/udp协议,socket已经为我们封装好了,我们只需要遵循socket的规定去编程,写出的程序自然就是遵循tcp/udp标准的

三、关于嵌套字

  套接字起源于 20 世纪 70 年代加利福尼亚大学伯克利分校版本的 Unix,即人们所说的 BSD Unix。 因此,有时人们也把套接字称为“伯克利套接字”或“BSD 套接字”。一开始,套接字被设计用在同 一台主机上多个应用程序之间的通讯。这也被称进程间通讯,或 IPC。套接字有两种(或者称为有两个种族),分别是基于文件型的和基于网络型的。

  套接字家族的名字:AF_UNIX

unix一切皆文件,基于文件的套接字调用的就是底层的文件系统来取数据,两个套接字进程运行在同一机器,可以通过访问同一个文件系统间接完成通信

套接字家族的名字:AF_INET

(还有AF_INET6被用于ipv6,还有一些其他的地址家族,不过,他们要么是只用于某个平台,要么就是已经被废弃,或者是很少被使用,或者是根本没有实现,所有地址家族中,AF_INET是使用最广泛的一个,python支持很多种地址家族,但是由于我们只关心网络编程,所以大部分时候我么只使用AF_INET)

一个生活中的场景。你要打电话给一个朋友,先拨号,朋友听到电话铃声后提起电话,这时你和你的朋友就建立起了连接,就可以讲话了。等交流结束,挂断电话结束此次交谈。 生活中的场景就解释了这工作原理。

Python学习32天(socket、tcp协议)

   大致就是这么一个过程

四、socket实现一个简单的传输

客户端:

import  socket

phone=socket.socket(socket.AF_INET,socket.SOCK_STREAM)

phone.connect((‘127.0.1.11‘,8000)) #拨通电话

phone.send(‘hello‘.encode(‘utf-8‘)) #发消息
data=phone.recv(1024)
print(‘收到服务端的发来的消息:‘,data)

服务端:

import socket

phone=socket.socket(socket.AF_INET,socket.SOCK_STREAM) #买手机
phone.bind((‘127.0.1.11‘,8000)) #绑定手机卡
phone.listen(5) #开机
print(‘---->‘)
conn,addr=phone.accept() #等电话

msg=conn.recv(1024) #收消息
print(‘客户端发来的消息是: ‘,msg)
conn.send(msg.upper())#发消息

conn.close()
phone.close()

五、tcp协议的三次握手、四次挥手

Python学习32天(socket、tcp协议)

 1.三次握手:

首先由客户端(client)向服务器发送SYN请求,同时传输链接seq,服务器(server)不管是好是坏都会返回一个链接seq+1,随后客户端确认链接返回ACK = y+1

整个过程会相互回应,经过三次最终建立双向的传输链接

关于listen()就是用来存放SYN发起的半链接,只要三步没有全走完,就都是半链接,listen里面的参数就是表示存放的半链接数

同时也因为tcp协议不区分好坏的回复,就容易收到SYN洪水攻击(感觉很牛逼,其实我啥都不知道)

2.数据传输:

这个么得说的,你来我往的传输

3.四次挥手

断开链接时,往往是谁先结束传输,谁就发起断开,发起后,只要对方确认即可断开,但是传输时双向的,所以需要四次

如服务器往往为了保证自己的正常运行,在完成数据传输后就会主动断开链接,客户端确认后,服务器向客户端的就会断开了,此时客户端未发送断开请求,但是服务器已主动进入TIME_WAIT状态,反之也是一样的。

今天其实好多是没有听明白的,虽然自己闹了一下服务器和客户端的交互,但是好low啊

两个任务吧,

1.有空还是看一下linux基础部分的计算机基础    2.搞一个服务器虚拟机玩玩

今天就是这些了,需要抓紧消化一下了,明天自己试一试在服务器里处理客户端传递来的参数,哎呀呀,感觉小程序的路正在一步步靠近。

~~~~~

相关推荐