Linux教程

Linux学习(一)

本文主要是介绍Linux学习(一),对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!

文章目录

    • 1. Linux基础篇 -目录结构
      • 1.1 基本介绍
      • 1.2 具体的目录结构(不用背,知道即可)
    • 2. Linux 实操篇-远程登录到 Linux 服务器
      • 2.1 为什么需要远程登录 Linux
      • 2.2 远程登录的软件
    • 3. Linux 实操篇- Vi 和 Vim 编辑器
      • 3.1 vi 和 vim 的基本介绍
      • 3.2 vi 和 vim 常用的三种模式
        • 3.2.1正常模式
        • 3.2.2插入模式
        • 3.2.3命令行模式
      • 3.3 各种模式的相互切换
      • 3.4 键盘
      • 3.5 常用快捷键
    • 4. Linux 实操篇-开机、重启和用户登录注销
      • 4.1 关机&重启命令
      • 4.2 用户登录和注销
    • 5. Linux 实操篇-用户管理
      • 5.1 基本介绍
      • 5.2 添加用户
        • 5.2.1基本语法
        • 5.2.3细节说明
      • 5.3 指定/修改密码
      • 5.4 删除用户
      • 5.5 查询用户信息指令
      • 5.6 切换用户
        • 5.6.1介绍
        • 5.6.2基本语法
        • 5.6.4细节说明
      • 5.7 查看当前用户/登录用户
      • 5.8 用户组
        • 5.8.1介绍
        • 5.8.2新增组
        • 5.8.3删除组
        • 5.8.4案例演示
        • 5.8.5修改用户的组
      • 5.9 用户和组相关文件
        • 5.9.1/etc/passwd 文件
        • 5.9.2/etc/shadow 文件
        • 5.9.3/etc/group 文件
    • 6. Linux 实操篇-实用指令
      • 6.1 指定运行级别
        • 6.1.1基本介绍
        • 6.1.2应用实例
        • 6.1.3 CentOS7 后运行级别说明
      • 6.2 找回 root 密码
        • 6.2.1面试题
      • 6.3 帮助指令
        • 6.3.1 man 获得帮助信息
        • 6.3.2 help 指令
        • 6.3.4 百度帮助更直接
      • 6.4 文件目录类
        • 6.4.1 pwd 指令
        • 6.4.2 ls 指令
        • 6.4.3 cd 指令
        • 6.4.4 mkdir 指令
        • 6.4.5 rmdir 指令删除空目录
        • 6.4.6 touch 指令
        • 6.4.7 cp 指令
        • 6.4.8 rm 指令
        • 6.4.9 mv 指令
        • 6.4.10 cat 指令
        • 6.4.11 more 指令
        • 6.4.12 less 指令
        • 6.4.13 echo 指令
        • 6.4.14 head 指令
        • 6.4.15 tail 指令
        • 6.4.16 > 指令 和 >> 指令
        • 6.4.17 ln 指令
        • 6.4.18 history 指令
      • 6.5 时间日期类
        • 6.5.1date 指令-显示当前日期
      • 6.6 搜索查找类
        • 6.6.1 find 指令
        • 6.6.2 locate 指令
        • 6.6.3 grep 指令和 管道符号 |
      • 6.7 压缩和解压类
        • 6.7.1 gzip / gunzip 指令
        • 6.7.2 zip/unzip 指令
        • 6.7.3 tar 指令
    • 7. Linux 实操篇-组管理和权限管理
      • 7.1 Linux 组基本介绍
      • 7.2 文件/目录 所有者
        • 7.2.1 查看文件的所有者
        • 7.2.2 修改文件所有者
      • 7.3 组的创建
        • 7.3.1 基本指令
        • 7.3.2 应用实例
      • 7.4 文件/目录 所在组
        • 7.4.1 查看文件/目录所在组
        • 7.4.2 修改文件/目录所在的组
      • 7.5 其它组
      • 7.6 改变用户所在组
        • 7.6.1 改变用户所在组
        • 7.6.2 应用实例
      • 7.7 权限的基本介绍
      • 7.8 rwx 权限详解,难点
        • 7.8.1 rwx 作用到文件
        • 7.8.2 rwx 作用到目录
      • 7.9 文件及目录权限实际案例
        • 7.9.1 ls -l 中显示的内容如下:
      • 7.10修改权限-chmod
        • 7.10.1 基本说明:
        • 7.10.2 第一种方式:+ 、-、= 变更权限
      • 7.11修改文件所有者-chown
        • 7.11.1 基本介绍
      • 7.12修改文件/目录所在组-chgrp
        • 7.12.1 基本介绍
        • 7.12.2 案例演示
      • 7.13最佳实践-警察和土匪游戏
      • 7.14课后练习
        • 7.12.2 案例演示
      • 7.13最佳实践-警察和土匪游戏
      • 7.14课后练习

