一、Linux简要介绍

  1. Linux命令基础
  2. Linux命令帮助
  3. 目录与文件基本操作

Linux家族

  1. Redhat 红帽 三个认证 (开源但是不免费)---》社区(系统开发者)---》Centos(服务器端)
  2. Ubuntu 最好的客户端系统,开源纯免费(软件开发人群)
  3. Debian ---》kali Linux(专用工具资源占用很少) 树莓派
  4. suse Linux---》ISP(电信,移动,联通) 定制版

shell——Linux系统的一种特殊程序——“翻译官”

用户登录Linux系统时就自动加载一个shell程序,Bash是Linux系统中默认使用的shell程序

Linux的内核是由C语言开发出来的(面向过程的语言),应用程序是用c++开发

编译器—— gcc gcc-c++ jdk(Java的编译器)Python的编译器就是Python2/3

源码文件———》(编译器)——》执行文件

Linux命令的分类

  1. 内部命令
  2. 外部命令
通用的命令行使用格式:

命令字 [选项] [参数] (对应于操作、功能、操作对象)

  1. -单个字符的组合
  2. -- 单词

对root@localhost ~]# 的介绍

  1. root ——当前用户
  2. @ ——分隔符
  3. localhost ——主机名字
  4. ~ ——当前目录位置
  5. #——管理员
  6. $ ——普通用户

路径简介

绝对路径:例如——/etc/sysconfig/network-scripts/

相对路径(以当前所在位置的路径):例如——sysconfig/

家目录:管理员(/root) 普通用户(/home)

根目录: /

二、Linux命令集(结合实例)

cd:切换工作目录

pwd:查看当前所在的绝对目录路径

[root@lokott ~]# cd /etc/sysconfig/network-scripts/  //进入绝对路径下的文件夹
[root@lokott network-scripts]# pwd      //显示当前所在的目录的绝对路径
/etc/sysconfig/network-scripts
[root@lokott network-scripts]# cd - //返回上次进入的目录命令,即cd /etc/sysconfig/network-scripts/
/root
[root@lokott ~]# cd -
/etc/sysconfig/network-scripts
[root@lokott network-scripts]# cd ..    //返回上层目录 
[root@lokott sysconfig]# cd ../../    //返回上两层目录 
[root@lokott /]# 

ls:显示当前目录的内容

  1. -l 显示文件详细信息
  2. -a 查看隐藏文件
  3. -A 查看除了. .. 的隐藏文件
  4. -d 显示本目录的信息
  5. -h 友好形式显示带有单位的信息
  6. -R 递归显示
  7. -- color 以颜色区分文件类型
    1. 黑色(数据文件)
    2. 蓝色(目录)
    3. 红色(压缩包)
    4. 绿色(执行文件/命令文件/脚本)
    5. 天蓝色(链接文件)
    6. 黄的(设备文件/磁盘文件)
[root@lokott ~]# ls
anaconda-ks.cfg  initial-setup-ks.cfg  note  shell  公共  模板  视频  图片  文档  下载  音乐  桌面
[root@lokott ~]# cd shell/
[root@lokott shell]# ls 
1.sh  2.sh  3.sh  4.sh  5.sh  6.sh  hello
[root@lokott shell]# ls -a
.  ..  1.sh  2.sh  3.sh  4.sh  5.sh  6.sh  hello
[root@lokott shell]# ls -A
1.sh  2.sh  3.sh  4.sh  5.sh  6.sh  hello
[root@lokott shell]# ls -l
总用量 24
-rwxr-xr-x. 1 root root 111 10月 25 19:10 1.sh
-rwxr-xr-x. 1 root root 124 10月 25 19:12 2.sh
-rwxr-xr-x. 1 root root 192 10月 25 19:25 3.sh
-rwxr-xr-x. 1 root root 104 10月 25 19:33 4.sh
-rwxr-xr-x. 1 root root 147 10月 25 19:36 5.sh
-rwxr-xr-x. 1 root root  26 10月 25 19:37 6.sh
drwxr-xr-x. 2 root root  18 10月 30 13:53 hello
[root@lokott shell]# ls -R
.:
1.sh  2.sh  3.sh  4.sh  5.sh  6.sh  hello

