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

相关文章

Ubuntu固定虚拟机ip地址的方法教程

《Ubuntu固定虚拟机ip地址的方法教程》本文详细介绍了如何在Ubuntu虚拟机中固定IP地址,包括检查和编辑`/etc/apt/sources.list`文件、更新网络配置文件以及使用Networ... 1、由于虚拟机网络是桥接,所以ip地址会不停地变化,接下来我们就讲述ip如何固定 2、如果apt安

如何解决Pycharm编辑内容时有光标的问题

《如何解决Pycharm编辑内容时有光标的问题》文章介绍了如何在PyCharm中配置VimEmulator插件,包括检查插件是否已安装、下载插件以及安装IdeaVim插件的步骤... 目录Pycharm编辑内容时有光标1.如果Vim Emulator前面有对勾2.www.chinasem.cn如果tools工

如何利用Java获取当天的开始和结束时间

《如何利用Java获取当天的开始和结束时间》:本文主要介绍如何使用Java8的LocalDate和LocalDateTime类获取指定日期的开始和结束时间,展示了如何通过这些类进行日期和时间的处... 目录前言1. Java日期时间API概述2. 获取当天的开始和结束时间代码解析运行结果3. 总结前言在J

Deepseek使用指南与提问优化策略方式

《Deepseek使用指南与提问优化策略方式》本文介绍了DeepSeek语义搜索引擎的核心功能、集成方法及优化提问策略,通过自然语言处理和机器学习提供精准搜索结果,适用于智能客服、知识库检索等领域... 目录序言1. DeepSeek 概述2. DeepSeek 的集成与使用2.1 DeepSeek API

修改若依框架Token的过期时间问题

《修改若依框架Token的过期时间问题》本文介绍了如何修改若依框架中Token的过期时间,通过修改`application.yml`文件中的配置来实现,默认单位为分钟,希望此经验对大家有所帮助,也欢迎... 目录修改若依框架Token的过期时间修改Token的过期时间关闭Token的过期时js间总结修改若依

Go Mongox轻松实现MongoDB的时间字段自动填充

《GoMongox轻松实现MongoDB的时间字段自动填充》这篇文章主要为大家详细介绍了Go语言如何使用mongox库,在插入和更新数据时自动填充时间字段,从而提升开发效率并减少重复代码,需要的可以... 目录前言时间字段填充规则Mongox 的安装使用 Mongox 进行插入操作使用 Mongox 进行更

使用C++将处理后的信号保存为PNG和TIFF格式

《使用C++将处理后的信号保存为PNG和TIFF格式》在信号处理领域,我们常常需要将处理结果以图像的形式保存下来,方便后续分析和展示,C++提供了多种库来处理图像数据,本文将介绍如何使用stb_ima... 目录1. PNG格式保存使用stb_imagephp_write库1.1 安装和包含库1.2 代码解

springboot日期格式化全局LocalDateTime详解

《springboot日期格式化全局LocalDateTime详解》文章主要分析了SpringBoot中ObjectMapper对象的序列化和反序列化过程,并具体探讨了日期格式化问题,通过分析Spri... 目录分析ObjectMapper与jsonSerializer结论自定义日期格式(全局)扩展利用配置

查询SQL Server数据库服务器IP地址的多种有效方法

《查询SQLServer数据库服务器IP地址的多种有效方法》作为数据库管理员或开发人员,了解如何查询SQLServer数据库服务器的IP地址是一项重要技能,本文将介绍几种简单而有效的方法,帮助你轻松... 目录使用T-SQL查询方法1:使用系统函数方法2:使用系统视图使用SQL Server Configu

Tomcat高效部署与性能优化方式

《Tomcat高效部署与性能优化方式》本文介绍了如何高效部署Tomcat并进行性能优化,以确保Web应用的稳定运行和高效响应,高效部署包括环境准备、安装Tomcat、配置Tomcat、部署应用和启动T... 目录Tomcat高效部署与性能优化一、引言二、Tomcat高效部署三、Tomcat性能优化总结Tom