时间:2021-05-22
实现一个简单的常驻任务是容易的,写一个while True就可以了,但是同时要能接收外界传来的参数,就稍微有点复杂.
我第一个想到的是网络编程中的server/client模式
server作为常驻进程,可以接受client传来的各种参数进行处理
服务端:server.py
import sockets = socket.socket(socket.AF_INET, socket.SOCK_STREAM)s.bind(('127.0.0.1', 10001))s.listen(5)def do_some(): passdef do_other(): passdef tcplink(sock, addr): print('Accept new connection from %s:%s...' % addr) sock.send(b'Welcome!') while True: data = sock.recv(1024) time.sleep(1) if not data or data.decode('utf-8') == 'exit': break data_str = data.decode('utf-8') data_list = data_str.split(',') if len(data_list) == 3: do_some() else: do_other() sock.send(('processing, %s!' % s3).encode('utf-8')) sock.close()if __name__ == '__main__': while True: # 接受一个新连接: data, addr = s.accept() # 创建新线程来处理TCP连接: t = threading.Thread(target=tcplink, args=(data, addr)) t.start()服务端实现完了,下面我们来实现客户端client.py,客户端支持传入参数或从文件读取参数,来向客户端发送请求
import socketimport sysif __name__ == '__main__': param = sys.argv[1] c_list = [] if param.endswith('txt'): with open(param, 'r') as file: for line in file.readlines(): c_list.append(line.strip().encode('utf8')) else: c = param.encode('utf8') c_list.append(c) s = socket.socket(socket.AF_INET, socket.SOCK_STREAM) s.connect(('127.0.0.1', 10001)) print(s.recv(1024).decode('utf-8')) for data in c_list: s.send(data) print(s.recv(1024).decode('utf-8')) s.send(b'exit') s.close()这样通过两个脚本,一个实现了常驻进程,一个实现了传入参数,就可以不断接受外界请求
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
1.定时任务实现方式定时任务实现方式:Java自带的java.util.Timer类,这个类允许你调度一个java.util.TimerTask任务。使用这种方
1.定时任务实现方式定时任务实现方式:Java自带的java.util.Timer类,这个类允许你调度一个java.util.TimerTask任务。使用这种方
这篇文章主要介绍了python已协程方式处理任务实现过程,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下#从g
1、使用AsyncTask异步任务实现,调用publishProgress()方法刷新进度来实现(已优化)publicclassMyAsyncTaskexten
首先,Python完整的异常处理语法结构如下:try:#业务实现代码exceptException1ase:#异常处理块1...exceptException2