./hello:
0.sh
[root@lokott shell]# ls -d
.
[root@lokott shell]# ls -ah
.  ..  1.sh  2.sh  3.sh  4.sh  5.sh  6.sh  hello

[root@lokott shell]# ls -lR
.:
总用量 24
-rwxr-xr-x. 1 root root 111 10月 25 19:10 1.sh
-rwxr-xr-x. 1 root root 124 10月 25 19:12 2.sh
-rwxr-xr-x. 1 root root 192 10月 25 19:25 3.sh
-rwxr-xr-x. 1 root root 104 10月 25 19:33 4.sh
-rwxr-xr-x. 1 root root 147 10月 25 19:36 5.sh
-rwxr-xr-x. 1 root root  26 10月 25 19:37 6.sh
drwxr-xr-x. 2 root root  18 10月 30 13:53 hello

./hello:
总用量 0
-rwxrwxrwx. 1 root root 0 10月 30 13:53 0.sh
[root@lokott shell]# 

alias:给命令取一个别名

du:统计目录及文件空间占用情况

  1. -a
  2. -h 友好显示
  3. -s

which: 查找命令存放目录

  1. 搜索范围由环境变量PATH决定

mkdir:创建目录

  1. -p递归嵌套创建

touch:创建文件

[root@lokott shell]# alias c='clear'   //clear是表示清屏相当于Ctrl+l的操作
[root@lokott shell]# which c   
alias c='clear'
    /usr/bin/clear
[root@lokott shell]# which clear
/usr/bin/clear
[root@lokott shell]# mkdir linux
[root@lokott shell]# ls
1.sh  2.sh  3.sh  4.sh  5.sh  6.sh  hello  linux
[root@lokott shell]# touch 0.sh
[root@lokott shell]# ls
0.sh  1.sh  2.sh  3.sh  4.sh  5.sh  6.sh  hello  linux
[root@lokott shell]# du -ah
4.0K    ./1.sh
4.0K    ./2.sh
4.0K    ./3.sh
4.0K    ./4.sh
4.0K    ./5.sh
4.0K    ./6.sh
0   ./hello/0.sh
0   ./hello
0   ./linux
0   ./0.sh
24K .
[root@lokott shell]# du -sh
24K .
[root@lokott shell]# du -as             //不可以设置选项为-as(h)
du: 不能既显示总用量,同时又显示每个项目
Try 'du --help' for more information.
[root@lokott shell]# 
[root@lokott shell]# mkdir -p  /2019/2018/2017   //连续创建文件夹
[root@lokott shell]# cd /2019/2018/2017/
[root@lokott 2017]# touch {1..10}.txt  //..表示创建连续10个名为1-10的txt文件
[root@lokott 2017]# ls
10.txt  1.txt  2.txt  3.txt  4.txt  5.txt  6.txt  7.txt  8.txt  9.txt

下面的操作过程中会出现文件节点(inode值):文件在磁盘中存储的标识序列 ln:创建链接文件(类似于Windows系统的快捷方式)

  1. 软链接:相当于快捷方式 -s
  2. 硬链接:给文件取别名(无法创建硬链接文件夹)
