AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / unix / 问题 / 457107
Accepted
Graham Nicholls
Graham Nicholls
Asked: 2018-07-19 15:06:58 +0800 CST2018-07-19 15:06:58 +0800 CST 2018-07-19 15:06:58 +0800 CST

将 bash 历史记录发送到系统日志

  • 772

Bash 4.N 版显然能够将命令历史记录写入系统日志,但我找不到有关如何配置它的信息。

我已经阅读了几页提供使用PROMPT_COMMAND, 和陷阱的 hack,并且我知道有一个可用的补丁,但这应该是不必要的,因为它现在是内置的。

我知道我可以auditd用来捕获命令,但我想使用 bash/syslog 组合。

bash command-history
  • 1 1 个回答
  • 7616 Views

1 个回答

  • Voted
  1. Best Answer
    slm
    2018-07-19T15:32:58+08:002018-07-19T15:32:58+08:00

    这种方法似乎是您正在寻找的。本文讨论了它,标题为:改进 Bash 取证功能。

    摘抄:

    在与他讨论这个话题时,我意识到有一些方法可以微调命令历史以改进取证调查。2009 年,我还写了一篇关于 Bash 的博客文章,其中给出了一些将 Bash 命令历史发送到远程 Syslog 服务器的想法。我检查了我的网络日志,这篇博文在过去 30 天内仍然很受欢迎,访问量超过 1000 次!请注意,我的博文已过时:从 4.1 版开始,Bash 原生支持 Syslog,但在大多数发行版中,它未启用。要使用此功能,您需要重新编译您的 shell。

    我发现这不是很方便,但好处是用户不能禁用它(除非他将他的 shell 切换到另一个 shell 或另一个 Bash 二进制文件)。您只需在 config-top.h 中定义“SYSLOG_HISTORY”:

    $ vi config-top.h
    #define SYSLOG_HISTORY
    #if defined (SYSLOG_HISTORY)
    #  define SYSLOG_FACILITY LOG_USER
    #  define SYSLOG_LEVEL LOG_INFO
    #endif
    
    ./configure
    make install
    

    因此,尽管该功能在 Bash 4.1+ 中可用,但在大多数流行的发行版中,它可能默认情况下并未与 Bash 一起编译。

    我还没有找到查看给定 Bash 编译时使用哪些选项的方法,因此要回答这个问题,您可能需要查看.spec构建 Bash RPM 时使用的上游文件,例如,在 Redhat 发行版上,同样的方法也可以用于基于 Debian 的发行版。

    作为确认,我查看了.specCentOS 7.2.1511 中包含的 Bash 的 Bash 文件,但它没有启用此功能:

    $ grep configure bash.spec
    %configure --with-bash-malloc=no --with-afs
    - Use the configure macro instead of calling ./configure directly
    

    滚动您自己的 RPM

    以下是我使用上述详细说明的要点构建自己的 Bash 的步骤。

    下载安装源码

    首先,我下载了可用于 CentOS 7.x 的 Bash源 RPM (SRPM) 。下载后,我将其安装到我的rpmbuild目录中:

    $ rpmdev-setuptree
    $ rpm -ivh bash-4.2.46-20.el7_2.src.rpm
    
    修补

    这会将文件解压缩到rpmbuild/SPEC&rpmbuild/SOURCES中。现在我们将tar.gz使用以下步骤复制解压后的 Bash 文件的内容:

    $ cd rpmbuild/SOURCES
    $ tar zxf bash-4.2.tar.gz
    $ cp -prf bash-4.2 bash-4.2-orig
    $ cd bash-4.2
    

    编辑rpmbuild/SOURCES/bash-4.2/config-top.h并使其看起来像这样:

    /* Define if you want each line saved to the history list in bashhist.c:
       bash_add_history() to be sent to syslog(). */
    #define SYSLOG_HISTORY
    #if defined (SYSLOG_HISTORY)
    #  define SYSLOG_FACILITY LOG_LOCAL1
    #  define SYSLOG_LEVEL LOG_DEBUG
    #endif
    

    编辑rpmbuild/SOURCES/bash-4.2/bashhist.c并使bash_syslog_history函数看起来像这样:

    void
    bash_syslog_history (line)
         const char *line;
    {
      char trunc[SYSLOG_MAXLEN];
    
      if (strlen(line) < SYSLOG_MAXLEN)
        syslog (SYSLOG_FACILITY|SYSLOG_LEVEL, "HISTORY: PID=%d UID=%d USER=%s CMD=%s", getpid(), current_user.uid, current_user.user_name, line);
      else
        {
          strncpy (trunc, line, SYSLOG_MAXLEN);
          trunc[SYSLOG_MAXLEN - 1] = '\0';
          syslog (SYSLOG_FACILITY|SYSLOG_LEVEL, "HISTORY: PID=%d UID=%d USER=%s CMD(TRUNCATED)=%s", getpid(), current_user.uid, current_user.user_name, trunc);
        }
    }
    

    现在生成一个.patch文件,其中包含我们对这两个文件的更改:

    $ cd $HOME/rpmbuild/SOURCES
    $ diff -Npru bash-4.2-orig bash-4.2 > bash_history_rsyslog.patch
    

    将这些行添加到$HOME/rpmbuid/SPEC/bash.spec. 将这些行放入 SPEC 文件中的适当位置:

    # history syslog
    Patch144: bash_history_rsyslog.patch
    ...
    ...
    %patch144 -p1 -b .history_rsyslog
    
    建造

    现在构建它:

    $ cd $HOME/rpmbuild/SPEC
    $ rpmbuild -ba bash.spec
    

    此构建的尾部将如下所示:

    ...
    Processing files: bash-debuginfo-4.2.46-20.el7.centos.x86_64
    Provides: bash-debuginfo = 4.2.46-20.el7.centos bash-debuginfo(x86-64) = 4.2.46-20.el7.centos
    Requires(rpmlib): rpmlib(FileDigests) <= 4.6.0-1 rpmlib(PayloadFilesHavePrefix) <= 4.0-1 rpmlib(CompressedFileNames) <= 3.0.4-1
    Checking for unpackaged file(s): /usr/lib/rpm/check-files /home/vagrant/rpmbuild/BUILDROOT/bash-4.2.46-20.el7.centos.x86_64
    Wrote: /home/vagrant/rpmbuild/RPMS/x86_64/bash-4.2.46-20.el7.centos.x86_64.rpm
    Wrote: /home/vagrant/rpmbuild/RPMS/x86_64/bash-doc-4.2.46-20.el7.centos.x86_64.rpm
    Wrote: /home/vagrant/rpmbuild/RPMS/x86_64/bash-debuginfo-4.2.46-20.el7.centos.x86_64.rpm
    Executing(%clean): /bin/sh -e /var/tmp/rpm-tmp.nGworU
    + umask 022
    + cd /home/vagrant/rpmbuild/BUILD
    + cd bash-4.2
    + rm -rf /home/vagrant/rpmbuild/BUILDROOT/bash-4.2.46-20.el7.centos.x86_64
    + exit 0
    
    安装

    完成后,我们可以安装生成的 RPM:

    $ sudo rpm -ivh --force $HOME/rpmbuild/RPMS/x86_64/bash-4.2.46-20.el7.centos.x86_64.rpm
    Preparing...                          ################################# [100%]
    Updating / installing...
       1:bash-4.2.46-20.el7.centos        ################################# [100%]
    
    配置 rsyslog

    现在修改 rsyslog 的/etc/rsyslog.conf配置:

    $ sudo vim /etc/rsyslog.conf
    ...
    ...
    $ModLoad imudp
    $UDP服务器运行 514

    $ModLoad imtcp
    $输入TCP服务器运行514
    
    ...
    ...
    
    #### 全球指令####
    $template IpTemplate,"/var/log/bash-log/%FROMHOST-IP%.log"
    *.* ?IpTemplate
    &~
    
    ...
    ...
    

    然后重启Rsyslog:

    $ sudo systemctl restart rsyslog
    
    测试并确认

    现在以 root 身份运行一个新的 Bash 实例,并运行几个命令:

    $ sudo -Es
    $ ls
    

    并尾随日志文件,/var/log/bash-log/127.0.0.1.log:

    $ tail /var/log/bash-log/127.0.0.1.log
    2018-07-19T23:23:37.568131-04:00 centos7 bash: HISTORY: PID=12511 UID=1000 USER=vagrant CMD=sudo -Es
    2018-07-19T23:23:37.573825-04:00 centos7 sudo: vagrant : TTY=pts/0 ; PWD=/home/vagrant/rpmbuild/SOURCES ; USER=root ; COMMAND=/bin/bash
    2018-07-19T23:23:37.589258-04:00 centos7 systemd-logind: Got message type=signal sender=org.freedesktop.DBus destination=n/a object=/org/freedesktop/DBus interface=org.freedesktop.DBus member=NameOwnerChanged cookie=4454 reply_cookie=0 error=n/a
    2018-07-19T23:23:37.590633-04:00 centos7 dbus[588]: [system] Activating service name='org.freedesktop.problems' (using servicehelper)
    2018-07-19T23:23:37.590806-04:00 centos7 dbus-daemon: dbus[588]: [system] Activating service name='org.freedesktop.problems' (using servicehelper)
    2018-07-19T23:23:37.592160-04:00 centos7 dbus[588]: [system] Activated service 'org.freedesktop.problems' failed: Failed to execute program /lib64/dbus-1/dbus-daemon-launch-helper: Success
    2018-07-19T23:23:37.592311-04:00 centos7 dbus-daemon: dbus[588]: [system] Activated service 'org.freedesktop.problems' failed: Failed to execute program /lib64/dbus-1/dbus-daemon-launch-helper: Success
    2018-07-19T23:23:37.602174-04:00 centos7 systemd-logind: Got message type=signal sender=org.freedesktop.DBus destination=n/a object=/org/freedesktop/DBus interface=org.freedesktop.DBus member=NameOwnerChanged cookie=4455 reply_cookie=0 error=n/a
    2018-07-19T23:23:38.520300-04:00 centos7 bash: HISTORY: PID=12585 UID=0 USER=root CMD=ls
    2018-07-19T23:23:49.210406-04:00 centos7 bash: HISTORY: PID=12585 UID=0 USER=root CMD=tail /var/log/bash-log/127.0.0.1.log
    

    注意到CMD=...此日志中的行吗?这些是我们刚刚运行的命令,一个ls& tail。

    预建?

    为了帮助人们解决这个问题,我冒昧地构建了 Bash RPM,并在 Copr 中进行了修改。

    • https://copr.fedorainfracloud.org/coprs/slmingol/bash/
    • 10

