twisted怎么做异步的tcp协议通讯

我用twisted主要时项目上需要一边进行发送命令给机器人,一边又需要不断去解析出来机器人实时上报的状态报文和服务端应答报文。就下面图示一样,使用twisted可以让下发命令和解析状态异步运行,互不影响。
客户端 机器人 desition命令 desition命令已经收到 主动上报状态right 主动上报状态right 主动上报状态right 主动上报状态right 断开连接 断开连接已经收到 客户端 机器人

怎么使用twisted

首先就是建立tcp连接,然后再实现协议报文的处理细节。协议的细节里用来构建命令发送和状态报文的解析。注意协议可以为tcp、http\https都可以。我这里例子用的是tcp

python 复制代码
#这里是构建tcp的连接使用,建立好连接,接下来才可以处理协议报文了。
from twisted.internet.protocol import ClientFactory
class ClientFactory(ClientFactory):
    """Tcp 连接模块,这里继承了twisted里的ClientFactory"""

    def startedConnecting(self, connector):
        print_with_timestamp('正在尝试连接...')

    def buildProtocol(self, addr):
        print_with_timestamp('已连接。')
        return ClientProtocol()

    def clientConnectionLost(self, connector, reason):
        print_with_timestamp('连接丢失。原因:', reason)

    def clientConnectionFailed(self, connector, reason):
        print_with_timestamp('连接失败。原因:', reason)

tcp连接构建完成后,我们处理协议报文的问题。

python 复制代码
from twisted.protocols.basic import LineReceiver
class ClientProtocol(LineReceiver):
	#这里继承了LineReceiver
	delimiter = b'\x5F\x5F\x65\x6E\x64\x5F\x5F'
	'''这个步骤对于tcp报文非常重要,tcp有帧尾代表一帧报文的结束符号。一个60字节的报文,真正传输时,tcp协议会一次性传输1024个字节以节省传输耗时,所以需要我们主动进行断开报文。delimiter就是这样用的。'''
	def __init__(self):
		reactor.callInThread(self.user_input)
		#开启的一个线程,专门用来发送命令,使得发送和接受互不影响。
	def lineReceived(self, line):
		print(line)
		这里时根据delimiter断包(防止粘包)后,一帧帧的tcp报文。
	def send(self,frame):
		'''这里用了发送tcp报文,frame需要你根据自己的情况构建报文结构,发送为16进制字节流,一般包含帧头、帧尾、帧长度、命令字节、数据字节组成一帧'''
		if self.transport:
			self.transport.write(frame)
			
	def user_input(self):
		'''这里接受实时用户输入的命令,并发送给机器'''
		    command_key = input("请输入要发送的命令关键字(输入'exit'退出): ").strip().upper()
            if command_key == 'EXIT':
                print_with_timestamp("正在退出...")
                self.transport.loseConnection()
                break

再写一个main函数启动运行即可

python 复制代码
from twisted.internet import reactor
from twisted.internet.endpoints import TCP4ClientEndpoint
def main():
    client_input = ClientFactory()
    sender_endpoint = TCP4ClientEndpoint(reactor, HOST, PORT)
    sender_endpoint.connect(client_input)
    reactor.run()
相关推荐
悟空胆好小1 小时前
分音塔科技(BABEL Technology) 的公司背景、股权构成、产品类型及技术能力的全方位解读
网络·人工智能·科技·嵌入式硬件
DoraBigHead1 小时前
《电磁波的浪漫,铜线上的灵魂》——计算机网络·物理层全解版
网络协议
ssswywywht2 小时前
OSPF实验
网络
FCM662 小时前
HCIA第一次实验报告:静态路由综合实验
网络·tcp/ip·信息与通信
apihz2 小时前
VM虚拟机全版本网盘+免费本地网络穿透端口映射实时同步动态家庭IP教程
android·服务器·开发语言·网络·数据库·网络协议·tcp/ip
dog2503 小时前
TCP 传输时 sk_buff 的 clone 和 unclone
网络·网络协议·tcp/ip
学习溢出4 小时前
【网络安全】理解安全事件的“三分法”流程:应对警报的第一道防线
网络·安全·web安全·网络安全·ids
智慧化智能化数字化方案5 小时前
华为IPD(集成产品开发)流程是其研发管理的核心体系
网络·华为ipd流程·ipd流程体系·ipd产品研发
kfepiza5 小时前
Linux的NetworkManager的nmcli配置网桥(bridge) 笔记250712
linux·运维·网络·笔记·tcp/ip·ip·tcp
cui_win6 小时前
【网络】Linux 内核优化实战 - net.netfilter.nf_conntrack_buckets
linux·网络·.net