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

相关文章

Redis 的 SUBSCRIBE命令详解

《Redis的SUBSCRIBE命令详解》Redis的SUBSCRIBE命令用于订阅一个或多个频道,以便接收发送到这些频道的消息,本文给大家介绍Redis的SUBSCRIBE命令,感兴趣的朋友跟随... 目录基本语法工作原理示例消息格式相关命令python 示例Redis 的 SUBSCRIBE 命令用于订

防止Linux rm命令误操作的多场景防护方案与实践

《防止Linuxrm命令误操作的多场景防护方案与实践》在Linux系统中,rm命令是删除文件和目录的高效工具,但一旦误操作,如执行rm-rf/或rm-rf/*,极易导致系统数据灾难,本文针对不同场景... 目录引言理解 rm 命令及误操作风险rm 命令基础常见误操作案例防护方案使用 rm编程 别名及安全删除

使用Python批量将.ncm格式的音频文件转换为.mp3格式的实战详解

《使用Python批量将.ncm格式的音频文件转换为.mp3格式的实战详解》本文详细介绍了如何使用Python通过ncmdump工具批量将.ncm音频转换为.mp3的步骤,包括安装、配置ffmpeg环... 目录1. 前言2. 安装 ncmdump3. 实现 .ncm 转 .mp34. 执行过程5. 执行结

Java使用jar命令配置服务器端口的完整指南

《Java使用jar命令配置服务器端口的完整指南》本文将详细介绍如何使用java-jar命令启动应用,并重点讲解如何配置服务器端口,同时提供一个实用的Web工具来简化这一过程,希望对大家有所帮助... 目录1. Java Jar文件简介1.1 什么是Jar文件1.2 创建可执行Jar文件2. 使用java

C++统计函数执行时间的最佳实践

《C++统计函数执行时间的最佳实践》在软件开发过程中,性能分析是优化程序的重要环节,了解函数的执行时间分布对于识别性能瓶颈至关重要,本文将分享一个C++函数执行时间统计工具,希望对大家有所帮助... 目录前言工具特性核心设计1. 数据结构设计2. 单例模式管理器3. RAII自动计时使用方法基本用法高级用法

从原理到实战解析Java Stream 的并行流性能优化

《从原理到实战解析JavaStream的并行流性能优化》本文给大家介绍JavaStream的并行流性能优化:从原理到实战的全攻略,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的... 目录一、并行流的核心原理与适用场景二、性能优化的核心策略1. 合理设置并行度:打破默认阈值2. 避免装箱

C# LiteDB处理时间序列数据的高性能解决方案

《C#LiteDB处理时间序列数据的高性能解决方案》LiteDB作为.NET生态下的轻量级嵌入式NoSQL数据库,一直是时间序列处理的优选方案,本文将为大家大家简单介绍一下LiteDB处理时间序列数... 目录为什么选择LiteDB处理时间序列数据第一章:LiteDB时间序列数据模型设计1.1 核心设计原则

Python实战之SEO优化自动化工具开发指南

《Python实战之SEO优化自动化工具开发指南》在数字化营销时代,搜索引擎优化(SEO)已成为网站获取流量的重要手段,本文将带您使用Python开发一套完整的SEO自动化工具,需要的可以了解下... 目录前言项目概述技术栈选择核心模块实现1. 关键词研究模块2. 网站技术seo检测模块3. 内容优化分析模

Java实现复杂查询优化的7个技巧小结

《Java实现复杂查询优化的7个技巧小结》在Java项目中,复杂查询是开发者面临的“硬骨头”,本文将通过7个实战技巧,结合代码示例和性能对比,手把手教你如何让复杂查询变得优雅,大家可以根据需求进行选择... 目录一、复杂查询的痛点:为何你的代码“又臭又长”1.1冗余变量与中间状态1.2重复查询与性能陷阱1.

Python内存优化的实战技巧分享

《Python内存优化的实战技巧分享》Python作为一门解释型语言,虽然在开发效率上有着显著优势,但在执行效率方面往往被诟病,然而,通过合理的内存优化策略,我们可以让Python程序的运行速度提升3... 目录前言python内存管理机制引用计数机制垃圾回收机制内存泄漏的常见原因1. 循环引用2. 全局变