[root@lokott shell]# ln -s 1.sh 8.sh
[root@lokott shell]# ln 1.sh 10.sh
[root@lokott shell]# ls -l
总用量 28
-rwxrwxrwx. 1 root root   0 10月 30 13:59 0.sh
-rwxr-xr-x. 2 root root 111 10月 25 19:10 10.sh  //硬链接
-rwxr-xr-x. 2 root root 111 10月 25 19:10 1.sh
-rwxr-xr-x. 1 root root 124 10月 25 19:12 2.sh
-rwxr-xr-x. 1 root root 192 10月 25 19:25 3.sh
-rwxr-xr-x. 1 root root 104 10月 25 19:33 4.sh
-rwxr-xr-x. 1 root root 147 10月 25 19:36 5.sh
-rwxr-xr-x. 1 root root  26 10月 25 19:37 6.sh
lrwxrwxrwx. 1 root root   4 10月 30 14:07 8.sh -> 1.sh  //软链接
drwxr-xr-x. 2 root root  18 10月 30 13:53 hello
drwxr-xr-x. 2 root root   6 10月 30 13:59 linux
[root@lokott shell]# ls -ih   //显示文件节点值的大小
19397655 0.sh  20564913 10.sh  20564913 1.sh  20564915 2.sh  20564917 3.sh  20564916 4.sh  20564918 5.sh  20564919 6.sh  19134334 8.sh  20565286 hello  35183604 linux
//上面文件左边的就是该文件的文件节点(inode值)软链接与源文件的文件节点是非一致的,而硬链接的文件节点与源文件是一致的 

cp :复制文件或目录 源|目标

  1. -f 不询问
  2. -i 询问是否覆盖原有
  3. -p 保持源文件的用户权限不变,权限高用户使用
  4. -r 递归复制

rm:删除

  1. -i:默认提醒
  2. -rf :强制递归删除

mv:移动文件或目录

[root@lokott shell]# cd hello/
[root@lokott hello]# ls
0.sh
[root@lokott hello]# cp ../5.sh .
[root@lokott hello]# ls
0.sh  5.sh
[root@lokott hello]# cp -i ../5.sh .
cp:是否覆盖"./5.sh"? yes
[root@lokott hello]# cp -f ../5.sh .    //猜测被alias了
cp:是否覆盖"./5.sh"? y
[root@lokott hello]# 
[root@lokott hello]# which cp     //查看cp命令果然是被alias更改了
alias cp='cp -i'
    /usr/bin/cp
[root@lokott hello]# cp -r ../linux/ .   //递归复制上层路径linux文件夹的所有内容到当前路径(目前无内容)
[root@lokott hello]# ls
0.sh  5.sh  linux
[root@lokott hello]# cd linux/
[root@lokott linux]# ls
[root@lokott linux]# mkdir 2020         //创建文件夹
[root@lokott linux]# ls
2020
[root@lokott linux]# cd 2020/
[root@lokott 2020]# touch 2.txt         //创建文件
[root@lokott 2020]# cd ../../
[root@lokott hello]# ls
0.sh  5.sh  linux
[root@lokott hello]# mv linux/ ../          //移动文件夹
mv:是否覆盖"../linux"? y
[root@lokott hello]# cd ..
[root@lokott shell]# ls
0.sh  10.sh  1.sh  2.sh  3.sh  4.sh  5.sh  6.sh  8.sh  hello  linux
[root@lokott shell]# ls -l linux/
总用量 0
drwxr-xr-x. 2 root root 19 10月 30 14:15 2020
[root@lokott shell]# cp -r linux/  hello/   //递归复制linux文件夹的所有内容到hello文件夹中
[root@lokott shell]# cd hello/
[root@lokott hello]# ls
0.sh  5.sh  linux
[root@lokott hello]# ls -l linux/
总用量 0
drwxr-xr-x. 2 root root 19 10月 30 14:16 2020
[root@lokott hello]# ls -lR linux/          //递归查看拷贝过来的文件夹的信息
linux/:
总用量 0
drwxr-xr-x. 2 root root 19 10月 30 14:16 2020

linux/2020:
总用量 0
-rw-r--r--. 1 root root 0 10月 30 14:16 2.txt

通配符

  1. ?表示一个
  2. *表示多个

find:查找文件或目录

find 【查找范围】【选项】[表达式]

  1. -name:根据目标名字查找
  2. -type:根据文件类型查找
  3. -size:根据大小查找
  4. -user:根据文件的用户所有者查找