1. Linux基础篇 -目录结构

1.1 基本介绍

  1. linux 的文件系统是采用级层式的树状目录结构,在此结构中的最上层是根目录“/”,然后在此目录下再创建其他的
    目录。
  2. 深刻理解 linux 树状文件目录是非常重要的,这里我给大家说明一下。
  3. 记住一句经典的话:在 Linux 世界里,一切皆文件(!!)
  4. 示意图

1.2 具体的目录结构(不用背,知道即可)

1) /bin [常用] (/usr/bin 、 /usr/local/bin)
   是 Binary 的缩写, 这个目录存放着最经常使用的命令
   
2) /sbin (/usr/sbin 、 /usr/local/sbin)
   s 就是 Super User 的意思,这里存放的是系统管理员使用的系统管理程序。
   
3) /home [常用]
   存放普通用户的主目录,在 Linux 中每个用户都有一个自己的目录,一般该目录名是以用户的账号命名, 老师演示体验

4) /root [常用]
   该目录为系统管理员,也称作超级权限者的用户主目录
   
5) /lib 系统开机所需要最基本的动态连接共享库,其作用类似于 Windows 里的 DLL 文件。几乎所有的应用程序都需要
   用到这些共享库
   
6) /lost+found 这个目录一般情况下是空的,当系统非法关机后,这里就存放了一些文件

7) /etc [常用]
   所有的系统管理所需要的配置文件和子目录, 比如安装 mysql 数据库 my.conf
   
8) /usr [常用]
   这是一个非常重要的目录,用户的很多应用程序和文件都放在这个目录下,类似与 windows 下的 program files 目录。
   
9) /boot [常用] 存放的是启动 Linux 时使用的一些核心文件,包括一些连接文件以及镜像文件

10) /proc [不能动] 这个目录是一个虚拟的目录,它是系统内存的映射,访问这个目录来获取系统信息

11) /srv [不能动] service 缩写,该目录存放一些服务启动之后需要提取的数据

12) /sys [不能动]这是 linux2.6 内核的一个很大的变化。该目录下安装了 2.6 内核中新出现的一个文件系统 sysfs =》【别
    动】
    
13) /tmp 这个目录是用来存放一些临时文件的

14) /dev
    类似于 windows 的设备管理器,把所有的硬件用文件的形式存储
    
15) /media [常用] linux 系统会自动识别一些设备,例如 U 盘、光驱等等,当识别后,linux 会把识别的设备挂载到这个
    目录下
    
16) /mnt [常用]
    系统提供该目录是为了让用户临时挂载别的文件系统的,我们可以将外部的存储挂载在/mnt/上,然后进入该目录就可以查看里的内容了。 d:/myshare
    
17) /opt 这是给主机额外安装软件所存放的目录。如安装 ORACLE 数据库就可放到该目录下。默认为空

18) /usr/local [常用]
    这是另一个给主机额外安装软件所安装的目录。一般是通过编译源码方式安装的程序
    
19) /var [常用]
    这个目录中存放着在不断扩充着的东西,习惯将经常被修改的目录放在这个目录下。包括各种日志文件
    
20) /selinux [security-enhanced linux]
    SELinux 是一种安全子系统,它能控制程序只能访问特定文件, 有三种工作模式,可以自行设置.


2. Linux 实操篇-远程登录到 Linux 服务器

2.1 为什么需要远程登录 Linux

  1. linux 服务器是开发小组共享
  2. 正式上线的项目是运行在公网
  3. 因此程序员需要远程登录到 Linux 进行项目管理或者开发

2.2 远程登录的软件

xshell 命令行控制
xftp 传输文件

软件下载地址 https://www.xshellcn.com/

3. Linux 实操篇- Vi 和 Vim 编辑器

3.1 vi 和 vim 的基本介绍

Linux 系统会内置 vi 文本编辑器
Vim 具有程序编辑的能力,可以看做是 Vi 的增强版本,可以主动的以字体颜色辨别语法的正确性,方便程序设计。
代码补完、编译及错误跳转等方便编程的功能特别丰富,在程序员中被广泛使用。

3.2 vi 和 vim 常用的三种模式

3.2.1正常模式

以 vim 打开一个档案就直接进入一般模式了(这是默认的模式)。在这个模式中, 你可以使用『上下左右』按键来
移动光标,你可以使用『删除字符』或『删除整行』来处理档案内容, 也可以使用『复制、粘贴』来处理你的文件数
据。

3.2.2插入模式

