1、线程池,ThreadingTCPServer

#coding=utf-8
'''
可并发,客户端互不影响,可以保持长连接,客户端发送消息 也不要求加 \r\n
''' #线程池(windows 可运行) from socketserver import *
import threading class MyTCPHandler(BaseRequestHandler): def handle(self):
while 1:
self.data=self.request.recv(1024).strip() cur_thread=threading.current_thread()
print('cur_thread.name:',cur_thread.name) #if not self.data:
if self.data=='bye':
print('客户端退出:',self.client_address[0])
break
print('客户端IP:%s:%s,内容:%s'%(self.client_address[0],self.client_address[1],self.data.decode())) self.request.sendall(self.data.upper()) if __name__=='__main__':
print('监听开始了。。。。')
server=ThreadingTCPServer(('127.0.0.1',9977),MyTCPHandler)
server.serve_forever()

client 客户端程序:

#coding=utf-8
'''
client
'''
from socket import * sk=socket() sk.connect(('127.0.0.1',9977))
while 1:
sk.settimeout(50) print('sending...now....')
s=input('输入:')
sk.send(s.encode())
if s=='bye':
break print(sk.recv(1024).decode()) sk.close()

2、ThreadingMixIn与TCPServer

#coding=utf-8
'''
貌似是一个真正的并发
客户端不等待,互不影响,linux下运行
'''
from socketserver import TCPServer,StreamRequestHandler,ThreadingMixIn import time
class Server(ThreadingMixIn,TCPServer):
pass class MyHandler(StreamRequestHandler): def handle(self):
addr=self.request.getpeername()
print('来自客户端:',addr)
print('from address:',self.client_address)
data=self.rfile.readline().strip()
print('*'*10)
print(type(data))
print(data.decode())
#if data.decode()=='bye' or not data:
# break
time.sleep(0.1)
if data:
self.wfile.write('服务器回复的消息'.encode('utf-8')) if __name__=='__main__': sever=Server(('127.0.0.1',9966),MyHandler) sever.serve_forever()

client客户端程序:

#coding=utf-8
from socket import * addr=('127.0.0.1',9966)
print('addr:',addr) while 1: sk=socket(AF_INET,SOCK_STREAM)
sk.connect(addr) print('send begin...')
data=input('please input something:')
sk.send((data+'\r\n').encode('utf-8'))
if data=='bye'or not data:
break print('recv begin....')
print(sk.recv(1024))
print('recv over...')
sk.close()

3、

#coding=utf-8
'''
貌似是串行,多连接,会等待1发送消息完成,才会处理2
'''
#from socketserver import TCPServer,ForkingMixIn,StreamRequestHandler
from socketserver import *
import time class Server(TCPServer,ForkingMixIn):
pass class MyHandler(StreamRequestHandler):
def handle(self):
addr=self.request.getpeername()
print('connect from :',addr)
try:
data=self.rfile.readline().strip()##客户端传的数据必须加上'\r\n'结尾
print('data:',data)
time.sleep(0.1)
except:
print('jie shou bao cuo le..')
if data:
self.wfile.write('this is a server message'.encode('utf-8')) if __name__=='__main__': server=Server(('127.0.0.1',9900),MyHandler)#连接是接收一次,关闭一次,每次传数据都要重新建立连接
print('server object:',server)
server.serve_forever()

client 客户端程序:

from socket import *

addr=('127.0.0.1',9900)

while 1:
sk=socket(AF_INET,SOCK_STREAM) #注意每次都要创建连接,服务端收一次数据就会关闭连接
sk.connect(addr)
data=input('input sth:')
if not data:
break
sk.send((data+'\r\n').encode()) #发送数据必须加\r\n结尾
data=sk.recv(1024)
if not data:
break
print(data.strip())
sk.close()

4、最基础的TCPServer小实例

#coding=utf-8

from socketserver import TCPServer,StreamRequestHandler as srh
import time
import traceback class MyHandler(srh):
def handle(self):
print('client address:',self.client_address)
try:
print('sever recv begin...')
dd=self.rfile.readline() #客户端发送一定加入\r\n结尾,否则会卡死
print('received data is:',dd) self.wfile.write('server send message!!'.encode())
#self.wfile.write('%s,%s'%(self.data,time.strf('%Y-%m-%d %H:%M:%S',time.time())))
except:
traceback.print_exc()
print('baocuo ru shang') server=TCPServer(('127.0.0.1',21567),MyHandler) #每次发送请求后自动关闭连接,不能长连接
server.serve_forever()

client客户端程序:

from socket import *

addr=('127.0.0.1',21567)

while 1:
sk=socket(AF_INET,SOCK_STREAM) #注意每次都要创建连接,服务端收一次数据就会关闭连接
sk.connect(addr)
data=input('input sth:')
if not data:
break
sk.send((data+'\r\n').encode()) #发送数据必须加\r\n结尾
data=sk.recv(1024)
if not data:
break
print(data.strip())
sk.close()

