点击登录
  • 成功不是先有钱,而是先有胆!
  • 你可以不努力,但最好别后悔!
  • 我希望你是因为我的钱才爱上我,而不是我的人!
  • 当你不够强大的时候,任何赞美都是嘲讽!
  • 能用钱解决的问题千万别用人情 !
  • 小孩子才关心对错,老板只看利弊结果!
  • 永远不要借钱给别人,借了 你就会失去一个朋友,还会多一个仇人!
  • 世界上最浪费时间的事就是给年轻人讲经验,讲一万句不如自己摔一跤,眼泪教你做人,后悔帮你成长,疼痛才是最好的老师!

Linux—常用命令(一)

Linux 代码搬运工 340次浏览 已收录 0个评论 扫描二维码

Linux---常用命令(一)
整理了一下linux常用命令,方便大家使用和学习。

一.文件处理命令

1.命令格式与目录处理命令

```
ls –a【查看隐藏文件】
ls –l【查看文件信息长格式显示】
ls –d【查看指定目录的详细信息】
ls –h【显示容量大小】
ls –i【查看任何文件的I 节点】
ll 文件名【查看一个文件的详细信息】

<pre class="line-numbers prism-highlight" data-start="1"><code class="language-null"> ## 2.目录处理命令
</code></pre>

<pre class="prism-highlight line-numbers" data-start="1"><code class="language-null">mkdir –p【递归创建目录】
cd【切换指定目录】
pwd【显示当前目录】
rmdir【删除空目录】
cp【复制文件到某个目录下】
cp –r【复制目录】
cp –p【保留文件属性】
mv【剪切文件、改名】
rm【删除文件】
rm –r【删除目录】
rm –f【强制执行】
</code></pre>

<pre class="line-numbers prism-highlight" data-start="1"><code class="language-null"> ## 3.文件处理命令
</code></pre>

<pre class="prism-highlight line-numbers" data-start="1"><code class="language-null">touch【创建空文件】
cat【查看文件内容】
cat –n【显示行号】
tac【显示文件内容(反向列示)】
more【分页显示文件内容(空格或f[翻页], Enter[换行], q或Q[退出])】
less【分页显示文件内容(可向上翻页),填写/可搜索关键词,n等于next,PageUp和PageDown】
head【显示文件前面几行】
head -n【指定行数,head –n 20 /etc/services】
tail【显示文件后面几行】
tail –n【指定行数】
tail –f【动态显示文件末尾内容】
</code></pre>

<pre class="line-numbers prism-highlight" data-start="1"><code class="language-null">## 4.链接命令
</code></pre>

<pre class="prism-highlight line-numbers" data-start="1"><code class="language-null">ln【生成链接文件,类似拷贝,可以同步更新】
ln –s【创建软链接,相当于快捷方式】
</code></pre>

<pre class="line-numbers prism-highlight" data-start="1"><code class="language-null"># 二. 权限管理命令
## 1.权限管理命令
</code></pre>

<pre class="prism-highlight line-numbers" data-start="1"><code class="language-null">chmod【改变文件或目录权限,u=所有者;g=所有组;o=其他人;a=全部,[{ugoa}{+-=}{rwx}],chmod u+x,o-r或640 文件名,r—4;w—2;x—1,rwx—7(4+2+1)】
chmod –R【递归修改,子目录的权限也修改】
</code></pre>

```
## 2.其他权限管理命令

    chown【改变文件或目录的所有者,chown 用户 文件或目录】
    chgrp【改变文件或目录的所属组】
    umask【显示,设置文件的缺省权限】

三. 文件搜索命令

1.文件搜索命令

```
find【文件搜索,find 搜索范围 匹配条件】
find 搜索范围 -name或-iname(不区分大小写) 匹配条件【根据文件名称搜索,匹配条件(abcd)=<em>bc</em>=ab??,<em>=匹配任意字符,?=匹配单个字符】
find 搜索范围 -size +n/-n/n(n代表文件的大小)【根据文件的大小搜索】
find 搜索范围 -size +163840 -a/-o -size -204800【查找(-a=大于80M小于100M的文件,-o=两个条件满足一个即可)】
find 搜索范围 -user 用户名【根据用户名搜索文件,搜索范围=/home】
find 搜索范围 -group 所属组名【根据所属组名搜索文件】
find 搜索范围 -cmin/-amin/-mmin -5【查找5分钟内被修改过(-cmin=文件属性,-amin=访问时间,-mmin=文件内容)的文件】
find 搜索范围 -type f/d/l【根据文件类型查找,f=文件,d=目录,l=软链接文件】
find 搜索范围 -inum n【根据i节点查找,n=i节点数】
以上搜索结果命令加(find /tmp -name *aaaa</em>) -exec/-ok 命令(ls -l[显示详细信息]) {} \;【对搜索结果执行命令操作】

```

2.其他搜索命令

        locate -i 文件名【在文件资料库中查找文件,-i=不区分大小写】
        updatedb【更新文件资料库,tmp目录不在更新范围内】
        which 命令(ls)【搜索命令所在目录及别名信息】
        whereis 命令(ls)【搜索命令所在目录及帮助文档路径】
        grep -i/-v mysql /root/install.log【在文件中搜索字符匹配的行并输出,-i=不区分大小写,-v=排除指定字串(^#=排除#带头的行)】

四. 帮助命令

man 命令或配置文件【获取帮助信息】
    info 命令【获取帮助信息,显示和man不同】
    whatis 命令【获取该命令的简介信息】
    apropos 配置文件名称【只查看配置文件的信息】
    命令 --help【获取该命令的选项信息】
    help 内置命令【查看Shell内置命令的帮助信息】

五. 用户管理命令

    useradd 用户名【添加新用户】
    passwd 用户名【设置用户密码】
   who【查看登录用户信息,tty本地登录,pts远程终端】
   w【查看登录用户的详细信息,全】

六. 压缩解压命令

    gzip 文件【压缩文件,压缩后的格式:.gz】
    gunzip 文件【解压.gz的压缩文件】
    tar -zcf temp.tar.gz temp【打包目录,-c:打包,-v:显示详细信息,-f:指定文件名,-z:打包同时压缩,temp:文件名】
    tar -zxf temp.tar.gz【解压目录,-x:解包,-v:显示详细信息,-f:指定文件名,-z:解包同时解压,temp:文件名】
    zip -r temp.zip temp【压缩问价或目录,-r:压缩目录,temp:文件名】
    unzip temp【解压.zip的压缩文件,temp:文件名或目录】
    bzip2 -k temp【压缩文件,-k:产生压缩文件后保留原文件,temp:文件名】
    bunzip2 -k temp【解压文件,-k:解压缩后保留原文件,temp:文件名】
    tar -cjf temp.tar.bz2 temp【压缩】
    tar -xjf temp.tar.bz2【解压】

七. 网络命令

    write 用户名【给在线用户发信息,以Ctrl+D保存结束】
    wall 信息【发广播信息】
    ping -c 4 IP地址【测试网络连通性,-c:指定发送次数为4次】
    ifconfig eth0 192.168.0.169【查看和设置网卡信息】
    mail 用户名【查看发送电子邮件,以Ctrl+D保存结束,help查看信息】
    last【列出目前与过去登入系统的用户信息】
    lastlog -u 502【检查某特定用户上次登录的时间】
    traceroute 网址【显示数据包到主机间的路径 IP等等】
    netstat -t/-u/-l/-r/-n【显示网络相关信息,-t:TCP协议,-u:UDP协议,-l:监听,-r:路由,-n:显示IP地址和端口号】
    netstat -tlun【查看本机监听的端口】
    netstat -an【查看本机所有的网络】
    netstat -rn【查看本机路由表】
    mount【挂载命令---详细找百度吧】
    mount /dev/sr0 /mnt/cdrom/【挂载光盘】
    umount /dev/sr0【卸载挂载点】

八.关机重启命令

    shutdown -h now【现在关机,-h:关机,now:现在】
    shutdown -h 20:30【定时关机,-h:关机】
    shutdown -r now【现在重启,-r:重启,now:现在】
    shutdown -r 20:30【定时重启,-r:重启】
    shutdown -c【取消前一个定时关机命令】
    init 0:关机/1:关机/2:不完全多用户/不含NFS服务/3:完全多用户/4:未分配/5:图形界面/6:重启【系统运行级别】
    cat /etc/inittab【修改系统默认运行级别】
    runlevel【查询系统运行级别,默认是N 3,N:代表上一次的系统级别】
    logout【退出登录命令——注意一定记得退出登录】

九.文本编辑器常用命令

1).vim常用操作