[root@lokott hello]# find . -name "*.sh"  //*号表示通配符
./0.sh
./5.sh
[root@lokott hello]# find . -type f
./0.sh
./5.sh
./linux/2020/2.txt
[root@lokott hello]# find . -size -10k
.
./0.sh
./5.sh
./linux
./linux/2020
./linux/2020/2.txt
./ifcfg-ens33
[root@lokott hello]# find . -size -10k | du -ah
0   ./0.sh
4.0K    ./5.sh
0   ./linux/2020/2.txt
0   ./linux/2020
0   ./linux
4.0K    ./ifcfg-ens33
8.0K    .
centos7系统启动的命令清单
1. init 0 关机
2. init 1 单用户模式(系统维护,破解密码)
3. init 2 多用户模式无网络
4. init 3 多用户模式有网络  *
5. init 4 保留
6. init 5多用户模式图形化界面有网络
7. init 6 重启 (reboot)

三、Linux的目录结构

树形目录结构

/etc 管理员的家目录

/home 普通用户家目录

/bin 所有用户的命令文件目录

/sbin 管理员命令文件目录

/boot 启动分区(grub启动菜单,压缩内核等)

/usr 应用程序目录

/etc 配置文件目录

/var 可变长文件目录(日志)

/dev  设备文件目录(磁盘,光驱)

/tmp 临时文件

/proc 硬件信息(CPU 内存)

/lib 服务管理文件(systemctl)

查看文件内容命令

cat [] 文件名 ... :查看文件内容

more [] 文件名 .. :全屏方式分页显示文件内容

less [] 文件名 ... :more命令的扩展 END 可以查找 (man less进行查看,这边不是非常方便演示效果)

head 看文件开头一部分内容(默认为10行)

tail:看文件尾部的内容(默认10行)

[root@lokott hello]# cat ifcfg-ens33 
TYPE="Ethernet"
PROXY_METHOD="none"
BROWSER_ONLY="no"
BOOTPROTO="dhcp"
DEFROUTE="yes"
IPV4_FAILURE_FATAL="no"
IPV6INIT="yes"
IPV6_AUTOCONF="yes"
IPV6_DEFROUTE="yes"
IPV6_FAILURE_FATAL="no"
IPV6_ADDR_GEN_MODE="stable-privacy"
NAME="ens33"
UUID="0d6ffef5-693f-4d48-88b5-d2e1a66cf9c4"
DEVICE="ens33"
ONBOOT="yes"
[root@lokott hello]# more ifcfg-ens33 
TYPE="Ethernet"
PROXY_METHOD="none"
BROWSER_ONLY="no"
BOOTPROTO="dhcp"
DEFROUTE="yes"
IPV4_FAILURE_FATAL="no"
IPV6INIT="yes"
IPV6_AUTOCONF="yes"
IPV6_DEFROUTE="yes"
IPV6_FAILURE_FATAL="no"
IPV6_ADDR_GEN_MODE="stable-privacy"
NAME="ens33"
UUID="0d6ffef5-693f-4d48-88b5-d2e1a66cf9c4"
DEVICE="ens33"
ONBOOT="yes"
root@lokott hello]# head ifcfg-ens33 
TYPE="Ethernet"
PROXY_METHOD="none"
BROWSER_ONLY="no"
BOOTPROTO="dhcp"
DEFROUTE="yes"
IPV4_FAILURE_FATAL="no"
IPV6INIT="yes"
IPV6_AUTOCONF="yes"
IPV6_DEFROUTE="yes"
IPV6_FAILURE_FATAL="no"
[root@lokott hello]# tail ifcfg-ens33 
IPV4_FAILURE_FATAL="no"
IPV6INIT="yes"
IPV6_AUTOCONF="yes"
IPV6_DEFROUTE="yes"
IPV6_FAILURE_FATAL="no"
IPV6_ADDR_GEN_MODE="stable-privacy"
NAME="ens33"
UUID="0d6ffef5-693f-4d48-88b5-d2e1a66cf9c4"
DEVICE="ens33"
ONBOOT="yes" 

统计文件内容

wc(默认全部统计)

  1. -l :统计行数
  2. -w:统计单词统计数
  3. -c:统计字节数
[root@lokott hello]# cat 5.sh 
#!/bin/bash
read -p "please input a ip address!" ip
ping -c1 $ip &>/dev/null
if [ $? -eq 0 ]
then 
    echo "$ip is up."
