4Python全栈之路系列之socketsesrver实现多并发

简介:

Python全栈之路系列之socketserver实现多并发


利用socketserver实现多并发,socketserver内部会调用socket模块进行功能上的实现


client.py客户端脚本文件内容

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
#!/usr/bin/env python
# _*_ coding:utf-8 _*_
 
import  socket
 
# 创建一个socket对象
obj  =  socket.socket()
 
# 制定服务端的IP地址和端口
obj.connect(( '127.0.0.1' 999 , ))
 
# 阻塞,等待服务端发送内容,接受服务端发送过来的内容,最大接受1024字节
ret_bytes  =  obj.recv( 1024 )
 
# 因为服务端发送过来的是字节,所以我们需要把字节转换为字符串进行输出
ret_str  =  str (ret_bytes, encoding = "utf-8" )
 
# 输出内容
print (ret_str)
 
while  True :
     # 当进入连接的时候,提示让用户输入内容
     inp  =  input ( "Client请输入要发送的内容>>> " )
     # 如果输出q则退出
     if  inp  = =  "q" :
         # 把q发送给服务端
         obj.sendall(bytes(inp, encoding = "utf-8" ))
         # 退出当前while
         break
     else :
         # 否则就把用户输入的内容发送给用户
         obj.sendall(bytes(inp, encoding = "utf-8" ))
         # 等待服务端回答
         print ( "正在等待Server输入内容......" )
         # 获取服务端发送过来的结果
         ret  =  str (obj.recv( 1024 ), encoding = "utf-8" )
         # 输出结果
         print (ret)
         
# 连接完成之后关闭链接
obj.close()

server.py服务端脚本文件内容

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
#!/usr/bin/env python
# _*_ coding:utf-8 _*_
 
import  socketserver
 
class  MyServer(socketserver.BaseRequestHandler):
 
     def  handle( self ):
     
         conn  =  self .request
         
         conn.sendall(bytes( "你好,欢迎登陆!" , encoding = "utf-8" ))
         
         while  True :
             # 输出等待客户端发送内容
             print ( "正在等待Client输入内容......" )
             # 接收客户端发送过来的内容
             ret_bytes  =  conn.recv( 1024 )
             # 转换成字符串类型
             ret_str  =  str (ret_bytes, encoding = "utf-8" )
             # 输出用户发送过来的内容
             print (ret_str)
             
             # 如果用户输入的是q
             if  ret_str  = =  "q" :
                 # 则退出循环,等待下个用户输入
                 break
             # 给客户端发送内容
             inp  =  input ( "Service请输入要发送的内容>>> " )
             conn.sendall(bytes(inp, encoding = "utf-8" ))
             
if  __name__  = =  "__main__" :
     server  =  socketserver.ThreadingTCPServer(( '127.0.0.1' 999 , ), MyServer)
     server.serve_forever()

效果图

wKioL1kVGlqQ0BO_AAFKJtRyllE761.png

同时打开多个客户端,服务端也不会出现错误










本文转自 Edenwy  51CTO博客,原文链接:http://blog.51cto.com/edeny/1924867,如需转载请自行联系原作者
目录
相关文章
|
1月前
|
算法 安全 调度
解决Python并发访问共享资源引起的竞态条件、死锁、饥饿问题的策略
解决Python并发访问共享资源引起的竞态条件、死锁、饥饿问题的策略
27 0
|
6月前
|
数据采集 并行计算 Java
【文末送书】Python高并发编程:探索异步IO和多线程并发
【文末送书】Python高并发编程:探索异步IO和多线程并发
127 0
|
1天前
|
监控 Python
Python监控主机是否存活,并发报警邮件
Python监控主机是否存活,并发报警邮件
|
15天前
|
JavaScript 前端开发 Docker
全栈开发实战:结合Python、Vue和Docker进行部署
【4月更文挑战第10天】本文介绍了如何使用Python、Vue.js和Docker进行全栈开发和部署。Python搭配Flask创建后端API,Vue.js构建前端界面,Docker负责应用的容器化部署。通过编写Dockerfile,将Python应用构建成Docker镜像并运行,前端部分使用Vue CLI创建项目并与后端交互。最后,通过Nginx和另一个Dockerfile部署前端应用。这种组合提升了开发效率,保证了应用的可维护性和扩展性,适合不同规模的企业使用。
|
1月前
|
Python
老男孩&路飞学城Python全栈
老男孩&路飞学城的Python全栈开发重点班由ALEX老师主讲,核心教学内容,100多天课程,近100G资料,含基础到实战。一线技术专家亲授,以案例教学引导学生逐步进入项目实战。
20 1
老男孩&路飞学城Python全栈
|
2月前
|
人工智能 PyTorch 开发工具
Python潮流周刊#5:并发一百万个任务要用多少内存?
Python潮流周刊#5:并发一百万个任务要用多少内存?
29 0
|
2月前
|
资源调度 安全 调度
在讨论Python多线程与并发
在讨论Python多线程与并发
12 2
|
2月前
|
存储 安全 计算机视觉
用 Python 脚本实现电脑唤醒后自动拍照 截屏并发邮件通知
用 Python 脚本实现电脑唤醒后自动拍照 截屏并发邮件通知

热门文章

最新文章