vim 文件名【进入或新建--进入命令模式】
        i/a/o【进入插入模式,a:在光标所在字符后插入,A:在光标所在行尾插入,i:在光标所在字符前插入,I:在光标所在行行首插入,o:在光标下插入新行,O:在光标上插入新行】

        :set nu【添加行号】
        :set nonu【取消行号】
        gg【到第一行】
        G【到最后一行】
        nG【到第n行】
        :n【到第n行--------推荐】
        $【移至行尾】
        0【移至行首】

        x【删除光标所在处字符-----------推荐】
        nx【删除光标所在处后n个字符】
        dd【删除光标所在行,ndd删除n行--------推荐】
        dG【删除光标所在行到文件末尾内容】
        D【删除光标所在处到行尾内容】
        :n,nd【删除指定范围的行】

        yy【复制当前行------------推荐】
        nyy【复制当前行一下n行】
        dd【剪切当前行】
        ndd【剪切当前行以下n行】
        p/P【粘贴在当前光标所在行下(p)或行上(P)--------推荐】

        r【取代光标所在处字符】
        R【从光标所在处开始替换字符,按ESC结束】
        u【取消上一步操作,撤销----------推荐】

        /string【搜索指定字符串,string:字符串,n:搜索指定字符串的下一个出现位置】
        :set ic【搜索时忽略大小写】
        :set noic【取消搜索时忽略大小写】
        :%s/old/new/g【全文替换指定字符串,冒号指全文替换,%s:全文搜索,old:要替换的字符串,new:替换的新的字符串,g:不询问确认】
        :n,ns/old/new/c【在一定范围内替换指定字符串,(n,ns:起始行,终止行s),c:询问确认】

        :w【保存修改------推荐】
        :w /tmp/temp.txt【另存为指定文件】
        :wq【保存退出---------推荐】
        :q!【不保存退出】
        ZZ【快捷键,保存修改并退出】
        :wq!【保存修改并退出(文件所有者及root可使用)】

        按ESC【退出模式,进入命令模式】

2).vim使用技巧

