自己搜藏的.bashrc文件

#! /bin/bash
#===============================================================
 #
 # 个人的$HOME/.bashrc文件, 基于bash-2.05a(或更高版本)
 #
 # 最后更新日期: 星期2 4月15 20:32:34 CEST 2003
 #
 # 这个文件(一般情况下)被只会被交互式shell读取.
 # 这里可以定义你的别名, 函数,
 # 和其他的一些交互式特征, 比如你的提示符.
 #
 # 这个文件(开始时)是为Solaris设计的,
 # 但是基于Redhat的默认.bashrc文件
 # --> 为Linux修改.
 # 在这里看到的大部分代码都是从网上找来的
 # 
 # 这仅仅是个例子而已. 可按照自己的需求进行裁减.
 #
 #
 #===============================================================


 # --> 注释由HOWTO的作者添加.
 # --> 然后又被ER编辑了一下 :-)


 #--------------------------------------
 # 如果有源代码的全局定义, 请在此处定义.
 #--------------------------------------


 if [ -f /etc/bashrc ]; then
 . /etc/bashrc # --> 读取/etc/bashrc, 如果存在的话.
 fi


 #-------------------------------------------------------------
 # $DISPLAY的自动设置 (如果还没设置的话)
 # 这用于linux - 可能运行的结果不同....
 # 问题是不同的终端种类对于'who am i'来说,
 # 将会给出不同的答案......
 # 我还没发现一种'通用'方法
 #-------------------------------------------------------------


 function get_xserver ()
 {
 case $TERM in
 xterm )
 XSERVER=$(who am i | awk '{print $NF}' | tr -d ')''(' )
 # Ane-Pieter Wieringa建议使用下面这种方式:
 # I_AM=$(who am i)
 # SERVER=${I_AM#*(}
 # SERVER=${SERVER%*)}


 XSERVER=${XSERVER%%:*}
 ;;
 aterm | rxvt)
 # 找出一些运行在这里的代码.....
 ;;
 esac
 }


 if [ -z ${DISPLAY:=""} ]; then
 get_xserver
 if [[ -z ${XSERVER} || ${XSERVER} == $(hostname) || ${XSERVER} == "unix" ]]; then
 DISPLAY=":0.0" # 在本地主机上显示
 else
 DISPLAY=${XSERVER}:0.0 # 在远端主机上显示
 fi
 fi


 export DISPLAY


 #----------
 # 一些设置
 #----------


 ulimit -S -c 0 # 不需要任何coredump
 set -o notify

 set -o noclobber #禁止重定向时覆盖文件

