s = socket.socket(socket.AF_INET,socket.SOCK_STREAM,0) 参数一:地址簇
socket.AF_INET ipv4(默认)
socket.AF_INET6 ipv6 socket.AF_UNIX 本地进程间通信 参数二:类型
socket.SOCK_STREAM 流式socket,TCP(默认)
socket.SOCK_DGRAM 数据报式socket,UDP
socket.SOCK_RAW 原始套接字,ICMP,IGMP
socket.SOCK_RDM 可靠的UDP形式
socket.SOCK_SEQPACKET 可靠的连续数据包服务 参数三:协议
0 (默认) 与特定地址家族相关的协议,如果是0,则系统会根据地址格式和套接类别,自动选择一个合适的协议 s.bind(ip_port)
s.listen(backlog) backlog:最大挂起数
s.setblocking(bool) 是否阻塞(默认为True),如果设为False,那么accept和recv时一旦无数据就会报错
s.accept() 默认阻塞的
s.connect(ip_port)连接出错会报错
s.connect_ex(ip_port) 连接成功返回0,出错返回编码
s.close()
s.recv(1024) 1024为最多接收的字节
s.recvfrom(1024) 返回值是元祖(data,address,)主要用于UDP
s.send() 发送的是字节(3.5) 不一定把所有消息都发完
s.sendall() 都发完
s.sendto(数据,address) 指定远程地址,主要用于UDP协议
s.settimeout(timeout) timeout 浮点数 单位秒,None为没有超时期
s.getpeername() 返回连接套接字的远程地址 元祖(ip_port)用于TCP
s.getsockname() 返回套接字字节的自己的地址 也是元祖 (ip_port) 用于TCP
s.fileno() 套接字的文件描述符 socket功能
socket功能
上面又复习了一次socket
下面我们开始分析socketserver的源码:
首先先贴出socketserver各类间的继承关系:
以上两个图包含了socketserver里的所有类和函数,方便以后查找他们之间的继承关系!图中“1”代表先继承,“2”代表后继承
现在我们来分析下面这段代码:
#/usr/bin/env python
#-*- coding:utf-8 -*-
#Authot:Zhang Yan import socketserver
ip_port=("127.0.0.1",9999,)
class MyServer(socketserver.BaseRequestHandler):
def handle(self):
pass
obj=socketserver.ThreadingTCPServer(ip_port,MyServer)
obj.serve_forever()
MyServer类的继承关系如下:
obj=socketserver.ThreadingTCPServer(ip_port,MyServer)
构建obj对象,执行ThreadingTCPServer类的__init__方法,所以obj是ThreadingTCPServer的对象
从下图可以看出执行的是TCPServer里的init方法
查看此段源码:
def __init__(self, server_address, RequestHandlerClass, bind_and_activate=True):
"""Constructor. May be extended, do not override."""
BaseServer.__init__(self, server_address, RequestHandlerClass) #在TCPServer的init方法里执行BaseServer的init方法
self.socket = socket.socket(self.address_family,
self.socket_type) #构建socket对象
if bind_and_activate:
try:
self.server_bind() #socket的bind方法
self.server_activate() #socket的listen方法
except:
self.server_close() #socket的close方法
raise
TCPserver的init
def __init__(self, server_address, RequestHandlerClass):
"""Constructor. May be extended, do not override."""
self.server_address = server_address
self.RequestHandlerClass = RequestHandlerClass
self.__is_shut_down = threading.Event() #执行threading.Event的init方法,构建对象
self.__shutdown_request = False
BaseServer的init
obj.serve_forever(),因为obj是ThreadingTCPServer的对象,所以先在ThreadTCPServer里找,没有的话在他的父类里找,如下图:
def serve_forever(self, poll_interval=0.5):
"""Handle one request at a time until shutdown. Polls for shutdown every poll_interval seconds. Ignores
self.timeout. If you need to do periodic tasks, do them in
another thread.
"""
self.__is_shut_down.clear()
try:
# XXX: Consider using another file descriptor or connecting to the
# socket to wake this up instead of polling. Polling reduces our
# responsiveness to a shutdown request and wastes cpu at all other
# times.
with _ServerSelector() as selector:
selector.register(self, selectors.EVENT_READ) while not self.__shutdown_request:
ready = selector.select(poll_interval)
if ready:
self._handle_request_noblock() #其他地方先不考虑,先看这两行,_handle_request_noblock是BaseServer的私有方法
self.service_actions() #self是obj,是ThreadTCPServer的对象,需要根据继承关系找到service_actions()方法
finally:
self.__shutdown_request = False
self.__is_shut_down.set()
BaseServer的serve_forever
python成长之路10——socketserver源码分析的更多相关文章
-
python day 15: IO多路复用,socketserver源码培析,
目录 python day 15 1. IO多路复用 2. socketserver源码分析 python day 15 2019/10/20 学习资料来自老男孩教育 1. IO多路复用 ''' I/ ...
-
kernel 3.10内核源码分析--hung task机制
kernel 3.10内核源码分析--hung task机制 一.相关知识: 长期以来,处于D状态(TASK_UNINTERRUPTIBLE状态)的进程 都是让人比较烦恼的问题,处于D状态的进程不能接 ...
-
python成长之路10
断点续传 python2.7 多继承 py35多继承 socketserver源码 支持并发处理socket i/o多路复用 上节回顾 socket ...
-
python基础-11 socket,IO多路复用,select伪造多线程,select读写分离。socketserver源码分析
Socket socket通常也称作"套接字",用于描述IP地址和端口,是一个通信链的句柄,应用程序通常通过"套接字"向网络发出请求或者应答网络请求. sock ...
-
Python之socketserver源码分析
一.socketserver简介 socketserver是一个创建服务器的框架,封装了许多功能用来处理来自客户端的请求,简化了自己写服务端代码.比如说对于基本的套接字服务器(socket-based ...
-
Python 日志打印之logging.getLogger源码分析
日志打印之logging.getLogger源码分析 By:授客 QQ:1033553122 #实践环境 WIN 10 Python 3.6.5 #函数说明 logging.getLogger(nam ...
-
Python学习---Django的request.post源码分析
request.post源码分析: 可以看到传递json后会帮我们dumps处理一次最后一字节形式传递过去
-
多线程高并发编程(10) -- ConcurrentHashMap源码分析
一.背景 前文讲了HashMap的源码分析,从中可以看到下面的问题: HashMap的put/remove方法不是线程安全的,如果在多线程并发环境下,使用synchronized进行加锁,会导致效率低 ...
-
Python创建容器和集合之源码分析
_collections_abc.py文件中提供了许多抽象基类,这些类将集合分解成许多互相独立的属性集 __all__ = ["Awaitable", "Coroutin ...
随机推荐
-
并行计算vs分布式计算
一般认为,集中在同一个机柜内或同一个地点的紧密耦合多处理机系统或大规模并行处理系统是并行处理系统,而用局域网或广域网连接的计算机系统是分布式处理系统.松散耦合并行计算机中的并行操作系统有时也称为分布式 ...
-
“The SQL Server license agreenment cannot be located for the selected edition.”MSSQL安装问题
今天老邹又来吐槽了.今天不和IE7较劲了.说点别的吧. 我呢什么软件都喜欢装最新版的,这部刚出来windows 8.1就赶紧装上了,随后就用上了vs2013.前天看到新闻说微软已经发布了sql ser ...
-
MongoDB复制集之将现有的单节点服务器转换为复制集
服务器情况: 现有的单节点 Primary 192.168.126.9:27017 新增的节点 Secondry 192.168.126.8:27017 仲裁节点 ...
-
【Jsp】JSP自己定义标签与MODEL1、MODEL2标准
在JSP2.0之后支持自己定义标签,如今一般都是jsp2.4的版本号了,所以无须考虑版本号的问题. 直接使用就能够了.尽管一般开发的过程中,非常少会自己定义JSP标签.可是通过一个JSP自己定义标签的 ...
-
2018-2019-2 网络对抗技术 20165317 Exp3 免杀原理与实践
2018-2019-2 网络对抗技术 20165317 Exp3 免杀原理与实践 实验内容 任务一:正确使用msf编码器,msfvenom生成如jar之类的其他文件,veil-evasion,自己利用 ...
-
Solr中在使用过程中遇到的";与";和";或";的问题
在进行全文检索的过程中,如果使用三星和手机,两个一块进行搜索的时候,关于三星的会被搜索出来,关于手机的信息也会被搜索出来,然后,需要将一些配置文件进行配置, <!-- DEPRECATED: T ...
-
thinkpad的E480安装ubuntu后wifi无法使用问题解决
买了新电脑,安装ubuntu新系统之后,遇到了一个比较麻烦的问题,在ubuntu中,无法使用wifi. 用新产品就是要当小白鼠啊,查了一下资料,发现这个使用的rtl8821ce的wifi芯片,该wif ...
-
ORA-03113: end-of-file on communication channel(归档满处理方法)
归档放在flash_recovery目录,由于归档占满了闪回目录,数据库启动报错ORA-03113: end-of-file on communication channel tail -1200f ...
-
65. Valid Number *HARD*
Validate if a given string is numeric. Some examples:"0" => true" 0.1 " => ...
-
python笔记--冒泡排序升级版
前言 面试的时候经常有面试官喜欢问如何进行冒泡排序?这个问题相信能难倒一批英雄好汉,本篇就详细讲解如何用python进行冒泡排序. 一.基本原理 1.概念: 冒泡排序(Bubble Sort),是一种 ...