通过进程PID查找Linux程序运行文件目录的指南

linux通过进程pid号查找程序运行文件目录

  • 执行步骤
  • 1. 通过ps命令查询正在运行程序的进程号
  • 2. 通过进程的状态目录查看运行目录
  • 关于/proc
  • /proc/{pid}目录下常见的文件介绍
  • cmdline
  • cwd
  • exe
  • fd
  • maps
  • stat
  • status
  • 有时候会遇到这样的情况,能看到程序的进程号,但不知道程序的目录在哪里?可以通过下面的文章了解一下方法。

    执行步骤

    1. 通过ps命令查询正在运行程序的进程号

    $ ps -aux|grep java
    root     22684     1  0 Feb23 ?        01:26:21 /data/app/jdk1.8.0_221/bin/java -jar pd-auth-server.jar
    

    2. 通过进程的状态目录查看运行目录

    $ cd /proc/22684
    # 可以看到该程序所在目录
    $ ll cwd
    lrwxrwxrwx 1 root root 0 Mar  3 14:29 cwd -> /data/app/ofpay
    
    # 可以看到调用的程序
    $ ll exe
    lrwxrwxrwx 1 root root 0 Feb 23 17:22 exe -> /data/app/jdk1.8.0_221/bin/java
    

    关于/proc

    Linux系统上的/proc目录是一种文件系统,即proc文件系统。与其它常见的文件系统不同的是,/proc是一种伪文件系统(也即虚拟文件系统),存储的是当前内核运行状态的一系列特殊文件,用户可以通过这些文件查看有关系统硬件及当前正在运行进程的信息,甚至可以通过更改其中某些文件来改变内核的运行状态。

    /proc/{pid}目录下常见的文件介绍

    cmdline

    启动当前进程的完整命令,但僵尸进程目录中的此文件不包含任何信息;可使用 more /proc/{pid}/cmdline 查看

    # 找到一个进程,进到该进程的目录
    $ cd /proc/22684
    # 查看cmdline,
    $ cat cmdline 
    /data/app/jdk1.8.0_221/bin/java-jarpd-auth-server.jar
    

    cwd

    指向当前进程运行目录的一个符号链接;

    $ cd /proc/22684
    $ ll cwd
    lrwxrwxrwx 1 root root 0 Mar  3 14:29 cwd -> /data/app/ofpay
    

    exe

    指向启动当前进程的可执行文件(完整路径)的符号链接,通过/proc/N/exe可以启动当前进程的一个拷贝;

    $ cd /proc/22684
    $ ll exe
    lrwxrwxrwx 1 root root 0 Feb 23 17:22 exe -> /data/app/jdk1.8.0_221/bin/java
    

    fd

    这是个目录,包含当前进程打开的每一个文件的文件描述符(file descriptor),这些文件描述符是指向实际文件的一个符号链接.

    $ cd /proc/22684/fd
    $ ll
    lr-x------ 1 root root 64 Feb 23 17:22 0 -> /dev/null
    l-wx------ 1 root root 64 Feb 23 17:22 1 -> /data/app/ofpay/logs/pd-auth-server.log
    l-wx------ 1 root root 64 Feb 23 17:22 10 -> /data/projects/logs/pd-auth-server/service.log
    lrwx------ 1 root root 64 Mar  4 06:29 100 -> socket:[135031013]
    lrwx------ 1 root root 64 Feb 29 12:26 101 -> socket:[135026985]
    lrwx------ 1 root root 64 Feb 25 18:18 102 -> socket:[135027089]
    lrwx------ 1 root root 64 Feb 23 17:29 103 -> socket:[134948665]
    l-wx------ 1 root root 64 Feb 29 00:43 105 -> /data/projects/logs/pd-auth-server/root.log
    lr-x------ 1 root root 64 Feb 29 16:24 106 -> /tmp/+~JF7078255511986524517.tmp
    lr-x------ 1 root root 64 Feb 29 16:25 107 -> /tmp/+~JF2639114678156368692.tmp
    lr-x------ 1 root root 64 Feb 29 16:25 109 -> /tmp/+~JF4658784623086533328.tmp
    l-wx------ 1 root root 64 Feb 23 17:22 11 -> /data/projects/logs/pd-auth-server/controller.log
    l-wx------ 1 root root 64 Feb 23 17:22 12 -> /data/projects/logs/pd-auth-server/dao.log
    l-wx------ 1 root root 64 Feb 23 17:22 13 -> /data/projects/logs/pd-auth-server/dao.log
    l-wx------ 1 root root 64 Feb 23 17:22 14 -> /data/projects/logs/pd-auth-server/dao.log
    l-wx------ 1 root root 64 Feb 23 17:22 15 -> /data/projects/logs/pd-auth-server/exception.log
    lr-x------ 1 root root 64 Feb 23 17:23 16 -> /data/app/jdk1.8.0_221/jre/lib/charsets.jar
    lr-x------ 1 root root 64 Feb 23 17:22 17 -> /data/app/jdk1.8.0_221/jre/lib/jsse.jar
    ......
    

    maps

    当前进程关联到的每个可执行文件和库文件在内存中的映射区域及其访问权限所组成的列表;

    $ cd /proc/22684/
    $ cat maps
    7fe628000000-7fe628001000 r--s 0000e000 fd:01 1057311                    /data/app/jdk1.8.0_221/jre/lib/ext/sunec.jar
    7fe628001000-7fe628005000 r--s 0003b000 fd:01 1057312                    /data/app/jdk1.8.0_221/jre/lib/ext/sunpkcs11.jar
    7fe628005000-7fe628020000 r--s 001d4000 fd:01 1057310                    /data/app/jdk1.8.0_221/jre/lib/ext/nashorn.jar
    7fe628020000-7fe628025000 r--s 002f9000 fd:01 1057418                    /data/app/jdk1.8.0_221/jre/lib/charsets.jar
    7fe628025000-7fe628038000 r--s 00345000 fd:01 1057600                    /data/app/jdk1.8.0_221/jre/lib/resources.jar
    7fe628038000-7fe628054000 r--s 00393000 fd:01 1057313                    /data/app/jdk1.8.0_221/jre/lib/ext/cldrdata.jar
    7fe628054000-7fe628357000 rw-p 00000000 00:00 0 
    7fe628357000-7fe628531000 r--s 03d88000 fd:01 1057338                    /data/app/jdk1.8.0_221/jre/lib/rt.jar
    ......
    

    stat

    当前进程的状态信息,包含一系统格式化后的数据列,可读性差,通常由ps命令使用;

    $ more stat
    22684 (java) S 1 22683 21860 0 -1 1077944320 942701 0 18 0 225359 293548 0 0 20 0 109 0 892468877 4916166656 175959 18446744073709551615 4194304 419628
    4 140723913966976 140723913949632 140626560466759 0 0 3 16800972 18446744073709551615 0 0 17 0 0 0 0 0 0 6294936 6295608 38010880 140723913967629 14072
    3913967685 140723913967685 140723913969624 0
    

    status

    与stat所提供信息类似,但可读性较好,如下所示,每行表示一个属性信息;

    cat status 
    Name:   java
    Umask:  0022
    State:  S (sleeping)
    Tgid:   22684
    Ngid:   0
    Pid:    22684
    PPid:   1
    TracerPid:      0
    Uid:    0       0       0       0
    Gid:    0       0       0       0
    FDSize: 256
    Groups: 0 
    VmPeak:  4800948 kB
    VmSize:  4800944 kB
    VmLck:         0 kB
    VmPin:         0 kB
    VmHWM:    998508 kB
    VmRSS:    703836 kB
    ......
    

    作者:thomore

    物联沃分享整理
    物联沃-IOTWORD物联网 » 通过进程PID查找Linux程序运行文件目录的指南

    发表回复