else 
    echo "$ip is down"
fi
[root@lokott hello]# wc -l 5.sh 
9 5.sh
[root@lokott hello]# wc -w 5.sh 
30 5.sh
[root@lokott hello]# wc -c 5.sh 
147 5.sh
[root@lokott hello]# 

检索和过滤文件内容

grep命令:在文件中查找不显示包含指定字符串的行

  • grep [options] PATTERN [FILE...]
  • grep [options] [-e PATTERN | -f FILE] [FILE...]
  1. -i :忽略大小写
  2. -v:反转查找,输出与查找条件不相符的行
[root@lokott hello]# grep -i up 5.sh 
    echo "$ip is up."
[root@lokott hello]# grep -v 'bash$' /etc/passwd 
bin:x:1:1:bin:/bin:/sbin/nologin
daemon:x:2:2:daemon:/sbin:/sbin/nologin
adm:x:3:4:adm:/var/adm:/sbin/nologin
lp:x:4:7:lp:/var/spool/lpd:/sbin/nologin
sync:x:5:0:sync:/sbin:/bin/sync
shutdown:x:6:0:shutdown:/sbin:/sbin/shutdown
halt:x:7:0:halt:/sbin:/sbin/halt
mail:x:8:12:mail:/var/spool/mail:/sbin/nologin
operator:x:11:0:operator:/root:/sbin/nologin
games:x:12:100:games:/usr/games:/sbin/nologin
ftp:x:14:50:FTP User:/var/ftp:/sbin/nologin
nobody:x:99:99:Nobody:/:/sbin/nologin
systemd-network:x:192:192:systemd Network Management:/:/sbin/nologin
dbus:x:81:81:System message bus:/:/sbin/nologin
polkitd:x:999:998:User for polkitd:/:/sbin/nologin
abrt:x:173:173::/etc/abrt:/sbin/nologin
libstoragemgmt:x:998:996:daemon account for libstoragemgmt:/var/run/lsm:/sbin/nologin
rpc:x:32:32:Rpcbind Daemon:/var/lib/rpcbind:/sbin/nologin
colord:x:997:995:User for colord:/var/lib/colord:/sbin/nologin
saslauth:x:996:76:Saslauthd user:/run/saslauthd:/sbin/nologin
rtkit:x:172:172:RealtimeKit:/proc:/sbin/nologin
pulse:x:171:171:PulseAudio System Daemon:/var/run/pulse:/sbin/nologin
chrony:x:995:991::/var/lib/chrony:/sbin/nologin
rpcuser:x:29:29:RPC Service User:/var/lib/nfs:/sbin/nologin
nfsnobody:x:65534:65534:Anonymous NFS User:/var/lib/nfs:/sbin/nologin
ntp:x:38:38::/etc/ntp:/sbin/nologin
tss:x:59:59:Account used by the trousers package to sandbox the tcsd daemon:/dev/null:/sbin/nologin
usbmuxd:x:113:113:usbmuxd user:/:/sbin/nologin
geoclue:x:994:989:User for geoclue:/var/lib/geoclue:/sbin/nologin
qemu:x:107:107:qemu user:/:/sbin/nologin
radvd:x:75:75:radvd user:/:/sbin/nologin
setroubleshoot:x:993:988::/var/lib/setroubleshoot:/sbin/nologin
sssd:x:992:987:User for sssd:/:/sbin/nologin
gdm:x:42:42::/var/lib/gdm:/sbin/nologin
gnome-initial-setup:x:991:986::/run/gnome-initial-setup/:/sbin/nologin
sshd:x:74:74:Privilege-separated SSH:/var/empty/sshd:/sbin/nologin
avahi:x:70:70:Avahi mDNS/DNS-SD Stack:/var/run/avahi-daemon:/sbin/nologin
postfix:x:89:89::/var/spool/postfix:/sbin/nologin
tcpdump:x:72:72::/:/sbin/nologin
apache:x:48:48:Apache:/usr/share/httpd:/sbin/nologin
root@lokott hello]# grep -v 'bash$' /etc/passwd | wc -l  //将结果写入管道后用wc命令显示结果数量
40
[root@lokott hello]# 

