python | 写一个简单ping|pong服务器

简介: python | 写一个简单ping|pong服务器

本篇文章所依赖的python 环境如下:

image.png


计算机网络应用体系结构,一般有以下几种:

  • C/S架构: 也称为客户端/客户端架构。
  • P2P架构: 是一种分布式网络架构。
  • 混个结构: 客户端/服务器架构 和 P2P架构都包含在内。

我们该篇文章,将介绍c/s网络结构。



客户端/服务器架构介绍


什么是客户端/服务器架构

客户端/服务器架构,也被称之为C/S架构,它是一种互联网最常见的网络结构,我们熟知的web服务器也是使用的C/S架构。还有数据库应用等,也是使用的C/S架构。


如何使用

在此网络架构中,服务器若想和客户端进行网络通信,服务器需要提前启动。客户端随之向服务器发送请求,服务器接收并且处理请求,最后将结果发送会客户端。服务器和客户端之间通信协议使用的是TCPUDP,前置称之为有连接服务器,后则称之为无连接服务。至于更上层的应用协议,如http是使用的TCP协议,如dns是使用的是UDP+TCP协议。


客户端/服务器架构缺点

此架构也是有缺点的,例如: 如果服务器发现故障,所有已经连接到服务器的客户端都会收到影响,以及服务器容易出现性能瓶颈等。



python socket编程

python中,为我们提供了一个内置socket模块,我们可以以此来创建一个自己的tcp服务器。


来看一个最简单的例子:

import socket
s = socket.socket(socket.AF_INET,socket.SOCK_STREAM)
s.bind(("0.0.0.0",9999))
s.listen(5)
while True:
    client , addr = s.accept()
    print(client,addr)

上述代码,首先引入socket模块,而后定义了一个socket函数,传入必要参数,该函数会返回一个套接字对象给我们。


socket函数的参数分为2个,第1个参数需要指定网络协议,第二个参数需要指定套接字类型。下面是网络协议和套接字类型的说明:


网络协议

  • socket.AF_INET: 最常用的协议,代表IPv4协议族。
  • socket.AF_INET6: 代表IPv6协议族。
  • socket.AF_UNIX: 表示Unix文件描述符。

套接字类型

  • socket.SOCK_STREAM: 表示流式套接字(TCP)。
  • socket.SOCK_DGRAM: 表示数据包套接字(UDP)。
  • socket.SOCK_RAW: 表示原始套接字。

上述,我们使用的是IPv4协议,并且使用的是TCP流式套接字。

接着便是bind函数,它会将套接字绑定到指定的地址和端口上,参数必须是元组,分别为: 地址 和 端口号。


后续的listen函数,是指定套接字监听的最大连接数,如上述所示,表示最大连接数为5,为0则是不设置连接数。


最后是一个死循环,其中定义了accept函数,该函数用于等待客户端连接并且返回新的套接字对象。

代码在运行之后,我们可以使用telnet来访问一下,它会打印客户端信息,例如:

image.png

上述结果为打印了client信息,和client addr的地址。



写一个最简单的ping/pong服务


有了上述的python基础,我们可以来写一个最简单的ping/pong服务,不过我们想同时监听tcp流 和 udp数据包,代码如下:

image.png


上述代码,我们使用多线程,分为对当前主机的所有网卡监听了tcp端口8888udp端口8888,而后使用bind将套接字绑定到地址和端口,在监听tcp的时候,我们需要通过listen方法指定监听队列长度,而udp不用。


这是因为tcpudp协议不同导致的,tcp是可靠传输协议,所以当有新的请求来的时候,会通过accept方法接收新的连接,会产生一个新的socket对象。


udp是一种无连接不可靠协议,可以直接向目标主机发送数据,所以不需要先建立连接。而是直接调用recv方法接收数据。


接着便定义了一个空的列表threadJobs用于存放线程名称,而后便定义了2个线程,调用的方法是pingPongServer传入的参数是套接字类型和我们定义的套接字。


pingPongServer方法中,因为如上所述udp不需要accept,所以我们需要根据传入的套接字类型进行判断,若是tcp则执行accept,而后接收数据;若是udp,则直接接收数据即可。


