zoukankan      html  css  js  c++  java
  • go 获得进程启动时间的两种方法

    自己在看别人代码的时候发现了两种不同的获得linux进程启动时间的方法,现在记录下来,方便以后查看。

    方法一:根据进行的pid,获得进程相关的文件夹,/proc/pid。将这个文件夹被修改的时间作为进程的启动时间。这样获取的进程启动时间不一定是准确的,但是相比方法二,花费的时间少。

    var stat os.FileInfo
    if stat, err = os.Lstat(fmt.Sprintf("/proc/%v", pid)); err != nil {
          return nil
    }
    proc.mtime = stat.ModTime().Unix()

    方法二:根据进程相关的文件/proc/pid/stat中的内容获得进程启动时距离系统启动时的时间间隔,根据间隔计算出进程的启动时间。这种方法获得的时间更准确,但是性能可能比方法一差。

    var (
        Uptime int64 // 系统启动时间戳
        scClkTck = int64(C.sysconf(C._SC_CLK_TCK))
    )

    func init() {
        sys := syscall.Sysinfo_t{}
        syscall.Sysinfo(&sys)
        Uptime = time.Now().Unix() - sys.Uptime
    }

    func ProcessStartTime(pid int) (ts time.Time) {
        buf, err := ioutil.ReadFile(fmt.Sprintf("/proc/%v/stat", pid))
        if err != nil {
            return time.Unix(0, 0)
        }
        if fields := strings.Fields(string(buf)); len(fields) > 22 {
            start, err := strconv.ParseInt(fields[21], 10, 0)
            if err == nil {
                if scClkTck > 0 {
                    return time.Unix(Uptime+(start/scClkTck), 0)
                }
                return time.Unix(Uptime+(start/100), 0)
            }
        }
        return time.Unix(0, 0)
    }

  • 相关阅读:
    设计模式-观察者模式
    ps一寸照的编辑
    ps剪切蒙版的使用
    ps扣头发
    mysql索引优化
    ES6 $ ES5
    sping-mybatis集成
    多线程--volatile
    eclipse.exe打开是报错
    Spring Aop 详解二
  • 原文地址:https://www.cnblogs.com/snowDream-shineDream/p/9294545.html
Copyright © 2011-2022 走看看