一、实战案例(练习)内容
假如你学习完Linux,想找一份儿Linux相关的运维工作,某天你接到一家公司给出的邀请,你来到该公司面试,面试前,运维主管给你出了一些简单的笔试题,题目如下:
1、创建一个10G的文件系统,类型为ext4,要求开机可自动挂载至单独数据/data目录;
fdisk /dev/sda
命令(输入 m 获取帮助):n
Select (default e): p
Last 扇区, +扇区 or +size{K,M,G} (17190912-41943039,默认为 41943039):+10G
命令(输入 m 获取帮助):p
命令(输入 m 获取帮助):w
partx -a /dev/sda
mkfs.ext4 /dev/sda1
mount /dev/sda1 data/
mount -a
df
2、显示`netstat -tan`命令结果中以‘LISTEN’后跟0个、1个或者多个空白字符结尾的行;
netstat -tan |grep 'LISTEN.*[[:space:]]'
3、添加用户nginx、zabbix、tomcat、nologin以及hadoop用户(nologin用户的shell
为/sbin/nologin);而后找出/etc/passwd文件中用户名与其shell名相同的行;
useradd nginx
useradd zabbix
useradd tomcat
useradd hadoop
useradd -s /sbin/nologin nologin
grep "^\([[:alnum:]]\+\>\).*\1$" /etc/passwd
4、找出/etc/rc.d/init.d/functions文件中某单词(单词中间可以存在下划线)后面跟着一组小括号的行;
grep "_*[[:alpha:]]*\(_*[[:alpha:]]*\)*[[:space:]]*()" /etc/rc.d/init.d/functions
grep -E -o "^[_[:alpha:]]+\(\)" /etc/rc.d/init.d/functions
5、使用echo输出一个路径,而后egrep找出其路径基名;进一步的使用egrep取出其目录名(注意是目录名,而非目录路径);
echo "/etc/fstab" | grep -E -o "[^/]+?"
6、查找/usr目录下不属于root、bin或hadoop的所有文件;
find /usr -not \( -user root -o -user bin -o -user hadoop \)
7、某天系统被入侵了,黑客在你系统下留下木马文件:
现需要查找当前系统上没有属主或属组,且最近一周内曾被访问过的所有文件;
另外,需要查找/etc目录下大于20k且类型为普通文件的所有文件;
find / -nouser -a -nogroup -a -atime -7
find /etc -size +20k -type f
8、创建目录/test/data,让某组内普通用户对其有写权限,且创建的所有文件的属组为目录所属的组;此外,每个用户仅能删除自己的文件。
mkdir -p /test/data
chmod g+w /test/data
chmod g+s /test/data
chmod o+t /test/data