8.6 管道符和做业控制linux
| 用于将前一个指令的输出做为后一个指令的输入:web
[root@localhost 10]# cat /etc/passwd|wc -l 42
上例中命令是查看文件内容并统计行数。shell
做业控制bash
ctrl+z:暂停less
fg(foregrouund):恢复命令dom
bg(background):到后台运行
ctrl+c:终止命令ssh
示例以下:svg
[root@localhost 10]# vi test1.txt [1]+ 已中止 vi test1.txt
上例中输入一些内容,按ESC键后,使用ctrl+z组合键暂停任务。spa
vi不支持在后台从新运行,换一个命令:.net
[root@localhost 10]# vmstat 1 > /tmp/1.log ^Z [1]- 已中止 vi test1.txt [2]+ 已中止 vmstat 1 > /tmp/1.log [root@localhost 10]# jobs [1]- 已中止 vi test1.txt [2]+ 已中止 vmstat 1 > /tmp/1.log [root@localhost 10]# bg 2 [2]+ vmstat 1 > /tmp/1.log &
知识点:多个被暂停的任务会有编号,使用jobs命令能够看到两个任务,使用bg命令或者fg命令时,则须要在后面加编号。这里使用命令bg 2把第2个暂停的任务放到后台从新运行(须要在命令后边加符号&,且中间有个空格)。vmstart 1是用来观察系统状态的一个命令。
关掉在后台运行得任务,若是没有退出刚才的shell,先使用命令fg 编号把任务调到前台,按ctrl+c组合键结束任务。
[root@localhost 10]# fg 2 vmstat 1 > /tmp/1.log ^C
另外一状况是,关闭当前的shell,再次打开另外一个shell时,使用jobs命令并不会显示在后台运行或者被暂停的任务。要想关闭这些任务,则须要先知道他们的pid。
[root@localhost 10]# vmstat 1 > /tmp/1.log & [2] 2321 [root@localhost 10]# ps aux |grep vmstat root 2321 0.0 0.1 152576 1388 pts/0 S 15:27 0:00 vmstat 1 root 2323 0.0 0.0 112720 984 pts/0 S+ 15:28 0:00 grep --color=auto vmstat
使用&把任务放到后台进行时,会显示pid信息。若是忘记这个pid,使用ps aux命令找到哪一个进程。结束进程使用kill命令,强制结束进程kill -9 [pid]。
8.8 shell变量
[root@localhost 10]# echo $PATH /usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/root/bin [root@localhost 10]# echo $HOME /root [root@localhost 10]# echo $PWD /tmp/10 [root@localhost 10]# echo $LOGNAME root
env:列出系统预设的所有系统变量(环境变量)
[root@localhost 10]# env XDG_SESSION_ID=2 HOSTNAME=localhost.localdomain TERM=xterm SHELL=/bin/bash HISTSIZE=1000 SSH_CLIENT=192.168.193.1 61876 22 SSH_TTY=/dev/pts/0 USER=root LS_COLORS=rs=0:di=01;34:ln=01;36:mh=00:pi=40;33:so=01;35:do=01;35:bd=40;33;01:cd=40;33;01:or=40;31;01:mi=01;05;37;41:su=37;41:sg=30;43:ca=30;41:tw=30;42:ow=34;42:st=37;44:ex=01;32:*.tar=01;31:*.tgz=01;31:*.arc=01;31:*.arj=01;31:*.taz=01;31:*.lha=01;31:*.lz4=01;31:*.lzh=01;31:*.lzma=01;31:*.tlz=01;31:*.txz=01;31:*.tzo=01;31:*.t7z=01;31:*.zip=01;31:*.z=01;31:*.Z=01;31:*.dz=01;31:*.gz=01;31:*.lrz=01;31:*.lz=01;31:*.lzo=01;31:*.xz=01;31:*.bz2=01;31:*.bz=01;31:*.tbz=01;31:*.tbz2=01;31:*.tz=01;31:*.deb=01;31:*.rpm=01;31:*.jar=01;31:*.war=01;31:*.ear=01;31:*.sar=01;31:*.rar=01;31:*.alz=01;31:*.ace=01;31:*.zoo=01;31:*.cpio=01;31:*.7z=01;31:*.rz=01;31:*.cab=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:*.svg=01;35:*.svgz=01;35:*.mng=01;35:*.pcx=01;35:*.mov=01;35:*.mpg=01;35:*.mpeg=01;35:*.m2v=01;35:*.mkv=01;35:*.webm=01;35:*.ogm=01;35:*.mp4=01;35:*.m4v=01;35:*.mp4v=01;35:*.vob=01;35:*.qt=01;35:*.nuv=01;35:*.wmv=01;35:*.asf=01;35:*.rm=01;35:*.rmvb=01;35:*.flc=01;35:*.avi=01;35:*.fli=01;35:*.flv=01;35:*.gl=01;35:*.dl=01;35:*.xcf=01;35:*.xwd=01;35:*.yuv=01;35:*.cgm=01;35:*.emf=01;35:*.axv=01;35:*.anx=01;35:*.ogv=01;35:*.ogx=01;35:*.aac=01;36:*.au=01;36:*.flac=01;36:*.mid=01;36:*.midi=01;36:*.mka=01;36:*.mp3=01;36:*.mpc=01;36:*.ogg=01;36:*.ra=01;36:*.wav=01;36:*.axa=01;36:*.oga=01;36:*.spx=01;36:*.xspf=01;36: MAIL=/var/spool/mail/root PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/root/bin PWD=/tmp/10 LANG=zh_CN.UTF-8 HISTCONTROL=ignoredups SHLVL=1 HOME=/root LOGNAME=root XDG_DATA_DIRS=/root/.local/share/flatpak/exports/share/:/var/lib/flatpak/exports/share/:/usr/local/share/:/usr/share/ SSH_CONNECTION=192.168.193.1 61876 192.168.193.128 22 LESSOPEN=||/usr/bin/lesspipe.sh %s XDG_RUNTIME_DIR=/run/user/0 _=/usr/bin/env OLDPWD=/root
set命令输出环境变量
-) cat ;; *) LC_ALL=C "$( dequote "$cmd" )" ${2:---help} 2>&1 ;; esac } | while read -r line; do [[ $line == *([ ' '])-* ]] || continue; while [[ $line =~ ((^|[^-])-[A-Za-z0-9?][[:space:]]+)\[?[A-Z0-9]+\]? ]]; do line=${line/"${BASH_REMATCH[0]}"/"${BASH_REMATCH[1]}"}; done; __parse_options "${line// or /, }"; done } _parse_usage () { eval local cmd=$( quote "$1" ); local line match option i char; { case $cmd in -) cat ;; *) LC_ALL=C "$( dequote "$cmd" )" ${2:---usage} 2>&1 ;; esac } | while read -r line; do while [[ $line =~ \[[[:space:]]*(-[^]]+)[[:space:]]*\] ]]; do match=${BASH_REMATCH[0]}; option=${BASH_REMATCH[1]}; case $option in -?(\[)+([a-zA-Z0-9?])) for ((i=1; i < ${#option}; i++ )) do char=${option:i:1}; [[ $char != '[' ]] && printf '%s\n' -$char; done ;; *) __parse_options "$option" ;; esac; line=${line#*"$match"}; done; done } _pci_ids () { COMPREPLY+=($( compgen -W "$( PATH="$PATH:/sbin" lspci -n | awk '{print $3}')" -- "$cur" )) } _pgids () { COMPREPLY=($( compgen -W '$( command ps axo pgid= )' -- "$cur" )) } _pids () { COMPREPLY=($( compgen -W '$( command ps axo pid= )' -- "$cur" )) } _pnames () { COMPREPLY=($( compgen -X '<defunct>' -W '$( command ps axo command= | \ sed -e "s/ .*//" -e "s:.*/::" -e "s/:$//" -e "s/^[[(-]//" \ -e "s/[])]$//" | sort -u )' -- "$cur" )) } _policyeditor () { local cur prev opts base; cur="${COMP_WORDS[COMP_CWORD]}"; prev="${COMP_WORDS[COMP_CWORD-1]}"; opts="-help -file -defaultfile -codebase -signedby -principals -verbose"; COMPREPLY=($(compgen -W "${opts}" -- ${cur})); return 0 } _quote_readline_by_ref () { if [[ $1 == \'* ]]; then printf -v $2 %s "${1:1}"; else printf -v $2 %q "$1"; fi; [[ ${!2} == \$* ]] && eval $2=${!2} } _realcommand () { type -P "$1" > /dev/null && { if type -p realpath > /dev/null; then realpath "$(type -P "$1")"; else if type -p greadlink > /dev/null; then greadlink -f "$(type -P "$1")"; else if type -p readlink > /dev/null; then readlink -f "$(type -P "$1")"; else type -P "$1"; fi; fi; fi } } _rl_enabled () { [[ "$( bind -v )" = *$1+([[:space:]])on* ]] } _root_command () { local PATH=$PATH:/sbin:/usr/sbin:/usr/local/sbin; local root_command=$1; _command } _scl () { local cur prev opts; COMPREPLY=(); cur="${COMP_WORDS[COMP_CWORD]}"; prev="${COMP_WORDS[COMP_CWORD-1]}"; opts="-l --list"; if [[ ${cur} == -* ]]; then COMPREPLY=($(compgen -W "${opts}" -- ${cur}));
set能够显示用户自定义的变量
[root@localhost 10]# myname=Aming [root@localhost 10]# echo $myname Aming [root@localhost 10]# set |grep myname myname=Aming
虽然你能够自定义变量,可是变量只能在当前shell中生效。
使用bash命令能够再打开一个shell,此时先前设置的myname变量已经存在,退出当前shell回到原来的shell,myname变量还在。
设置环境变量一直生效。
[root@localhost 10]# echo "export myname=Aming" >> /etc/profile [root@localhost 10]# source !$ source /etc/profile [root@localhost 10]# bash [root@localhost 10]# echo $myname Aming [root@localhost 10]# exit exit [root@localhost 10]# su -test
仅容许当前用户使用该变量。在用户主目录下的.bashrc文件的最后一行加入export myname=Aming,而后运行source.bashrc就能够生效了。这时再登陆test帐户,myname变量则不会生效了。这里source命令的做用是将目前设定的配置刷新,即不用注销再登陆也能生效。
linux自定义变量的规定:
当变量内容带有特殊字符(如空格时),须要加上单引号。
[root@localhost ~]# myname='Aming Li' [root@localhost ~]# echo $myname Aming Li
当变量内容为自己带有单引号,这是就须要加双引号。
[root@localhost ~]# myname="Aming' s" [root@localhost ~]# echo $myname Aming' s [root@localhost ~]#
若是变量内容须要用到其余命令,运行结果则可使用双引号。
变量内容能够累加其余变量的内容,但须要加双引号。
[root@localhost ~]# myname="$LOGNAME"Aming [root@localhost ~]# echo $myname rootAming
若是你不当心把双引号错加为单引号,则得不到你想要的结果。
[root@localhost ~]# myname='$LOGNAME'Aming [root@localhost ~]# echo $myname $LOGNAMEAming [root@localhost ~]#
使用双引号时,不会取消双引号中特殊字符自己的做用(这里是$),而使用单引号时,里面的特殊字符将所有失去其自己的做用。
若是在当前的shell中运行bash指令,则会进入一个新的shell,这个shell就是原来的shell。用pstree指令查看:
[root@localhost ~]# pstree |grep bash |-sshd---sshd---bash-+-grep [root@localhost ~]# bash [root@localhost ~]# history
[root@localhost ~]# pstree |grep bash |-sshd---sshd---bash---bash-+-grep
安装pstree命令:yum install psmisc命令安装。
pstree命令会把linux系统中的全部进程以树形结构显示出来。在父shell中设定变量后,进入字shell时,该变量是不会生效的。若是想让这个变量在子shell中生效,则要用到export指令:
[root@localhost ~]# abc=123 [root@localhost ~]# echo $abc 123 [root@localhost ~]# bash [root@localhost ~]# echo $abc [root@localhost ~]# exit exit [root@localhost ~]# export abc [root@localhost ~]# echo $abc 123 [root@localhost ~]# bash [root@localhost ~]# echo $abc 123
其实export命令就是声明一下这个变量,让该shell的子shell也知道变量abc的值是123.设置变量以后,若是想取消某个变量,只要输入unset变量名便可。
[root@localhost ~]# echo $abc 123 [root@localhost ~]# unset abc [root@localhost ~]# echo $abc
8.9 环境变量配置文件
[root@localhost ~]# echo $PS1 [\u@\h \W]\$
\u指用户名,\h指主机名,\w指当前目录,\$指字符#(若是是普通用户,则显示为$).
用户主目录下有几个隐藏文件。
.bash_profile:该文件定义了用户的我的化路径与环境变量的文件名称。
.bashrc:该文件包含专属于本身的shell的bash信息。
.bash_history:该文件用于记录命令历史。
.bash_logout:退出