3

是否有 ruby​​ 方法来获取进程开始时间?shell中类似以下内容:

 $ ps -p $$ -o lstart
 STARTED
 Thu Oct 18 11:49:22 2012

我希望避免解析 ps 输出。另外,我知道如何在 linux 上解析 /proc/self/status 以获取信息,但我希望有一个更便携的解决方案。

更新: 一种可移植的方式正是我想要的。我使用 sys/proctable 并使用以下行来获得我想要的:

ProcTable.ps($$).starttime

谢谢,科恩。

更新: 我玩了一下,发现它不像我想象的那么便携。在 Darwin 上,返回一个 Time 对象。在 Linux 上,返回一个整数,该整数对应于自引导以来的 jiffies 数。不幸的是,您需要使用 sysconf 系统调用来获取 ms/jiffy 的数量。这个系统调用不能直接在 ruby​​ 上使用。我使用以下内容来获取 Linux 上的 proc 开始时间:

module LinuxCLib
  extend FFI::Library
  ffi_lib 'c'

  @@cg = FFI::ConstGenerator.new(nil, :required => true) do |gen|
    gen.include('unistd.h')
    gen.const(:_SC_CLK_TCK)
  end

  attach_function :sysconf, [:int], :long

  def self.hz
    self.sysconf(@@cg["_SC_CLK_TCK"].to_i)
  end
end

def self.get_proc_starttime
  proc_jiffies_since_boot_starttime = Sys::ProcTable.ps($$).starttime
  stat_lines = File.open("/proc/stat").readlines
  system_s_since_epoch_boottime = catch(:boottime) do
    stat_lines.each do |line|
      split_line = line.split
      throw :boottime, split_line[1].to_i if split_line[0] == "btime"
    end
    nil
  end
  proc_s_since_epoch_starttime = (
      proc_jiffies_since_boot_starttime/LinuxCLib::hz + system_s_since_epoch_boottime)
  Time.at(proc_s_since_epoch_starttime)
end
4

1 回答 1

2

有一个 gem 可以做到这一点:sys-proctable

它解析文件/proc

安装宝石

gem install sys-proctable

需要宝石

require 'sys/proctable'
include Sys

对于所有进程

ProcTable.ps{ |p|
    puts p.comm
    puts p.starttime
}

对于一个单一的过程(如你的例子)

p = ProcTable.ps($$)
puts p.inspect

如果您不想使用 gem,也许您可​​以从源代码/proc中提取他们如何解析文件的部分

编辑:

我误读了您确实知道如何解析/proc文件的部分。但也许宝石仍然对您有用,使其便于携带等。

于 2012-10-22T18:42:32.563 回答