按下 i, I, o, O, a, A, r, R 等任何一个字母之后才会进入编辑模式, 一般来说按 i 即可.

3.2.3命令行模式

输入 esc 再输入:在这个模式当中, 可以提供你相关指令,完成读取、存盘、替换、离开 vim 、显
示行号等的动作则是在此模式中达成的!

3.3 各种模式的相互切换

在这里插入图片描述

3.4 键盘

在这里插入图片描述

3.5 常用快捷键

1) 拷贝当前行 yy , 拷贝当前行向下的 5 行 5yy,并粘贴(输入 p)。
2) 删除当前行 dd , 删除当前行向下的 5 行 5dd
3) 在文件中查找某个单词 [命令行下 /关键字 , 回车 查找 , 输入 n 就是查找下一个 ]
4) 设置文件的行号,取消文件的行号.[命令行下 : set nu 和 :set nonu]
5) 编辑 /etc/profile 文件,在一般模式下, 使用快捷键到该文档的最末行[G]和最首行[gg]
6) 在一个文件中输入 "hello" ,在一般模式下, 然后又撤销这个动作 u
7) 编辑 /etc/profile 文件,在一般模式下, 并将光标移动到 , 输入 20,再输入 shift+g

vim环境的变更

在一般模式下
	按 ESC  在输入 set nu 之后 会显示行号 输入数字可以到达

一般模式切换到指令行模式

:W  保存
:q  退出
:q! 强制退出不保存
:wq 保存后退出

指令行模式切换到一般模式

按 i即可进入编写模式

4. Linux 实操篇-开机、重启和用户登录注销

4.1 关机&重启命令

1) shutdown –h now 立该进行关机
2) shudown -h 1 "hello, 1 分钟后会关机了" 
3) shutdown –r now 现在重新启动计算机
4) halt 关机,作用和上面一样. 
5) reboot 现在重新启动计算机
6) sync 把内存的数据同步到磁盘.
  1. 不管是重启系统还是关闭系统,首先要运行 sync 命令,把内存中的数据写到磁盘中
  2. 目前的 shutdown/reboot/halt 等命令均已经在关机前进行了 sync , 老韩提醒: 小心驶得万年船

4.2 用户登录和注销

登录基本语法

su - 用户名

注销语法

logout
1)登录时尽量少用 root 帐号登录,因为它是系统管理员,最大的权限,避免操作失误。
可以利用普通用户登录,登录后再用”su - 用户名’命令来切换成系统管理员身份.
2) 在提示符下输入 logout 即可注销用户 就会退回上一级

使用细节
1)logout 注销指令在图形运行级别无效,在运行级别 3 下有效. 
2) 运行级别这个概念,后面给大家介绍

5. Linux 实操篇-用户管理

5.1 基本介绍

Linux 系统是一个多用户多任务的操作系统,任何一个要使用系统资源的用户,都必须首先向系统管理员申请一个账号,然后以这个账号的身份进入系统

5.2 添加用户

5.2.1基本语法

useradd 用户名

5.2.3细节说明

1. 当创建用户成功后,会自动的创建和用户同名的家目录  /home/用户名

2. 也可以通过 useradd -d 指定目录 新的用户名,给新创建的用户指定家目录

5.3 指定/修改密码

基本语法

passwd 用户名

5.4 删除用户

基本语法

userdel 用户名

5.5 查询用户信息指令

基本语法

id 用户名

5.6 切换用户

5.6.1介绍

在操作 Linux 中,如果当前用户的权限不够,可以通过 su - 指令,切换到高权限用户,比如 root

5.6.2基本语法

su - 切换用户名

5.6.4细节说明

1) 从权限高的用户切换到权限低的用户,不需要输入密码,反之需要。
2) 当需要返回到原来用户时,使用 exit/logout 指令

5.7 查看当前用户/登录用户

基本语法

whoami/ who am I

5.8 用户组

5.8.1介绍

类似于角色,系统可以对有共性/权限的多个用户进行统一的管理

在这里插入图片描述

5.8.2新增组

指令 : groupadd 组名

5.8.3删除组

指令(基本语法): groupdel 组名

5.8.4案例演示

  1. 增加用户时直接加上组
  2. 指令(基本语法) : useradd –g 用户组 用户名
  3. 增加一个用户 zwj, 直接将他指定到 wudang
  4. groupadd wudang
  5. useradd -g wudang zw

5.8.5修改用户的组

指令(基本语法):usermod –g 用户组 用户名

案例演示

创建一个组 mojiao
把 zwj 放入到 mojiao
指令: usermod -g mojiao zwj

5.9 用户和组相关文件

5.9.1/etc/passwd 文件