#set +o noclobber #重定向时可以覆盖已有文件

 set -o ignoreeof
 set -o nounset
 #set -o xtrace # 对于调试来说非常有用


 # 使能选项:
 shopt -s cdspell
 shopt -s cdable_vars
 shopt -s checkhash
 shopt -s checkwinsize
 shopt -s mailwarn
 shopt -s sourcepath
 shopt -s no_empty_cmd_completion # 仅限于bash>=2.04
 shopt -s cmdhist
 shopt -s histappend histreedit histverify
 shopt -s extglob # 对于complete命令(按情况补全)来说是必要的


 # 禁用选项:
 shopt -u mailwarn
 unset MAILCHECK # 当有邮件到达时, 我不希望我的shell提示我




 export TIMEFORMAT=$'\nreal %3R\tuser %3U\tsys %3S\tpcpu %P\n'
 export HISTIGNORE="&:bg:fg:ll:h"
 export HOSTFILE=$HOME/.hosts # 将远端主机的列表放入~/.hosts






 #-----------------------
 # 问候, 问侯报文等等...
 #-----------------------


 # 先定义一些颜色:
 red='\e[0;31m'
 RED='\e[1;31m'
 blue='\e[0;34m'
 BLUE='\e[1;34m'
 cyan='\e[0;36m'
 CYAN='\e[1;36m'
 NC='\e[0m' # 没有颜色
 # --> 很好. 与使用"ansi.sys"的DOS效果相同.


 # 在黑色背景下看起来非常好.....
 echo -e "${CYAN}This is BASH ${RED}${BASH_VERSION%.*}${CYAN} - DISPLAY on ${RED}$DISPLAY${NC}\n"
 date
 if [ -x /usr/games/fortune ]; then
 /usr/games/fortune -s # 让我们的每天充满乐趣.... :-)
 fi


 function _exit() # 在退出shell时运行的函数
 {
 echo -e "${RED}Hasta la vista, baby${NC}"
 }
 trap _exit EXIT


 #---------------
 # Shell提示符
 #---------------


 if [[ "${DISPLAY#$HOST}" != ":0.0" && "${DISPLAY}" != ":0" ]]; then
 HILIT=${red} # 远端主机: 提示符为红
 else
 HILIT=${cyan} # 本地主机: 提示符为青色
 fi


 # --> 下面提示符函数中\W和\w的替换实例,
 #+ --> 用来获得完整路径名的显示.


 function fastprompt()
 {
 unset PROMPT_COMMAND
 case $TERM in
 *term | rxvt )
 PS1="${HILIT}[\h]$NC \W > \[\033]0;\${TERM} [\u@\h] \w\007\]" ;;
 linux )
 PS1="${HILIT}[\h]$NC \W > " ;;
 *)
 PS1="[\h] \W > " ;;
 esac
 }


 function powerprompt()
 {
 _powerprompt()
 {
 LOAD=$(uptime|sed -e "s/.*: \([^,]*\).*/\1/" -e "s/ //g")
 }


 PROMPT_COMMAND=_powerprompt
 case $TERM in
 *term | rxvt )
 PS1="${HILIT}[\A \$LOAD]$NC\n[\h \#] \W > \[\033]0;\${TERM} [\u@\h] \w\007\]" ;;
 linux )
 PS1="${HILIT}[\A - \$LOAD]$NC\n[\h \#] \w > " ;;
 * )
 PS1="[\A - \$LOAD]\n[\h \#] \w > " ;;
 esac
 }


 powerprompt # 这是默认提示符 - 可能比较慢
 # 如果很慢的话, 可以使用fastprompt来代替....


 #===============================================================
 #
 # 别名和函数
 #
 # 事实上, 这里定义的一些函数非常大
 # (比如'lowercase'), 但是我的机器是512M内存, 所以 .....
 # 如果你想让这个文件小一点,
 # 可以将这些函数放到脚本中.
 #
 # 其中的许多函数来自于bash-2.04
 # 中的例子.
 #
 #===============================================================


 #-------------------
 # 个人的别名
 #-------------------


 alias rm='rm -i'
 alias cp='cp -i'
 alias mv='mv -i'
 # -> 防止偶然的文件误操作.
 alias mkdir='mkdir -p'


 alias h='history'
 alias j='jobs -l'
 alias r='rlogin'
 alias which='type -all'
 alias ..='cd ..'
 alias path='echo -e ${PATH//:/\\n}'
 alias print='/usr/bin/lp -o nobanner -d $LPDEST' # 假设LPDEST被定义
 alias pjet='enscript -h -G -fCourier9 -d $LPDEST' # 使用enscript的漂亮的打印
 alias background='xv -root -quit -max -rmode 5' # 将一张图片作为背景
 alias du='du -kh'
 alias df='df -kTh'


 # 'ls'家族 (假定使用GNU ls)
 alias la='ls -Al' # 显示隐藏文件
 alias ls='ls -hF --color' # 为识别的文件类型添加颜色
 alias lx='ls -lXB' # 按扩展名排序
 alias lk='ls -lSr' # 按尺寸排序
 alias lc='ls -lcr' # 按修改时间排序
 alias lu='ls -lur' # 按访问时间排序
 alias lr='ls -lR' # 递归ls
 alias lt='ls -ltr' # 按日期排序
 alias lm='ls -al |more' # 管道给'more'
 alias tree='tree -Csu' # 'ls'的另一种好方法


 # 裁减'less'
 alias more='less'
 export PAGER=less
 export LESSCHARSET='latin1'
 export LESSOPEN='|/usr/bin/lesspipe.sh %s 2>&-' # 如果lesspipe.sh存在, 就用这个
 export LESS='-i -N -w -z-4 -g -e -M -X -F -R -P%t?f%f \
 :stdin .?pb%pb\%:?lbLine %lb:?bbByte %bb:-...'


 # 拼写错误 - 纯粹个人喜好 :-)
 alias xs='cd'
 alias vf='cd'
 alias moer='more'
 alias moew='more'
 alias kk='ll'


 #----------------
 # 一些有趣东西
 #----------------


 function xtitle ()
 {
 case "$TERM" in
 *term | rxvt)
 echo -n -e "\033]0;$*\007" ;;
 *)
 ;;
 esac
 }


 # 别名...
 alias top='xtitle Processes on $HOST && top'
 alias make='xtitle Making $(basename $PWD) ; make'
 alias ncftp="xtitle ncFTP ; ncftp"


 # .. 和函数
 function man ()
 {
 for i ; do
 xtitle The $(basename $1|tr -d .[:digit:]) manual
 command man -F -a "$i"
 done
 }


 function ll(){ ls -l "$@"| egrep "^d" ; ls -lXB "$@" 2>&-| egrep -v "^d|total "; }
 function te() # xemacs/gnuserv的包装器
 {
 if [ "$(gnuclient -batch -eval t 2>&-)" == "t" ]; then
 gnuclient -q "$@";
 else
 ( xemacs "$@" &);
 fi
 }


 #---------------------------
 # 与文件和字符串相关的函数:
 #---------------------------


 # 使用名字模式来查找文件:
 function ff() { find . -type f -iname '*'$*'*' -ls ; }
 # 使用pattern $1和Execute $2来查找文件:
 function fe() { find . -type f -iname '*'$1'*' -exec "${2:-file}" {} \; ; }
 # 在一系列文件中找到模式, 并高亮
 function fstr()
 {
 OPTIND=1
 local case=""
 local usage="fstr: find string in files.
 Usage: fstr [-i] \"pattern\" [\"filename pattern\"] "
 while getopts :it opt
 do
 case "$opt" in
 i) case="-i " ;;
 *) echo "$usage"; return;;
 esac
 done
 shift $(( $OPTIND - 1 ))
 if [ "$#" -lt 1 ]; then
 echo "$usage"
 return;
 fi
 local SMSO=$(tput smso)
 local RMSO=$(tput rmso)
 find . -type f -name "${2:-*}" -print0 | xargs -0 grep -sn ${case} "$1" 2>&- | \
 sed "s/$1/${SMSO}\0${RMSO}/gI" | more
 }


 function cuttail() # 在文件中切掉n行, 默认为10行
 {
 nlines=${2:-10}
 sed -n -e :a -e "1,${nlines}!{P;N;D;};N;ba" $1
 }


 function lowercase() # 将文件名转换为小写
 {
 for file ; do
 filename=${file##*/}
 case "$filename" in
 */*) dirname==${file%/*} ;;
 *) dirname=.;;
 esac
 nf=$(echo $filename | tr A-Z a-z)
 newname="${dirname}/${nf}"
 if [ "$nf" != "$filename" ]; then
 mv "$file" "$newname"
 echo "lowercase: $file --> $newname"
 else
 echo "lowercase: $file not changed."
 fi
 done
 }


 function swap() # 交换两个文件名
 {
 local TMPFILE=tmp.$$
 mv "$1" $TMPFILE
 mv "$2" "$1"
 mv $TMPFILE "$2"
 }




 #----------------------
 # 进程/系统相关的函数:
 #----------------------


 function my_ps() { ps $@ -u $USER -o pid,%cpu,%mem,bsdtime,command ; }
 function pp() { my_ps f | awk '!/awk/ && $0~var' var=${1:-".*"} ; }


 # 这个函数与linux上的'killall'基本一致
 # 但是与Solaris上的却不相同
 function killps() # 按进程名进行kill
 {
 local pid pname sig="-TERM" # 默认signal
 if [ "$#" -lt 1 ] || [ "$#" -gt 2 ]; then
 echo "Usage: killps [-SIGNAL] pattern"
 return;
 fi
 if [ $# = 2 ]; then sig=$1 ; fi
 for pid in $(my_ps| awk '!/awk/ && $0~pat { print $1 }' pat=${!#} ) ; do
 pname=$(my_ps | awk '$1~var { print $5 }' var=$pid )
 if ask "Kill process $pid <$pname> with signal $sig?"
 then kill $sig $pid
 fi
 done
 }


 function my_ip() # 获得IP地址
 {
 MY_IP=$(/sbin/ifconfig ppp0 | awk '/inet/ { print $2 } ' | sed -e s/addr://)
 MY_ISP=$(/sbin/ifconfig ppp0 | awk '/P-t-P/ { print $3 } ' | sed -e s/P-t-P://)
 }


 function ii() # 获得当前主机相关的信息
 {
 echo -e "\nYou are logged on ${RED}$HOST"
 echo -e "\nAdditionnal information:$NC " ; uname -a
 echo -e "\n${RED}Users logged on:$NC " ; w -h
 echo -e "\n${RED}Current date :$NC " ; date
 echo -e "\n${RED}Machine stats :$NC " ; uptime
 echo -e "\n${RED}Memory stats :$NC " ; free
 my_ip 2>&- ;
 echo -e "\n${RED}Local IP Address :$NC" ; echo ${MY_IP:-"Not connected"}
 echo -e "\n${RED}ISP Address :$NC" ; echo ${MY_ISP:-"Not connected"}
 echo
 }


 # 杂项工具:


 function repeat() # 重复n次的命令
 {
 local i max
 max=$1; shift;
 for ((i=1; i <= max ; i++)); do # --> C风格的语法
 eval "$@";
 done
 }


 function ask()
 {
 echo -n "$@" '[y/n] ' ; read ans
 case "$ans" in
 y*|Y*) return 0 ;;
 *) return 1 ;;
 esac
 }


 #=========================================================================
 #
 # 按情况补全, complete命令 - BASH-2.04及其后续版本
 # 大部分摘自bash 2.05文档
 # 和Ian McDonalds的'Bash completion'软件包(http://www.caliban.org/bash/index.shtml#completion)
 # 某些特征可能需要使用bash-2.05a
 #
 #=========================================================================


 if [ "${BASH_VERSION%.*}" \< "2.05" ]; then
 echo "You will need to upgrade to version 2.05 for programmable completion"
 return
 fi


 shopt -s extglob # 必须的
 set +o nounset # 否则某些自动补全将会失败


 complete -A hostname rsh rcp telnet rlogin r ftp ping disk
 complete -A export printenv
 complete -A variable export local readonly unset
 complete -A enabled builtin
 complete -A alias alias unalias
 complete -A function function
 complete -A user su mail finger


 complete -A helptopic help # 通常与内建命令一样
 complete -A shopt shopt
 complete -A stopped -P '%' bg
 complete -A job -P '%' fg jobs disown


 complete -A directory mkdir rmdir
 complete -A directory -o default cd


 # 压缩
 complete -f -o default -X '*.+(zip|ZIP)' zip
 complete -f -o default -X '!*.+(zip|ZIP)' unzip
 complete -f -o default -X '*.+(z|Z)' compress
 complete -f -o default -X '!*.+(z|Z)' uncompress
 complete -f -o default -X '*.+(gz|GZ)' gzip
 complete -f -o default -X '!*.+(gz|GZ)' gunzip
 complete -f -o default -X '*.+(bz2|BZ2)' bzip2
 complete -f -o default -X '!*.+(bz2|BZ2)' bunzip2
 # Postscript,pdf,dvi.....(译者: 打印格式相关)
 complete -f -o default -X '!*.ps' gs ghostview ps2pdf ps2ascii
 complete -f -o default -X '!*.dvi' dvips dvipdf xdvi dviselect dvitype
 complete -f -o default -X '!*.pdf' acroread pdf2ps
 complete -f -o default -X '!*.+(pdf|ps)' gv
 complete -f -o default -X '!*.texi*' makeinfo texi2dvi texi2html texi2pdf
 complete -f -o default -X '!*.tex' tex latex slitex
 complete -f -o default -X '!*.lyx' lyx
 complete -f -o default -X '!*.+(htm*|HTM*)' lynx html2ps
 # 多媒体
 complete -f -o default -X '!*.+(jp*g|gif|xpm|png|bmp)' xv gimp
 complete -f -o default -X '!*.+(mp3|MP3)' mpg123 mpg321
 complete -f -o default -X '!*.+(ogg|OGG)' ogg123






 complete -f -o default -X '!*.pl' perl perl5


 # 这是一个'通用的'补全函数 - 当命令具有一个所谓的"长选项"模式it works when commands have
 # 的时候, 它就会工作, 比如: 'ls --all' 代替 'ls -a'


 _get_longopts ()
 {
 $1 --help | sed -e '/--/!d' -e 's/.*--\([^[:space:].,]*\).*/--\1/'| \
 grep ^"$2" |sort -u ;
 }


 _longopts_func ()
 {
 case "${2:-*}" in
 -*) ;;
 *) return ;;
 esac


 case "$1" in
 \~*) eval cmd="$1" ;;
 *) cmd="$1" ;;
 esac
 COMPREPLY=( $(_get_longopts ${1} ${2} ) )
 }
 complete -o default -F _longopts_func configure bash
 complete -o default -F _longopts_func wget id info a2ps ls recode




 _make_targets ()
 {
 local mdef makef gcmd cur prev i


 COMPREPLY=()
 cur=${COMP_WORDS[COMP_CWORD]}
 prev=${COMP_WORDS[COMP_CWORD-1]}


 # 如果之前的参数为-f, 那就返回可能的补全文件名.
 # 我们可以让它更智能一些, 并且返回匹配的
 # `makefile Makefile *.mk', 不管存在与否
 case "$prev" in
 -*f) COMPREPLY=( $(compgen -f $cur ) ); return 0;;
 esac


 # 如果我们需要一个选项, 那就返回可能的posix选项
 case "$cur" in
 -) COMPREPLY=(-e -f -i -k -n -p -q -r -S -s -t); return 0;;
 esac


 # 前尝试`makefile'再尝试`Makefile'
 if [ -f makefile ]; then
 mdef=makefile
 elif [ -f Makefile ]; then
 mdef=Makefile
 else
 mdef=*.mk # 局部约定
 fi


 # 在我们扫描目标文件之前, 察看makefile文件名是否
 # 使用-f指定
 for (( i=0; i < ${#COMP_WORDS[@]}; i++ )); do
 if [[ ${COMP_WORDS[i]} == -*f ]]; then
 eval makef=${COMP_WORDS[i+1]} # eval for tilde expansion(波浪号扩展)
 break
 fi
 done


 [ -z "$makef" ] && makef=$mdef


 # 如果我们有特别偏爱的补全单词,
 # 那么可以限制的补全这个单词
 if [ -n "$2" ]; then gcmd='grep "^$2"' ; else gcmd=cat ; fi


 # 如果我们不想使用*.mk, 我们可以使用
 # 或者使用test -f $makef或者使用输入重定向
 COMPREPLY=( $(cat $makef 2>/dev/null | awk 'BEGIN {FS=":"} /^[^.# ][^=]*:/ {print $1}' | tr -s ' ' '\012' | sort -u | eval $gcmd ) )
 }


 complete -F _make_targets -X '+($*|*.[cho])' make gmake pmake




 # cvs(1) 补全
 _cvs ()
 {
 local cur prev
 COMPREPLY=()
 cur=${COMP_WORDS[COMP_CWORD]}
 prev=${COMP_WORDS[COMP_CWORD-1]}


 if [ $COMP_CWORD -eq 1 ] || [ "${prev:0:1}" = "-" ]; then
 COMPREPLY=( $( compgen -W 'add admin checkout commit diff \
 export history import log rdiff release remove rtag status \
 tag update' $cur ))
 else
 COMPREPLY=( $( compgen -f $cur ))
 fi
 return 0
 }
 complete -F _cvs cvs


 _killall ()
 {
 local cur prev
 COMPREPLY=()
 cur=${COMP_WORDS[COMP_CWORD]}


 # 获得进程列表(第一个sed表达式处理
 # swap out出去的进程, 第二个
 # 获得进程的basename)
 COMPREPLY=( $( /usr/bin/ps -u $USER -o comm | \
 sed -e '1,1d' -e 's#[]\[]##g' -e 's#^.*/##'| \
 awk '{if ($0 ~ /^'$cur'/) print $0}' ))


 return 0
 }


 complete -F _killall killall killps




 # 一个元命令补全函数, 用于sudo(8)这种命令,
 # 需要先对这个命令进行补全, 然后需要按照这个命令自己的补全定义进行补全
 # - 当前并不是非常可靠(比如 mount和umount命令
 # 就不能很好的工作), 但还是很有用的 - 作者, Ian McDonald, 我修改了一下.


 _my_command()
 {
 local cur func cline cspec


 COMPREPLY=()
 cur=${COMP_WORDS[COMP_CWORD]}


 if [ $COMP_CWORD = 1 ]; then
 COMPREPLY=( $( compgen -c $cur ) )
 elif complete -p ${COMP_WORDS[1]} &>/dev/null; then
 cspec=$( complete -p ${COMP_WORDS[1]} )
 if [ "${cspec%%-F *}" != "${cspec}" ]; then
 # complete -F
 #
 # COMP_CWORD和COMP_WORDS()不是只读的,
 # 所以我们可以在传递到补全例程之前,
 # 设置它们


 # 设置当前的标志号减1
 COMP_CWORD=$(( $COMP_CWORD - 1 ))
 # 获得函数名
 func=${cspec#*-F }
 func=${func%% *}
 # 获得去掉第一个命令后的命令行
 cline="${COMP_LINE#$1 }"
 # 分离当前命令, 传递给数组
 COMP_WORDS=( $cline )
 $func $cline
 elif [ "${cspec#*-[abcdefgjkvu]}" != "" ]; then
 # complete -[abcdefgjkvu]
 #func=$( echo $cspec | sed -e 's/^.*\(-[abcdefgjkvu]\).*$/\1/' )
 func=$( echo $cspec | sed -e 's/^complete//' -e 's/[^ ]*$//' )
 COMPREPLY=( $( eval compgen $func $cur ) )
 elif [ "${cspec#*-A}" != "$cspec" ]; then
 # complete -A
 func=${cspec#*-A }
 func=${func%% *}
 COMPREPLY=( $( compgen -A $func $cur ) )
 fi
 else
 COMPREPLY=( $( compgen -f $cur ) )
 fi
 }




 complete -o default -F _my_command nohup exec eval trace truss strace sotruss gdb
 complete -o default -F _my_command command type which man nice


 # 本地变量:
 # mode:shell-script
 # sh-shell:bash
 # End:


#----------------------------------------------------------------------------------
##
###                                add this
##
#----------------------------------------------------------------------------------
export LS_COLORS='no=00:fi=00:di=01;33:ln=01;36:pi=40;33:so=01;35:do=01;35:bd=40;33;01:cd=40;33;01:or=40;31;01:su=37;41:sg=30;43:tw=30;42:ow=34;42:st=37;44:ex=01;32:*.tar=01;31:*.tgz=01;31:*.arj=01;31:*.taz=01;31:*.lzh=01;31:*.zip=01;31:*.z=01;31:*.Z=01;31:*.gz=01;31:*.bz2=01;31:*.deb=01;31:*.rpm=01;31:*.jar=01;31:*.jpg=01;35:*.jpeg=01;35:*.gif=01;35:*.bmp=01;35:*.pbm=01;35:*.pgm=01;35:*.ppm=01;35:*.tga=01;35:*.xbm=01;35:*.xpm=01;35:*.tif=01;35:*.tiff=01;35:*.png=01;35:*.mov=01;35:*.mpg=01;35:*.mpeg=01;35:*.avi=01;35:*.fli=01;35:*.gl=01;35:*.dl=01;35:*.xcf=01;35:*.xwd=01;35:*.flac=01;35:*.mp3=01;35:*.mpc=01;35:*.ogg=01;35:*.wav=01;35:*.c=00;32:*.h=00;33:*.o=00;36:'
function xgrep()
{
grep -rs "$1" ./ | grep -v svn | grep "$1"

}

# Set colors for man pages
man() {
  env \
  LESS_TERMCAP_mb=$(printf "\e[1;31m") \
  LESS_TERMCAP_md=$(printf "\e[1;31m") \
  LESS_TERMCAP_me=$(printf "\e[0m") \
  LESS_TERMCAP_se=$(printf "\e[0m") \
  LESS_TERMCAP_so=$(printf "\e[1;44;33m") \
  LESS_TERMCAP_ue=$(printf "\e[0m") \
  LESS_TERMCAP_us=$(printf "\e[1;32m") \
  man "$@"

}



export HISTTIMEFORMAT='%F %T  ' #配置命令历史显示格式

#使用 Ctrl+R 搜索历史

HISTSIZE=450 
HISTFILESIZE=450

#使用 HISTCONTROL 强制 history 不记住特定的命令
将 HISTCONTROL 设置为 ignorespace,并在不想被记住的命令前面输入一个空格:
# export HISTCONTROL=ignorespace # ls -ltr # pwd # service httpd stop [Note that there is a space at the beginning of #service, to ignore this command from history] # history | tail -3 67 ls -ltr 68 pwd 69 history | tail -3
#使用 -c 选项清除所有的命令历史
#如果你想清除所有的命令历史,可以执行:
# history -c


你可能感兴趣的:(自己搜藏的.bashrc文件)