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

相关文章

MySQL深分页进行性能优化的常见方法

《MySQL深分页进行性能优化的常见方法》在Web应用中,分页查询是数据库操作中的常见需求,然而,在面对大型数据集时,深分页(deeppagination)却成为了性能优化的一个挑战,在本文中,我们将... 目录引言:深分页,真的只是“翻页慢”那么简单吗?一、背景介绍二、深分页的性能问题三、业务场景分析四、

Linux进程CPU绑定优化与实践过程

《Linux进程CPU绑定优化与实践过程》Linux支持进程绑定至特定CPU核心,通过sched_setaffinity系统调用和taskset工具实现,优化缓存效率与上下文切换,提升多核计算性能,适... 目录1. 多核处理器及并行计算概念1.1 多核处理器架构概述1.2 并行计算的含义及重要性1.3 并

nginx -t、nginx -s stop 和 nginx -s reload 命令的详细解析(结合应用场景)

《nginx-t、nginx-sstop和nginx-sreload命令的详细解析(结合应用场景)》本文解析Nginx的-t、-sstop、-sreload命令,分别用于配置语法检... 以下是关于 nginx -t、nginx -s stop 和 nginx -s reload 命令的详细解析,结合实际应

C#连接SQL server数据库命令的基本步骤

《C#连接SQLserver数据库命令的基本步骤》文章讲解了连接SQLServer数据库的步骤,包括引入命名空间、构建连接字符串、使用SqlConnection和SqlCommand执行SQL操作,... 目录建议配合使用:如何下载和安装SQL server数据库-CSDN博客1. 引入必要的命名空间2.

Linux系统性能检测命令详解

《Linux系统性能检测命令详解》本文介绍了Linux系统常用的监控命令(如top、vmstat、iostat、htop等)及其参数功能,涵盖进程状态、内存使用、磁盘I/O、系统负载等多维度资源监控,... 目录toppsuptimevmstatIOStatiotopslabtophtopdstatnmon

PowerShell中15个提升运维效率关键命令实战指南

《PowerShell中15个提升运维效率关键命令实战指南》作为网络安全专业人员的必备技能,PowerShell在系统管理、日志分析、威胁检测和自动化响应方面展现出强大能力,下面我们就来看看15个提升... 目录一、PowerShell在网络安全中的战略价值二、网络安全关键场景命令实战1. 系统安全基线核查

go中的时间处理过程

《go中的时间处理过程》:本文主要介绍go中的时间处理过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1 获取当前时间2 获取当前时间戳3 获取当前时间的字符串格式4 相互转化4.1 时间戳转时间字符串 (int64 > string)4.2 时间字符串转时间

MyBatisPlus如何优化千万级数据的CRUD

《MyBatisPlus如何优化千万级数据的CRUD》最近负责的一个项目,数据库表量级破千万,每次执行CRUD都像走钢丝,稍有不慎就引起数据库报警,本文就结合这个项目的实战经验,聊聊MyBatisPl... 目录背景一、MyBATis Plus 简介二、千万级数据的挑战三、优化 CRUD 的关键策略1. 查

Golang如何对cron进行二次封装实现指定时间执行定时任务

《Golang如何对cron进行二次封装实现指定时间执行定时任务》:本文主要介绍Golang如何对cron进行二次封装实现指定时间执行定时任务问题,具有很好的参考价值,希望对大家有所帮助,如有错误... 目录背景cron库下载代码示例【1】结构体定义【2】定时任务开启【3】使用示例【4】控制台输出总结背景

Mysql常见的SQL语句格式及实用技巧

《Mysql常见的SQL语句格式及实用技巧》本文系统梳理MySQL常见SQL语句格式,涵盖数据库与表的创建、删除、修改、查询操作,以及记录增删改查和多表关联等高级查询,同时提供索引优化、事务处理、临时... 目录一、常用语法汇总二、示例1.数据库操作2.表操作3.记录操作 4.高级查询三、实用技巧一、常用语