相关问题

  • 通过命令的标准输出以编程方式导出环境变量[重复]

  • 从文本文件传递变量的奇怪问题

  • 虽然行读取保持转义空间?

  • `tee` 和 `bash` 进程替换顺序

  • 运行一个非常慢的脚本直到它成功

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    如何将 GPG 私钥和公钥导出到文件

    • 4 个回答
  • Marko Smith

    ssh 无法协商:“找不到匹配的密码”,正在拒绝 cbc

    • 4 个回答
  • Marko Smith

    我们如何运行存储在变量中的命令?

    • 5 个回答
  • Marko Smith

    如何配置 systemd-resolved 和 systemd-networkd 以使用本地 DNS 服务器来解析本地域和远程 DNS 服务器来解析远程域?

    • 3 个回答
  • Marko Smith

    如何卸载内核模块“nvidia-drm”?

    • 13 个回答
  • Marko Smith

    dist-upgrade 后 Kali Linux 中的 apt-get update 错误 [重复]

    • 2 个回答
  • Marko Smith

    如何从 systemctl 服务日志中查看最新的 x 行

    • 5 个回答
  • Marko Smith

    Nano - 跳转到文件末尾

    • 8 个回答
  • Marko Smith

    grub 错误:你需要先加载内核

    • 4 个回答
  • Marko Smith

    如何下载软件包而不是使用 apt-get 命令安装它?

    • 7 个回答
  • Martin Hope
    rocky 如何将 GPG 私钥和公钥导出到文件 2018-11-16 05:36:15 +0800 CST
  • Martin Hope
    Wong Jia Hau ssh-add 返回:“连接代理时出错:没有这样的文件或目录” 2018-08-24 23:28:13 +0800 CST
  • Martin Hope
    Evan Carroll systemctl 状态显示:“状态:降级” 2018-06-03 18:48:17 +0800 CST
  • Martin Hope
    Tim 我们如何运行存储在变量中的命令? 2018-05-21 04:46:29 +0800 CST
  • Martin Hope
    Ankur S 为什么 /dev/null 是一个文件?为什么它的功能不作为一个简单的程序来实现? 2018-04-17 07:28:04 +0800 CST
  • Martin Hope
    user3191334 如何从 systemctl 服务日志中查看最新的 x 行 2018-02-07 00:14:16 +0800 CST
  • Martin Hope
    Marko Pacak Nano - 跳转到文件末尾 2018-02-01 01:53:03 +0800 CST
  • Martin Hope
    Kidburla 为什么真假这么大? 2018-01-26 12:14:47 +0800 CST
  • Martin Hope
    Christos Baziotis 在一个巨大的(70GB)、一行、文本文件中替换字符串 2017-12-30 06:58:33 +0800 CST
  • Martin Hope
    Bagas Sanjaya 为什么 Linux 使用 LF 作为换行符? 2017-12-20 05:48:21 +0800 CST

热门标签

linux bash debian shell-script text-processing ubuntu centos shell awk ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve