zoukankan      html  css  js  c++  java
  • ZT acct 中文man页面(1)

    acct 中文man页面(1)

    2011-08-18 13:57 佚名 博客转载 我要评论(0) 字号:T | T
    一键收藏,随时查看,分享好友!

    如果在内核编译时开启了进程记账选项(CONFIG_BSD_PROCESS_ACCT),则可以通过调用acct(2) 来开始进程记账。

    AD:2013云计算架构师峰会超低价抢票中

    名字

    acct - 进程记账文件

    概要

    #include <sys/acct.h>

    描述

    如果在内核编译时开启了进程记账选项(CONFIG_BSD_PROCESS_ACCT),则可以通过调用acct(2) 来开始进程记账。如:

    acct("/var/log/pacct");

    在进程记账开启之后,每当系统内有进程终止内核将写一个记录到记账文件。这个记录包含已经终止进程的信息,它定义在头文件 <sys/acct.h>

    #define ACCT_COMM 16
    
    typedef u_int16_t comp_t;
    
    struct acct {
    char ac_flag; /* 记账标记 */
    u_int16_t ac_uid; /* 记账用户 ID */
    u_int16_t ac_gid; /* 记账组 ID */
    u_int16_t ac_tty; /* 控制终端 */
    u_int32_t ac_btime; /* 进程创建时间
    (从开机起的秒数) */
    comp_t ac_utime; /* 用户 CPU 时间 */
    comp_t ac_stime; /* 系统 CPU 时间 */
    comp_t ac_etime; /* 流失的时间 */
    comp_t ac_mem; /* 平均内存用量 (kB) */
    comp_t ac_io; /* Characters transferred (未使用) */
    comp_t ac_rw; /* 读写的块 (未使用) */
    comp_t ac_minflt; /* Minor page faults */
    comp_t ac_majflt; /* Major page faults */
    comp_t ac_swaps; /* Number of swaps (unused) */
    u_int32_t ac_exitcode; /* 进程终止状态
    (参看 wait(2)) */
    char ac_comm[ACCT_COMM+1];
    /* 命令名 (执行文件名;以0结尾) */
    char ac_pad[X]; /* 填充字节 */
    };
    
    enum { /* 在 ac_flag 域可以设置的位 */
    AFORK = 0x01, /* 调用 fork 之后,但还没有调用 exec */
    ASU = 0x02, /* 使用超级用户权限 */
    ACORE = 0x08, /* 核心转储 */
    AXSIG = 0x10 /* 由信号杀死 */
    };
    

    这里的 comp_t 数据类型是一个浮点值,是由以 8 为底的 3 位指数和 13 位尾数构成。一个这个类型的值 c 可以通过下面的公式转换为一个(长)整型:

        v = (c & 0x1fff) << (((c >> 13) & 0x7) * 3);
    

    ac_utimeac_stimeac_etime 的时间测量单位是时钟嘀嗒,把这个值除以 sysconf(_SC_CLK_TCK) 转换为秒数。

    记账文件格式版本 3

    从内核版本 2.6.8 开始,一个记账文件的改善版本可以在编译内核时指定 CONFIG_BSD_PROCESS_ACCT_V3 来启用,当设置这个选项之后,记账文件里包含额外的域,并且 c_uidac_gid 域的宽度从 16 位增加到 32 位(在 2.4 内核之后 UID 和 GID 宽度增加了)。这个新的记录结构如下:

    struct acct_v3 {
    char ac_flag; /* Flags */
    char ac_version; /* 总是设置为 ACCT_VERSION (3) */
    u_int16_t ac_tty; /* 控制终端 */
    u_int32_t ac_exitcode; /* 进程终止状态 */
    u_int32_t ac_uid; /* 真实用户 ID */
    u_int32_t ac_gid; /* 真实组 ID */
    u_int32_t ac_pid; /* 进程 ID */
    u_int32_t ac_ppid; /* 父进程 ID */
    u_int32_t ac_btime; /* 进程创建时间 */
    float ac_etime; /* 流失的埋单 */
    comp_t ac_utime; /* 用户 CPU 时间 */
    comp_t ac_stime; /* 系统时间 */
    comp_t ac_mem; /* 平均内存使用量 (kB) */
    comp_t ac_io; /* 传输的字符数量 (未使用) */
    comp_t ac_rw; /* 读写的块数
    (未使用) */
    comp_t ac_minflt; /* 次页异常 */
    comp_t ac_majflt; /* 主页异常 */
    comp_t ac_swaps; /* 交换的次数 (未使用) */
    char ac_comm[ACCT_COMM]; /* 命令名 */
    };
    
    

    版本

    acct_v3 结构体在 glibc 2.6 之后定义。

    遵循于

    进程记账最初出现在 BSD,现在则在大多数系统存在。它是一个没有标准化的特性,并且在系统之间存在许多细节的不同。

    注意

    记账文件里记录以进程终止的时间顺序排列。

    包括 2.6.9 在内或之后的内核,当使用 NPTL 线程库时,当一个线程被创建时会添加一个分隔记账记录;当整个进程的最后一个线程终止时,从 2.6.10 一个单独记账记录会写入。

    proc/sys/kernel/acct 文件在 proc(5) 里描述,它定义当磁盘空间不足时如何控制进程记账行为。

    参看

    lastcomm(1), acct(2), accton(8), sa(8)

     

    内容导航
     第 1 页:中文man  第 2 页:英文man
  • 相关阅读:
    使用xca生成SSL证书
    在 Apache error_log 中看到多个信息,提示 RSA server certificate CommonName (CN) 与服务器名不匹配(转)
    SSL/TLS 高强度加密: 常见问题解答
    JAVA 集合操作总结
    VUE 微信开发
    实战 ant design pro 中的坑
    Spring boot 配置 mybatis xml和动态SQL 分页配置
    VUE打包上线优化
    VUE中如何优雅的动态绑定长按事件
    用C自撸apache简易模块,搭建图片处理服务器。
  • 原文地址:https://www.cnblogs.com/jeanschen/p/3372361.html
Copyright © 2011-2022 走看看