python脚本简化jar操作命令

简介: 本篇和大家分享的是使用python简化对jar包操作命令,封装成简短关键字或词,达到操作简便的目的。最近在回顾和构思shell脚本工具,后面一些文章应该会分享shell内容,希望大家继续关注。 获取磁盘中jar启动包 获取某个程序进程pid 自定义jar操作命令 获取磁盘中jar启动包 这一步.

本篇和大家分享的是使用python简化对jar包操作命令,封装成简短关键字或词,达到操作简便的目的。最近在回顾和构思shell脚本工具,后面一些文章应该会分享shell内容,希望大家继续关注。

  • 获取磁盘中jar启动包
  • 获取某个程序进程pid
  • 自定义jar操作命令

获取磁盘中jar启动包

这一步骤主要扫描指定磁盘中待启动的jar包,然后获取其路径,方便后面操作java命令:

#获取磁盘中jar启动包
def find_file_bypath(strDir):
    filelist = os.listdir(strDir)
    for file in filelist:
        if os.path.isdir(strDir + "/" + file):
            find_file_bypath(strDir + "/" + file)
        else:
            if(file.find(".jar") >= 0):
                fileInfo = MoFileInfo(file,strDir + "/" + file)
                all_list.append(fileInfo)

这个递归获取路径就不多说了,可以参考前一篇文章

获取某个程序进程pid

在linux中获取某个程序pid并打印出来通常的命令是:

ps -ef | grep 程序名字

在py工具中同样用到了grep命令,通过执行linux命令获取相对应的pid值:

#获取pid
def get_pid(name):
    child = subprocess.Popen(['pgrep', '-f', name], stdout=subprocess.PIPE, shell=False)
    response = child.communicate()[0]
    print(response)
    return response

这里直接取的第一个值,因为上面第一节已经能够定位到程序jar包的名字,所以获取pid很容易

自定义jar操作命令

自定义其实就是用我们随便定义的单词或关键字来代替jar包操作命令,这里我封装了有5种,分别如下:

  • nr:nohup java -jar {} 2>&1 &
  • r:java -jar {}
  • k:kill -9 {}
  • d:rm -rf {}
  • kd:kill -9 {}

{}代表的是pid和jar包全路径,相关代码:

#执行命令
def exec_file(index):
    try:
        if(index <= -1):
            pass
        else:
         fileInfo = all_list[int(index)]
         print("你选择的是:{}".format(fileInfo.path))
         strcmd = raw_input("请输入执行命令(nr:nohup启动java r:java启动 k:kill d:删除java包   kd:kill+删除jar包):\r\n")
         if(strcmd == "nr"):
            os.system("nohup java -jar {} 2>&1 & ".format(fileInfo.path))
         elif(strcmd == "r"):
            os.system("java -jar {}".format(fileInfo.path))
         elif(strcmd == "k"):
            pid = get_pid(fileInfo.name)
            print("pid:" + pid)
            strcmd_1 = "kill -9 {}".format(pid)
            exec_cmd(strcmd_1)
         elif(strcmd == "d"):
            strcmd_1 = "rm -rf {}".format(fileInfo.path)
            exec_cmd(strcmd_1)
         elif(strcmd == "kd"):
            pid = get_pid(fileInfo.name)
            strcmd_1 = "kill -9 {}".format(pid)
            exec_cmd(strcmd_1)

            strcmd_1 = "rm -rf {}".format(fileInfo.path)
            exec_cmd(strcmd_1)
         else:
            print("无任何操作")
    except:
        print("操作失败")

这里python操作linux命令用到的方式是os.system(command),这样已定保证了linux命令执行成功后才继续下一步的操作;下面是本次分享内容的全部代码:

#!/usr/bin/python
#coding=utf-8
import os
import subprocess
from subprocess import check_output

all_list = []

class MoFileInfo:
    def __init__(self,name,path):
        self.name = name
        self.path = path

#获取磁盘中jar启动包
def find_file_bypath(strDir):
    filelist = os.listdir(strDir)
    for file in filelist:
        if os.path.isdir(strDir + "/" + file):
            find_file_bypath(strDir + "/" + file)
        else:
            if(file.find(".jar") >= 0):
                fileInfo = MoFileInfo(file,strDir + "/" + file)
                all_list.append(fileInfo)

def show_list_file():
    for index,x in enumerate(all_list):
        print("{}. {}".format(index,x.name))

#获取pid
def get_pid(name):
    child = subprocess.Popen(['pgrep', '-f', name], stdout=subprocess.PIPE, shell=False)
    response = child.communicate()[0]
    print(response)
    return response

