1、Runtime
通过命令行调用py文件,是支持多线程运行的,不会限制启动线程的数量。另一方面,数据不经过java传输给python程序,只要告诉python程序去哪个数据库读取哪一段的数据以完成某种AI算法,数据由python程序自身去读取,避免无用的数据传输。并且结果直接由python返回,不再经过java,相关的参数,在调用前就已经通过java的Runtime传给python了。
String cmds = String.format("python D:\\syscall.py -f docker_percent -s 1568294220 -e 1568294230 -n openstack01 -mh %s -mp %s -mq %s -mu %s -mpd %s",
mq_host, mq_port,queue_no+"",mq_user,mq_pwd);
// 执行CMD命令
Process pcs = Runtime.getRuntime().exec(cmds);
pcs.waitFor();
在syscall.py文件中需要使用argparse进行参数解析,才能进行这种传参的方式。
import argparse
if __name__ == "__main__":
start = time.time()
parser = argparse.ArgumentParser()
parser.add_argument("-f", "--function", required=True, help="The function you want to call.")
parser.add_argument("-s", "--start", required