python线程的GIL
GIL (全局解释器锁)
python --- 》 支持多线程 ----》 同步和互斥 ---》加锁 ---》解释器加锁 ————》 解释器同一时刻只能解释一个线程
解决方法 :
* 使用 多进程代替多线程
* 使用其他解释器
单线程
line cpu: 3.2390809059143066
line IO: 3.4946115016937256
多线程
thread cpu: 3.5669941902160645
thread IO: 4.673508644104004 (如果是网络IO操作)
多进程
process cpu: 1.852142572402954
process io: 2.1611037254333496
python 并行
多进程 + 协程
设计模式
设计模式是一种编程方法和解决问题的思路,是大量长期实践中总结的最佳实践
程序设计原则 :
高内聚 : 在同一模块内,实现尽可能单一的功能,不使功能混杂
低耦合 : 不同的模块之间,尽量相互独立,减少模块间的影响
生产者消费者模式
一部分线程(进程)生产数据资源
一部分线程(进程)消耗数据资源
两者互不影响,却能够保持某种平衡
iso ---- 》 OSI模型
osi 七层模型
应用层 : 提供osi的用户服务,用什么程序处理,选择什么样的 传输层协议
表示层 :完成数据转换,格式化和压缩,和加密相关
会话层 :建立或解除节点连接
传输层 :提供什么样的传输服务,流量控制,连接的建立断开
网络层 : 提供什么样的路由选择,用户控制,网络互联
链路层: 进行消息的发送和接收,提供链路流控制
物理层: 物理接口和设备的选择,故障的检测等
4层 5层(TCP/IP模型)
应用层 应用层
传输层 传输层
网络层 网络层
物理链路层 链路层
物理层
协议 : 网络协议 ,计算机双方都必须遵守的约定。
应用层协议 : TFTP FTP NFS SMTP DNS HTTP
传输层 : TCP UDP
网络层 : IP ARP ICMP
链路层 : PPP
物理层 : IEEE 802 xxx
TCP/IP
主机 : 主机名 ----》 IP 127.0.0.1 localhost
In [3]: socket.gethostname()
Out[3]: 'tedu'
In [4]: socket.gethostbyname('localhost')
Out[4]: '127.0.0.1'
说明 : 在编程中表示网络主机通常使用该主机的ip地址
表示本机通常使用 '127.0.0.1' 'localhost' ''
表
IP地址
IPV4
192.168.1.12 0--255 点分十进制
可以使用32位2进制表示
IPV6 128 位
192.168.1.0网段
192.168.1.1网关地址
192.168.1.255 广播地址
In [8]: socket.gethostbyaddr('www.baidu.com')
Out[8]: ('127.0.0.1', [], ['119.75.216.20'])
主机名 别名 IP地址
地址点分十进制和二进制之间转换
In [17]: socket.inet_aton('192.8.8.8')
Out[17]: b'\xc0\x08\x08\x08'
In [18]: socket.inet_ntoa(b'\xc0\x08\x08\x08')
Out[18]: '192.8.8.8'
In [19]: socket.inet_pton(socket.AF_INET,'192.8.8.8')
Out[19]: b'\xc0\x08\x08\x08'
In [20]: socket.inet_ntop(socket.AF_INET,b'\xc0\x08\x08\x08')
Out[20]: '192.8.8.8'
端口
端口是地址的一部分,决定使用哪个应用
取值范围 1 -- 65535
1--255 众所周知的端口 256---1023 UNIX系统占用端口
1024 -- 49151 已登记端口
49152-- 65535 动态或私有端口
建议使用10000以上端口号 8888 9999 6666 8000 8800
In [29]: socket.getservbyname('ssh')
Out[29]: 22
字节序 : 信息在内存中的存储方式
大端序 : 高序字节存储在低地址
小端序: 低序字节存储在低地址
网络字节序 (大端序)
本地字节序 ----》网络字节序
socket.htons() 将16位本地字节序转换为网罗字节序
socket.htonl() 将32位本地字节序转换为网罗字节序
网络字节序 ---- 》 本地字节序
socket.ntohs() 将网罗字节序转换为16位本地字节序
socket.ntohl() 将网罗字节序转换为32位本地字节序