输入重定向是指把文件导入到命令中,而输出重定向则是把原本要输出到屏幕的数据信息写入到指定文件中
标准输入重定向(STDIN,文件描述为0):默认从键盘输入,也可也从其他文件或命令输入
标准输出重定向(STDOUT,文件描述为1):默认输出到屏幕
错误重定向(STDERR,文件描述为2):默认输出到屏幕
输入重定向中用到的符号及其作用
命令 < 文件 将文件作为命令的标准输入
命令 << 分节符 从标准输入中读入,知道遇见分节符才停止
命令 <文件1> 文件2 将文件1作为命令的标准输入并将标准输出到文件2
输出重定向中用到的符号及其作用
命令 > 文件 将标准输出重定向到一个文件中(清空原有文件的数据)
命令 2> 文件 将错误输出重定向到一个文件中(清空原有文件的数据)
命令 >> 文件 将标准输出重定向到一个文件中(追加到原有内容的后面)
命令 2>> 文件 将错误输出重定向到一个文件中(追加到原有内容的后面)
命令 >> 文件 2>&1 或 命令 &>> 文件 将标准输出和错误输出重定向到一个文件中(追加到原有内容的后面)
2、管道符命令
管道符是为了把前一个命令原本要输出到屏幕的标准正常数据当作后一个命令的标准输入
3、命令行的通配符
5、常用的转义符
4个最常用的转义符
反斜杠 \ 使用反斜杠后面的一个变量变成单纯的字符串
单引号‘ ‘ 转义其中所有的变量为单纯的字符串
双引号" "保留其中的变量属性,不进行转义处理
反引号‘‘ 把其中的命令执行后返回结果
![]
5、重要的环境变量
变量是计算机系统用于保存可变值得数据类型
用户在执行一条命令后,linux系统中到底发生了什么事情?通常来说,命令在linux中执行分为4个步骤
第一步:判断用户是否以绝对路径或者相对路径得方式输入命令?(如/bin/ls),如果是的话直接执行
第二步:Linux 系统检查用户输入的命令是否为“别名命令”,即用一个自定义的命令名称来替换原本的命令名称。可以用alias 命令来创建一个属于自己的命令别名,格式为“alias 别名=命令”。若要取消一个命令别名,则是用unalias 命令,格式为“unalias 别名”。我们之前在使用rm 命令删除文件时,Linux 系统都会要求我们再确认是否执行删除操作,其实这就是Linux 系统为了防止用户误删除文件而特意设置的rm 别名命令,接下来我们把它取消掉:
第三步:Bash 解释器判断用户输入的是内部命令还是外部命令。内部命令是解释器内部的指令,会被直接执行;而用户在绝大部分时间输入的是外部命令,这些命令交由步骤4 继续处理。可以使用“type 命令名称”来判断用户输入的命令是内部命令还是外部命令。
第四步:系统在多个路径中查找用户输入的命令文件,而定义这些路径的变量叫作PATH,可以简单地把它理解成是“解释器的小助手”,作用是告诉Bash 解释器待执行的命令可能存放的位置,然后Bash 解释器就会乖乖地在这些位置中逐个查找。PATH 是由多个路径值组成的变量,每个路径值之间用冒号间隔,对这些路径的增加和删除操作将影响到Bash 解释器对Linux 命令的查找。
这里有比较经典的问题:“为什么不能将当前目录(.)添加到PATH 中呢? ” 原因是,尽管可以将当前目录(.)添加到PATH 变量中,从而在某些情况下可以让用户免去输入命令所在路径的麻烦。但是,如果在比较常用的公共目录/tmp 中存放了一个与ls 或cd 命令同名的文件,而用户又恰巧在公共目录中执行了这些命令,那么就极有可能中招了。
所以,作为一名态度谨慎、有经验的运维人员,在接手了一台Linux 系统后一定会在执行命令前先检查PATH 变量中是否有可疑的目录,另外读者从前面的PATH 变量示例中是否也感觉到环境变量特别有用呢。我们可以使用env 命令来查看到Linux 系统中所有的环境变量;
linux系统常见的10格系统变量
HOME 用户的主目录(即家目录)
SHELL 用户在使用的shell解释器名称
HISTSIZE 输出的历史命令记录
HISTFILESIZE 保存的历史命令记录条数
MAIL邮件保存路径
LANG 系统语言、语系名称
RANDOM 生成一个随机数字
PS1 Bash 解释器的提示符
PATH 定义解释器搜索用户执行命令的路径
EDITOR 用户默认的文本编辑器
通过export将变量提升为全局变量