history命令内容格式优化:添加日期时间及IP地址

2024-09-07 13:08

本文主要是介绍history命令内容格式优化:添加日期时间及IP地址,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

  • 一、历史记录格式
    • 1.1操作步骤
    • 1.2其他说明
  • 二、历史记录问题
    • 2.1记录显示不全
    • 2.2定时自动记录

一、历史记录格式

1.1操作步骤

  • [可选步骤]清空当前历史记录:history -c && > ~/.bash_history && history -r

  • 编辑对应的配置文件:
    1. 用户配置文件:vim ~/.bashrc
    2. 系统配置文件[推荐]:sudo vim /etc/profile

  • 最下面添加以下配置内容:
# Improve the history print content format
USER_IP=`who -u am i 2>/dev/null | awk '{print $NF}' | sed -e 's/[()]//g'`
if [ -z "$USER_IP" ]; thenUSER_IP=`hostname`
fi
export HISTTIMEFORMAT="格式以自己的审美任意设定【见下面的参考】"

常用HISTTIMEFORMAT变量格式参考:

#以空格间隔
export HISTTIMEFORMAT="%F %T  ${USER_IP}  "
#以连接符间隔
export HISTTIMEFORMAT="%F %T — ${USER_IP}  "
#以中括号间隔
export HISTTIMEFORMAT="[%F %T]  [${USER_IP}]  "

  • 刷新重载配置文件:
    1. 重载用户配置:source ~/.bashrc
    2. 重载系统配置:source /etc/profile

  • 测试查看历史记录:history

1.2其他说明

网上常常会有将whoami加入到HISTTIMEFORMAT变量中的做法,我个人并不建议这么做,因为history命令打印出来的历史操作记录,本身就只有当前登录用户的历史操作记录,并无实际作用,例如当你使用root用户登录系统时,使用history命令打印出来的历史操作记录,只会是root用户所操作过的历史记录,因此主观感觉没必要添加,示例:

#示例变量格式
export HISTTIMEFORMAT="%F %T  `whoami`@${USER_IP}  "
#执行history命令后打印效果如下:1  2021-01-12 12:42:51  root@192.168.0.222  exit2  2021-01-12 12:45:34  root@192.168.0.222  source /etc/profile3  2021-01-12 12:45:37  root@192.168.0.222  history4  2021-01-12 12:46:08  root@192.168.0.222  vim /etc/profile5  2021-01-12 12:46:56  root@192.168.0.222  echo $HISTTIMEFORMAT6  2021-01-13 09:48:34  root@192.168.0.222  hostname7  2021-01-13 09:51:56  root@192.168.0.222  vim /etc/profile8  2021-01-13 12:45:34  root@192.168.0.222  source /etc/profile9  2021-01-13 12:50:48  root@192.168.0.222  history10  2021-01-13 12:52:02  root@192.168.0.222  exit

其中root@将永远都不会改变,你登录的是什么用户,这里就会一直都是这个用户名,当然也许很多用户会觉得配合用户名来打印的话,会更加美观,其实也并无不可,大家可随意配置HISTTIMEFORMAT变量的格式即可!

二、历史记录问题

2.1记录显示不全

经常有人发现执行history命令后,总感觉记录不全,例如一台运行了多年的Linux系统,部署了很多东西,你登录进去后却发现命令只有几条,那么应该会有以下几种可能性供参考:

  1. 确认所登录的用户,是同一个用户,当然如果系统内只有一个用户的话(例如root用户),排除该可能性,不同用户有各自的操作历史记录;
  2. 执行wwho命令,来查看是否有其他用户在登录,其中w命令显示的信息更全面,主要查看打印出来的LOGIN@列的值,是指A用户登录到系统的时间,只有当其A用户退出后、该A用户执行的命令才会被记录到历史记录文件中,并且当前用户也需要exit退出后再登录,或者执行history -a && history -r命令,才能查看A用户的操作记录【这种情况通常发生在系统无超时限制、导致登录用户可一直保持登录状态】;
  3. 操作记录被其他用户清理过,例如执行过上文的可选步骤清空当前历史记录命令,又或者删除过~/.bash_history文件!

2.2定时自动记录

用户可以通过cron定时器,定时自动将操作历史追加写入到操作历史记录文件中,以防出现异常退出导致的命令丢失问题:

