python 网络编程:socket和select实现伪并发

上节地址:Python网络编程:socket

先补充点内容:

一、send和sendall区别

send,sendall

ret = send(‘safagsgdsegsdgew‘) #send 发送完成后会有一个返回值,告知发送了多少,并不一定会把数据全部发送过去。

sendall:内部调用send,将数据全部发送完为止。

因此我们使用时最好使用sendall

二、粘包

粘包问题需要理解recv()的使用,我们定义接收值的时候会写recv(1024)表示一次接收1024字节,但是有时候接收的数据大于1024字节,这样socket默认变不发送了,等待下次接收其他命令时在将上次没有发送完的数据继续发送过去,这样就形成了粘包问题。对于粘包,可以在正式收发数据之前先判断下数据的大小,然后分片发送。下面是利用socket和subprocess实现的类似cmd的程序。

#!/usr/bin/env python
# _*_ coding:utf_8 _*_
import socket
ip_port=(‘127.0.0.1‘,9002)
s = socket.socket()
s.connect(ip_port)
while True:
    send_data = input(‘>>: ‘).strip()
    if len(send_data) == 0:continue
    if send_data == ‘exit‘:break
    s.send(bytes(send_data,encoding=‘utf-8‘))
    #解决粘包问题
    ready_tag = s.recv(1024)  #收取待发送字节的长度
    ready_tag=str(ready_tag,encoding=‘utf8‘)
    if ready_tag.startswith(‘Ready‘):  #数据包格式为Ready|9124
        msg_size=int(ready_tag.split(‘|‘)[-1])
    start_tag = ‘Start‘
    s.sendall(bytes(start_tag,encoding=‘utf8‘))  #发送消息,表示开始传输
    recv_size = 0
    #print(msg_size)
    recv_msg = b‘‘
    while recv_size < msg_size:
        recv_data = s.recv(1024)
        recv_msg+=recv_data
        recv_size+=len(recv_data)
    print(str(recv_msg,encoding=‘utf8‘))
    #收消息
    # recv_data=s.recv(1024)
    # print(str(recv_data,encoding=‘utf-8‘))

s.close()

socket_client

#!/use/bin/env python
#_*_ coding:utf_8 _*_
import socket
import subprocess
ip_addr=(‘127.0.0.1‘,9002)
s=socket.socket()   #创建对象
s.bind(ip_addr)     #绑定连接地址
s.listen(5)         #设置监听主机数
while True:
    conn,addr=s.accept()
    i = 0
    while True:
        print(i)
        try:
            recv_data = conn.recv(1024)
            print(‘------0‘)
            #print(str(recv_data,encoding=‘utf-8‘))
            if len(recv_data) == 0:break
            #执行系统命令
            p=subprocess.Popen(str(recv_data,encoding=‘utf-8‘),shell=True,stdout=subprocess.PIPE,stderr=subprocess.PIPE)#执行系统命令,windows平台命令的标准输出是gbk编码,需要转换
            res = p.stdout.read() #获取标准输出
            if len(res) == 0:   #执行错误命令,send_data为空
                send_data = str(p.stderr.read(),encoding=‘utf-8‘)
            else:
                send_data=str(res,encoding=‘gbk‘)
            send_data=bytes(send_data,encoding=‘utf-8‘)    #要发送的数据

            #判断粘包
            ready_tag=‘Ready|%s‘ %len(send_data)
            conn.send(bytes(ready_tag,encoding=‘utf8‘)) #发送数据长度
            feedback=conn.recv(1024)  #接收确认信息
            feedback=str(feedback,encoding=‘utf8‘)
            if feedback.startswith(‘Start‘):
                print(send_data)
                conn.sendall(send_data)  #发送命令的执行结果
            #conn.sendall(send_data)
            print(‘succeed‘)
            i+=1

        except Exception:
            break
    conn.close()

socket cmd

时间: 2024-07-29 21:05:02

python 网络编程:socket和select实现伪并发的相关文章

python网络编程——socket进阶篇(select/poll/epoll)

原 生socket客户端在与服务端建立连接时,即服务端调用accept方法时是阻塞的,同时服务端和客户端在收数据(调用recv)时也是阻塞的.原生 socket服务端在同一时刻只能处理一个客户端请求,即服务端不能同时与多个客户端进行通信,实现并发,导致服务端资源闲置(此时服务端只占据 I/O,CPU空闲). 现在的需求是:我们要让多个客户端连接至服务器端,而且服务器端需要处理来自多个客户端请求.很明显,原生socket实现不了这种需求,此时我们该采用什么方式来处理呢? 解决方法:采用I/O多路复

python网络编程socket (一)

提起网络编程,不同于web编程,它主要是C/S架构,也就是服务器.客户端结构的.对于初学者而言,最需要理解的不是网络的概念,而是python对于网络编程都提供了些什么模块和功能.不同于计算机发展的初级阶段,程序员走到今天,已经脱离了手工打造一切,要自己实现所有细节的年代.现在提倡的是不要重复造轮子,而是学习别人的轮子怎么用,只有那些有需求或能专研的人才去设计轮子甚至汽车,so,这是一个速成的年代. 因此,对于一个面向工作的python程序员,学习python的网络编程,其实学的就是那么几个模块,

Python网络编程中的select 和 poll I/O复用的简单使用

转载至http://www.cnblogs.com/coser/archive/2012/01/06/2315216.html 首先列一下,sellect.poll.epoll三者的区别 select select最早于1983年出现在4.2BSD中,它通过一个select()系统调用来监视多个文件描述符的数组,当select()返回后,该数组中就绪的文件描述符便会被内核修改标志位,使得进程可以获得这些文件描述符从而进行后续的读写操作. select目前几乎在所有的平台上支持,其良好跨平台支持也

Python网络编程—socket(一)

从今天开始python基础就介绍完毕了,下面我们将进阶到socket网络编程的介绍,那么socket是什么呢?我们带着这个问题开始今天的介绍: 一.socket初探 socket通常也称作"套接字",用于描述IP地址和端口,是一个通信链的句柄,应用程序通常通过"套接字"向网络发出请求或者应答网络请求. socket其实也是一种特殊的文件,一些socket函数就是对其进行的操作(读/写.打开.关闭) 那么socket对文件操作和file对文件操作有什么区别呢? fil

Python 网络编程——socket

一 客户端/服务器架构 客户端(Client)服务器(Server)架构,即C/S架构,包括 1.硬件C/S架构(打印机) 2.软件C/S架构(web服务) 理想/目标状态—— 最常用的软件服务器是 Web 服务器.一台机器里放一些网页或 Web 应用程序,然后启动 服务.这样的服务器的任务就是接受客户的请求,把网页发给客户(如用户计算机上的浏览器),然 后等待下一个客户请求.这些服务启动后的目标就是“永远运行下去”.虽然它们不可能实现这样的 目标,但只要没有关机或硬件出错等外力干扰,它们就能运

Python网络编程-Socket简单通信

学习python中使用python进行网络编程,编写简单的客户端和服务器端进行通信,大部分内容来源于网络教程,这里进行总结供以后查阅. 先介绍下TCP的三次握手: 1,简单的发送消息: 服务器端: import socket sk = socket.socket() ip_port = ("127.0.0.1", 8888) sk.bind(ip_port) sk.listen(5) print("正在进行等待接受数据...") conn, address = sk

Python 网络编程socket大全 用途---用于客户端和服务器端之间相互通讯

本章目录 一.什么是socket 二.为什么需要socket 三.socket的发展 四.python中的socket 五.基于TCP的socket 六.基于UDP的socket 六. 粘包问题详解 七.粘包的解决方案 八.socketserver实现并发通讯 **引入:为什么一定要先学习网络协议?** 之所以学习网络编程就是为了让我们的程序能够利用网络来传输数据,开发出C/S构架的应用程序 而网络的核心,就是协议,没有协议就没有互联网,我们要开发出C/S结构程序则必须遵循这些协议的标准! `就

Python网络编程—socket套接字编程(UDP)

套接字介绍 1.套接字 : 实现网络编程进行数据传输的一种技术手段 2.Python实现套接字编程:import socket 3.套接字分类 流式套接字(SOCK_STREAM): 以字节流方式传输数据,实现tcp网络传输方案.(面向连接--tcp协议--可靠的--流式套接字) 数据报套接字(SOCK_DGRAM):以数据报形式传输数据,实现udp网络传输方案.(无连接--udp协议--不可靠--数据报套接字) UDP套接字编程 服务端流程 1.创建数据报套接字 sockfd = socket

Python网络编程—socket套接字编程(TCP)

套接字介绍 1.套接字 : 实现网络编程进行数据传输的一种技术手段 2.Python实现套接字编程:import socket 3.套接字分类 流式套接字(SOCK_STREAM): 以字节流方式传输数据,实现tcp网络传输方案.(面向连接--tcp协议--可靠的--流式套接字) 数据报套接字(SOCK_DGRAM):以数据报形式传输数据,实现udp网络传输方案.(无连接--udp协议--不可靠--数据报套接字) tcp套接字 服务端流程 1.创建套接字 sockfd=socket.socket