```
:r /tmp/temp.txt(被导入的文件)【把temp.txt的内容导入到光标处】
:r !date(命令)【可以在不退出vim的情况下,执行相应的操作命令,date:系统时间命令】
:map ^P I#【定义快捷键:map,^P:按ctrl+v+p(快捷键按Ctrl+p),注释该行】
:map ^B 0x【定义快捷键:map,^B:按ctrl+v+b(快捷键按Ctrl+b),取消注释该行】
:1,4s/^/#//g【多行注释,把1到4行的行首添加#】
:1,4s/^#//g【取消多行注释,把1到4行的行首的#去掉】
:1,4s/^/\/\//g【多行注释,把1到4行的行首添加//】
:1,4s/^\/\//g【取消多行注释,把1到4行的行首的//去掉】
:ab mymail [email protected]【替换,在编辑时填写mymail回车时就会被替换成邮箱】

<pre class="prism-highlight line-numbers" data-start="1"><code class="language-null"> #快捷键或编辑模式命令 在重启后会失效,必须在/root/.vimrc或/home/***/.vimrc目录下才会被永久保存---注意填写时不用填写:了
</code></pre>

========================================================================================================

<pre class="line-numbers prism-highlight" data-start="1"><code class="language-null">## 一、软件包管理简介
### 1.软件包分类
```
源码包---脚本安装包
二进制包(RPM包、系统默认包)---常见
```
### 二、RPM包管理-rpm命令管理

01.RPM包命令原则
http-2.2.15-15.e16.centos.1.i686.rpm
httpd------------软件包名
2.2.15-----------软件版本
15---------------软件发布的次数
e16.centos-------适合的Linux平台
i686-------------适合的硬件平台
rpm--------------rpm包扩展名
02.RPM包依赖性
树形依赖:a->b->c
环形依赖:a->b->c->a
模块依赖:模块依赖查询网站www.rpmfind.net
03.包全名与包名
包全名:操作的包是没有安装的软件包时,使用包全名,而且要注意路径
包名:操作已经安装的软件包时,使用包名,是搜索/var/lib/rpm/中的数据库
04.RPM安装
rpm -ivh 包全名【-i:安装,-v:显示详细信息,-h:显示进度,--nodeps:不检测依赖性】
05.RPM包升级
rpm -Uvh 包全名【-U:升级】
06.卸载
rpm -e 包名【-e:卸载,--nodeps:不检测依赖性】
07.查询是否安装
rpm -q 包名【查询包是否安装,-q:查询】
rpm -q | grep 包名【查询包是否安装,-q:查询,grep:管道符--查询与包名相关的包】
rpm -qa【查询所有已经安装的RPM包,-a:所有】
08.查询软件包详细信息
rpm -qi 包名【-i:查询软件信息,-p:查询未安装包信息(包全名)】
09.查询包中文件安装位置
rpm -ql 包名【-l:列表,-p:查询未安装包信息(包全名)】
10.查询系统文件属于哪个RPM包
rpm -qf 系统文件名【-f:查询系统文件属于哪个软件包】
11.查询软件包的依赖性
rpm -qR 包名【-R:查询软件包的依赖性,-p:查询未安装包信息】
12.RPM包校验
rpm -V 已安装的包名【-V:校验指定RPM包中的文件】
1).验证内容中的8个信息的具体内容如下
S:文件大小是否改变
M:文件类型或文件的权限(rwx)是否被改变
5:文件MD5校验和是否改变(可以看成文件内容是否改变)
D:设备的中,从代码是否改变
L:文件路径是否改变
U:文件属主(所有者)是否改变
G:文件的数组是否改变
T:文件的修改时间是否改变
2).文件类型
c:配置文件
d:普通文件
g:"鬼"文件,很少见,就是该文件不应该被这个RPM包包含
l:授权文件
r:描述文件
13.RPM包中文件提取
rpm2cpio 包全名 | \ cpio -idv .文件绝对路径【rpm2cpio:将rpm包转换为cpio格式的命令,cpio:是一个标准工具,它用于创建软件档案文件和从档案文件中提取文件】
cpio 选项 <[文件设备]【-i:copy-in模式,还原,-d:还原时自动新建目录,-v:显示还原过程】

### 三、RPM包管理-yum在线管理

01.IP地址配置和网络yum源
1).IP地址配置
setup【配置网络】
vim /etc/sysconfig/network-script/ifcfg-eth0【进去vim编辑器模式,把ONBOOT="no"改成ONBOOT="yes"】
service network restart【重启网络服务】
2).网络yum源
vim /etc/yum.repos.d/CentOS-Base.repo【进入vim编辑器模式】
[base]---------容器名称,一定要放在[]中
name-----------容器说明,可以自己随便写
mirrorlist-----镜像站点,这个可以注释掉
baseurl--------我们的yum源服务器的地址.默认是CentOS官方的yum源服务器,是可以使用的,如果你觉得慢可以改成你喜欢的yum源地址
enabled--------此容器是否生效,如果不写或写出enable=1都是生效,写成enable=0就是不生效
gpgcheck-------如果是1是指RPM的数字证书生效,如果是0则不生效
gpgkey---------数字证书的公钥文件保存位置.不用修改
02.yum命令
1.常用yum命令
1).查询软件包
yum list【查询所有可用软件包列表】
yum search 关键字【搜索服务器上所有和关键字相关的包】
2).安装
yum -y install 包名【install:安装,-y:自动回答yes】
3).升级
yum -y update 包名【update:升级,-y:自动回答yes==[建议别用,注意:yum -y update(升级全部,包括liunx内核也会被升级,用当机的可能,慎用!)]】
4).卸载
yum -y remove 包名【remove:卸载,-y:自动回答yes===[建议别用]】
5).
2.YUM软件组管理命令
yum grouplist【列出所有可用的软件组列表】
yum groupinstall 软件组名【安装指定软件组,组名可以由grouplist查询出来,如果软件包名有空格用""括起来】
yum groupremove 软件组名【卸载指定软件组】
03.光盘yum源搭建
1.光盘yum源搭建步骤
1).挂载光盘
mount /dev/cdrom /mnt/cdrom/
2).让网络yum源文件失效
cd /etc/yum.repos.d【进入yum源目录】
mv CentOS-Base.repo CentOS-Base.repo.bak【网络yum源默认读取.repo结尾的,现在把网络yum源名字加上.bak,这样网络yum源失效,就会让光盘yum源生效】
mv CentOS-Debuginfo.repo CentOS-Debuginfo.repo.bak
mv CentOS-Vault.repo CentOS-Vault.repo.bak
cp CentOS-Media.repo CentOS-Media.repo.bak【这个是光盘yum源,这里备份一个】
3).修改光盘yum源文件
vim /etc/yum.repos.d/CentOS-Media.repo【进入vim编辑器模式,把内容更改成如下,在操作(yum list)命令查询是否成功,注意注释#不要乱写】
[c6-media]
name=CentOS-$releasever - Media
baseurl=file:///mnt/cdrom/
#地址为你自己的光盘挂载地址--file:///mnt/cdrom/
# file:///media/CentOS/
# file:///media/cdrom/
# file:///media/cdrecorder/
#注释这三个不存在的地址
gpgcheck=1
enabled=1
#把enable=0改成enable=1,让这个yum源配置文件生效
gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-CentOS-6

### 四、源码包管理
  ```
    1.源码包和RPM包的区别
        1).区别
            安装之前的区别:概念上的区别
            安装之后的区别:安装位置不同
        2).RPM包安装位置
            是安装在默认位置中
            RPM包默认安装路径
            /etc/-------------配置文件安装目录
            /usr/bin/---------可执行的命令安装目录
            /usr/lib/---------程序所使用的函数库保存位置
            /usr/share/doc/---基本的软件使用手册保存位置
            /usr/share/man/---帮助文件保存位置
        3).安装在指定位置当中,一般是/usr/local/软件吗/
        4).安装位置不同带来的影响
            &gt;RPM包安装的服务可以使用系统服务管理命令(service)来管理,例如RPM包安装的apache的启动方法是:
                /etc/rc.d/init.d/httpd start或service httpd start【开启服务】
                service httpd stop【停止服务】
            &gt;而源码包安装的服务则不能被服务管理命令管理,因为没有安装到默认路径中,所以只能用绝对路径进行服务的管理,如:
                /usr/local/apache2/bin/apachectl start
    2.源码包安装过程
        1).安装准备
            安装C语言编译器
            下载源码包http://mirror.bit.edu.cn/apache/httpd/
        2).安装注意事项
            源代码保存位置:/usr/local/src/
            软件安装位置:/usr/local/
            如何确定安装过程报错:
                安装过程停止
                并出现error、warning或no的提示
        3).源码包安装过程
            下载源码包
            解压缩下载的源码包
            进入解压缩目录
                (./configure)软件配置与检测
                定义需要的功能选项
                检测系统环境是否符合安装要求(检测系统是否安装gcc[c语言编译器]等等)
                把定义好的功能选项和检测系统环境的信息都写入Makefile文件,用于后续的编辑

                ./configure --prefix=/usr/local/apache2
                make【编译】
                make clean【如果以上两个步骤有错误,就执行清空临时文件命令,没有错误就不用执行】
                make install【编译安装】
        4).源码包的卸载
            不需要卸载命令,直接删除安装目录即可.不会遗留任何垃圾文件

五、脚本安装包与软件包选择

    1.脚本安装包
        #脚本安装包并不是独立的软件包类型,常见安装的是源码包
        #是认为把安装过程写成了自动安装的脚本,只要执行脚本,定义简单的参数,就可以完成安装
        #非常类似于Windows下软件的安装方式
    2.Webmin的作用
        #Webmin是一个基于Web的Linux系统管理界面.您就可以通过图形化的方式设置用户帐号、apache、DNS、文件共享等服务.
    3.Webmin安装过程
        #下载软件http://sourceforge.net/projects/webadmin/files/webmin/
        #解压缩,并进入加压缩目录
        #执行安装脚本(./setup.sh)
        #卸载(/etc/webmin/uninstall.sh)
        #安装完了注意先把防火墙关了(service iptables stop),不然外界不能访问