socketserver 多进程、多线程应用实例的更多相关文章

  1. [转帖]Windows和Linux对决(多进程多线程)

    Windows和Linux对决(多进程多线程) https://blog.csdn.net/world_2015/article/details/44920467 太长了 还没看完.. 还是没太理解好 ...

  2. (转) C#多线程赛跑实例

    专于:http://blog.csdn.net/lidatgb/article/details/8363035 结合上篇<多线程的基础>,这次我们写一个多线程的赛跑实例,内容很简单:超人和 ...

  3. vc 基于对话框多线程编程实例——线程之间的通信

     vc基于对话框多线程编程实例——线程之间的通信 实例:

  4. C#多线程编程实例 螺纹与窗口交互

    C#多线程编程实例 螺纹与窗口交互 代码: public partial class Form1 : Form { //声明线程数组 Thread[] workThreads = new Thread ...

  5. gdb常用命令及使用gdb调试多进程多线程程序

    一.常用普通调试命令 1.简单介绍GDB 介绍: gdb是Linux环境下的代码调试⼯具.使⽤:需要在源代码⽣成的时候加上 -g 选项.开始使⽤: gdb binFile退出: ctrl + d 或 ...

  6. c# 多线程 创建对象实例

    本次的标题是我在写单例模式的博客时遇到的问题,所以今天专门写了的demo让自己记住怎么简单的使用多线程. 一直纠结的是怎么在for循环中多次实例化对象,好复现单例模式在没有加锁的情况下出现多个实例对象 ...

  7. python采用 多进程/多线程/协程 写爬虫以及性能对比,牛逼的分分钟就将一个网站爬下来!

    首先我们来了解下python中的进程,线程以及协程! 从计算机硬件角度: 计算机的核心是CPU,承担了所有的计算任务.一个CPU,在一个时间切片里只能运行一个程序. 从操作系统的角度: 进程和线程,都 ...

  8. 也说性能测试,顺便说python的多进程+多线程、协程

    最近需要一个web系统进行接口性能测试,这里顺便说一下性能测试的步骤吧,大概如下 一.分析接口频率 根据系统的复杂程度,接口的数量有多有少,应该优先对那些频率高,数据库操作频繁的接口进行性能测试,所以 ...

  9. linux下C语言多线程编程实例

    用一个实例.来学习linux下C语言多线程编程实例. 代码目的:通过创建两个线程来实现对一个数的递加.代码: //包含的头文件 #include <pthread.h> #include ...

  10. Python 多进程 多线程 协程 I/O多路复用

    引言 在学习Python多进程.多线程之前,先脑补一下如下场景: 说有这么一道题:小红烧水需要10分钟,拖地需要5分钟,洗菜需要5分钟,如果一样一样去干,就是简单的加法,全部做完,需要20分钟:但是, ...

随机推荐

  1. 解决kalilinux:“下列签名无效: KEYEXPIRED 1425567400"

    Kali linux由于太长时间未更新,而出现GPG错误 KEYEXPIRED 1425567400.经检查源未出现问题可以解析,deb也不冲突,就是密钥过期了. 解决方式 使用一条命令,添加新的密钥 ...

  2. HTML5+CSS3系列教程——如何制作简单按钮笔记

      1.按钮的制作方式 用图片(目前用的不多) 纯CSS a标签 input 图片二决定了input的类型 当input的type属性是submit button等这些的时候他呈现一个按钮 butto ...

  3. 浅谈UML的概念和模型

    讲了UML的基本的九种图:http://blog.csdn.net/jiuqiyuliang/article/details/8552956 来具体讲讲这九种视图: 1.用例图(use case di ...

  4. Tomcat部署WEB应用方式

    罗列在Tomcat部署web应用的几种方法,供以后翻阅,本博文以helloapp应用为例 Tomcat目录介绍 简单目录介绍如下 bin目录:包含tomcat启动/关闭等脚本,支持linux.wind ...

  5. SQL Server直接执行.sql文件

    SQL Server直接执行.sql文件    客户的数据库数据被篡改,利用Log Explorer工具根据日志生成的回滚脚本有200多M,不可能一下子扔到查询分析器里去执行,于是想是否SQL Ser ...

  6. Jetbrains系列产品2019.2.3最新激活方法

    Jetbrains系列产品2019.2.3最新激活方法[持续更新] 发表于 2018-08-25 | 分类于 软件调试 本站惯例:本文假定你知道Jetbrains家的产品.不知道可以问问搜索引擎. 大 ...

  7. 【学习笔记】RMQ-Range Minimum/Maximum Query (区间最小/最大值)

    RMQ是一类询问区间最小/最大值的问题. 这类问题一般分成两类:静态区间(无修改),动态区间(带修改). 对于动态区间查询最大/最小,我们显然可以用线段树来解决…… 那么对于静态区间查询最大/最小的问 ...

  8. C语言细节

    一些常见细节 int *p[]和 int (*p)[] 的区别 int *p[4]; //定义一个指针数组,该数组中每个元素是一个指针,每个指针指向哪里就需要程序中后续再定义了. int (*p)[4 ...

  9. substr函数索引创建测试

    技术群里小伙伴,沟通说一条经常查询的SQL缓慢,单表SQL一个列作为条件,列是int数值类型,索引类型默认创建. 一.SQL文本substr函数索引创建测试 ,) nm1 ')需求,将上述SQL执行速 ...

  10. 创建新表,自动授权trigger

    需求 一个用户下三个表,开发人员不定时进行rename表名称,create原表名称 as old_table 插入少量数据,另一个业务用户需要访问该表,由于表名称rename导致经常需要手工授权. 需 ...