python-day8socket、粘包、并发、多用户ftp
@以字符串名称形式引入外部模块:同级文件lib里面有个函数a打印66
1.解释器内部使用
m=__import__('lib')
print(m.a())
结果:
66
None
- 官方推荐用户使用
import importlib
m=importlib.import_module('lib')
print(m.a())
@类
F()()#执行类下面的__call__方法
__metaclass__暂时用不到
@@上周提到?
Fligh.status
Status.setter
Status.delter
__call__方法(没用过)
__mataclass__(没用过,以后可能用)
断言
@assert m is int#AssertionError
@ socket复习
博客里的Day7
@socket
tcp/ip send, recv
udp
family address
AF.INET ipv4
AF.INET6
AF.UNIX 。local
socket protocol type
sock.SOCK_STREAM tcp/ip
socket.SOCK_DGRAM 数据报式socket , for UDP
服务端
server = socket.socket(AF.INET,sock.SOCK_STREAM)
server.bind(localhost,9999)
server.listen()
while True:
conn,addr = server.accept() #阻塞?
while True:
print("new conn",addr)
data = conn.recv(1024) #8192最多,1024的整数 #recv默认是阻塞的
if not data:
break #客户端已断开, conn.recv收到的就都是空数据,
print(data)
conn.send(data.upper())
@判断一条程序是否被执行了,前后都print一句话。
@@@socket实现简单的ssh客户端
博客园Day8
@b”xxx”,xxx必须是ASCII码里面的内容才能转,中文转不了。
@send的时候如果服务器端允许接受的小于客户端发送量,剩余的进入缓冲区,第二次发的时候不发新的,而先发缓冲区里面的。系统默认最多buffer就8k,缓冲区满了发、超时也发,send相当于强制超时。
@整数不能encode,需要先转成字符串。
@8-4中问题,直接看截图就行,主要是调试一下错误。
同样的代码在unix和windows里面不一样,问题原因:不应该直接判断文件长度(字符数),而应该先encode再判断多少byte。
@socket判断信息长度版
- client端
import socket
client=socket.socket()
client.connect(('localhost',9999))
while True:
cmd=input('>>:').strip()
if len(cmd)==0:continue
client.send(cmd.encode('utf-8'))#必须是byte类型
cmd_res_size=client.recv(1024)
print("命令结果大小:",cmd_res_size)
client.send('准备好接受,可以发了'.encode('utf-8'))
received_size=0
received_data=b''
while received_size<int(cmd_res_size.decode()):
data=client.recv(1024)
received_size+=len(data)#每次收到的有可能小于1024,用len判断
received_data+=data
else:
print("cmd res receive done...",received_size)
print(received_data.decode())
client.close()
ssh端
import socket,os
server=socket.socket()#实例化,默认不填参数
server.bind(('localhost',9999))
server.listen()
while True:
conn,addr=server.accept()#conn是新的套接字对象,用来接收和发送数据。addr是连接客户端的地址。接收TCP 客户的连接(阻塞式)等待连接的到来
print('new conn:',addr)
while True:
print('等待新指令')
data=conn.recv(1024)
if not data:
print('客户端已断开')
break
print('执行指令:',data)
cmd_res=os.popen(data.decode()).read()#接收了字符串,执行结果也是
print('before send',len(cmd_res))
if len(cmd_res)==0:
cmd_res='none is output'#字符串前面加b就不能encode了
conn.send(str(len(cmd_res.encode())).encode('utf-8'))
client_ack = conn.recv(1024)#等客户端回复,防止粘包
conn.send(cmd_res.encode('utf-8'))#发送数据不可为空
print('send done')
server.close()
@男生着装:优衣库、zara、HM、tiger鞋;
@socket 粘包,两块数据一起发,如两次send,系统会从缓冲区将两者并成一条发出去。
sleep(0.25)还是有可能粘住
@8-7-4-30’’
python-day8socket、粘包、并发、多用户ftp的更多相关文章
- Python之粘包
Python之粘包 让我们基于tcp先制作一个远程执行命令的程序(1:执行错误命令 2:执行ls 3:执行ifconfig) 注意注意注意: res=subprocess.Popen(cmd.deco ...
- Python进阶----粘包,解决粘包(旗舰版)
Python进阶----粘包,解决粘包(旗舰版) 一丶粘包 只有TCP有粘包现象,UDP永远不会粘包 什么是粘包 存在于客户端接收数据时,不能一次性收取全部缓冲区中的数据.当下一次再有数据来时 ...
- python 网络编程粘包解决方案2 + ftp上传 + socketserver
一.struct 神奇的打包工具 struct 代码: import struct num = 156 #将int类型的数据打包成4个字节的数据 num_stru = struct.pack('i', ...
- 一小时学会用Python Socket 开发可并发的FTP服务器!!
socket是什么 什么是socket所谓socket通常也称作"套接字",用于描述IP地址和端口,是一个通信链的句柄.应用程序通常通过"套接字"向网络发出请求 ...
- Python socket 粘包
目录 1 TCP的三次握手四次挥手 0 1.1 三次握手 1 1.2 四次挥手 2 2 粘包现象 3 2.1 基于TCP制作远程执行命令操作(win服务端) 4 2.1 基于TCP制作远程执行命令操作 ...
- python 解决粘包问题
客户端发送hello,如果服务端 recv(1) ,那只能接收到 h 这一个字符,然后再recv(1) 一下,可以再接收一个 e , 因为客户端发送的结果长,所以只能把其他的先缓存下来,下次recv的 ...
- Python socket粘包解决
socket粘包: socket 交互send时,连续处理多个send时会出现粘包,soket会把两条send作为一条send强制发送,会粘在一起. send发送会根据recv定义的数值发送一个固定的 ...
- Python socket粘包问题(最终解决办法)
套接字: 就是将传输层以下的协议封装成子接口 对于应用程序来说只需调用套接字的接口,写出的程序自然是遵循tcp或udp协议的 实现第一个功能个:实现:通过客户端向服务端发送命令,调取windows下面 ...
- Python socket粘包问题(初级解决办法)
server端配置: import socket,subprocess,struct from socket import * server=socket(AF_INET,SOCK_STREAM) s ...
- python socket粘包及实例
1.在linux中经常出现粘包的出现(因为两个send近靠着,造成接受到的数据是在一起的.)解决方法: 在服务端两send的中间中再添加一个recv(),客户端添加一个send(),服务端收到信息确认 ...
随机推荐
- 新学了几个python模块,不是很鸡肋。
先说一个模块分类(基本上所有模块都是小写开头,虽然规范的写法是变量的命名规范,但是,都是这样写的) 1,C编写并镶嵌到python解释器中的内置模块 2,包好的一组模块的包 3.已经被编译好的共享库, ...
- mysql 生成时间序列数据 - 存储过程
由于时间自动转换为int值, 做一步转化,也可在调用时处理 use `test`; CREATE table test.test1 as SELECT state, id, `规格条码`, `色号条码 ...
- python中使用redis实战
from redis import StrictRedis rds = StrictRedis(host='127.0.0.1', port=6379, db=0, decode_responses= ...
- zabbix升级遇到连接不上数据库的问题
问题 迁移zabbix-server端时,原来是4.0版本,现在为4.2版本,遇到如下问题 解决办法 update dbversion set mandatory=;
- DNS缓存服务器与转发服务器
DNS缓存服务器与转发服务器 什么是缓存服务器(cache-only) 缓存服务器只需要根区域解析库文件,不包含任何其它区域解析库文件,这样的服务器就叫着缓存服务器.这样的服务器只有缓存搜寻结果的功能 ...
- OpenStack控制节点上搭建Q版keystone服务(step3)
keystone服务监听两个端口:5000和35357 一.安装和配置 1.安装keystone组件 yum install openstack-keystone httpd mod_wsgi -y ...
- JavaScript的定时器如何先触发一次再延时
var data3=0; (function count3(){ console.log("count3:",data3++); setTimeout(count3,1000); ...
- 数据分组分析—-groupby
数据分组分析—-groupby 代码功能: 对于综合表格data,基于title进行分组处理,并统计每一组的size,得到的是一个series序列,此序列可以放入索引中使用,index() impor ...
- TypeScript安装备忘:npm proxy设置
如果使用了代理网络,因为npm无法自动识别Internet代理,则需要手动设置npm代理才能下载包. 设置命令: npm config set proxy http://proxyhost:pr ...
- kafka 暂停消费
1.代码实现 kafkaListener 需要指定id,例如这里是:full-part-id. @KafkaListener(topics = "part-full-topic", ...