用户(user)的配置文件,记录用户的各种信息
每行的含义:用户名:口令:用户标识号:组标识号:注释性描述:主目录:登录 Shell
在这里插入图片描述

5.9.2/etc/shadow 文件

口令的配置文件
每行的含义:登录名:加密口令:最后一次修改时间:最小时间间隔:最大时间间隔:警告时间:不活动时间:失效时间:标志

5.9.3/etc/group 文件

组(group)的配置文件,记录 Linux 包含的组的信息
每行含义:组名:口令:组标识号:组内用户列表

6. Linux 实操篇-实用指令

6.1 指定运行级别

6.1.1基本介绍

运行级别说明:
0 :关机
1 :单用户【找回丢失密码】
2:多用户状态没有网络服务
3:多用户状态有网络服务
4:系统未使用保留给用户
5:图形界面
6:系统重启
常用运行级别是 3 和 5 ,也可以指定默认运行级别, 后面演示

6.1.2应用实例

命令:init [0123456] 
例如 init 1
应用案例: 
通过 init 来切换不同的运行级别,比如动 5-3 , 然后关机。

6.1.3 CentOS7 后运行级别说明

在 centos7 以前, /etc/inittab 文件中 . 进行了简化 ,如下:
multi-user.target: analogous to runlevel 3
graphical.target: analogous to runlevel 5

#To view current default target, run:
systemctl get-default

#To set a default target, run:
systemctl set-default TARGET.target

6.2 找回 root 密码

6.2.1面试题

如何找回 root 密码

6.3 帮助指令

6.3.1 man 获得帮助信息

基本语法:man [命令或配置文件](功能描述:获得帮助信息)

案例:查看 ls 命令的帮助信息 man ls
在 linux 下,隐藏文件是以 .开头 , 选项可以组合使用 比如 ls -al, 比如 ls -al /root

6.3.2 help 指令

基本语法:help 命令 (功能描述:获得 shell 内置命令的帮助信息)

6.3.4 百度帮助更直接

如果英语不太好的,也可以直接百度靠谱。

6.4 文件目录类

6.4.1 pwd 指令

基本语法 :pwd (功能描述:显示当前工作目录的绝对路径)

6.4.2 ls 指令

基本语法:ls [选项] [目录或是文件]

 常用选项

-a :显示当前目录所有的文件和目录,包括隐藏的。
-l :以列表的方式显示信息

6.4.3 cd 指令

基本语法:cd [参数] (功能描述:切换到指定目录)

理解:绝对路径和相对路径

cd ~ 或者 cd :回到自己的家目录, 比如 你是 root , cd ~ 到 /root
cd .. 回到当前目录的上一级目录

6.4.4 mkdir 指令

 mkdir 指令用于创建目录

基本语法:mkdir [选项] 要创建的目录

 常用选项
-p :创建多级目录

 应用实例
案例 1:创建一个目录 /home/dog
mkdir /home/dog
案例 2:创建多级目录 /home/animal/tiger
mkdir -p /home/animal/tiger
rmdir 指令

6.4.5 rmdir 指令删除空目录

 基本语法

rmdir [选项] 要删除的空目录
 应用实例
案例:删除一个目录 /home/dog
 使用细节
rmdir 删除的是空目录,如果目录下有内容时无法删除的。
提示:如果需要删除非空目录,需要使用 rm -rf 要删除的目录
比如: rm -rf /home/animal

6.4.6 touch 指令

 touch 指令创建空文件
 基本语法

touch 文件名称

 应用实例
案例: 在/home 目录下 , 创建一个空文件 hello.txt

6.4.7 cp 指令

cp 指令拷贝文件到指定目录

基本语法

cp [选项] source dest

 常用选项
-r :递归复制整个文件夹

 应用实例
案例 1: 将 /home/hello.txt 拷贝到 /home/bbb 目录下
cp hello.txt /home/bbb

案例 2: 递归复制整个文件夹,举例, 比如将 /home/bbb 整个目录, 拷贝到 /opt
cp -r /home/bbb /opt

 使用细节
强制覆盖不提示的方法:\cp , \cp -r /home/bbb /opt

6.4.8 rm 指令

说明:rm 指令移除文件或目录
 基本语法

rm [选项] 要删除的文件或目录

 常用选项
-r :递归删除整个文件夹
-f : 强制删除不提示

 应用实例
案例 1: 将 /home/hello.txt 删除 , rm /home/hello.txt
案例 2: 递归删除整个文件夹 /home/bbb , rm -rf /home/bbb [删除整个文件夹,不提示]

 使用细节
强制删除不提示的方法:带上 -f 参数即可

6.4.9 mv 指令

mv 移动文件与目录或重命名
 基本语法