````
### 六、用户和用户组管理
1.用户配置文件
    1).用户信息文件/etc/passwd
        ①.用户管理简介
            ◆所以越是对服务器安全性要求高的服务器,越是要建立合理的用户权限等级制度和服务器操作规范
            ◆在Linux中主要是通过用户配置文件来查看和修改用户信息
        ②./etc/passwd
            第一字段:用户名称
            第二字段:密码标志
            第三字段:UID(用户ID)--0:超级用户,1-499:系统用户(伪用户),500-65535:普通用户
            第四字段:GID(用户初始组ID)
            第五字段:用户说明
            第六字段:家目录--普通用户:/home/用户名/,超级用户:/root/
            第七字段:登录之后的Shell
        ③.初始组和附加组
            初始组:就是指用户一登录就立刻拥有这个用户组的相关权限,每个用户的初始组只能有一个,一般就是和这个用户的用户名相同的组名作为这个用户的初始组.
            附加组:指用户可以加入多个其他的用户组,并拥有这些组的权限,附加组可以有多个.
        ④.Shell是什么
            Shell就是Linux的命令解释器
            在/etc/passwd当中,除了标准Shell是/bin/bash之外,还可以写如/sbin/nologin
    2).影子文件/etc/shadow
        1.字段的解释
            第一字段:用户名
            第二字段:加密密码
                加密算法升级为SHA512散列加密算法
                如果密码位是"!!"或"*"代表没有密码,不能登录
            第三字段:密码最后一次修改日期
                使用1970年1月1日作为标准时间,每过一天时间戳加1
            第四字段:两次密码的修改间隔时间(和第三字段相比)
            第五字段:密码有效期(和第三字段相比)
            第六字段:密码修改到期前的警告天数(和第五字段相比)
            第七字段:密码过期后的宽限天数(和第五字段相比)
                0:代表密码过期后立即生效
                -1:则代表密码永久不会生效
            第八字段:帐号失效时间
                要用时间戳表示
            第九字段:保留字段
        2.时间戳换算
            把时间戳换算为如期
                date -d "1970-01-01 16066 days"
            把日期换算为时间戳
                echo $(($(date --date="2015/8/31" +%s)/86400+1))
    3).组信息文件/etc/gtoup和组密码文件/etc/gshadow
        1.组信息文件/etc/group
            第一字段:组名
            第二字段:组密码标志
            第三字段:GID
            第四字段:组中附加用户
        2.组密码文件/etc/gshadow
            第一字段:组名
            第二字段:组密码
            第三字段:组管理员用户名
            第四字段:组中附加用户
2.用户管理相关文件
    1).用户的家目录
        普通用户:/home/用户名/,所有者和所属组都是此用户,权限是700
        超级用户:/root/,所有者和所属组都是root用户,权限是500
    2).用户的邮箱
        /var/spool/mail/用户名/
    3).用户模板目录
        /etc/skel/
3.用户管理命令
    1).用户添加命令useradd
        ①.useradd命令格式
            -u UID:手工指定用户的UID号
            -d 家目录:手工指定用户的家目录
            -c 用户说明:手工指定用户的说明
            -g 组名:手工指定用户的初始组
            -G 组名:指定用户的附加组
            -s shell:手工指定用户的登录Shell,默认是/bin/bash
    2).修改用户密码passwd
        ①.passwd命令格式
            -S:查询用户密码的密码状态.仅root用户可用
            -l:暂时锁定用户.仅root用户可用
            -u:解锁用户.仅用户可用
            --stdin:可以通过管道符输出的数据作为用户的密码
    3).修改用户信息usermod,修改用户密码状态chage
        ①.修改用户信息usermod
            -u UID:修改用户的UID号
            -c 用户说明:修改用户的说明信息
            -G 组名:修改用户的附加组
            -L:临时锁定用户
            -U:解锁用户锁定
        ②.修改用户密码状态chage
            -l:列出用户的详细密码状态
            -d 日期:修改密码最后一次更改日期(shadow3字段)
            -m 天数:两次密码修改间隔(4字段)
            -M 天数:密码有效期(5字段)
            -W 天数:密码过期前警告天数(6字段)
            -I 天数:密码过后宽限天数(7字段)
            -E 日期:帐号失效时间(8字段)
    4).删除用户userdel,用户切换命令su
        ①.删除用户userdel
            -r:删除用户的同时删除用户家目录
        ②.查看用户ID
            id 用户名
        ③.切换用户身份su(su - 用户名)
            -:选项只使用"-"代表连带用户的环境变量一起切换,["-"必须加上]
            -c 命令:仅执行一次命令,而不切换用户身份
4.用户组管理命令
    1).添加用户组
        groupadd 组名【-g GID:指定组ID】
    2).修改用户组
        groupmod 组名【-g GID:修改组ID,-n 新组名:修改组名】
    3).删除用户组
        groupdel 组名
    4).把用户添加入组或从组中删除
        gpasswd 选项 组名【-a 用户名:把用户加入组,-d 用户名:把用户从组中删除】
### 七、权限管理
1.ACL权限
    1).ACL权限简介与开启
        ①.
        ②.查看分区ACL权限是否开启
            dumpe2fs -h /dev/sda3【dumpe2fs命令是查询指定分区详细文件系统信息的命令,-h:仅显示超级块中信息,而不显示磁盘块组的详细信息】
        ③.临时开启分区ACL权限
            mount -o remount,acl /【重新挂载根分区,并挂载加入acl权限】
        ④.永久开启分区ACL权限
            vim /etc/fstab【进入编辑模式,UUID=asdqq-qweqwe-qweqwe-qweqew-qweqwe2131123 / ext4 defaults,acl 1 1(加入acl)】
            mount -o remount /【重新挂载文件系统,使修改生效】
    2).查看与设定ACL权限
        ①.查看ACl命令
            getfacle 文件名【查看acl权限】
        ②.设定ACL权限的命令(setfacl 选项 文件名)
            -m:设定ACl权限(u:用户名:权限)
            -x:删除指定的ACl权限
            -b:删除所有的ACl权限
            -d:设定默认ACL权限
            -k:删除默认ACL权限
            -R:递归设定ACL权限
    3).最大有效权限与删除ACL权限
        ①.最大有效权限mask
            mask是用来指定最大有效权限的.如果我给用户赋予了ACL权限,是需要和mask的权限"相与"才能得到用户的真正权限
            setfacl -m m:rx 文件名【修改最大有效权限,设定mask权限为r-x.使用"m:权限"格式】
        ②.删除ACL权限
            setfacl -x u:用户名 文件名【删除指定用户的ACl权限】
            setfacl -x g:组名 文件名【删除指定用户组的ACl权限】
            setfacl -b 文件名【会删除文件的所有的ACL权限】
    4).默认ACL权限和递归ACL权限
        ①.递归ACL权限
            递归是父目录在设定ACL权限时,所有的子文件和子目录也会拥有相同的ACl权限
            setfacl -m u:用户名:权限 -R 文件名
        ②.默认ACL权限
            默认ACl权限的作用是如果给父目录设定了默认ACl权限,那么父目录中所有新建的子文件都会继承父目录的ACL权限.
            setfacl -m d:u:用户名:权限 文件名
2.文件特殊权限
    1).SetUID
        ①.SetUID的功能
            >只有可以执行的二进制程序才能设定SUID权限
            >命令执行者要对该程序拥有x(执行)权限
            >命令执行者在执行该程序时获得该程序文件属主的身份(在执行程序的过程中灵魂附体为文件的属主)
            >SetUID权限只在该程序执行过程中有效,也就是说身份改变只在程序执行过程中有效.
            >passwd命令拥有SetUID权限,所以普通可以修改自己的密码[ll /usr/bin/passwd]
            >cat命令没有SetUID权限,所以普通用户不能查看/etc/shadow文件[ll /bin/cat]
        ②.设定SetUID的方法
            >4代表SUID[chmod 4755 文件名,chmod u+s 文件名]
        ③.取消SetUID的方法
            >chmod 755 文件名
            >chmod u-s 文件名
        ④.危险的SetUID
            >关键目录应严格控制写权限.比如"/"、"/usr"等
            >用户的密码设置要严格遵守密码的三原则
            >对系统中默认应该具有SetUID权限的文件做一列表,定时检查有没有这之外的文件被设置了SetUID权限.
    2).SetGID
        ①.SetGID针对文件的作用
            >只有可执行的二进制程序才能设置SGID权限
            >命令执行者要对该程序拥有x(执行)权限
            >命令执行在执行程序的时候,组身份升级为该程序文件的属组.
            >SetGID权限同样只在该程序执行过程中有效,也就是说组身份改变只在程序执行过程中有效.
            >/usr/bin/locate是可执行二进制程序,可以赋予SGID.
            >执行用户lamp对/usr/bin/locate命令拥有执行权限.
            >执行/usr/bin/locate命令时,组身份会升级为slocate组,而slocate组对/var/lib/mlocate/mlocate.db数据库拥有r权限,所以普通用户可以使用locate命令,查询mlocate.db数据库.
            >命令结束,lamp用户的组身份返回为lamp组.
        ②.SetGID针对目录的作用
            >普通用户必须对此目录拥有r和x权限,才能进入此目录.
            >普通用户在此目录中的有效组会变成此目录的属组.
            >若普通用户对此目录拥有w权限时,新建的文件默认属组是这个目录的属组.
        ③.设定SetGID
            >2代表SGID[chmod 2755 文件名,chmod g+s 文件名]
        ④.取消SetGID
            >chmod 755 文件名
            >chmod g-s 文件名
    3).Sticky BIT
        ①.SBIT粘着位作用
            >粘着位目录只针对目录有效
            >普通用户对该目录拥有w和x权限,即普通用户可以在此目录拥有写入权限.
            >如果没有粘着位,因为普通用户拥有w权限,所以可以删除此目录下所有文件,包括其他用户建立的文件.一但赋予了粘着位,除了root可以删除所有文件,普通用户就算拥有w权限,也只能删除自己建立的文件,但是不能删除其他用户建立的文件.
        ②.设置与取消粘着位
            >设置粘着位
                chmod 1775 目录名
                chmod o+t 目录名
            >取消粘着位
                chmod 777 目录名
                chmod o-t 目录名
3.文件系统属性chattr权限
    1).chattr命令格式
        chattr [+-=][选项] 文件或目录名【+:增加权限,-:删除权限,=:等于某权限】
            选项:>i:如果对文件设置i属性,那么不允许对文件进行删除、改名,也不能添加和修改数据;如果对目录设置i属性,那么只能修改目录下文件的数据,但不允许建立和删除文件.
                     >a:如果对文件设置a属性,那么只能在文件中增加数据,但是不能删除也不能修改数据;如果对目录设置a属性,那么只允许在目录中建立和修改文件,但是不允许删除.
    2).查看文件系统属性
        lsattr 选项 文件名【-a:显示所有文件和目录,-d:若目标是目录,仅列出目录本身的属性,而不是子文件的】
4.系统命令sudo权限
    1).sudo权限
        >root把本来只能超级用户执行的命令赋予普通用户执行.
        >sudo的操作对象是系统命令.
    2).sudo使用
        >visudo【实际修改的是/etc/sudoers文件】
            root ALL=(ALL) ALL
            #用户名 被管理主机的地址=(可使用的身份) 授权命令(绝对路径)
            %whell ALL=(ALL) ALL
            #%组名 被管理主机的地址=(可使用的身份) 授权命令(绝对路径)
    3).授权sc用户可以重启服务器
        >visudo【进入vim编辑模式】
            sc ALL=/sbin/shutdown -r now【例】
    4).普通用户执行sudo赋予的命令(不建议给普通用户授权vim这样的工具权限)
        sudo -l【查看可用的sudo命令】
        sudo /sbin/shutdown -r now【普通用户执行sudo赋予的命令】
### 八、文件系统管理
1.回顾分区和文件系统
    1).分区类型
        >主分区:总共最多只能分四个
        >扩展分区:只能有一个,也算做主分区的一种,也就是说主分区加扩展分区最多有四个.但是扩展分区不能存储数据和格式化,必须再划分成逻辑分区才能使用.
        >逻辑分区:逻辑分区是在扩展分区中划分的,如果是IDE硬盘,Linux最多支持59个逻辑分区,如果是SCSI硬盘Linux最多支持11个逻辑分区.
    2).文件系统
        >ext2:是ext文件系统的升级版本,RedHatLinux7.2版本以前的系统默认都是ext2文件系统.1993年发布,最大支持16TB的分区和最大2TB的文件.
        >ext3:ext3文件系统是ext2文件系统的升级版本,最大的区别就是带日志功能,以在系统突然停止时提高文件系统的可靠性.支持最大16TB的分区和最大2TB的文件.
        >ext4:它是ext3文件系统的升级版.ext4在性能、伸缩性和可靠性方面进行了大量改进.ext4的变化可以说是翻天覆地的,比如向下兼容ext3、最大1EB文件系统和16TB文件、无线数量子目录、extents连续数据块概念、多块分配、延迟分配、持久预分配、快速FSCK、日志校验、无日志模式、在线碎片整理、inode增强、默认启用barrier等.