#编辑定时器:
crontab -e#在最下面插入以下语句:
# 每隔十分钟自动将当前操作追加写入操作历史记录文件中
*/10 * * * * history -a > /dev/null 2>&1#查看定时任务列表是否存在:
crontab -l

这篇关于history命令内容格式优化:添加日期时间及IP地址的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1145138

相关文章

一文详解如何在Python中从字符串中提取部分内容

《一文详解如何在Python中从字符串中提取部分内容》:本文主要介绍如何在Python中从字符串中提取部分内容的相关资料,包括使用正则表达式、Pyparsing库、AST(抽象语法树)、字符串操作... 目录前言解决方案方法一:使用正则表达式方法二:使用 Pyparsing方法三:使用 AST方法四:使用字

Python中使用正则表达式精准匹配IP地址的案例

《Python中使用正则表达式精准匹配IP地址的案例》Python的正则表达式(re模块)是完成这个任务的利器,但你知道怎么写才能准确匹配各种合法的IP地址吗,今天我们就来详细探讨这个问题,感兴趣的朋... 目录为什么需要IP正则表达式?IP地址的基本结构基础正则表达式写法精确匹配0-255的数字验证IP地

Java中Date、LocalDate、LocalDateTime、LocalTime、时间戳之间的相互转换代码

《Java中Date、LocalDate、LocalDateTime、LocalTime、时间戳之间的相互转换代码》:本文主要介绍Java中日期时间转换的多种方法,包括将Date转换为LocalD... 目录一、Date转LocalDateTime二、Date转LocalDate三、LocalDateTim

Linux ls命令操作详解

《Linuxls命令操作详解》通过ls命令,我们可以查看指定目录下的文件和子目录,并结合不同的选项获取详细的文件信息,如权限、大小、修改时间等,:本文主要介绍Linuxls命令详解,需要的朋友可... 目录1. 命令简介2. 命令的基本语法和用法2.1 语法格式2.2 使用示例2.2.1 列出当前目录下的文

Mysql表如何按照日期字段的年月分区

《Mysql表如何按照日期字段的年月分区》:本文主要介绍Mysql表如何按照日期字段的年月分区的实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、创键表时直接设置分区二、已有表分区1、分区的前置条件2、分区操作三、验证四、注意总结一、创键表时直接设置分区

Spring Boot项目部署命令java -jar的各种参数及作用详解

《SpringBoot项目部署命令java-jar的各种参数及作用详解》:本文主要介绍SpringBoot项目部署命令java-jar的各种参数及作用的相关资料,包括设置内存大小、垃圾回收... 目录前言一、基础命令结构二、常见的 Java 命令参数1. 设置内存大小2. 配置垃圾回收器3. 配置线程栈大小

golang获取当前时间、时间戳和时间字符串及它们之间的相互转换方法

《golang获取当前时间、时间戳和时间字符串及它们之间的相互转换方法》:本文主要介绍golang获取当前时间、时间戳和时间字符串及它们之间的相互转换,本文通过实例代码给大家介绍的非常详细,感兴趣... 目录1、获取当前时间2、获取当前时间戳3、获取当前时间的字符串格式4、它们之间的相互转化上篇文章给大家介

Python通过模块化开发优化代码的技巧分享

《Python通过模块化开发优化代码的技巧分享》模块化开发就是把代码拆成一个个“零件”,该封装封装,该拆分拆分,下面小编就来和大家简单聊聊python如何用模块化开发进行代码优化吧... 目录什么是模块化开发如何拆分代码改进版:拆分成模块让模块更强大:使用 __init__.py你一定会遇到的问题模www.

Feign Client超时时间设置不生效的解决方法

《FeignClient超时时间设置不生效的解决方法》这篇文章主要为大家详细介绍了FeignClient超时时间设置不生效的原因与解决方法,具有一定的的参考价值,希望对大家有一定的帮助... 在使用Feign Client时,可以通过两种方式来设置超时时间:1.针对整个Feign Client设置超时时间

springboot+dubbo实现时间轮算法

《springboot+dubbo实现时间轮算法》时间轮是一种高效利用线程资源进行批量化调度的算法,本文主要介绍了springboot+dubbo实现时间轮算法,文中通过示例代码介绍的非常详细,对大家... 目录前言一、参数说明二、具体实现1、HashedwheelTimer2、createWheel3、n