mv oldNameFile newNameFile (功能描述:重命名)
mv /temp/movefile /targetFolder (功能描述:移动文件)
 应用实例
案例 1: 将 /home/cat.txt 文件 重新命名为 pig.txt
案例 2:将 /home/pig.txt 文件 移动到 /root 目录下
案例 3: 移动整个目录 , 比如将 /opt/bbb 移动到 /home 下 mv /opt/bbb /home/

6.4.10 cat 指令

cat 查看文件内容
 基本语法

cat [选项] 要查看的文件

 常用选项
-n :显示行号

 应用实例
案例 1: /etc/profile 文件内容,并显示行号
 使用细节
cat 只能浏览文件,而不能修改文件,为了浏览方便,一般会带上 管道命令 | more
cat -n /etc/profile | more [进行交互]

6.4.11 more 指令

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

more 要查看的文件

在这里插入图片描述

6.4.12 less 指令

less 指令用来分屏查看文件内容,它的功能与 more 指令类似,但是比 more 指令更加强大,支持各种显示终端。less
指令在显示文件内容时,并不是一次将整个文件加载之后才显示,而是根据显示需要加载内容,对于显示大型文件具有
较高的效率。

基本语法

less 要查看的文件

在这里插入图片描述

6.4.13 echo 指令

echo 输出内容到控制台
基本语法

echo [选项] [输出内容]

应用实例
案例: 使用 echo 指令输出环境变量, 比如输出 $PATH $HOSTNAME, echo $HOSTNAME

6.4.14 head 指令

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

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

应用实例

案例: 查看/etc/profile 的前面 5 行代码
head -n 5 /etc/profile

6.4.15 tail 指令

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

1、tail 文件 (功能描述:查看文件尾 10 行内容)

2、tail -n 5 文件 (功能描述:查看文件尾 5 行内容,5 可以是任意行数)

3、tail -f 文件 (功能描述:实时追踪该文档的所有更新)

应用实例

案例 1: 查看/etc/profile 最后 5 行的代码
tail -n 5 /etc/profile
案例 2: 实时监控 mydate.txt , 看看到文件有变化时,是否看到, 实时的追加 hello,world
tail -f /home/mydate.txt

6.4.16 > 指令 和 >> 指令

输出重定向和 >> 追加
基本语法

ls -l >文件 (功能描述:列表的内容写入文件 a.txt 中(覆盖写))

ls -al >>文件 (功能描述:列表的内容追加到文件 aa.txt 的末尾)

cat 文件 1 > 文件 2 (功能描述:将文件 1 的内容覆盖到文件 2)

echo "内容">> 文件 (追加)

应用实例

案例 1: 将 /home 目录下的文件列表 写入到 /home/info.txt 中, 覆盖写入
ls -l /home > /home/info.txt [如果 info.txt 没有,则会创建]
案例 2: 将当前日历信息 追加到 /home/mycal 文件中
指令为: cal >> /home/mycal

6.4.17 ln 指令

软链接也称为符号链接,类似于 windows 里的快捷方式,主要存放了链接其他文件的路径
基本语法

ln -s [原文件或目录] [软链接名] (功能描述:给原文件创建一个软链接)

应用实例

案例 1: 在/home 目录下创建一个软连接 myroot,连接到 /root 目录
ln -s /root /home/myroot
案例 2: 删除软连接 myroot
rm /home/myroot

细节说明
当我们使用 pwd 指令查看目录时,仍然看到的是软链接所在目录。

6.4.18 history 指令

查看已经执行过历史命令,也可以执行历史指令
基本语法

history (功能描述:查看已经执行过历史命令)

应用实例

案例 1: 显示所有的历史命令
history
案例 2: 显示最近使用过的 10 个指令。
history 10
案例 3:执行历史编号为 5 的指令
!5

6.5 时间日期类

6.5.1date 指令-显示当前日期

基本语法

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

 应用实例

案例 1: 显示当前时间信息
date
案例 2: 显示当前时间年月日
date "+%Y-%m-%d
案例 3: 显示当前时间年月日时分秒
date "+%Y-%m-%d %H:%M:%S" 9.5.2date 指令-设置日期

基本语法

date -s 字符串时间

应用实例

案例 1: 设置系统当前时间 , 比如设置成 2020-11-03 20:02:10
date -s “2020-11-03 20:02:10” 9.5.3cal 指令

查看日历指令 cal
基本语法

cal [选项] (功能描述:不加选项,显示本月日历)

应用实例

案例 1: 显示当前日历 cal
案例 2: 显示 2020 年日历 : cal 2020

6.6 搜索查找类

6.6.1 find 指令

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

find [搜索范围] [选项]

选项说明
在这里插入图片描述

应用实例

