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:退出