一、 什么是 Shell
管理整个计算机硬件的其实是操作系统的核心 (kernel),这个核心是需要被保护的! 所以我们一般使用者就只能通过 shell 来跟核心沟通,以让核心达到我们所想要达到的工作。
image.png
二、Bash
Bash:Bouren Again SHell的简称,也是基于GNU的架构下发展出来的,是众多shell中的一个。
Linux系统中的shell保存在 /etc/shells 这个文件中,可以这样查看:
# cat /etc/shells
# chsh -l //查看目前系统安装的shell
# /bin/sh //改变目前的shell
# cat /etc/shells //CentOS7 中默认可用 Shell
三、Bash 的功能
命令别名: alias, unalias
藏终端输入:stty
# stty -echo //隐藏命令的输入
# stty echo //恢复
程序化脚本: (shell scripts)
可以将你平时管理系统常需要的连续命令写成一个文件, 该文件并且可以通过交互式的方式来运行。
命令别名: alias
# alias //显示目前终端的全部别名
# alias ll=“ls -l” // 设置别名
# unalias ll //取消别名设置
Bash shell 的内建命令 type
用途: 用来测试命令的类型
type [-tpa] (name)
选项和参数:
:不加任何选项,会显示name是外部命令,还是bash内置命令
-t //会将name以下面这些关键字来表示出他的意义:
file:外部命令
alias:命令别名
builtin:bash内置命令
不显示任何数据时,表示name不是任何命令
-p //后面接外部命令时,才会显示出命令的完整文件名
-a //会由PATH变量定义的路径中,将所有含name的指令都列出来,包括alias
历史命令:history
查看及操作:
# history //列出全部历史命令记录
# history 10 //显示最近10条执行过的命令
# history -c //清除目前 shell 中的所有历史命令
# history -w //即刻写入 .bash_history
使用执行:
# !25 //执行第25条历史命令
# ! ser //执行最近一次以 “ser”开头的命令
# !! //执行上一条命令
history 无法记录时间
解决方法:可以透过~/.bash_logout来进行history的记录,并加上date来增加时间参数
注意history的安全问题,历史命令的记录数量上要控制好
注意:同一帐号同时多次在线执行命令时,这样会产生多个bash,那么会以最后一个登出的命令历史记录为准
建议使用一个用户登入bash,再用[Ctrl]+z fg bg 来控制前后台来切换不同的工作
bash 的登录主机欢迎信息: /etc/issue, /etc/motd
当你登录到系统之前,想了解这个系统的一些简单的硬件及软件版本信息等可以做如下设置:
/etc/issue //修改这个文件的内容即可
\d:本地端时间的日期;
\I:显示第几个终端机接口;
\m:显示硬件的等级(386/i486/i586/686..) ;
\n:显示主机的网络名称;
\o:显示domain name ;
\r:操作系统的版本(相当于uname -r)
\t:显示本地端时间的时间;
\s:操作系统的名称;
\v:操作系统的版本。
/etc/motd //编辑这个文件,会在用户登录之后看到一些欢迎信息
文件系统及程序限制关系
为了放置有人恶意打开多个大容量的档案,是内存耗尽导致系统宕机,bash可以限制用户的某些系统资源。
ulimit [-SHacdfltu] [配额]
选项与参数:
-H:hard limit ,严格的设定,必定不能超过这个设定的数值;
-S:soft limit ,警告的设定,可以超过这个设定值,但是若超过则有警告讯息。在设定上,通常soft会比hard小,
举例来说,soft可设定为80而hard设定为100,那么你可以使用到90 (因为没有超过100),但介于80~100 之间时,系统会有警告讯息通知你!
-a:后面不接任何选项与参数,可列出所有的限制额度;
-c:当某些程序发生错误时,系统可能会将该程序在内存中的信息写成档案(除错用);
-f:此shell可以建立的最大档案容量(一般可能设定为2GB)单位为Kbytes;
-d:程序可使用的最大断裂内存(segment)容量;
-I:可用于锁定(lock)的内存量;
-t:可使用的最大CPU时间(单位为秒) ;
-u:单一用户可以使用的最大程序(process)数量;
最常用的就是 -f 了
例如:限制用户仅等建立10MBytes以下容量的文件
ulimit -f 10240
永久生效,编辑 /etc/security/limits.conf
格式:
用户 限制的级别 类型 限制的值
比如:
chen soft nofile 100
chen hard nofile 100
//nofile 限制文件打开数量
//nproc 网络连接数
Bash 快捷键
编辑命令
Ctrl + a :移到命令行首
Ctrl + e :移到命令行尾
Ctrl + f :按字符前移(右向)
Ctrl + b :按字符后移(左向)
Alt + f :按单词前移(右向)
Alt + b :按单词后移(左向)
Ctrl + xx:在命令行首和光标之间移动
Ctrl + u :从光标处删除至命令行首
Ctrl + k :从光标处删除至命令行尾
Ctrl + w :从光标处删除至字首
Alt + d :从光标处删除至字尾
Ctrl + d :删除光标处的字符
Ctrl + h :删除光标前的字符
Ctrl + y :粘贴至光标后
Alt + c :从光标处更改为首字母大写的单词
Alt + u :从光标处更改为全部大写的单词
Alt + l :从光标处更改为全部小写的单词
Ctrl + t :交换光标处和之前的字符
Ctrl+c :终止目前在进行的命令
Ctrl+d :输入结束(EOF),例如写邮件结束的时候
Ctrl+u :在提示符下,删除光标前面所有的字符
Ctrl+h :在命令提示符下,删除光标前面的单个字符
Ctrl+k :在命令提示符下,删除光标后面所有的字符
通配符与特殊符号
通配符如下:
* 代表 0个到无穷多个 任意字符
? 代表 一定有一个 任意字符
[] 同样代表 一定有一个在括号内 的字符(非任意字符) 例如[abcd]代表了一定有一个字符,可能是a,b, c, d这四个任何一个
[-] 若有减号在中括号内时,代表 在编码顺序内的所有字符 例如[0-9]代表0到9之间的所有数字,因为数字的语系编码是连续的!
[^] 若中括号内的第一个字符为指数符号(^) , 那表示反向选择 例如[^abc]代表一定有一个字符,只要是非a, b, c的其他字符就接受的意思。
示例:
范例一:找出 /etc/ 下面以 cron 为开头的文件名
[root@localhost ~]# ll -d /etc/cron* >==加上 -d 是为了仅显示目录而已
范例二:找出 /etc/ 下面文件名“刚好是五个字母”的文件名
[root@localhost ~]# ll -d /etc/????? >==由于 ? 一定有一个,所以五个 "?" 就对了
范例三:找出 /etc/ 下面文件名含有数字的文件名
[root@localhost ~]# ll -d /etc/*[0-9]* >==记得中括号左右两边均需 *
范例四:找出 /etc/ 下面,文件名开头非为小写字母的文件名:
[root@localhost ~]# ll -d /etc/[^a-z]* >==注意中括号左边没有 *
范例五:将范例四找到的文件复制到 /tmp/upper 中
[root@localhost ~]# mkdir /tmp/upper; cp -a /etc/[^a-z]* /tmp/upper
特殊符号如下:
# 批注符号
\ 转移符号,可以将具有特殊意义的符号变为一般字符
| 管道符,把前一个命令的结果传递给后一个命令,可以多个,以此类推
; 连续下达命令的分隔符
$ 取用变量值的前缀符号
& 将一个工作置于后台
! 逻辑运算意义上的非
/ 路径分隔符
>,>> 输出重定向,>覆盖, >>追加
<,<< 输入重定向
'' 单引号,单引号内的字符均视为一般字符
"" 双引号,其内的字符具有特殊意义,具有变量置换功能
`` 其内的命令可以先执行,建议用$( )取代
() 在中间为子shell的起始与结束
{} 在中间为命令区块的组合