案例 1: 按文件名:根据名称查找/home 目录下的 hello.txt 文件
find /home -name hello.txt
案例 2:按拥有者:查找/opt 目录下,用户名称为 nobody 的文件
find /opt -user nobody
案例 3:查找整个 linux 系统下大于 200M 的文件(+n 大于 -n 小于 n 等于, 单位有 k,M,G)
find / -size +200M

6.6.2 locate 指令

locate 指令可以快速定位文件路径。locate 指令利用事先建立的系统中所有文件名称及路径的 locate 数据库实现快速
定位给定的文件。Locate 指令无需遍历整个文件系统,查询速度较快。为了保证查询结果的准确度,管理员必须定期更
新 locate 时刻
基本语法

locate 搜索文件

特别说明
由于 locate 指令基于数据库进行查询,所以第一次运行前,必须使用 updatedb 指令创建 locate 数据库。
应用实例

案例 1: 请使用 locate 指令快速定位 hello.txt 文件所在目录
which 指令,可以查看某个指令在哪个目录下,比如 ls 指令在哪个目录
which ls

6.6.3 grep 指令和 管道符号 |

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

基本语法
grep [选项] 查找内容 源文件

常用选项
在这里插入图片描述

应用实例
案例 1: 请在 hello.txt 文件中,查找 “yes” 所在行,并且显示行号
写法 1: cat /home/hello.txt | grep “yes” 写法 2: grep -n “yes” /home/hello.txt

6.7 压缩和解压类

6.7.1 gzip / gunzip 指令

gzip 用于压缩文件, gunzip 用于解压的
基本语法

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

应用实例

案例 1: gzip 压缩, 将 /home 下的 hello.txt 文件进行压缩
gzip /home/hello.txt

案例 2: gunzip 压缩, 将 /home 下的 hello.txt.gz 文件进行解压缩
gunzip /home/hello.txt.gz

6.7.2 zip/unzip 指令

zip 用于压缩文件, unzip 用于解压的,这个在项目打包发布中很有用的

基本语法

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

zip 常用选项
-r:递归压缩,即压缩目录
unzip 的常用选项
-d<目录> :指定解压后文件的存放目录
应用实例

案例 1: 将 /home 下的 所有文件/文件夹进行压缩成 myhome.zip
zip -r myhome.zip /home/ [将 home 目录及其包含的文件和子文件夹都压缩]
案例 2: 将 myhome.zip 解压到 /opt/tmp 目录下
mkdir /opt/tmp
unzip -d /opt/tmp /home/myhome.zip

6.7.3 tar 指令

tar 指令 是打包指令,最后打包后的文件是 .tar.gz 的文件。

基本语法

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

在这里插入图片描述

应用实例

案例 1: 压缩多个文件,将 /home/pig.txt 和 /home/cat.txt 压缩成 pc.tar.gz
tar -zcvf pc.tar.gz /home/pig.txt /home/cat.txt

案例 2: 将/home 的文件夹 压缩成 myhome.tar.gz
tar -zcvf myhome.tar.gz /home/

案例 3: 将 pc.tar.gz 解压到当前目录
tar -zxvf pc.tar.gz

案例4: 将myhome.tar.gz 解压到 /opt/tmp2目录下 (1) mkdir /opt/tmp2 (2) tar -zxvf /home/myhome.tar.gz -C /opt/tmp

7. Linux 实操篇-组管理和权限管理

7.1 Linux 组基本介绍

在 linux 中的每个用户必须属于一个组,不能独立于组外。在 linux 中每个文件
有所有者、所在组、其它组的概念。

  1. 所有者
  2. 所在组
  3. 其它组
  4. 改变用户所在的组

7.2 文件/目录 所有者

一般为文件的创建者,谁创建了该文件,就自然的成为该文件的所有者。

7.2.1 查看文件的所有者

基本语法

指令:ls –ahl

7.2.2 修改文件所有者

指令:chown 用户名 文件名

应用案例

要求:使用 root 创建一个文件 apple.txt ,然后将其所有者修改成 tom
chown tom apple.txt

7.3 组的创建

7.3.1 基本指令

groupadd 组名

7.3.2 应用实例

创建一个组, ,monster
groupadd monster
 创建一个用户 fox ,并放入到 monster 组中
useradd -g monster fox

7.4 文件/目录 所在组

当某个用户创建了一个文件后,这个文件的所在组就是该用户所在的组(默认)。

7.4.1 查看文件/目录所在组

基本指令

ls –ahl

应用实例, 使用 fox 来创建一个文件,看看该文件属于哪个组?

-rw-r--r--. 1 fox 0 11 月 5 12:50 ok.txt

7.4.2 修改文件/目录所在的组