2.文件系统常用命令
    1).df命令、du命令、fsck命令和dump2fs命令
        ①.文件系统查看命令df[df 选项 挂载点]
            -a:显示所有的文件系统信息,包括特殊文件系统,如/proc、/sysfs
            -h:使用习惯单位显示容量,如KB,MB或GB等.
            -T:显示文件系统类型
            -m:以MB为单位显示容量
            -k:以KB为单位显示容量.默认就是以KB为单位.
        ②.统计目录或文件大小[du 选项 目录或文件名]
            -a:显示每个子文件的磁盘占用量.默认只统计子目录的磁盘占用量.
            -h:使用习惯单位显示磁盘占用量,如KB,MB或GB等.
            -s:统计总占用量,而不列出子目录和子文件的占用量.
        ③.du命令和df命令的区别
            >df命令是从文件系统考虑的,不光要考虑文件占用的空间,还要统计被命令或程序占用的空间(最常见的就是文件已经删除,但是程序并没有释放空间)
            >du命令是面向文件的,只会计算文件或目录占用的空间.
        ④.文件系统修复命令fsck[fsck 选项 分区设备文件名]
            -a:不用显示用户提示,自动修复文件系统.
            -y:自动修复.和-a作用一致,不过有些文件系统只支持-y.
        ⑤.显示磁盘状态命令dumpe2fs[dumpe2fs 分区设备文件名]
    2).挂载命令
        ①.查询与自动挂载
            >mount -l【查询系统中已经挂载的设备,-l:会显示卷标名称】
            >mount -a【依据配置文件/etc/fstab的内容,自动挂载】
        ②.挂载命令格式
            >mount [选项] 设备文件名 挂载点【挂载命令】
            -t 文件系统:加入文件系统类型来指定挂载的类型,可以ext3、ext4、iso9660等文件系统.
            -L 卷标名:挂载指定卷标的分区,而不是安装设备文件名挂载.
            -o 特殊选项:可以指定挂载的额外选项.
            >atime/noatime:更新访问时间/不更新访问时间.访问分区文件时,是否更新文件的访问时间,默认为更新.
            >async/sync:异步/同步,默认为异步.
            >auto/noauto:自动/手动,mount -a命令执行时,是否会自动安装/etc/fstab文件内容挂载,默认为自动.
            >defaults:定义默认值,相当于rw,suid,dev,exec,auto,nouser,async这七个选项.
            >exec/noexec:[常用]执行/不执行,设定是否允许在文件系统中执行可执行文件,默认是exec允许.
            >remount:[常用]重新挂载已经挂载的文件系统,一般用于指定修改特殊权限.
            >rw/ro:读写/只读,文件系统挂载时,是否具有读写权限,默认是rw.
            >suid/nosuid:具有/不具有SUID权限,设定文件系统是否具有SUID和SGID的权限,默认是具有.
            >user/nouser:允许/不允许普通用户挂载,设定文件系统是否允许普通用户挂载,默认是不允许,只有root可以挂载分区.
            >usrquota:写入代表文件系统支持用户磁盘配额,默认不支持.
            >grpquota:写入代表文件系统支持组磁盘配额,默认不支持.
    3).挂载光盘与U盘
        ①.挂载光盘
            >mkdir /mnt/cdrom/【建立挂载点】
            >mount -t iso9660 /dev/cdrom /mnt/cdrom/或mount /dev/sr0 /mnt/cdrom/【挂载光盘】
        ②.卸载命令[umount 设备文件名或挂载点]
            umount /mnt/cdrom/
        ③.挂载U盘
            >fdisk -l【查看U盘设备文件名】
            >mount -t vfat /dev/sdb1 /mnt/usb/【注意:Linux默认不支持NTFS文件系统】
        ④.卸载U盘
            >umount /mnt/usb/
    4).支持NTFS文件系统
        ①.下载NTFS-3G插件
            
Open Source: NTFS-3G
②.安装NTFS-3G tar -zxf ntfs-3g_ntfsprogs-2015.3.14.tgz【解压】 cd ntfs-3g_ntfsprogs-2015.3.14【进入解压目录】 ./configure【编译器准备,没有指定安装目录,安装到默认位置中】 make【编译】 make install【编译安装】 ③.使用 mount -t ntfs-3g 分区设备文件名 挂载点【mount -t ntfs-3g /dev/sdb1 /mnt/usb/】 ④.卸载NTFS移动硬盘 >umount /mnt/usb/ 3.fdisk分区 1).fdisk命令分区过程 ①.添加新硬盘 ②.查看新硬盘 fdisk -l ③.使用fdisk命令分区 fdisk /dev/sdb >--------fdisk交互指令说明-------- >a:设置可引导标记 >b:编辑bsd磁盘标签 >c:设置DOS操作系统兼容标记 >d:删除一个分区 >l:显示已知的文件系统类型.82为Linux swap分区,83为Linux分区 >m:显示帮助菜单 >n:新建分区 >o:建立空白DOS分区表 >p:显示分区列表 >q:不保存退出 >s:新建空白SUN磁盘标签 >t:改变一个分区的系统ID >u:改变显示记录单位 >v:验证分区表 >w:保存退出 >x:附加功能(仅专家) ④.重新读取分区表信息 partprobe ⑤.格式化分区 mkfs -t ext4 /dev/sdb1 2).分区自动挂载与fstab文件修复 ①./etc/fstab文件[/dev/sdb1 /disk1 ext4 defaults 1 2] >第一字段:分区设备文件名或UUID(硬盘通用唯一识别码) >第二字段:挂载点 >第三字段:文件系统名称 >第四字段:挂载参数 >第五字段:指定分区是否被dump备份,0代表不备份,1代表每天备份,2代表不定期备份 >第六字段:指定分区是否被fsck检测,0代表不检测,其他数字代表检测的优先级,那么当然1的优先级比2高 ②.mount -a【依据配置文件/etc/fstab的内容,自动挂载】 ③./etc/fstab文件修复 mount -o remount,rw / 4.分配swap分区 1).free命令 free【查看内存与swap分区使用状况】 >cached(缓存):是指把读取出来的数据保存在内存当中,当再次读取时,不用读取硬盘而直接从内存当中读取,加速了数据的读取过程. >buffer(缓存):是指在写入数据时,先把分散的写入操作保存到内存当中,当达到一定程度再集中写入硬盘,减少了磁盘碎片和硬盘的反复寻道,加速了数据的写入过程 2).新建swap分区 fdisk /dev/sdb【别忘记把分区ID改为82】 3).格式化 mkswap /dev/sdb6 4).加入swap分区 swapon /dev/sdb6【加入swap分区】 swapoff /dev/sdb6【取消swap分区】 5).swap分区开机自动挂载 vim /etc/fstab【进入vim命令模式】 /dev/sdb6 swap swap defaults 0 0


# 十、Shell基础 ## 1.Shell概述

1).shell是什么

shell是一个命令行解释器,它为用户提供了一个向Linux内核发送请求以便运行程序的界面系统级程序,用户可以用shell来启动、挂起、停止甚至是编写一些程序.
shell还是一个功能相当强大的编程语言,易编写,易调试,灵活性较强.shell是解释执行的脚本语言,在shell中可以直接调用Linux系统命令.
2).shell的分类
bourne shell:从1979起Unix就开始使用bourne shell,bourne shell的主文件名为sh.
bash:bash与sh兼容,现在使用的Linux就是使用bash作为用户的基本shell
3).Linux支持的Shell
cat /etc/shells



