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 是一种安全子系统,它能控制程序只能访问特定文件, 有三种工作模式,可以自行设置.
xshell 命令行控制 xftp 传输文件 软件下载地址 https://www.xshellcn.com/
Linux 系统会内置 vi 文本编辑器
Vim 具有程序编辑的能力,可以看做是 Vi 的增强版本,可以主动的以字体颜色辨别语法的正确性,方便程序设计。
代码补完、编译及错误跳转等方便编程的功能特别丰富,在程序员中被广泛使用。
以 vim 打开一个档案就直接进入一般模式了(这是默认的模式)。在这个模式中, 你可以使用『上下左右』按键来
移动光标,你可以使用『删除字符』或『删除整行』来处理档案内容, 也可以使用『复制、粘贴』来处理你的文件数
据。
按下 i, I, o, O, a, A, r, R 等任何一个字母之后才会进入编辑模式, 一般来说按 i 即可.
输入 esc 再输入:在这个模式当中, 可以提供你相关指令,完成读取、存盘、替换、离开 vim 、显
示行号等的动作则是在此模式中达成的!
、
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即可进入编写模式
1) shutdown –h now 立该进行关机 2) shudown -h 1 "hello, 1 分钟后会关机了" 3) shutdown –r now 现在重新启动计算机 4) halt 关机,作用和上面一样. 5) reboot 现在重新启动计算机 6) sync 把内存的数据同步到磁盘.
登录基本语法
su - 用户名
注销语法
logout
1)登录时尽量少用 root 帐号登录,因为它是系统管理员,最大的权限,避免操作失误。 可以利用普通用户登录,登录后再用”su - 用户名’命令来切换成系统管理员身份. 2) 在提示符下输入 logout 即可注销用户 就会退回上一级 使用细节 1)logout 注销指令在图形运行级别无效,在运行级别 3 下有效. 2) 运行级别这个概念,后面给大家介绍
Linux 系统是一个多用户多任务的操作系统,任何一个要使用系统资源的用户,都必须首先向系统管理员申请一个账号,然后以这个账号的身份进入系统
useradd 用户名
1. 当创建用户成功后,会自动的创建和用户同名的家目录 /home/用户名 2. 也可以通过 useradd -d 指定目录 新的用户名,给新创建的用户指定家目录
基本语法
passwd 用户名
基本语法
userdel 用户名
基本语法
id 用户名
在操作 Linux 中,如果当前用户的权限不够,可以通过 su - 指令,切换到高权限用户,比如 root
su - 切换用户名
1) 从权限高的用户切换到权限低的用户,不需要输入密码,反之需要。 2) 当需要返回到原来用户时,使用 exit/logout 指令
基本语法
whoami/ who am I
类似于角色,系统可以对有共性/权限的多个用户进行统一的管理
指令 : groupadd 组名
指令(基本语法): groupdel 组名
指令(基本语法):usermod –g 用户组 用户名
案例演示
创建一个组 mojiao 把 zwj 放入到 mojiao 指令: usermod -g mojiao zwj
用户(user)的配置文件,记录用户的各种信息
每行的含义:用户名:口令:用户标识号:组标识号:注释性描述:主目录:登录 Shell
口令的配置文件
每行的含义:登录名:加密口令:最后一次修改时间:最小时间间隔:最大时间间隔:警告时间:不活动时间:失效时间:标志
组(group)的配置文件,记录 Linux 包含的组的信息
每行含义:组名:口令:组标识号:组内用户列表
运行级别说明: 0 :关机 1 :单用户【找回丢失密码】 2:多用户状态没有网络服务 3:多用户状态有网络服务 4:系统未使用保留给用户 5:图形界面 6:系统重启 常用运行级别是 3 和 5 ,也可以指定默认运行级别, 后面演示
命令:init [0123456] 例如 init 1 应用案例: 通过 init 来切换不同的运行级别,比如动 5-3 , 然后关机。
在 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
如何找回 root 密码
基本语法:man [命令或配置文件](功能描述:获得帮助信息)
案例:查看 ls 命令的帮助信息 man ls
在 linux 下,隐藏文件是以 .开头 , 选项可以组合使用 比如 ls -al, 比如 ls -al /root
基本语法:help 命令 (功能描述:获得 shell 内置命令的帮助信息)
如果英语不太好的,也可以直接百度靠谱。
基本语法 :pwd (功能描述:显示当前工作目录的绝对路径)
基本语法:ls [选项] [目录或是文件]
常用选项
-a :显示当前目录所有的文件和目录,包括隐藏的。 -l :以列表的方式显示信息
基本语法:cd [参数] (功能描述:切换到指定目录)
理解:绝对路径和相对路径
cd ~ 或者 cd :回到自己的家目录, 比如 你是 root , cd ~ 到 /root cd .. 回到当前目录的上一级目录
mkdir 指令用于创建目录
基本语法:mkdir [选项] 要创建的目录
常用选项
-p :创建多级目录
应用实例 案例 1:创建一个目录 /home/dog mkdir /home/dog 案例 2:创建多级目录 /home/animal/tiger mkdir -p /home/animal/tiger rmdir 指令
基本语法
rmdir [选项] 要删除的空目录
应用实例 案例:删除一个目录 /home/dog 使用细节 rmdir 删除的是空目录,如果目录下有内容时无法删除的。 提示:如果需要删除非空目录,需要使用 rm -rf 要删除的目录 比如: rm -rf /home/animal
touch 指令创建空文件
基本语法
touch 文件名称
应用实例
案例: 在/home 目录下 , 创建一个空文件 hello.txt
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
说明:rm 指令移除文件或目录
基本语法
rm [选项] 要删除的文件或目录
常用选项
-r :递归删除整个文件夹
-f : 强制删除不提示
应用实例 案例 1: 将 /home/hello.txt 删除 , rm /home/hello.txt 案例 2: 递归删除整个文件夹 /home/bbb , rm -rf /home/bbb [删除整个文件夹,不提示] 使用细节 强制删除不提示的方法:带上 -f 参数即可
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/
cat 查看文件内容
基本语法
cat [选项] 要查看的文件
常用选项
-n :显示行号
应用实例 案例 1: /etc/profile 文件内容,并显示行号 使用细节 cat 只能浏览文件,而不能修改文件,为了浏览方便,一般会带上 管道命令 | more cat -n /etc/profile | more [进行交互]
more 指令是一个基于 VI 编辑器的文本过滤器,它以全屏幕的方式按页显示文本文件的内容。more 指令中内置了若干快捷键(交互的指令),详见操作说明
基本语法
more 要查看的文件
less 指令用来分屏查看文件内容,它的功能与 more 指令类似,但是比 more 指令更加强大,支持各种显示终端。less
指令在显示文件内容时,并不是一次将整个文件加载之后才显示,而是根据显示需要加载内容,对于显示大型文件具有
较高的效率。
基本语法
less 要查看的文件
echo 输出内容到控制台
基本语法
echo [选项] [输出内容]
应用实例
案例: 使用 echo 指令输出环境变量, 比如输出 $PATH $HOSTNAME, echo $HOSTNAME
head 用于显示文件的开头部分内容,默认情况下 head 指令显示文件的前 10 行内容
基本语法
head 文件 (功能描述:查看文件头 10 行内容) head -n 5 文件 (功能描述:查看文件头 5 行内容,5 可以是任意行数)
应用实例
案例: 查看/etc/profile 的前面 5 行代码 head -n 5 /etc/profile
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
输出重定向和 >> 追加
基本语法
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
软链接也称为符号链接,类似于 windows 里的快捷方式,主要存放了链接其他文件的路径
基本语法
ln -s [原文件或目录] [软链接名] (功能描述:给原文件创建一个软链接)
应用实例
案例 1: 在/home 目录下创建一个软连接 myroot,连接到 /root 目录 ln -s /root /home/myroot 案例 2: 删除软连接 myroot rm /home/myroot
细节说明
当我们使用 pwd 指令查看目录时,仍然看到的是软链接所在目录。
查看已经执行过历史命令,也可以执行历史指令
基本语法
history (功能描述:查看已经执行过历史命令)
应用实例
案例 1: 显示所有的历史命令 history 案例 2: 显示最近使用过的 10 个指令。 history 10 案例 3:执行历史编号为 5 的指令 !5
基本语法
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
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
locate 指令可以快速定位文件路径。locate 指令利用事先建立的系统中所有文件名称及路径的 locate 数据库实现快速
定位给定的文件。Locate 指令无需遍历整个文件系统,查询速度较快。为了保证查询结果的准确度,管理员必须定期更
新 locate 时刻
基本语法
locate 搜索文件
特别说明
由于 locate 指令基于数据库进行查询,所以第一次运行前,必须使用 updatedb 指令创建 locate 数据库。
应用实例
案例 1: 请使用 locate 指令快速定位 hello.txt 文件所在目录 which 指令,可以查看某个指令在哪个目录下,比如 ls 指令在哪个目录 which ls
grep 过滤查找 , 管道符,“|”,表示将前一个命令的处理结果输出传递给后面的命令处理。
基本语法
grep [选项] 查找内容 源文件
常用选项
应用实例
案例 1: 请在 hello.txt 文件中,查找 “yes” 所在行,并且显示行号
写法 1: cat /home/hello.txt | grep “yes” 写法 2: grep -n “yes” /home/hello.txt
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
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
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
在 linux 中的每个用户必须属于一个组,不能独立于组外。在 linux 中每个文件
有所有者、所在组、其它组的概念。
一般为文件的创建者,谁创建了该文件,就自然的成为该文件的所有者。
基本语法
指令:ls –ahl
指令:chown 用户名 文件名
应用案例
要求:使用 root 创建一个文件 apple.txt ,然后将其所有者修改成 tom chown tom apple.txt
groupadd 组名
创建一个组, ,monster groupadd monster 创建一个用户 fox ,并放入到 monster 组中 useradd -g monster fox
当某个用户创建了一个文件后,这个文件的所在组就是该用户所在的组(默认)。
基本指令
ls –ahl
应用实例, 使用 fox 来创建一个文件,看看该文件属于哪个组?
-rw-r--r--. 1 fox 0 11 月 5 12:50 ok.txt
基本指令
chgrp 组名 文件名
应用实例
使用 root 用户创建文件 orange.txt ,看看当前这个文件属于哪个组,然后将这个文件所在组,修改到 fruit 组。 1. groupadd fruit 2. touch orange.txt 3. 看看当前这个文件属于哪个组 -> root 组 4. chgrp fruit orange.txt
除文件的所有者和所在组的用户外,系统的其它用户都是文件的其它组
在添加用户时,可以指定将该用户添加到哪个组中,同样的用 root 的管理权限可以改变某个用户所在的组。
usermod –g 新组名 用户名 usermod –d 目录名 用户名 改变该用户登陆的初始目录。特别说明:用户需要有进入到新目录的权限。
将 zwj 这个用户从原来所在组,修改到 wudang 组 usermod -g wudang zwj
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
1) [ r ]代表可读(read): 可以读取,查看 2) [ w ]代表可写(write): 可以修改,但是不代表可以删除该文件,删除一个文件的前提条件是对该文件所在的目录有写权 限,才能删除该文件. 3) [ x ]代表可执行(execute):可以被执行
1) [ r ]代表可读(read): 可以读取,ls 查看目录内容 2) [ w ]代表可写(write): 可以修改, 对目录内创建+删除+重命名目录 3) [ x ]代表可执行(execute):可以进入该目录
-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 文件名
通过 chmod 指令,可以修改文件或者目录的权限。
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
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
chgrp newgroup 文件/目录 【 改变所在组】
请将 /home/abc .txt 文件的所在组修改成 shaolin (少林) groupadd shaolin chgrp shaolin /home/abc.txt 请将 /home/test 目录下所有的文件和目录的所在组都修改成 shaolin(少林) chgrp -R shaolin /home/test
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) 示意图
练习文件权限管理[课堂练习], 完成如下操作. 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 文件/目录 【 改变所在组】
请将 /home/abc .txt 文件的所在组修改成 shaolin (少林) groupadd shaolin chgrp shaolin /home/abc.txt 请将 /home/test 目录下所有的文件和目录的所在组都修改成 shaolin(少林) chgrp -R shaolin /home/test
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) 示意图
练习文件权限管理[课堂练习], 完成如下操作. 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) 示意图