一文带你使用 Python 实现 Socket 编程

简介: 整个计算机网络都是由协议组成。其实可以把协议类比成我们人类用的语言,我们和老外交流,双方得说一样的语言,就好像遵从同样的“协议”。网络上的两台机器之间要交流,也是如此。

七层网络模型——OSI 标准

OSI 七层模型是一个标准,规定了机器(主要是电脑)之间如何通信。因此假如你想要让你的洗碗机和洗衣机通信的话,就需要遵从 OSI 模型,或者至少从 OSI 模型获得启发。这意味着需要遵从分层的通信方式。


image.png


关于这七层模型,有一个记忆口诀:All People Seem To Need Data Processing


翻译成英语是“似乎所有人都需要数据处理”。这一句话由七个英语单词组成,每一个的首字母正好是按第 7 层到第 1 层的首字母的顺序。



当然,👨‍🎓标准和实际应用还是有区别的,实际运用起来是如下的五层网络模型。

五层网络模型


比如:A 客户端 -- B 服务器传输数据:首先经过应用层,往下,到达传输层,所有的都会经过传输往下网络层,路由选择数据链路层,中继器,路由器最后到达物理层,网线 或者 无线电波


由下往上,数据组包,组好数据-->字符串或者 JSON 数据,


我们用到最多的是应用层协议,


根据 IP 地址到 Web 服务器-->操作系统-->80 端口-->Ngix-->UWSGI


解析地址--DNS,通过域名查询 IP 协议。浏览器实现了 HTTP 协议


聊天工具与 HTTP 协议不一样,如果直接与底层协议打交道,编程复杂


操作系统给我们提供了 SOCKET,一种 API,方便直接跟传输层打交道。


实现自己的应用功能,HTTP 协议单向,Socket 编程的意义。Socket 本身并不是协议,是工具,用于连接应用和 TCP/UDP 打交道,从而实现自己的协议。

Client 和 Server 实现通信

TCP 服务器和客户端连接图如下:


image.png

Python Socket 编程

image.png


简易通信:


  1. 创建一个服务器server_socket.py,绑定本地 IP,端口 9999,然后进行服务监听,然后等待客户端发送数据,并打印从客户端接收到的数据。
# server_socket.py
import socket
# 创建套接字
server = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
# 绑定IP和端口,元组存储地址和端口
server.bind(('0.0.0.0', 9999))
# 服务端监听
server.listen()
# accept接受到用户的请求
sock, addr = server.accept()
# 接受从客户端发送的数据,一次获取1k的数据
data = sock.recv(1024)
# 打印接收的数据
print(data.decode('utf8'))
# 关闭服务器连接
server.close()


  1. 创建客户端client_socket.py,向本地 IP,9999 端口发起连接
# client_socket.py
import socket
# 创建套接字
client = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
# 要连接的服务器
client.connect(('127.0.0.1', 9999))
# 要发送的数据
client.send('Hello, Server'.encode('utf8'))
# 关闭连接
client.close()


先运行服务器程序,然后允许客户端程序,再回到服务器端控制台,可以看到如下输出:


image.png


双向通信:

# socket_server.py
import socket
# 创建套接字
server = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
# 绑定IP和端口,元组存储地址和端口
server.bind(('0.0.0.0', 8888))
# 服务端监听
server.listen()
# accept接受到用户的请求
sock, addr = server.accept()
# 循环发送与接收消息
while True:
    # 接受从客户端发送的数据,一次获取1k的数据
    data = sock.recv(1024)
    # 打印客户端接收的数据
    print('客户端:', data.decode('utf8'))
    # 服务器发送给客户端的数据
    re_data = input('服务器:')
    sock.send(re_data.encode('utf8'))
# client_socket.py
import socket
# 创建套接字
client = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
# 要连接的服务器
client.connect(('127.0.0.1', 8888))
while True:
    # 要发送的数据
    re_data = input('客户端:')
    client.send(re_data.encode('utf8'))
    # 要接收的数据
    data = client.recv(1024)
    print('服务端:', data.decode('utf8'))


我们还是先运行服务器代码socket_server.py,接着运行客户端client_socket.py


  1. 客户端给服务器发送:你好,服务器。
  2. 在服务器端收到信息后,回复一个:Hello,客户端
  3. 客户端再给服务端:一起来聊天吧


演示如下:


image.png


通过这个过程,实现了单个客户端与服务器的通信,如果说一个服务器程序想同时跟多个客户端交互,就需要利用到多线程编程,这里先不讲。


Socket 编程是网络编程的重要组成部分,掌握异步 IO 和协程的前提,关于 Socket 编程还有更多内容等着学习。


相关文章
|
6月前
|
数据采集 机器学习/深度学习 人工智能
Python:现代编程的首选语言
Python:现代编程的首选语言
861 102
|
6月前
|
数据采集 机器学习/深度学习 算法框架/工具
Python:现代编程的瑞士军刀
Python:现代编程的瑞士军刀
418 104
|
6月前
|
人工智能 自然语言处理 算法框架/工具
Python:现代编程的首选语言
Python:现代编程的首选语言
332 103
|
6月前
|
机器学习/深度学习 人工智能 数据挖掘
Python:现代编程的首选语言
Python:现代编程的首选语言
272 82
|
5月前
|
Python
Python编程:运算符详解
本文全面详解Python各类运算符,涵盖算术、比较、逻辑、赋值、位、身份、成员运算符及优先级规则,结合实例代码与运行结果,助你深入掌握Python运算符的使用方法与应用场景。
389 3
|
5月前
|
数据处理 Python
Python编程:类型转换与输入输出
本教程介绍Python中输入输出与类型转换的基础知识,涵盖input()和print()的使用,int()、float()等类型转换方法,并通过综合示例演示数据处理、错误处理及格式化输出,助你掌握核心编程技能。
613 3
|
5月前
|
并行计算 安全 计算机视觉
Python多进程编程:用multiprocessing突破GIL限制
Python中GIL限制多线程性能,尤其在CPU密集型任务中。`multiprocessing`模块通过创建独立进程,绕过GIL,实现真正的并行计算。它支持进程池、队列、管道、共享内存和同步机制,适用于科学计算、图像处理等场景。相比多线程,多进程更适合利用多核优势,虽有较高内存开销,但能显著提升性能。合理使用进程池与通信机制,可最大化效率。
421 3
|
5月前
|
Java 调度 数据库
Python threading模块:多线程编程的实战指南
本文深入讲解Python多线程编程,涵盖threading模块的核心用法:线程创建、生命周期、同步机制(锁、信号量、条件变量)、线程通信(队列)、守护线程与线程池应用。结合实战案例,如多线程下载器,帮助开发者提升程序并发性能,适用于I/O密集型任务处理。
540 0
|
6月前
|
数据采集 机器学习/深度学习 人工智能
Python:现代编程的多面手
Python:现代编程的多面手
249 0
|
6月前
|
存储 人工智能 算法
Python实现简易成语接龙小游戏:从零开始的趣味编程实践
本项目将中国传统文化与编程思维相结合,通过Python实现成语接龙游戏,涵盖数据结构、算法设计与简单AI逻辑,帮助学习者在趣味实践中掌握编程技能。
593 0

推荐镜像

更多