Ctrl + r 可以进行命令的搜索

[root@lokott hello]# vim ifcfg-ens33 用快捷键!进入下面的模式输入之前敲击过的命令会自动查找 (reverse-i-search)`v': vim ifcfg-ens33

压缩命令

gzip命令和bzip2命令:制作压缩文件、解压缩文件

  1. -9表示的是高压缩比
  2. -d进行解压缩
[root@lokott hello]# ls
0.sh  5.sh  ifcfg-ens33  linux
[root@lokott hello]# gzip -9 0.sh 5.sh 
[root@lokott hello]# ls
0.sh.gz  5.sh.gz  ifcfg-ens33  linux
[root@lokott hello]# gzip -d 0.sh.gz 
[root@lokott hello]# gzip -d 5.sh.gz 
[root@lokott hello]# ls
0.sh  5.sh  ifcfg-ens33  linux
[root@lokott hello]# bzip2 -9 0.sh 5.sh 
[root@lokott hello]# bzip2 -d 0.sh.bz2 
[root@lokott hello]# bzip2 -d 5.sh.bz2 
[root@lokott hello]# ls
0.sh  5.sh  ifcfg-ens33  linux
[root@lokott hello]# 

tar命令:制作归档文件、释放归档文件

  1. -c:创建文件包
  2. -x:解压文件包
  3. -v:显示详细过程
  4. -f: 执行
  5. -p:保留原有权限
  6. -t:查看压缩包的内容
  7. -C:解压到某个地方去
  8. -z:gz格式
  9. -j:bz2格式
[root@lokott hello]# ls
0.sh  5.sh  ifcfg-ens33  linux
[root@lokott hello]# tar czvf if.tar.gz ifcfg-ens33 
ifcfg-ens33
[root@lokott hello]# ls
0.sh  5.sh  ifcfg-ens33  if.tar.gz  linux
[root@lokott hello]# tar xzvf if.tar.gz -C ../
ifcfg-ens33
[root@lokott hello]# cd ..
[root@lokott shell]# ls
0.sh  10.sh  1.sh  2.sh  3.sh  4.sh  5.sh  6.sh  8.sh  hello  ifcfg-ens33  linux
[root@lokott shell]# 
//如果是bz2格式就将文件格式的后缀名更换后用j替换z的命令

四、文本编辑器vi/vim(对vim编辑器的熟练操作可以提高工作效率)

作用

  1. 创建或修改文本文件
  2. 维护Linux系统中的各种配置文件

命令模式、输入模式、末行模式(底线命令模式)转换关系和操作

Linux的简单介绍和基础命令(下)

vim编辑器的相关操作命令

行号设置操作

  1. :set nu
  2. :set nu!和:set nonu 取消行号 注意!!!记住切换为末行模式(底线命令模式)

定位行(命令模式下)

  1. gg:定位到开头
  2. G:定位到结尾
  3. 3G:3表示行号,定位到第三行

复制粘贴删除

  1. x:删除光标处的单个字符
  2. dd :删除当前光标所在行
  3. dw:删除光标所在位置的一个单词
  4. #dd :删除从光标所在行开始的#行内容
  5. ddp:上下行调换位置
  6. yy:复制改行到剪切板
  7. nyy:复制n行到剪切板
  8. p:粘贴

vim编辑器中的其他操作

shift+r 替换 在光标处进行替换

PG UP 向上翻页

PG DN 向下翻页

:e ~/install.log 打开新的文件进行编辑(末行模式下)

:r file——在编辑的数据中,读入另一个档案的数据。亦即将 『filename』 这个档案内容加到游标所在行后面(末行模式下)

:w /opt/test.txt 将该文件写入到opt下并且重新命名为test.txt文件但是不保持与源文件相同权限

:n1,n2s/word1/word2/g 在n1到n2行之间将所有的word1换为word2

:%s/word1/word2/g 将所有的word1换为word2