<四>初识Bash

Bash Shell

  • 记录命令历史
    我们敲过的命令,linux是会有记录的,预设可以记录1000条历史命令。这些命令保存在用户的家目录中的.bash_history文件中,但只有当用户正常退出当前shell时,在当前shell中运行的命令才会保存至.bash_history文件中。
  • 指令和文件名补全 (Tab箭)
  • 别名
    • 别名:alias [命令别名]=[‘具体的命令’],例alias aming=’pwd’
    • 解除别名: unalias 命令别名,例unalias 别名
  • 作业控制
    Ctrl+z使任务停止fg命令恢复它(调到前台)bg命令使他到后台运行jobs查看被暂停或者在后台运行的任务;暂停的任务丢在后台跑起来,就使用bg;输入命令末尾加空格加& 使命令在后台运行;若jobs 命令可以看到多个任务,那么使用bg或者fg的时候,就需要在后面加一个编号了;
  • 输入指令
    如果输入的指令太长可以在末尾加 \ 换行处理

变量

  • env
    通常shell预设的变量都是大写的,可以用env查看系统预设的环境变量不过登录的用户不一样这些环境变量的值也不一样;一下是一些常见环境变量的解释:PATH决定了shell将到哪些目录中寻找命令或程序,HOME 当前用户主目录 HISTSIZE 历史记录数 LOGNAME 当前用户的登录名,HOSTNAME 指主机的名称 SHELL 前用户Shell类型 LANG 语言相关的环境变量,多语言可以修改此环境变量 MAIL 当前用户的邮件存放目录 PWD 当前目录
  • set
    env命令显示的变量只是环境变量,系统预设的变量其实还有很多,您可以使用set命令把系统预设的全部变量都显示出来;set不仅可以显示系统预设的变量,也可以连同用户自定义的变量显示出来。可以自定义变量,但是该变量只能在当前shell中生效。
  • 变量设定规则
  • 为什么需要自定义变量
    1. 路径名称太长,且需经常切换目录,方便使用
    2. 常用在脚本程序中
  • 设定
    • 基本形式A=B,若B中有空格或特殊符号,可这样“B”或‘B’;但注意双引号内特殊字符可以保留变量特性,而单引号不行;变量内容中本身带有单引号,这就需要用到双引号了;个人觉得为了简单就用双引号就好
    • 变量内容中需要用到其他命令运行结果则可以使用反引号`
      例:echo ‘pwd’
    • 扩增变量,如”$变量”添加的内容
    • 取消变量unset
  • export
    如果在当前shell中运行bash指令后,则会进入一个新的shell,这个shell就是原来shell的子shell了,不妨可以用pstree指令来查看一下。
    pstree |grep bash
    在父shell中设定一个变量后,进入子shell后该变量是不会生效的,这时需要用到export;export其实就是声明一下这个变量的意思;如果export后面不加任何变量名,则它会声明所有的变量;
    在引用他人的文件或程序时,export非诚重要,尤其是在需要两三个文件互相引用时,如果忘记设定export,那么不同文件中的相同变量值将需要一再地重复设定。所以,只要在头一个文件使用export,那么后续文件引用该变量时,会自动读取该变量内容

历史别名与历史命令

  • alias与unalias
  • history
    命令历史有关的有一个有意思的字符那就是 ‘!’ 了;!! 连续两个 ‘!’, 表示执行上一条指令;!n 这里的n是数字,表示执行命令历史中第n条指令,例如 !1002 表示执行命令历史中第1002个命令; !字符串 (字符串大于等于1),例如 !pw 表示执行命令历史中最近一次以 ‘pw’ 为开头的指令。

bash shell的配置文件

  • 系统设定值
    每个用户进入到bash shell后先读取的配置文件,默认有一下几个
    • /etc/profile
      这个文件预设了几个重要的变量,例如PATH, USER, LOGNAME, MAIL, INPUTRC, HOSTNAME, HISTSIZE, umask等等
    • /etc/bashrc
      这个文件主要预设umask以及PS1。这个PS1就是我们在敲命令时,前面那串字符了,例如linux系统PS1就是 [root@localhost ~]#, 我们不妨看一下PS1的值:echo $PS1
  • 个人设定值
    • ~/.bash_profile
      定义了用户的个人化路径与环境变量的文件名称。每个用户都可使用该文件输入专用于自己使用的shell信息,当用户登录时,该文件仅仅执行一次
    • ~/.bashrc
      这个文件对于设定个人喜好的bash设定最为重要的。
    • ~/ .bash_history :记录命令历史用的。
    • ~/.bash_logout:当退出shell时,会执行该文件。可以把一些清理的工作放到这个文件中
  • source
    若需将当前的配置文件内容读入一次,需要重新注销再登录,若不要这么麻烦可以使用soruce 变量配置文件 即可;

通配符和特殊符号

  • 列举一些常用的:* , ? , [] , ` ;
  • 连续输入命令:command1;command2 (执行完第一条命令无论成功与否都执行第二条命令); command1 && command2; comand1 || command2

命令重定向

  • 基本指令
    指令 > 设备或文件 (若文件已存在,则取代之)
    指令 >> 设备或文件(若文件已存在,则在后面追加之,错误信息不能通过此重定向到文件中)
    指令 < 设备或文件(从设备或文件输入)
    指令 2> 设备或文件(错误输出)
    • 例子
      ls -al 1> list.txt 2> list.err
      ls -al 1> list.txt 2> /dev/null (将错误信息丢弃就好)
  • 问题:为什么需要命令重定向
    • 当屏幕输出信息很重要需要保存时
    • 一些系统例行命令(如:/etc/crontab)的执行结果,希望它可以保存下来时;
    • 一些执行命令的错误信息,我么已经知道并想丢弃时
    • 错误信息和正确信息需要分开保存时

