文章目录
- 1. Linux基础篇 -目录结构
- 2. Linux 实操篇-远程登录到 Linux 服务器
- 3. Linux 实操篇- Vi 和 Vim 编辑器
- 4. Linux 实操篇-开机、重启和用户登录注销
- 5. Linux 实操篇-用户管理
- 6. Linux 实操篇-实用指令
- 7. Linux 实操篇-组管理和权限管理
1. Linux基础篇 -目录结构
1.1 基本介绍
- linux 的文件系统是采用级层式的树状目录结构,在此结构中的最上层是根目录“/”,然后在此目录下再创建其他的
目录。 - 深刻理解 linux 树状文件目录是非常重要的,这里我给大家说明一下。
- 记住一句经典的话:在 Linux 世界里,一切皆文件(!!)
- 示意图
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
- linux 服务器是开发小组共享
- 正式上线的项目是运行在公网
- 因此程序员需要远程登录到 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 把内存的数据同步到磁盘.
- 不管是重启系统还是关闭系统,首先要运行 sync 命令,把内存中的数据写到磁盘中
- 目前的 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案例演示
- 增加用户时直接加上组
- 指令(基本语法) : useradd –g 用户组 用户名
- 增加一个用户 zwj, 直接将他指定到 wudang
- groupadd wudang
- 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 中每个文件
有所有者、所在组、其它组的概念。
- 所有者
- 所在组
- 其它组
- 改变用户所在的组
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) 示意图