用Python实现一个简单的多线程TCP服务器的教程
2015-05-05 00:00
1101 查看
最近看《python核心编程》,书中实现了一个简单的1对1的TCPserver,但是在实际使用中1对1的形势明显是不行的,所以研究了一下如何在server端通过启动不同的线程(进程)来实现每个链接一个线程。
其实python在类的设计上已经考虑到了这一方面的需求,我们只要在自己的server上继承一下SocketServer.BaseRequestHandler就可以了。
server端代码如下:
客户端代码如下(基本和书中一模一样,只是把循环中的关闭链接注释掉了):
从客户端的代码可以看出,每次输入都会建立一次新的请求。
测试一下,启动server和client之后,在client中输入测试:
其实python在类的设计上已经考虑到了这一方面的需求,我们只要在自己的server上继承一下SocketServer.BaseRequestHandler就可以了。
server端代码如下:
#!/usr/bin/env python import SocketServer from time import ctime HOST = '' PORT = 21567 ADDR = (HOST, PORT) class MyRequestHandler(SocketServer.BaseRequestHandler): def handle(self): print '...connected from:', self.client_address while True: self.request.sendall('[%s] %s' % (ctime(),self.request.recv(1024))) tcpServ = SocketServer.ThreadingTCPServer(ADDR, MyRequestHandler) print 'waiting for connection...' tcpServ.serve_forever()
客户端代码如下(基本和书中一模一样,只是把循环中的关闭链接注释掉了):
#!/usr/bin/env python from socket import * HOST = 'localhost' PORT = 21567 BUFSIZ = 1024 ADDR = (HOST, PORT) while True: tcpCliSock = socket(AF_INET, SOCK_STREAM) tcpCliSock.connect(ADDR) data = raw_input('> ') if not data: break tcpCliSock.send('%s\r\n' % data) data = tcpCliSock.recv(BUFSIZ) if not data: break print data.strip() #tcpCliSock.close()
从客户端的代码可以看出,每次输入都会建立一次新的请求。
测试一下,启动server和client之后,在client中输入测试:
相关文章推荐
- 用Python实现一个简单的多线程TCP服务器的教程
- 用Python实现一个简单的WebSocket服务器
- 用Python实现一个简单的能够发送带附件的邮件程序的教程
- 使用Python的Twisted框架实现一个简单的服务器
- Python实现同时兼容老版和新版Socket协议的一个简单WebSocket服务器
- Python实现同时兼容老版和新版Socket协议的一个简单WebSocket服务器
- 代码笔记 | 一个用python实现的简单的文件服务器
- 用Reactor框架实现一个简单的tcp服务器
- 使用python多线程实现一个简单spider
- python 实现一个简单的 WebSocket 服务器
- 使用python多线程实现一个简单spider
- 用Java socket (TCP通信模型)实现一个简单的web 服务器
- python socket实现简单的(TCP/UDP)服务器/客户端
- python多进程、多线程服务器和客户端的简单实现
- 用Python实现一个简单的能够发送带附件的邮件程序的教程
- 用 Java 实现一个简单的多线程 web 服务器
- Java Socket实现一个简单的多线程回显服务器。
- Linux Socket 事件触发模型 epoll 示例 这里会写一个用C语言的TCP服务器的完全实现的简单程序
- golang简单实现一个基于TLS/SSL的 TCP服务器和客户端
- 【网络】实现简单的TCP、UDP服务器、TCP多进程/多线程服务器