#执行命令
def exec_file(index):
    try:
        if(index <= -1):
            pass
        else:
         fileInfo = all_list[int(index)]
         print("你选择的是:{}".format(fileInfo.path))
         strcmd = raw_input("请输入执行命令(nr:nohup启动java r:java启动 k:kill d:删除java包   kd:kill+删除jar包):\r\n")
         if(strcmd == "nr"):
            os.system("nohup java -jar {} 2>&1 & ".format(fileInfo.path))
         elif(strcmd == "r"):
            os.system("java -jar {}".format(fileInfo.path))
         elif(strcmd == "k"):
            pid = get_pid(fileInfo.name)
            print("pid:" + pid)
            strcmd_1 = "kill -9 {}".format(pid)
            exec_cmd(strcmd_1)
         elif(strcmd == "d"):
            strcmd_1 = "rm -rf {}".format(fileInfo.path)
            exec_cmd(strcmd_1)
         elif(strcmd == "kd"):
            pid = get_pid(fileInfo.name)
            strcmd_1 = "kill -9 {}".format(pid)
            exec_cmd(strcmd_1)

            strcmd_1 = "rm -rf {}".format(fileInfo.path)
            exec_cmd(strcmd_1)
         else:
            print("无任何操作")
    except:
        print("操作失败")

def exec_cmd(strcmd):
    str = raw_input("是否执行命令(y/n):" + strcmd + "\r\n")
    if(str == "y"):
        os.system(strcmd)

strDir = raw_input("请输入jar所在磁盘路径(默认:/root/job):\r\n")
strDir = strDir if (len(strDir) > 0) else "/root/job"
#获取运行包
find_file_bypath(strDir)
#展示运行包
show_list_file()
#选择运行包
strIndex = raw_input("请选择要运行的编号:\r\n")
#执行命令
exec_file(strIndex)
目录
相关文章
|
4月前
|
JSON 算法 API
深度分析小红书城API接口,用Python脚本实现
小红书作为以UGC内容为核心的生活方式平台,其非官方API主要通过移动端抓包解析获得,涵盖内容推荐、搜索、笔记详情、用户信息和互动操作等功能。本文分析了其接口体系、认证机制及请求规范,并提供基于Python的调用框架,涉及签名生成、登录态管理与数据解析。需注意非官方接口存在稳定性与合规风险,使用时应遵守平台协议及法律法规。
|
4月前
|
JSON API 数据安全/隐私保护
【干货满满】分享微店API接口到手价,用python脚本实现
微店作为知名社交电商平台,其开放平台提供商品查询、订单管理等API接口。本文介绍如何通过微店API获取商品到手价(含优惠、券等),涵盖认证机制、Python实现及关键说明。
|
4月前
|
JSON API 数据安全/隐私保护
【干货满满】分享淘宝API接口到手价,用python脚本实现
淘宝开放平台通过API可获取商品到手价,结合商品详情与联盟接口实现优惠计算。需使用AppKey、AppSecret及会话密钥认证,调用taobao.tbk.item.info.get接口获取最终价格。代码示例展示签名生成与数据解析流程。
|
4月前
|
JSON API 数据格式
深度分析大麦网API接口,用Python脚本实现
大麦网为国内领先演出票务平台,提供演唱会、话剧、体育赛事等票务服务。本文基于抓包分析其非官方接口,并提供Python调用方案,涵盖演出列表查询、详情获取及城市列表获取。需注意非官方接口存在稳定性风险,使用时应遵守平台规则,控制请求频率,防范封禁与法律风险。适用于个人学习、演出信息监控等场景。
|
4月前
|
JSON API 开发者
深度分析阿里妈妈API接口,用Python脚本实现
阿里妈妈是阿里巴巴旗下营销平台,提供淘宝联盟、直通车等服务,支持推广位管理、商品查询等API功能。本文详解其API调用方法,重点实现商品推广信息(佣金、优惠券)获取,并提供Python实现方案。
|
4月前
|
JSON API 数据安全/隐私保护
深度分析虾皮城API接口,用Python脚本实现
虾皮开放平台提供丰富的API接口,支持商品管理、订单处理及促销信息查询等功能。本文详解API认证机制与调用方法,基于Python实现商品价格及到手价获取方案,适用于电商数据分析与运营。
|
4月前
|
JSON API 数据安全/隐私保护
【干货满满】分享拼多多API接口到手价,用python脚本实现
拼多多开放平台提供商品价格查询API,通过“pdd.ddk.goods.detail”接口可获取商品基础价、优惠券、拼团价等信息。结合client_id、client_secret及签名机制实现身份认证,支持推广位ID获取专属优惠。本文提供完整Python实现,涵盖签名生成、接口调用与价格解析逻辑,适用于比价工具、导购平台等场景。
|
4月前
|
API 数据安全/隐私保护 开发者
深度分析苏宁API接口,用Python脚本实现
深度分析苏宁API接口,用Python脚本实现
|
4月前
|
前端开发 Shell API
深度分析58同城API接口,用Python脚本实现
58同城为国内知名分类信息平台,涵盖房产、招聘、二手车等多领域。本文基于网页抓包与解析,分享其非官方接口的Python实现方案,分析核心接口特性与反爬应对策略,适用于数据学习与信息聚合。注意:非官方接口存在风险,使用需遵守平台规则。
|
4月前
|
JSON API 数据安全/隐私保护
【干货满满】分享京东API接口到手价,用python脚本实现
淘宝开放平台提供丰富API,通过商品详情接口与淘宝联盟接口,可获取含优惠券、满减后的商品到手价。本文介绍基于Python的实现方案,涵盖签名生成、接口调用、价格解析及错误处理,适用于比价工具、导购平台等场景。

热门文章

最新文章

推荐镜像

更多