启动服务器进程之后,我们分别使用telnetnc127.0.0.18888端口发送hello pdudo字符串,服务器接收到的信息为:

image.png

客户端发送数据后,接收到的信息如下:

image.png


一个简单的ping/pong服务器就写完了。



总结


本篇文章介绍了网络架构的分类,分为是 c/s架构、p2p架构 以及 网络架构;接着介绍了c/s架构的介绍以及优缺点。后面举了一个最简单的python socket的例子,最后实现了一个tcpudpping``pong小案例。




相关文章
|
27天前
|
弹性计算 安全 开发工具
灵码评测-阿里云提供的ECS python3 sdk做安全组管理
批量变更阿里云ECS安全组策略(批量变更)
|
2月前
|
缓存 监控 Linux
Python 实时获取Linux服务器信息
Python 实时获取Linux服务器信息
|
3月前
|
Python
Socket学习笔记(二):python通过socket实现客户端到服务器端的图片传输
使用Python的socket库实现客户端到服务器端的图片传输,包括客户端和服务器端的代码实现,以及传输结果的展示。
186 3
Socket学习笔记(二):python通过socket实现客户端到服务器端的图片传输
|
3月前
|
JSON 数据格式 Python
Socket学习笔记(一):python通过socket实现客户端到服务器端的文件传输
本文介绍了如何使用Python的socket模块实现客户端到服务器端的文件传输,包括客户端发送文件信息和内容,服务器端接收并保存文件的完整过程。
208 1
Socket学习笔记(一):python通过socket实现客户端到服务器端的文件传输
|
3月前
|
IDE 网络安全 开发工具
IDE之pycharm:专业版本连接远程服务器代码,并配置远程python环境解释器(亲测OK)。
本文介绍了如何在PyCharm专业版中连接远程服务器并配置远程Python环境解释器,以便在服务器上运行代码。
564 0
IDE之pycharm:专业版本连接远程服务器代码,并配置远程python环境解释器(亲测OK)。
|
3月前
|
域名解析 弹性计算 安全
无法ping通ECS服务器公网IP的排查方法
无法ping通ECS服务器公网IP的排查方法
|
Linux Python
Python 技术篇-用paramiko库实现linux服务器文件下载到winodws本地实例演示
Python 技术篇-用paramiko库实现linux服务器文件下载到winodws本地实例演示
370 0
Python 技术篇-用paramiko库实现linux服务器文件下载到winodws本地实例演示
|
1月前
|
人工智能 数据可视化 数据挖掘
探索Python编程:从基础到高级
在这篇文章中,我们将一起深入探索Python编程的世界。无论你是初学者还是有经验的程序员,都可以从中获得新的知识和技能。我们将从Python的基础语法开始,然后逐步过渡到更复杂的主题,如面向对象编程、异常处理和模块使用。最后,我们将通过一些实际的代码示例,来展示如何应用这些知识解决实际问题。让我们一起开启Python编程的旅程吧!
|
1月前
|
存储 数据采集 人工智能
Python编程入门:从零基础到实战应用
本文是一篇面向初学者的Python编程教程,旨在帮助读者从零开始学习Python编程语言。文章首先介绍了Python的基本概念和特点,然后通过一个简单的例子展示了如何编写Python代码。接下来,文章详细介绍了Python的数据类型、变量、运算符、控制结构、函数等基本语法知识。最后,文章通过一个实战项目——制作一个简单的计算器程序,帮助读者巩固所学知识并提高编程技能。
|
22天前
|
Unix Linux 程序员
[oeasy]python053_学编程为什么从hello_world_开始
视频介绍了“Hello World”程序的由来及其在编程中的重要性。从贝尔实验室诞生的Unix系统和C语言说起,讲述了“Hello World”作为经典示例的起源和流传过程。文章还探讨了C语言对其他编程语言的影响,以及它在系统编程中的地位。最后总结了“Hello World”、print、小括号和双引号等编程概念的来源。
106 80

热门文章

最新文章

下一篇
开通oss服务