基本指令

chgrp 组名 文件名

应用实例

使用 root 用户创建文件 orange.txt ,看看当前这个文件属于哪个组,然后将这个文件所在组,修改到 fruit 组。

1. groupadd fruit
2. touch orange.txt
3. 看看当前这个文件属于哪个组 -> root 组
4. chgrp fruit orange.txt

7.5 其它组

除文件的所有者和所在组的用户外,系统的其它用户都是文件的其它组

7.6 改变用户所在组

在添加用户时,可以指定将该用户添加到哪个组中,同样的用 root 的管理权限可以改变某个用户所在的组。

7.6.1 改变用户所在组

usermod –g 新组名 用户名
usermod –d 目录名 用户名 改变该用户登陆的初始目录。特别说明:用户需要有进入到新目录的权限。

7.6.2 应用实例

将 zwj 这个用户从原来所在组,修改到 wudang 组
usermod -g wudang zwj

7.7 权限的基本介绍

ls -l 中显示的内容如下:
-rwxrw-r-- 1 root root 1213 Feb 2 09:39 abc
0-9 位说明
第 0 位确定文件类型(d, - , l , c , b)
l 是链接,相当于 windows 的快捷方式
d 是目录,相当于 windows 的文件夹
c 是字符设备文件,鼠标,键盘
b 是块设备,比如硬盘
第 1-3 位确定所有者(该文件的所有者)拥有该文件的权限。---User
第 4-6 位确定所属组(同用户组的)拥有该文件的权限,---Group
第 7-9 位确定其他用户拥有该文件的权限 ---Other

7.8 rwx 权限详解,难点

7.8.1 rwx 作用到文件

1) [ r ]代表可读(read): 可以读取,查看
2) [ w ]代表可写(write): 可以修改,但是不代表可以删除该文件,删除一个文件的前提条件是对该文件所在的目录有写权
   限,才能删除该文件.
3) [ x ]代表可执行(execute):可以被执行

7.8.2 rwx 作用到目录

1) [ r ]代表可读(read): 可以读取,ls 查看目录内容
2) [ w ]代表可写(write): 可以修改, 对目录内创建+删除+重命名目录
3) [ x ]代表可执行(execute):可以进入该目录

7.9 文件及目录权限实际案例

7.9.1 ls -l 中显示的内容如下:

-rwxrw-r-- 1 root root 1213 Feb 2 09:39 abc
 10 个字符确定不同用户能对文件干什么
第一个字符代表文件类型: - l d c b
其余字符每 3 个一组(rwx) 读(r) 写(w) 执行(x)
第一组 rwx : 文件拥有者的权限是读、写和执行
第二组 rw- : 与文件拥有者同一组的用户的权限是读、写但不能执行
第三组 r-- : 不与文件拥有者同组的其他用户的权限是读不能写和执行
 可用数字表示为: r=4,w=2,x=1 因此 rwx=4+2+1=7 , 数字可以进行组合

其它说明

1 文件:硬连接数或 目录:子目录数
root 用户
root 组

1213 文件大小(字节),如果是文件夹,显示 4096 字节
Feb 2 09:39 最后修改日期
abc 文件名

7.10修改权限-chmod

7.10.1 基本说明:

通过 chmod 指令,可以修改文件或者目录的权限。

7.10.2 第一种方式:+ 、-、= 变更权限

u:所有者 g:所有组 o:其他人 a:所有人(u、g、o 的总和)

1) chmod u=rwx,g=rx,o=x 文件/目录名
2) chmod o+w 文件/目录名
3) chmod a-x 文件/目录名
    案例演示
4) 给 abc 文件 的所有者读写执行的权限,给所在组读执行权限,给其它组读执行权限。
   chmod u=rwx,g=rx,o=rx abc
5) 给 abc 文件的所有者除去执行的权限,增加组写的权限
   chmod u-x,g+w abc
6) 给 abc 文件的所有用户添加读的权限
   chmod a+r abc
   10.10.3 第二种方式:通过数字变更权限
   r=4 w=2 x=1 rwx=4+2+1=7
   chmod u=rwx,g=rx,o=x 文件目录名
   相当于 chmod 751 文件/目录名

案例演示

要求:将 /home/abc.txt 文件的权限修改成 rwxr-xr-x, 使用给数字的方式实现:

chmod 755 /home/abc.txt

7.11修改文件所有者-chown

7.11.1 基本介绍

chown newowner 文件/目录 改变所有者
chown newowner:newgroup 文件/目录 改变所有者和所在组
-R 如果是目录 则使其下所有子文件或目录递归生效

案例演示

1) 请将 /home/abc.txt 文件的所有者修改成 tom
   chown tom /home/abc.txt
