Linux 命令汇总 | vim | shell | 进阶【2022 版】

目录

一、Linux 上下五千年

1.1 历史长河

Linux,全称 GNU/Linux,是一种免费使用和自由传播的类 UNIX 操作系统,其内核由林纳斯·本纳第克特·托瓦兹于 1991 年 10 月 5 日首次发布。

它主要受到 Minix 和 Unix 思想的启发,是一个基于 POSIX 的多用户、多任务、支持多线程和多 CPU 的操作系统。它能运行主要的 Unix 工具软件、应用程序和网络协议。它支持 32 位和 64 位硬件。

Linux 继承了 Unix 以网络为核心的设计思想,是一个性能稳定的多用户网络操作系统。Linux 有上百种不同的发行版,如基于社区开发的 debian、archlinux,和基于商业开发的 Red Hat Enterprise Linux、SUSE、Oracle Linux 等。

Linux内核版本

内核(kernel)是系统的心脏,是运行程序和管理像磁盘和打印机等硬件设备的核心程序,它提供了一个在裸设备与应用程序间的抽象层。

Linux 内核版本又分为稳定版和开发版,两种版本是相互关联,相互循环:

  1. 稳定版:具有工业级强度,可以广泛地应用和部署。新的稳定版相对于较旧的只是修正一些 bug 或加入一些新的驱动程序。

  2. 开发版:由于要试验各种解决方案,所以变化很快。内核源码网址:http://www.kernel.org 所有来自全世界的对 Linux 源码的修改最终都会汇总到这个网站,由 Linus 领导的开源社区对其进行甄别和修改最终决定是否进入到 Linux 主线内核源码中。

Linux发行版本

Linux 发行版 (也被叫做 GNU/Linux 发行版) 通常包含了包括桌面环境、办公套件、媒体播放器、数据库等应用软件。

目前市面上较知名的发行版有:Ubuntu、RedHat、CentOS、Debian、Fedora、SuSE、OpenSUSE、Arch Linux、SolusOS 等。

Linux 和 Windows 区别

1.2 下载安装

下载 VirtualBox ---> 官网下载入口

下载 Linux 镜像(这里以centos7为例) ---> 官网下载入口

打开 VirtualBox,点击新建,输入名称、类型和版本

4、分配内存大小

5、创建虚拟硬盘


6、选择第一个


7、选择动态分配


8、选择位置和大小


9、创建之后,选择设置 ---> 存储,选择盘片


10、设置网络,选择桥接网络


11、启动 linux 系统,会进入安装页面,这里需要将时间设置成 亚洲/上海,选择 最小安装(无桌面)

踩坑秘籍

输入 ifconfig 没有这个指令
yum search ifconfig
yum install net-tools.x86_64
输入 ifconfig 发现没有分配 IP
vi /etc/sysconfig/network-scripts/ifcfg-ens33
将 ONBOOT=no 改为 ONBOOT=yes(是否开机启用的意思)
linux 重启之后 IP 发生变化
vim /etc/sysconfig/network-scripts/ifcfg-ens33
将 BOOTPORTO=dhcp 改为 BOOTPORTO=static 原本是自动获取 ip,现在改成固定 ip
ONBOOT=yes 这个是 no 的话就改为 yes,表示修改配置后自动启用网卡
如果你是 192.168.x.x 网段的,就添加这几行配置, 比如这里我把 ip 固定为 192.168.1.6 IPADDR=192.168.1.6 NETMASK=255.255.255.0 GATEWAY=192.168.1.1
如果你是 10.x.x.x 网段的,就添加这几行配置,比如这里我把 ip 固定为 10.0.0.6 IPADDR=10.0.0.6 NETMASK=255.255.255.0 GATEWAY=10.0.0.1
然后重启网络配置 service network restart 之后,ifconfig 查看 ip,这里 ip 就是 192.168.1.6 了,然后 ping www.baidu.com ,可以 ping 通,重启 Linux 后 ip 就不会改变了。

