::  Blog Posts  ::  RSS Feed  ::  RSS Reverse Feed  ::  Contact  ::  Tagged: tech, shell, logging

February 13rd, 2012

You Should Be Logging Shell History

Do you work on the command line? If so, you should be logging your shell history. Don't shells already do this? Not enough. They log only the most recent commands [1] and they don't include when or where you ran them. Not only that, but they don't save until the shell exits, which means you lose the data in a crash. It's a mess, but you can fix it: tell the shell to log this information immediately before it shows the next command prompt. [2] For bash, put this in the init file [3]:

  promptFunc()
  {
    # right before prompting for the next command, save the previous
    # command in a file.
    echo "$(date +%Y-%m-%d--%H-%M-%S) $(hostname) $PWD $(history 1)" >> ~/.full_history
  }
  PROMPT_COMMAND=promptFunc
You'd think running these extra commands would slow your system down, and I'm sure they do relative to doing nothing or having this built into the shell, but the prompt still feels like it appears instantly.

(Yes, I've written about this before, but I'm continually surprised how many people don't have something like this. It saves me gobs of time.)

Update 2013-04-15: To ease searching, you could add another function:

  function histgrep {
    cat ~/.full_history | grep "$@" | tail
  }
Now instead of:
  $ cat ~/.full_history | grep foo | tail
you can have just:
  $ histgrep foo


[1] Bash defaults to 500 lines. At my previous job I had ~100K lines logged while at my current one I have 73K.

[2] This does mean that if you have a crash while a command is running that command will not be written back to the history file. This is bad, but I don't think there's a 'post command entry' hook in bash.

[3] On my Mac this goes in ~/.bash_profile; on Linux I'd put it in ~/.bashrc. For other shells you'll need something similar.

Top Posts:

Comment on google plus, facebook, r/commandline or write jeff@jefftk.com.


  ::  Blog Posts  ::  RSS Feed  ::  RSS Reverse Feed  ::  Contact  ::  Tagged: tech, shell, logging