Linux 常用命令练习二 实验二
linux 常用命令练习,涉及到文件和目录管路,用户和组的管理等,实验二。例如:以root账号登录。查看CentOS根目录下有哪些内容。在当前目录下,建立权限为741的目录,如何保证每个用户都可以在/tmp/test中新建文件,但只能删除自己的文件而不能删除别人的文件?
PART 1
-
以root账号登录:
su root
-
查看CentOS根目录下有哪些内容:
cd / ls -a
-
进入/tmp目录,创建一个名为example的目录,并进入该目录。
cd tmp mkdir example cd example
-
显示当前所在目录:
pwd
-
在当前目录下,建立权限为741的目录test:
mkdir test chmod 741 test
-
将root用户家目录下的.bashrc复制到/tmp/example目录下。
我现在位于example目录中,如果你现在不是root用户,命令前面加上
sudo
cp /root/.bashrc ./
-
重复步骤6,要求在覆盖前询问是否覆盖
cp /root/.bashrc ./ -i
-
用touch命令,在当前目录下建立文件abc
touch abc
-
查看文件abc的权限,大小,创建时间。
ls -l abc
-
强制删除该文件
rm -f abc
PART 2
-
使用cat命令加行号显示文件/etc/issue的内容。
我现在位于
/
根目录下cat -n etc/issue
-
使用more命令查看文件/etc/man_db.conf 的内容。
more etc/man_db.conf
-
使用less命令查看文件/etc/man_db.conf的内容
less etc/man_db.conf
-
使用head命令查看文件/etc/man_db.conf前15行的内容
head -n 15 etc/man_db.conf
-
将/usr/bin/passwd中的内容使用ASCII方式输出。
od -c /usr/bin/passwd
PART 3
-
将当前目录设为/root.
在root用户下
cd /root
-
执行 echo pwd>>pwd.sh命令,了解命令产生的结果。
在当前目录下创建pwd.sh文件并追加pwd内容。 如果已经存在了pwd.sh文件,那么就是在pwd.sh文件中追加pwd
-
查看文件pwd.sh的权限。
ls -l pwd.sh
-
执行./pwd.sh,能否执行,为什么?
不能,因为没有可执行权限
-
将pwd.sh文件权限为可执行,再重新执行./pwd.sh。
chmod 777 pwd.sh ./pwd.sh
-
新建用户user1,user2,user3。
adduser user1 adduser user2 adduser user3
-
在/tmp下新建文件夹test。
mkdir /tmp/test
-
查看test文件夹的权限是多少?
ls -ld /tmp/test
-
修改test文件夹的权限为777。
chmod /tmp/test
-
分别使用user1、user2和user3在/tmp/test下新建文件:用户名.txt
以user1为例:
su user1 touch /tmp/test/user1.txt
-
以user1身份看能否删除user2和user3的文件?
yes
-
如何保证每个用户都可以在/tmp/test中新建文件,但只能删除自己的文件而不能删除别人的文件?
将test设置sticky特殊权限即可
chmod o+t /tmp/test
-
修改/tmp/test的权限为1777
这里其实和上面的设置是一样的
chmod 1777 /tmp/test
-
验证user1、user2和user3都可以在/tmp/test下新建、修改、删除自己的文件
确实可以
-
以user1身份看能否删除user2和user3的文件?
不行,因为设置了sticky特殊权限
PART 4
-
用file命令查看/root/.bashrc的类型。
file /root/.bashrc # 为 ASCII text,文本文件
-
用file命令查看以下三个文件的类型: /etc/passwd /bin/bash /dev/console 了解这三个文件的作用。
/etc/passwd 文件: 类型:文本文件 作用:/etc/passwd 文件是Linux系统中存储用户账户信息的文件之一。每行代表一个用户账户,包含了有关该用户的各种信息,如用户名、用户ID(UID)、主组ID(GID)、用户的家目录、默认的shell等等。这些信息用于验证用户的身份和权限管理。 /bin/bash 文件: 类型:可执行文件 作用:/bin/bash 是Bash Shell的执行文件路径。Bash是一种常用的命令行解释器和脚本语言,它允许用户与Linux系统进行交互,运行命令和脚本。通常,当一个用户登录到系统时,它的默认shell会被设置为Bash,以便用户可以使用Bash的功能。 /dev/console 文件: 类型:字符设备文件 作用:/dev/console 是Linux系统的控制台设备文件。它提供了对系统控制台的访问权限,可以用于读取和写入控制台上的信息。这是一个特殊文件,通常不直接由普通用户操作,而是由系统管理员或特权用户使用,用于系统日志和维护目的。
-
用which命令查询ifconfig和mkdir命令的完整文件名。
which ifconfig # /usr/sbin/ifconfig which mkdir # /usr/bin/mkdir
-
用find命令查找/下所有名称为man.config的文件。
find / -type f -name man.config
-
用locate命令查找/下所有名称为man.config的文件
locate man.config
-
用find命令找出系统中大于1M的文件
find / -type f -size +1M
PART 5
-
新建组:software
请确保你在root用户下,如果不是需要再命令前面加上
sudo
groupadd software
-
新建账户student_1并设置主组群为software。分别查看/etc/passwd文件、/etc/shadow文件最后一行内容,并记录。
useradd -m -G software -s /bin/bash student_1 tail -n 1 /etc/passwd tail -n 1 /etc/shadow # 结果为: # student_1:x:1001:1002::/home/student_1:/bin/bash # student_1:!:19622:0:99999:7:::
-
验证student_1账户在图形界面下能否登录系统?
我密码都不知道,咋登录??这题目应该是想让我说不能
-
修改账户student_1密码为:123456,查看/etc/shadow文件最后一行内容,并记录。
passwd student_1 tail -n 1 /etc/shadow # 结果为:student_1:$6$I5.OjvCHxCQP7M2U$nypnVO982w3d4IIgYoL1AmUgg1tGtSZuJpt9N72u9hlx/CDYmsdIMC9kYVTCcSf.CPamPFq6aTtCn1u/0KT130:19622:0:99999:7:::
-
验证student_1账户在图形界面下能否登录系统?
yes
-
删除student_1账户的密码
passwd -d student_1
-
验证student_1账户在图形界面下能否登录系统?
这题目应该是想让我说能,这里我们删除密码之后再看一下shadow,发现那里是空的,应该是如果是!就不可以登录,有显示加密密码或者空密码就可以登录。
-
修改账户名为: test
usermod -l test student_1
-
删除账户及主目录和邮箱。
userdel -r test
-
创建一个新组,组名为computer,查看/etc/group文件最后一行内容,并记录。
groupadd computer tail -n 1 /etc/group # computer:x:1003:
-
创建两个新账户,名为test1,test2,并将其主组群和附属组都设为computer。查看/etc/group文件最后一行内容,并记录。设置computer组密码。
useradd -m -G computer -s /bin/bash test1 useradd -m -G computer -s /bin/bash test2 tail -n 1 /etc/group # 我这里显示的是test2:x:1004: # 但我感觉题目想让我看到的是computer:x:1003:test1,test2,这是我这里倒数第三行的内容 gpasswd computer
-
将当前用户切换为test1,用touch命令在/home/test1下创建一个新文件,文件名为ex_test1.txt;将当前用户切换为test2,用touch命令在/home/test2下创建一个新文件,文件名为ex_test2.txt;
su test1 touch /home/test1/ex_test1.txt su test2 touch /home/test2/ex_test2.txt
-
将当前用户切换为root,查找属于用户test1的文件,查找属于组computer的文件。
su find / -type f -user test1 find / -type f -group computer
-
在computer组中删除用户test2, 查看/etc/group文件最后一行内容,并记录。
gpasswd -d test2 computer tail -n 1 /etc/group # 我这里显示的还是test2:x:1004: # 但是我感觉题目想让我看到的是computer:x:1003:test1,这是我这里倒数第三行的内容
PART 6
开放原子开发者工作坊旨在鼓励更多人参与开源活动,与志同道合的开发者们相互交流开发经验、分享开发心得、获取前沿技术趋势。工作坊有多种形式的开发者活动,如meetup、训练营等,主打技术交流,干货满满,真诚地邀请各位开发者共同参与!
更多推荐
所有评论(0)