2) 请将 /home/test 目录下所有的文件和目录的所有者都修改成 tom
   chown -R tom /home/test

7.12修改文件/目录所在组-chgrp

7.12.1 基本介绍

chgrp newgroup 文件/目录 【 改变所在组】

7.12.2 案例演示

请将 /home/abc .txt 文件的所在组修改成 shaolin (少林)
groupadd shaolin
chgrp shaolin /home/abc.txt
请将 /home/test 目录下所有的文件和目录的所在组都修改成 shaolin(少林)
chgrp -R shaolin /home/test

7.13最佳实践-警察和土匪游戏

police , bandit
jack, jerry: 警察
xh, xq: 土匪

1) 创建组 groupadd police ; groupadd bandit
2) 创建用户
   useradd -g police jack ; useradd -g police jerry
   useradd -g bandit xh; useradd -g bandit xq
3) jack 创建一个文件,自己可以读 r 写 w,本组人可以读,其它组没人任何权限
   首先 jack 登录 ; vim jack.txt ; chmod 640 jack.txt
4) jack 修改该文件,让其它组人可以读, 本组人可以读写
   chmod o=r,g=r jack.txt
5) xh 投靠 警察,看看是否可以读写. usermod -g police xh
6) 测试,看看 xh 是否可以读写,xq 是否可以, 小结论,就是如果要对目录内的文件进行操作,需要要有对该目录的
   相应权限
7) 示意图

7.14课后练习

练习文件权限管理[课堂练习], 完成如下操作. 1) 建立两个组(神仙(sx),妖怪(yg))

2) 建立四个用户(唐僧,悟空,八戒,沙僧)
3) 设置密码
4) 把悟空,八戒放入妖怪 唐僧 沙僧 在神仙
5) 用悟空建立一个文件 (monkey.java 该文件要输出 i am monkey)
6) 给八戒一个可以 r w 的权限
7) 八戒修改 monkey.java 加入一句话( i am pig)
8) 唐僧 沙僧 对该文件没有权限
9) 把 沙僧 放入妖怪组
10) 让沙僧 修改 该文件 monkey, 加入一句话 ("我是沙僧,我是妖怪!");
11) 对文件夹 rwx 的细节讨论和测试!!!
    x: 表示可以进入到该目录, 比如 cd
    r: 表示可以 ls , 将目录的内容显示
    w: 表示可以在该目录,删除或者创建文件
12) 示意图
chgrp newgroup 文件/目录 【 改变所在组】

7.12.2 案例演示

请将 /home/abc .txt 文件的所在组修改成 shaolin (少林)
groupadd shaolin
chgrp shaolin /home/abc.txt
请将 /home/test 目录下所有的文件和目录的所在组都修改成 shaolin(少林)
chgrp -R shaolin /home/test

7.13最佳实践-警察和土匪游戏

police , bandit
jack, jerry: 警察
xh, xq: 土匪

1) 创建组 groupadd police ; groupadd bandit
2) 创建用户
   useradd -g police jack ; useradd -g police jerry
   useradd -g bandit xh; useradd -g bandit xq
3) jack 创建一个文件,自己可以读 r 写 w,本组人可以读,其它组没人任何权限
   首先 jack 登录 ; vim jack.txt ; chmod 640 jack.txt
4) jack 修改该文件,让其它组人可以读, 本组人可以读写
   chmod o=r,g=r jack.txt
5) xh 投靠 警察,看看是否可以读写. usermod -g police xh
6) 测试,看看 xh 是否可以读写,xq 是否可以, 小结论,就是如果要对目录内的文件进行操作,需要要有对该目录的
   相应权限
7) 示意图

7.14课后练习

练习文件权限管理[课堂练习], 完成如下操作. 1) 建立两个组(神仙(sx),妖怪(yg))

2) 建立四个用户(唐僧,悟空,八戒,沙僧)
3) 设置密码
4) 把悟空,八戒放入妖怪 唐僧 沙僧 在神仙
5) 用悟空建立一个文件 (monkey.java 该文件要输出 i am monkey)
6) 给八戒一个可以 r w 的权限
7) 八戒修改 monkey.java 加入一句话( i am pig)
8) 唐僧 沙僧 对该文件没有权限
9) 把 沙僧 放入妖怪组
10) 让沙僧 修改 该文件 monkey, 加入一句话 ("我是沙僧,我是妖怪!");
11) 对文件夹 rwx 的细节讨论和测试!!!
    x: 表示可以进入到该目录, 比如 cd
    r: 表示可以 ls , 将目录的内容显示
    w: 表示可以在该目录,删除或者创建文件
12) 示意图
这篇关于Linux学习(一)的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!