1.3、目录介绍

  1. / :根目录,一般根目录下只存放目录,在 Linux 下有且只有一个根目录。所有的东西都是从这里开始。当你在终端里输入“/home”,你其实是在告诉电脑,先从/(根目录)开始,再进入到 home 目录。
  2. /bin :/usr/bin: 可执行二进制文件的目录,如常用的命令 ls、tar、mv、cat 等。
  3. /boot :放置 linux 系统启动时用到的一些文件,如 Linux 的内核文件:/boot/vmlinuz,系统引导管理器:/boot/grub。
  4. /dev :存放 linux 系统下的设备文件,访问该目录下某个文件,相当于访问某个设备,常用的是挂载光驱 mount /dev/cdrom /mnt。
  5. /etc :系统配置文件存放的目录,不建议在此目录下存放可执行文件,重要的配置文件有 /etc/inittab、/etc/fstab、/etc/init.d、/etc/X11、/etc/sysconfig、/etc/xinetd.d。
  6. /home :系统默认的用户家目录,新增用户账号时,用户的家目录都存放在此目录下,表示当前用户的家目录,edu 表示用户 edu 的家目录。
  7. /lib :/usr/lib: /usr/local/lib:系统使用的函数库的目录,程序在执行过程中,需要调用一些额外的参数时需要函数库的协助。
  8. /lost+fount :系统异常产生错误时,会将一些遗失的片段放置于此目录下。
  9. /mnt : /media:光盘默认挂载点,通常光盘挂载于 /mnt/cdrom 下,也不一定,可以选择任意位置进行挂载。
  10. /opt :给主机额外安装软件所摆放的目录。
  11. /proc :此目录的数据都在内存中,如系统核心,外部设备,网络状态,由于数据都存放于内存中,所以不占用磁盘空间,比较重要的目录有/proc/cpuinfo、/proc/interrupts、/proc/dma、/proc/ioports、/proc/net/* 等。
  12. /root :系统管理员 root 的家目录。
  13. /sbin :/usr/sbin: /usr/local/sbin:放置系统管理员使用的可执行命令,如 fdisk、shutdown、mount 等。与 /bin 不同的是,这几个目录是给系统管理员 root 使用的命令,一般用户只能"查看"而不能设置和使用。
  14. /tmp :一般用户或正在执行的程序临时存放文件的目录,任何人都可以访问,重要数据不可放置在此目录下。
  15. /srv :服务启动之后需要访问的数据目录,如 www 服务需要访问的网页数据存放在 /srv/www 内。
  16. /usr :应用程序存放目录,/usr/bin 存放应用程序,/usr/share 存放共享数据,/usr/lib 存放不能直接运行的,却是许多程序运行所必需的一些函数库文件。/usr/local: 存放软件升级包。/usr/share/doc: 系统说明文件存放目录。/usr/share/man: 程序说明文件存放目录。
  17. /var :放置系统执行过程中经常变化的文件,如随时更改的日志文件 /var/log,/var/log/message:所有的登录文件存放目录,/var/spool/mail:邮件存放的目录,/var/run:程序或服务启动后,其 PID 存放在该目录下。

1.4 网络配置

1.4.1 三种网络模式

  1. 桥接 在网络网卡上安装了一个桥接协议,让这块网卡处于混杂模式,可以同时连接多个网络的做法。 桥接下,类似于把物理主机虚拟为一个交换机,所有桥接设置的虚拟机连接到这个交换机的一个接口上,物理主机也同样查在这个交换机当中,所以所有桥接下网卡与网卡都是交换模式的,相互可以访问而不干扰。

  2. NAT虚拟机使用 VMnet8 网卡与主机单独组网,主机对于虚拟机相当于路由器,VMnet8 网卡通过 NAT 地址转换协议与物理机网卡通信

  3. Host-only(仅与主机通信)【不常用】虚拟机使用 VMnet1 网卡与主机单独组网,主机对于虚拟机相当于路由器

1.4.2 ifconfig

功能描述:显示所有网络接口的配置信息

1.4.3 ping

功能描述 :测试当前服务器是否可以连接目的主机

1.4.4 修改 IP 地址

  1. 查看 IP 配置文件 vim /etc/sysconfig/network-scripts/${ifcfg-ens33}
  2. 以下标红的项必须修改,有值的按照下面的值修改,没有该项的要增加
点击查看代码
TYPE="Ethernet" #网络类型(通常是 Ethemet) 
PROXY_METHOD="none" 
BROWSER_ONLY="no" 
BOOTPROTO="static" #IP 的配置方法[none|static|bootp|dhcp](引导 时不 使用协议|静态分配 IP|BOOTP 协议|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="e83804c1-3257-4584-81bb-660665ac22f6" #随机 id 
DEVICE="ens33" #接口名(设备,网卡) 
ONBOOT="yes" #系统启动的时候网络接口是否有效(yes/no) 
#IP 地址 
IPADDR=192.168.1.100 
#网关 
GATEWAY=192.168.1.2 
#域名解析器 
DNS1=192.168.1.2
  1. 编辑完后,按键盘 esc ,然后输入 :wq 回车即可

  2. 执行 service network restart 重启网络

修改 IP 地址后可能会遇到的问题

  1. 物理机能 ping 通虚拟机,但是虚拟机 ping 不通物理机,一般都是因为物理机的 防火墙问题,把防火墙关闭就行
  2. 虚拟机能 Ping 通物理机,但是虚拟机 Ping 不通外网,一般都是因为 DNS 的设置有问题
  3. 虚拟机 Ping www.baidu.com 显示域名未知等信息,一般查看 GATEWAY 和 DNS 设 置是否正确
  4. 如果以上全部设置完还是不行,需要关闭 NetworkManager 服务 systemctl stop NetworkManager 关闭 systemctl disable NetworkManager 禁用
  5. 如果检查发现 systemctl status network 有问题 需要检查 ifcfg-ens33

1.4.5 主机名称

修改主机名称

  1. 查看当前服务器主机名称 hostname
  2. 如果感觉此主机名不合适,我们可以进行修改。通过编辑/etc/hostname 文件 vi /etc/hostname
  3. 修改完成后重启生效
    修改 hosts 映射文件
  4. vim /etc/hosts
  5. 192.168.2.101 localhost

1.4.6 远程登录

通常在工作过程中,公司中使用的真实服务器或者是云服务器,都不允许除运维人员之外的员工直接接触,因此就需要通过远程登录的方式来操作。

所以,远程登录工具就是必不可缺的,目前,比较主流的有 Xshell, SSH Secure Shell, SecureCRT,FinalShell 等,可以根据自己的习惯自行选择。【我用的是 FinalShell】

1.5 系统管理

1.5.1 Linux 中的进程和服务

  1. 计算机中,一个正在执行的程序或命令,被叫做“进程”(process)
  2. 启动之后一直存在、常驻内存的进程,一般被称作“服务”(service)

1.5.2 systemctl

systemctl start | stop | restart | status 服务名

  1. 查看防火墙服务的状态 systemctl status firewalld
  2. 停止防火墙服务 systemctl stop firewalld
  3. 启动防火墙服务 systemctl start firewalld
  4. 重启防火墙服务 systemctl restart firewalld

1.5.3 systemctl 设置后台服务的自启配置

  1. 查看服务开机启动状态 systemctl list-unit-files
  2. 关掉指定服务的自动启动 systemctl disable service_name
  3. 开启指定服务的自动启动 systemctl enable service_name

查看服务的方法:

/usr/lib/systemd/system
ls -al

1.5.4 系统运行级别

  1. CentOS7 的运行级别为: multi-user.target(多用户有网,无图形界面)graphical.target (多用户有网,有图形界面)
  2. 查看当前运行级别:systemctl get-default
  3. 修改当前运行级别 systemctl set-default TARGET.target(这里 TARGET 取 multi-user 或者 graphical)

1.5.5 防火墙

临时关闭防火墙

  1. 查看防火墙状态:systemctl status firewalld
  2. 临时关闭防火墙:systemctl stop firewalld
    开机启动时关闭防火墙
  3. 查看防火墙开机启动状态: systemctl enable firewalld.service
  4. 设置开机时关闭防火墙:systemctl disable firewalld.service

1.5.6 关机

在 linux 领域内大多用在服务器上,很少遇到关机的操作。毕竟服务器上跑一个服务是永无止境的,除非特殊情况下,不得已才会关机。
Linux 系统中为了提高磁盘的读写效率,对磁盘采取了 “预读迟写”操作方式。当用户 保存文件时,Linux 核心并不一定立即将保存数据写入物理磁盘中,而是将数据保存在缓冲区中,等缓冲区满时再写入磁盘,这种方式可以极大的提高磁盘写入数据的效率。
但是, 也带来了安全隐患,如果数据还未写入磁盘时,系统掉电或者其他严重问题出现,则将导 致数据丢失。使用 sync 指令可以立即将缓冲区的数据写入磁盘。

  1. sync(功能描述:将数据由内存同步到硬盘中)
    2. halt (功能描述:停机,关闭系统,但不断电)
  2. poweroff (功能描述:关机,断电)
  3. reboot(功能描述:就是重启,等同于 shutdown -r now)
  4. shutdown [选项] 时间
点击查看代码
(1)将数据由内存同步到硬盘中 
[root@]#sync 
(2)重启 
[root@]# reboot 
(3)停机(不断电) 
[root@]#halt 
(4)计算机将在 1 分钟后关机,并且会显示在登录用户的当前屏幕中 
[root@]#shutdown -h 1 ‘This server will shutdown after 1 mins’ 
(5)立马关机(等同于 poweroff) 
[root@]# shutdown -h now 
(6)系统立马重启(等同于 reboot) 
[root@]# shutdown -r now

1.6 软件管理

1.6.1 RPM

RPM(RedHat Package Manager),RedHat 软件包管理工具,是 Linux 这系列操作系统里面的打包安装工具。
RPM 包的名称格式 Apache-1.3.23-11.i386.rpm - “apache” 软件名称

  • “1.3.23-11”软件的版本号,主版本和此版本
  • “i386”是软件所运行的硬件平台,Intel 32 位处理器的统称
  • “rpm”文件扩展名,代表 RPM 包

RPM 查询命令(rpm -qa)查询所安装的所有 rpm 软件包rpm -qa由于软件包比较多,一般都会采取过滤rpm -qa | grep rpm软件包

RPM 卸载命令(rpm -e

  1. rpm -e RPM软件包
  2. rpm -e --nodeps 软件包
  • -e:卸载软件包
  • --nodeeps:卸载软件时,不检查依赖。这样的话,那些使用该软件包的软件在此之后可能就不能正常工作了

RPM 安装命令(rpm -ivhrpm -ivh RPM 包全名

  • -i:install,安装
  • -v:--verbose,显示详细信息
  • -h:--hash,进度条
  • --nodeps:安装前不检查依赖

1.6.2 YUM

YUM(全称为 Yellow dog Updater, Modified)是一个在 Fedora 和 RedHat 以及 CentOS 中的 Shell 前端软件包管理器,基于 RPM 包管理,能够从指定的服务器自动下载 RPM 包 并且安装,可以自动处理依赖性关系,并且一次安装所有依赖的软件包,无须繁琐地一次次下载、安装。

我的理解:yum 类似 maven,可以从镜像网站下载应用程序,并直接安装。

  1. 语法 yum [选项] [参数]
  2. 选项说明-y:对所有提问都回答 yes
  3. 参数说明

1、修改网络 YUM 源默认的系统 YUM 源,需要连接国外 apache 网站,网速比较慢,可以修改关联的网络 YUM 源为国内镜像的网站,比如网易 163,aliyun 等。
安装 wget, wget 用来从指定的 URL 下载文件 yum install wget -y

2、在/etc/yum.repos.d/目录下,备份默认的 repos 文件cp CentOS-Base.repo CentOS-Base.repo.bak

3、下载网易 163 或者是 aliyun 的 repos 文件,任选其一 wget http://mirrors.aliyun.com/repo/Centos-7.repo//阿里云 wget http://mirrors.163.com/.help/CentOS7-Base-163.repo //网易 163
使用下载好的 repos 文件替换默认的 repos 文件例如:用 CentOS7-Base-163.repo 替换 CentOS-Base.repomv CentOS7-Base-163.repo CentOS-Base.repo

4、清理旧缓存数据,缓存新数据 yum clean allyum makecache

二、Linux 命令大汇总

先把这些记下来,面试通常会考的,嘻嘻,开心吧!!!

查看内存:free -h
查看磁盘存储情况:df -h
查 看磁盘 IO 读写情况:iotop(需要安装一下:yum install iotop)、 iotop -o(直接查看输出比较高的磁盘读写程序)
查看端口占用情况:netstat -tunlp | grep 端口号
查看进程:ps -aux

2.1 帮助命令

2.1.1 man 获得帮助信息

man [命令或配置文件] man ls

2.1.2 help 获得 shell 内置命令的帮助信息

一部分基础功能的系统命令是直接内嵌在 shell 中的,系统加载启动之后会随着 shell 一起加载,常驻系统内存中。这部分命令被称为“内置(built-in)命令”;相应的其它命令 被称为“外部命令”。

help cd

2.1.3 ctrl + c 停止进程

2.1.4 ctrl+l 清屏,等同于 clear

2.1.5 reset 彻底清屏

2.1.6 tab 键 提示(更重要的是可以防止敲错)

2.1.7 上下键 查找执行过的命令 👆👇

2.2 文件目录类

2.2.1 pwd 显示当前工作目录的绝对路径

2.2.2 ls 列出目录的内容

每行列出的信息依次是:

  1. 文件类型与权限
  2. 链接数
  3. 文件属主
  4. 文件属组
  5. 文件大小用 byte 来表示
  6. 建立或最近修改的时间
  7. 名字
  • -a:全部的文件,连同隐藏档( 开头为 . 的文件) 一起列出来(常用)
  • -l:长数据串列出,包含文件的属性与权限等等数据;等价于“ll”

2.2.3 cd 切换目录

2.2.4 mkdir 创建一个新的目录

-p:创建多层目录

2.2.5 rmdir 删除一个空的目录

rmdir

2.2.6 touch file_name 创建空文件

touch file_name

2.2.7 cp 复制文件或目录

cp

cp [选项] source dest(功能描述:复制 source 文件到 dest)

  • -r 递归复制整个文件夹

2.2.8 rm 删除文件或目录

rm [选项] deleteFile(功能描述:递归删除目录中所有内容)

  1. -r 递归删除目录中所有内容
  2. -f 强制执行删除操作,而不提示用于进行确认。
  3. -v 显示指令的详细执行过程

2.2.9 mv 移动文件与目录或重命名

  1. mv oldNameFile newNameFile (功能描述:重命名)
  2. mv /temp/movefile /targetFolder(功能描述:移动文件)

2.2.10 cat 查看文件内容

cat [选项] 要查看的文件

  • -n 显示所有行的行号,包括空行

2.2.11 more 文件内容分屏查看器

more 指令是一个基于 VI 编辑器的文本过滤器,它以全屏幕的方式按页显示文本文件 的内容。more 指令中内置了若干快捷键,详见操作说明。

more 要查看的文件

  1. 空白键 (space) 代表向下翻一页
  2. Enter 代表向下翻『一行』
  3. q 代表立刻离开 more ,不再显示该文件内容
  4. Ctrl+F 向下滚动一屏
  5. Ctrl+B 返回上一屏
  6. = 输出当前行的行号
  7. :f 输出文件名和当前行的行号

2.2.12 less 分屏显示文件内容

less 指令用来分屏查看文件内容,它的功能与 more 指令类似,但是比 more 指令更加 强大,支持各种显示终端。

less 指令在显示文件内容时,并不是一次将整个文件加载之后 才显示,而是根据显示需要加载内容,对于显示大型文件具有较高的效率。

less 要查看的文件

  1. 空白键 向下翻动一页
  2. [pagedown] 向下翻动一页
  3. [pageup] 向上翻动一页
  4. /字串 向下搜寻『字串』的功能;n:向下查找;N:向上查找
  5. ?字串 向上搜寻『字串』的功能;n:向上查找;N:向下查找
  6. q 离开 less 这个程序

2.2.13 echo 输出内容到控制台

echo [选项] [输出内容]

  • \\ 输出\本身
  • \n 换行符
  • \t 制表符,也就是 Tab 键

2.2.14 head 显示文件头部内容

head 用于显示文件的开头部分内容,默认情况下 head 指令显示文件的前 10 行内容。

  1. head 文件 (功能描述:查看文件头 10 行内容)
  2. head -n 5 文件 (功能描述:查看文件头 5 行内容,5 可以是任意行数)

2.2.15 tail 输出文件尾部内容

tail 用于输出文件中尾部的内容,默认情况下 tail 指令显示文件的后 10 行内容。

  1. tail 文件 (功能描述:查看文件尾部 10 行内容)
  2. tail -n 5 文件 (功能描述:查看文件尾部 5 行内容,5 可以是任意行数)
  3. tail -f 文件 (功能描述:实时追踪该文档的所有更新)

2.2.16 > 输出重定向和 >> 追加

  1. ls -l > 文件 (功能描述:列表的内容写入文件 a.txt 中(覆盖写))
  2. ls -al >> 文件 (功能描述:列表的内容追加到文件 aa.txt 的末尾)
  3. cat 文件 1 > 文件 2 (功能描述:将文件 1 的内容覆盖到文件 2)
  4. echo “内容” >> 文件

2.2.17 ln 软链接

软链接也称为符号链接,类似于 windows 里的快捷方式,有自己的数据块,主要存放 了链接其他文件的路径。ln -s [原文件或目录] [软链接名](功能描述:给原文件创建一个软链接)

  1. 删除软链接: rm -rf 软链接名,而不是 rm -rf 软链接名/
  2. 如果使用 rm -rf 软链接名/ 删除,会把软链接对应的真实目录下内容删掉
  3. 查询:通过 ll 就可以查看,列表属性第 1 位是 l,尾部会有位置指向。

2.2.18 history 查看已经执行过历史命令

2.3 时间日期类

2.3.1 date 显示当前时间

  1. date (功能描述:显示当前时间)
  2. date +%Y (功能描述:显示当前年份)
  3. date +%m (功能描述:显示当前月份)
  4. date +%d (功能描述:显示当前是哪一天)
  5. date "+%Y-%m-%d %H:%M:%S" (功能描述:显示年月日时分秒)

2.3.2 date 显示非当前时间

  1. date -d '1 days ago'(功能描述:显示前一天时间)
  2. date -d '-1 days ago'(功能描述:显示明天时间)

2.3.3 date 设置系统时间

date -s "2023-06-19 20:52:18"

2.3.4 cal 查看日历
cal 2023

2.4 用户管理命令

2.4.1 useradd 添加新用户

  1. useradd 用户名 (功能描述:添加新用户)
  2. useradd -g 组名 用户名 (功能描述:添加新用户到某个组)

2.4.2 passwd 设置用户密码

passwd 用户名

2.4.3 id 查看用户是否存在

id username

2.4.4 cat /etc/passwd 查看创建了哪些用户

cat /etc/passwd

2.4.5 su 切换用户

  1. su 用户名称 (功能描述:切换用户,只能获得用户的执行权限,不能获得环境变量)
  2. su - 用户名称 (功能描述:切换到用户并获得该用户的环境变量及执行权限)

2.4.6 userdel 删除用户

  1. userdel 用户名 (功能描述:删除用户但保存用户主目录)
  2. userdel -r 用户名 (功能描述:用户和用户主目录,都删除)

2.4.7 who 查看登录用户信息

  1. whoami (功能描述:显示自身用户名称)
  2. who am i (功能描述:显示登录用户的用户名以及登陆时间)

2.4.8 sudo 设置普通用户具有 root 权限

  1. useradd issavior
    2. passwd issavior
  2. vim /etc/sudoers
  3. 修改 /etc/sudoers 文件,找到下面一行(91 行),在 root 下面添加一行,如下所示:
点击查看代码
## Allow root to run any commands anywhere 
root ALL=(ALL) ALL
issavior ALL=(ALL) ALL

**或者配置成采用 sudo 命令时,不需要输入密码**
点击查看代码
root ALL=(ALL) ALL 
issavior ALL=(ALL) NOPASSWD:ALL

**修改完毕,现在可以用 issavior 帐号登录,然后用命令 sudo ,即可获得 root 权限进行 操作。**

2.4.9 usermod 修改用户

将用户加入到用户组 usermod -g 用户组 用户名

2.5 用户组管理命令

每个用户都有一个用户组,系统可以对一个用户组中的所有用户进行集中管理。

不同 Linux 系统对用户组的规定有所不同, 如 Linux 下的用户属于与它同名的用户组,这个用户组在创建用户时同时创建。

用户组的管理涉及用户组的添加、删除和修改。组的增加、删除和修改实际上就是对 /etc/group 文件的更新。

2.5.1 groupadd 新增组

groupadd 组名

2.5.2 groupdel 删除组

groupdel 组名

2.5.3 groupmod 修改组

groupmod -n 新组名 老组名

2.5.4 cat /etc/group 查看创建了哪些组

cat /etc/group

2.6 文件权限类

2.6.1 文件属性

Linux 系统是一种典型的多用户系统,不同的用户处于不同的地位,拥有不同的权限。

为了保护系统的安全性,Linux 系统对不同的用户访问同一文件(包括目录文件)的权限做 了不同的规定。

在 Linux 中我们可以使用 ll 或者 ls -l 命令来显示一个文件的属性以及文件所属 的用户和组。

2.6.2 chmod 改变权限

第一种方式变更权限 chmod [{ugoa}{+-=}{rwx}]文件或目录 第二种方式变更权限 chmod [mode=421 ] [文件或目录]

2.6.3 chown 改变所有者

chown [选项] [最终用户] [文件或目录](功能描述:改变文件或者目录的所有 者)

2.6.4 chgrp 改变所属组

chgrp [最终用户组] [文件或目录](功能描述:改变文件或者目录的所属组)

2.7 搜索查找类

2.7.1 find 查找文件或者目录

find [搜索范围] [选项]

find 指令将从指定目录向下递归地遍历其各个子目录,将满足条件的文件显示在终端。

2.7.2 locate 快速定位文件路径

locate 搜索文件

locate 指令利用事先建立的系统中所有文件名称及路径的 locate 数据库实现快速定位给 定的文件。

Locate 指令无需遍历整个文件系统,查询速度较快。

为了保证查询结果的准确 度,管理员必须定期更新 locate 时刻。

2.7.3 grep 过滤查找及“|”管道符

grep 选项 查找内容 源文件

管道符,“|”,表示将前一个命令的处理结果输出传递给后面的命令处理

2.8 压缩和解压类

2.8.1 gzip/gunzip 压缩

gzip 文件 (功能描述:压缩文件,只能将文件压缩为*.gz 文件)

gunzip 文件.gz (功能描述:解压缩文件命令)

2.8.2 zip/unzip 压缩

zip [选项] XXX.zip 将要压缩的内容(功能描述:压缩文件和目录的命令)

unzip [选项] XXX.zip (功能描述:解压缩文件)

2.8.3 tar 打包

tar [选项] XXX.tar.gz 将要打包进去的内容 (功能描述:打包目录,压缩后的 文件格式.tar.gz)

2.9 磁盘查看和分区类

2.9.1 du 查看文件和目录占用的磁盘空间

du 目录/文件 (功能描述:显示目录下每个子目录的磁盘使用情况)

2.9.2 df 查看磁盘空间使用情况

df 选项 (功能描述:列出文件系统的整体磁盘使用量,检查文件系统的磁盘空间占 用情况)

2.9.3 lsblk 查看设备挂载情况

lsblk (功能描述:查看设备挂载情况)

2.9.4 mount/umount 挂载/卸载

mount [-t vfstype] [-o options] device dir(功能描述:挂载设备)umount 设备文件名或挂载点(功能描述:卸载设备)

2.9.5 fdisk 分区

fdisk -l(功能描述:查看磁盘分区详情)fdisk 硬盘设备名(功能描述:对新增硬盘进行分区操作)

2.10 进程管理类

2.10.1 ps 查看当前系统进程状态

ps aux | grep xxx(功能描述:查看系统中所有进程)

ps -ef | grep xxx(功能描述:可以查看子父进程之间的关系)

2.10.2 kill 终止进程

kill [选项] 进程号(功能描述:通过进程号杀死进程)

killall 进程名称(功能描述:通过进程名称杀死进程,也支持通配符,这 在系统因负载过大而变得很慢时很有用)

2.10.3 pstree 查看进程树

pstree [选项]

2.10.4 top 实时监控系统进程状态

top [选项]

2.10.5 netstat 显示网络状态和端口占用信息

netstat -anp | grep 进程号(功能描述:查看该进程网络信息)

netstat –nlp | grep 端口号(功能描述:查看网络端口号占用情况)

2.11 crontab 系统定时任务

crontab [选项]

三、编译器之神~vim

VI 是 Unix 操作系统和类 Unix 操作系统中最通用的文本编辑器。

VIM 编辑器是从 VI 发展出来的一个性能更强大的文本编辑器。可以主动的以字体颜 色辨别语法的正确性,方便程序设计。VIM 与 VI 编辑器完全兼容。

3.1 一般模式

以 vi 打开一个档案就直接进入一般模式了(这是默认的模式)。

在这个模式中, 你可 以使用『上下左右』按键来移动光标,你可以使用『删除字符』或『删除整行』来处理档 案内容, 也可以使用『复制、粘贴』来处理你的文件数据。

3.2 编辑模式

在一般模式中可以进行删除、复制、粘贴等的动作,但是却无法编辑文件内容的!

要等到你按下『i, I, o, O, a, A』等任何一个字母之后才会进入编辑模式。

注意了!通常在 Linux 中,按下这些按键时,在画面的左下方会出现『INSERT 或 REPLACE』的字样,此时才可以进行编辑。而如果要回到一般模式时, 则必须要按下 『Esc』这个按键即可退出编辑模式。

进入编辑模式

** 『Esc』键 退出编辑模式,之后所在的模式为一般模式。**

3.3 指令模式

强制保存退出:wq!在一般模式当中,输入『 : / ?』3 个中的任何一个按钮,就可以将光标移动到最底下那 一行。

在这个模式当中, 可以提供你『搜寻资料』的动作,而读取、存盘、大量取代字符、 离开 vi 、显示行号等动作是在此模式中达成的!

四、脚本之魂~shell

4.1 简介

Shell 是一个用 C 语言编写的程序,它是用户使用 Linux 的桥梁。Shell 既是一种命令语言,又是一种程序设计语言。

Shell 是指一种应用程序,这个应用程序提供了一个界面,用户通过这个界面访问操作系统内核的服务。

Ken Thompson 的 sh 是第一种 Unix Shell,Windows Explorer 是一个典型的图形界面 Shell。

4.2 脚本格式

脚本以#!/bin/bash 开头(指定解析器)

4.3 变量

4.3.1 系统预定义变量

常用系统变量 $HOME$PWD$SHELL$USER

4.3.2 自定义变量

  • 基本语法定义变量:变量名=变量值,注意,=号前后不能有空格撤销变量:unset 变量名声明静态变量:readonly 变量,注意:不能 unset
  • 变量定义规则变量名称可以由字母、数字和下划线组成,但是不能以数字开头,环境变量名建 议大写。等号两侧不能有空格在 bash 中,变量默认类型都是字符串类型,无法直接进行数值运算。变量的值如果有空格,需要使用双引号或单引号括起来。

4.3.3 特殊变量

  1. $n (功能描述:n 为数字,代表该脚本名称,1-代表第一到第九个参数,十以上的参数,十以上的参数需要用大括号包含,如{10})
  2. $# (功能描述:获取所有输入参数个数,常用于循环,判断参数的个数是否正确以及 加强脚本的健壮性)。
  3. $* (功能描述:这个变量代表命令行中所有的参数,$*把所有的参数看成一个整体)
  4. $@ (功能描述:这个变量也代表命令行中所有的参数,不过 $@把每个参数区分对待)
  5. $? (功能描述:最后一次执行的命令的返回状态。如果这个变量的值为 0,证明上一 个命令正确执行;如果这个变量的值为非 0(具体是哪个数,由命令自己来决定),则证明 上一个命令执行不正确了。)

4.4 运算符

“$((运算式))” 或 “$[运算式]”

4.5 条件判断

  1. ** test condition**
  2. [ condition ](注意 condition 前后要有空格)

注意:条件非空即为 true

4.6 流程控制

4.6.1 if 判断

点击查看代码
(1)单分支 
if [ 条件判断式 ];then 
	程序 
fi


或者 

if [ 条件判断式 ] 
then
	程序 
fi

(2)多分支 
if [ 条件判断式 ] 
then
	程序 
elif [ 条件判断式 ] 
then
	程序 
else
	程序 
fi 

4.6.2 case 语句

点击查看代码
case $变量名 in 
"值 1")
	如果变量的值等于值 1,则执行程序 1 
;;
"值 2")
	如果变量的值等于值 2,则执行程序 2 
;; 
	…省略其他分支… 
*) 
	如果变量的值都不是以上的值,则执行此程序 
;;
esac

4.6.3 for 循环

点击查看代码
for (( 初始值;循环控制条件;变量变化 ))
do
	程序
done

4.6.4 while 循环

点击查看代码
while [ 条件判断式 ] 
do 
	程序 
done

4.7 read 读取控制台输入

read (选项) (参数)

4.8 函数

4.8.1 系统函数

basename

basename [string / pathname] [suffix](功能描述:basename 命令会删掉所有的前 缀包括最后一个(‘/’)字符,然后将字符串显示出来。

dirname

dirname 文件绝对路径(功能描述:从给定的包含绝对路径的文件名中去除文件名 (非目录的部分),然后返回剩下的路径(目录的部分))

4.8.2 自定义函数

点击查看代码
[ function ] funname[()] 
{ 
	Action; [return int;] 
}

4.9 正则表达式

正则表达式使用单个字符串来描述、匹配一系列符合某个语法规则的字符串。

在很多文 本编辑器里,正则表达式通常被用来检索、替换那些符合某个模式的文本。

在 Linux 中,grep, sed,awk 等文本处理工具都支持通过正则表达式进行模式匹配。

  1. ^ 匹配一行的开头

  2. $ 匹配一行的结束

  3. . 匹配一个任意的字符

  4. * ** 不单独使用,他和上一个字符连用,表示匹配上一个字符 0 次或多次**

  5. [ ] 表示匹配某个范围内的一个字符

  6. \ 表示转义,并不会单独使用。由于所有特殊字符都有其特定匹配模式,当我们想匹配 某一特殊字符本身时(例如,我想找出所有包含 ' 的行),就会碰到困难。此时我们就要 将转义字符和特殊字符连用,来表示特殊字符本身

posted @ 2022-09-26 14:13  师出牛犊  阅读(367)  评论(0)    收藏  举报
返回顶部