## 2.Shell脚本的执行方式
    1).echo输出命令[echo 选项 输出内容]
        -e:支持反斜线控制的字符转换[echo -e "abc\n"]
        ------转义字符--------
        \\:输出/本身
        \a:输出警告声
        \b:退格键,也就是向左删除键
        \c:取消输出行末的换行符.和"-n"选项一致
        \e:ESCAPE键
        \f:换页符
        \n:换行符
        \r:回车符
        \t:制表符,也就是Tab键
        \v:垂直制表符
        \0nnn:按照八进制ASCII码表输出字符.其中0为数字零,nnn是三位八进制数
        \xhh:按照十六进制ASCII码输出字符.其中hh是两位十六进制数
    2).第一个脚本
        vim /tmp/helloworld.sh
        #!/bin/bash【shell脚本必须填写这个标题】
    3).脚本执行
        >赋予执行权限,直接运行
            chmod 755 /tmp/helloworld.sh【分配权限】
            /tmp/helloworld.sh【执行】
        >通过Bash调用执行脚本
            bash /tmp/helloworld.sh【执行】




## 3.bash的基本功能
    1).历史命令与命令补全
        ①.历史命令
            history 选项 历史命令保存文件
            -c:清空历史命令
            -w:把缓存中的历史命令写入历史命令保存文件
            &gt;.bash_history【家目录的常用命令保存文件】
            &gt;历史命令默认会保存1000条,可以在环境变量配置文件/etc/profile中进行修改
            &gt;历史命令的调用
                /使用上、下箭头调用以前的历史命令
                /使用"!n"重复执行第n条历史命令
                /使用"!!"重复执行上一条命令
                /使用"!字串"重复执行最后一条以该字串开头的命令
        ②.命令与文件补全
            &gt;在bash中,命令与文件补全是非常方便与常用的功能,我们只要在输入命令或文件时,按"Tab"键就会自动进行补全
    2).命令别名与常用快捷键
        ①.命令别名
            alias 别名='原命令'【设定命令别名】
            alias【查询命令别名】
            &gt;命令执行时顺序
                1.第一顺位执行用绝对路径或相对路径执行的命令
                2.第二顺位执行别名
                3.第三顺位执行bash的内部命令
                4.第四顺位执行按照$PATH环境变量定义的目录查找顺序找到的第一个命令
            &gt;让别名永久生效
                vim /root/.bashrc
            &gt;删除别名
                unalias 别名
        ②.bash常用快捷键
            ctrl+a:把光标移动到命令行开头.如果我们输入的命令过长,想要把光标移动到命令行开头时使用
            ctrl+e:把光标移动到命令行结尾
            ctrl+c:强制终止当前的命令
            ctrl+l:清屏,相当于clear命令
            ctrl+u:删除或剪切光标之前的命令.我输入了一行很长的命令,不用使用退格键一个一个字符的删除,使用这个快捷键会更加方便
            ctrl+k:删除或剪切光标之后的内容
            ctrl+y:粘贴ctr+u或ctrl+k剪切的内容
            ctrl+r:在历史命令中搜索,按下ctrl+r之后,就会出现搜索界面,只要输入搜索内容,就会从历史命令中搜索
            ctrl+d:退出当前终端
            ctrl+z:暂停,并放入后台.这个快捷键牵扯工作管理的内容,我们在系统管理章节详细介绍
            ctrl+s:暂停屏幕输出
            ctrl+q:恢复屏幕输出
    3).输入输出重定向
        ①.标准输入输出
            | 设备 | 设备文件名 | 文件描述符 | 类型      |
            | 键盘 | /dev/stdin|    0       |标准输入    |
            |显示器|/dev/sdtout|    1       |标准输出    |
            |显示器|/dev/sdterr|    2       |标准错误输出|
        ②.输出重定向
            -----------------------------------------------------------------------------------
         |       类型      |    符号     |      作用
         |------------------------------------------------------------------------------------
         |                 |   命令&gt;文件  |以覆盖的方式,把命令的正确输出输出到指定的文件或设备当中
         |  标准输出重定向  |-----------------------------------------------------------------
         |                 |   命令&gt;&gt;文件 |以追加的方式,把命令的正确输出输出到指定的文件或设备当中
            -------------------------------------------------------------------------------------
         |                 |  错误名2&gt;文件 |以覆盖的方式,把命令的错误输出输出到指定的文件或设备当中
         |标准错误输出重定向|-------------------------------------------------------------------
         |                 |错误命令2&gt;&gt;文件|以追加的方式,把命令的错误输出输出到指定的文件或设备当中

-------------------------------------------------------------------------------------

         |               |命令&gt;文件2&gt;&amp;1     |以覆盖的方式,把正确输出和错误输出都保存到同一个文件中
         |               |命令&gt;&gt;文件2&gt;&amp;1    | 以追加的方式,把正确输出和错误输出都保存到同一个文件中
         |正确输出和      |命令&amp;&gt;文件       | 以覆盖的方式,把正确输出和错误输出都保存到同一个文件中
         |错误输出同时保存|命令&amp;&gt;&gt;文件       |以追加的方式,把正确输出和错误输出都保存到同一个文件中
         |               |命令&gt;&gt;文件 2&gt;&gt;文件|把正确的输出追加到文件1中,把错误的输出追加到文件2中
          ------------------------------------------
        ③.输入重定向
            wc [选项] [文件名]【-c:统计字节数,-w:统计单词数,-l:统计行数】
            命令dd if=输入文件 of=输出文件 bs=字节数 count=个数
                if:指定源文件或源设备
                of:指定目标文件或目标设备
                bs:指定一次输入/输出多少字节,即把这些字节看做一个数据块
                count:指定输入/输出多少个数据块
        ②.管道符
            命令1 | 命令2【命令1的正确输出作为命令2的操作对象】
            &gt;grep [选项] "搜索内容"
                -i:忽略大小写
                -n:输出行号
                -v:反向查找
                --color=auto:搜索出的关键字用颜色显示
    5).通配符与其他特殊符号
        ①.通配符
            ?:匹配一个任意字符
            *:匹配0个或多个任意字符,也就是可以匹配任何内容
            []:匹配中括号中任意一个字符.例如:[abc]代表一定匹配一个字符,或者是a,或者是b,或者是c
            [-]:匹配中括号中任意一个字符,-代表一个范围.例如:[a-z]代表匹配一个小写字母
            [^]:逻辑非,表示匹配不是中括号内的一个字符.例如:[^0-9]代表匹配一个不是数字的字符
        ②.bash中其他特殊符号
            '':单引号,在单引号中所有的特殊符号,如"$"和"`"(反引号)都没有特殊含义.
            "":双引号,在双引号中特殊符号都没有特殊含义,但是"$"、"`"和"\"是例外,拥有"调用变量的值"、"引用命令"和"转义符"的特殊含义
            ``:反引号,反引号括起来的内容是系统命令,在bash中会先执行它.和$()作用一样,不过推荐使用$(),因为反引号非常容易看错.
            $():和反引号作用一样,用来引用系统命令
            #:在shell脚本中,#开头的行代表注释.
            $:用于调用变量的值,如需要调用变量name的值时,需要用$name的方式得到变量的值.
            \:转义符,跟在\之后的特殊符号将失去特殊含义,变为普通字符.如\$将输出"$"符号,而不当做是变量引用.