管道命令

统计root登陆的次数
last | grep root | wc -l

一些常用命令

  • cut用来截取某一个字段
    • 语法: cut -d ‘分隔字符’ [-cf] n 这里的n是数字 (-c后接的是第几个字符 -f后接的是第几个区块)
      例1:cat /etc/passwd | cut -d “:” -f 1
      将 passwd文件中每一行里的”:”作为分隔符,列出第一个区块,也就是姓名所在
      例2:last | cut -c 1-20
      将last之后的数据,每一行的1~20个字符取出来
    • 常用在分析日志文件,主要用途在于将同一行的数据进行分解,最常用在分析一些数据或文字数据的时候,这是因为有时候我们会以某些字符(如空格等)作为分隔参数,以取得我们想要的数据
  • wc计数
    • wc [lmw] 文件 (l-行,m-字符,w-字) 一般和其他命令一起用
  • uniq 删除重复的行只显示一个
  • tee 用于命令重定向时,若想在重定向时让数据同时显示在文件和屏幕上可以用 tee,例:last | tee last.list
  • split命令分隔文件
    split [-bl] 输入文件 输出文件前导字符 (b:以文件大小来分,l:以行数来分)
    例: split -l 5 /etc/passwd test 就会产生testaa,testab,testac等文件

参考《鸟哥的Linux》 《跟阿敏学Linux》

头歌前面我们学习过使用commit构建一个镜像,由于commit在构建镜像时,很容易将无关内容添加到镜像且维护起来十分困难。所以我们不推荐使用commit来构建一个镜像。官方推荐使用Dockerfile来构建一个镜像,这个教程将详细地来讲述Dockerfile。 本关任务是初识Dockerfile,要求学习者参照示例完成使用Dockerfile构建一个名为busybox:v1的镜像,Dockerfile的内容为:以busybox为基础镜像,在基础镜像上,创建一个hello.txt文件。 相关知识 为了完成本关卡,你需要掌握: Dockerfile 简介; FROM 指令和 RUN 指令; 使用 Dockerfile 构建一个镜像; Dockerfile 构建镜像的过程详解。 Dockerfile 简介 从之前的学习中我们可以了解到:镜像的定制实际上就是定制每一层所添加的配置、文件。那么如果我们可以把每一层修改、安装、构建、操作的命令都写入一个脚本,用这个脚本来构建、定制镜像,那么之前提及的无法重复的问题、镜像构建透明性的问题、体积的问题就都会解决。这个脚本就是Dockerfile。 Dockerfile描述了组装镜像的步骤,其中每一条命令都是单独执行的,除了FROM指令外,其他每一条指令都在上一条指定所生成的镜像基础上执行,执行完会生成一个新的镜像层,新的镜像层覆盖在原来的镜像层之上,从而形成了新的镜像。Dockerfile所生成的最终镜像就是在基础叠加镜像上一层层的镜像层组成的。 在Dockerfile中,指令不区分大小写,但是为了与参数区分,推荐大写。Docker会顺序执行Dockerfile中的指令,第一条必须是FROM指令,它用于指定构建镜像的基础镜像。在Dockerfile中,以#开头的行是注释。 下面我们开始介绍Dockerfile最基本的两条指令:FROM指令和RUN指令。 FROM 指令和 RUN 指令 ●FROM指定基础镜像; 格式:FROM <image>或 FROM <image>:<tag>。 FROM指令的功能是为后面的指令提供基础镜像,因此一个有效的Dockerfile必须以FROM指令作为第一条非注解指令。若FROM指令中tag参数为空,则tag默认为latest;若参数image或tag指定镜像不存在,则返回错误。 ●RUN执行命令; 格式:RUN <command>(shell格式)或RUN [“executable”, “param1“, “param2”](exec格式,非常推荐)。 RUN 指令是用来执行命令行命令的。RUN指令会在前一条命令创建出的镜像的基础上创建一个容器,并在容器中运行命令。在命令结束运行后提交新容器为新镜像,新镜像被Dockerfile的下一条指令使用。 之前说过,Dockerfile中每一个指令都会建立一个镜像层,RUN也不例外。每一个RUN 的行为,就和之前学习的docker commit定制镜像的过程一样:在之前镜像的基础上创建一个容器,在其上执行这些命令,执行结束后,最后 commit 这一层的修改,构成新的镜像。 使用 Dockerfile 构建一个镜像 下面介绍使用Dockerfile构建一个镜像,步骤如下: 首先创建一个空文件夹:mkdir newdir; 然后进入该文件夹:cd newdir; 在该文件夹下创建一个名为Dockerfile的文件,根据实际需求补全Dockerfile的内容; 使用Dockerfile构建一个镜像:docker build -t testimage .(注意这个小数点)其中-t指定新镜像的镜像名。 下面举一个实例,使用Dockerfile构建一个名为testimage的镜像,该镜像具备ubuntu:latest的运行环境,而且在镜像的/目录下创建了一个dir1文件夹。 #先创建一个新的空文件夹 mkdir newdir #进入这个新文件夹中 cd newdir #创建一个Dockerfile文件 touch Dockerfile #补全Dockerfile的内容(为了方便展示,这里用的是echo向Dockerfile中输入内容) echo "FROM ubuntu:latest" > Dockerfile echo "RUN mkdir /dir1" >> Dockerfile #使用该Dockerfile构建一个名为testimage的镜像 docker build -t testimage . Dockerfile 构建镜像的过程详解: 上面的实例创建了一个Dockerfile文件,Dockerfile的内容如下: FROM ubuntu:latest RUN mkdir /dir1 执行d
最新发布
10-22
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值