## 4.bash的变量
    1).用户自定义变量
        &gt;变量定义[name='hello world']
        &gt;变量叠加[name="$name"123456]
        &gt;变量调用[echo $name]
        &gt;变量查看[set]
        &gt;变量删除[unset name]
    2).环境变量
        ①.环境变量是什么
            &gt;用户自定义变量只在当前的shell中生效,而环境变量会在当前shell和这个shell的所有子shell当中生效.如果把环境变量写入相应的配置文件,那么这个环境变量就会在所有的shell中生效.
        ②.设置环境变量
            export 变量名=变量值【申明变量】
            env【查询变量】
            unset 变量名【删除变量】
        ③.系统常见环境变量
            &gt;PATH:系统查找命令的路径
                echo $PATH /usr/lib/qt-3.3/bin:/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin:/root:bin
            &gt;PATH:"$PATH":/root/bin【PATH变量叠加】
            &gt;PS1定义系统提示符的变量【PS1='[\[email protected]\h \w]\$ '】
                \d:显示日期,格式为"星期 月 日"
                \h:显示简写主机名.如默认主机名"localhost"
                \t:显示24小时制时间,格式为"HH:MM:SS"
                \T:显示12小时制时间,格式为"HH:MM:SS"
                \A:显示24小时制时间,格式为"HH:MM"
                \u:显示当前用户名
                \w:显示当前所在目录的完整名称
                \W:显示当前所在目录的最后一个目录
                \#:执行的第几个命令
                \$:提示符.如果是root用户会显示提示符为"#",如果是普通用户会显示提示符为"$"
    3).位置参数变量
        $n:n为数字,$0代表命令本身,$1-$9代表第一到第九个参数,十以上的参数需要用大括号包含,如${10}
        $*:这个变量代表命令行所有的参数,$*把所有的参数看成一个整体
        [email protected]:这个变量也代表命令行中所有的参数,不过[email protected]把每个参数区分对待
        $#:这个变量代表命令行中所有参数的个数
    4).预定义变量
        ①.预定义变量
            $?:最后一次执行的命令的返回状态.如果这个变量的值为0,证明上一个命令正确执行;如果这个变量的值为非0(具体是哪个数,由命令自己来决定),则证明上一个命令执行不正确了.【常用】
            $$:当前进程的进程号(PID)
            $!:后台运行的最后一个进程的进程号(PID)
        ②.接收键盘输入
            read [选项] [变量名]【read -s -p "请输入动态口令: " kouling echo "您输入的口令是: $koulin"】
                -p "提示信息":在等待read输入时,输出提示信息
                -t 秒数:read命令会一直等待用户输入,使用此选项可以指定等待时间
                -n 字符数:read命令只接受指定的字符数,就会执行
                -s:隐藏输入的数据,适用于机密信息的输入
## 5.bash的运算符

    1).数值运算与运算符
        ①.declare [+/-] [选项] 变量名【declare声明变量类型】
                -:给变量设定类型属性
                +:取消变量的类型属性
                -i:将变量声明为整数型(integer)
                -x:将变量声明为环境变量
                -p:显示指定变量的被声明的类型
        ②.数值运算-方法
            declare -i cc=$aa+$bb
            dd=$(expr $aa+$bb)【expr或let数值运算工具】
            ff=$(($aa+$bb))【"$((运算式))"或"$[运算式]"】
        ③.运算符
            优先级|  运算符       |说明
            --------------------------------------------------------
            13      -,+                 单目负,单目正
            12      !,~                     逻辑非,按位取反或补码
            11      *,/,%                   乘,除,取模
            10      +,-                     加,减
            9           &gt;                    按位左移,按位右移
            8            =,                 小于或等于,大于或等于,小于,大于
            7           ==,!=                   等于,不等于
            6           &amp;                           按位与
            5           ^                           按位异或
            4           |                           按位或
            3           &amp;&amp;                      逻辑与
            2           ||                      逻辑或
            1           =,+=,-=,*=,/=,%=,&amp;=,^=,|=,&gt;=             赋值,运算且赋值
    2).变量测试与内容替换
        变量置换方式 | 变量y没有设值                     |  变量y为空值          |  变量y设值
        ----------------------------------------------------------------------------------
        x=${y-新值}   x=新值                             x为空                   x=$y
        x=${y:-新值}  x=新值                             x=新值                  x=$y
        x=${y+新值}   x为空                              x=新值                  x=新值
        x=${y:+新值}  x为空                              x为空                   x=新值
        x=${y=新值}   x=新值,y=新值                      x为空,y值不变            x=$y,y值不变
        x=${y:=新值}  x=新值,y=新值                      x=新值,y=新值            x=$y,y值不变
        x=${y?新值}   新值输出到标准错误输出(就是屏幕)    x为空                    x=$y
        x=${y:?新值}  新值输出到标准错误输出              新值输出到标准错误输出   x=$y



## 6.环境遍历配置文件
    1).环境变量配置文件简介
        ①.source命令
            source 配置文件【强制配置文件生效】
            . 配置文件【强制配置文件生效】
        ②.环境变量配置文件简介
            &gt;环境变量配置文件中主要是定义对系统的操作环境生效的系统默认环境变量,比如PATH,HISTSIZE,PS1,HOSTNAME等默认环境变量.
            &gt;/etc/profile
            &gt;/etc/profile.d/*.sh
            &gt;~/.bash_profile
            &gt;~/.bashrc
            &gt;/etc/bashrc
    2).环境变量配置文件作用
        ①./etc/profile的作用
            &gt;USER变量
            &gt;LOGNAME变量
            &gt;MAIL变量
            &gt;PATH变量
            &gt;HOSTNAME变量
            &gt;HISTSIZE变量
            &gt;umask
            &gt;调用/etc/profile.d/*.sh文件
    3).其它配置文件和登录信息
        ①.注销时生效的环境变量配置文件
            ~/.bash_logout
        ②.其他配置文件
            ~/.bash_history
        ③.shell登录信息
            &gt;本地终端欢迎信息:/etc/issue
                \d:显示当前系统日期
                \s:显示操作系统名称
                \l:显示登录的终端号,这个比较常用
                \m:显示硬件体系结构,如i286,i686等
                \n:显示主机名
                \o:显示域名
                \r:显示内核版本
                \t:显示当前系统时间
                \u:显示当前登录用户的序列号
            &gt;远程终端欢迎信息:/etc/issue.net
                转义符在/etc/issue.net文件中不能使用
                是否显示此欢迎信息,由ssh的配置文件/etc/ssh/sshd_config决定,加入"Banner /etc/issue.net"行才能显示(记得重启SSH服务)

登录后欢迎信息:/etc/motd
不管是本地登录,还是远程登录,都可以显示此欢迎信息
```


(未完待续)


华树超独立博客 ,版权所有丨如未注明 , 均为原创, 转载请注明,!谢谢合作!
喜欢 (0)
支付宝[]
分享 (0)
关于作者:
我之所以这么努力是因为我什么都没有,却什么都想要!
发表我的评论
取消评论
表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址