1.在11月内,每天早上6点到12点,每隔2小时执行一次/usr/bin/httpd.sh怎么实现?
00 06-12/2 * 11 * /bin/bash /usr/bin/httpd.sh
2.已知oldboy.txt文件有如下内容:
183.250.220.178|-l[20/jul/2017:10:35:14 +0800]|POST /audiosearch/search
HTTP/1.1|200|54|-lDalvik/1.6.0(linux;U;Android 4,4,4;Konka Android TV 638
Build/KTU84P)|-l-5.069|5.001,0.005|[www.kuyun.com|8771|172.21.19.67:8084,172.21.19.66:8084]
请取出Android字符串(不少于两种方法)?
sed –nr ‘2s#.*U;(.*) 4,.*#\1#gp’ oldboy.txt
awk –F “[; ]+” ‘NR==2{print $4}’ oldboy.txt
3、 已知有test.txt文件
a) 追加输入1-10数字序列到文件中,要求数字成列竖向显示
seq 10 >>test.txt
b) 打印出文件第4-8行的内容
grep –C2 “6” test.txt
sed -n '4,8p' test.txt
4.在Linux系统中,查找3天内修改过的文件名为‘oldboyedu.txt’的文件,并把它打包到/tmp目录下并以当天日期命名?
find –type f –name “oldboyedu.txt” –mtime -3 –exec tar zcvf /oldboy$(date –d +%F).tar.gz {} \;
|xargs tar zcvf /tmp/$(date +%F).tar.gz
5、如何赋予oldboy.txt文件-rw-r--r-x 权限,并且所有者为oldboy,所属组为sa?
chmod 645 oldboy.txt
chown oldboy.sa oldboy.txt
6、.什么是SUID?作用是?举一个使用SUID的命令,它是如何利用SUID工作的?
他是特殊权限位 作用是给一个文件设置了SUID权限 那么他就有跟所属主一样的权限 特殊权限,一般对二进制命令文件进行设置,所有用户执行该命令都具有所有者权限
passwd命令 它的所属用户的root,但是所有用户都可以通过passwd修改密码
chmod +s oldboy.txt
7、有一个/opt/backup.sh的备份脚本,如何在10月的每天06-18点,每3小时执行并在13点单独执行一次。
00 06-18/3,13 * 10 * /bin/sh /opt/backup.sh
8、企业开发人员和你要一个oldboy用户临时拥有root权限10天,你该如何解决?
useradd –e `date +%F -d "+10 day"` oldboy
vimsudo oldboy ALL=(ALL) ALL
9、请将ip add结果中的eth0网卡对应ip地址取出(用awk或sed加正则表达式取)。
[root@oldboyedu ~]# ip add
2: eth0: mtu 1500 qdisc pfifo_fast state UP group default qlen 1000
link/ether 00:0c:29:2a:ca:54 brd ff:ff:ff:ff:ff:ff
inet 10.0.0.2/24 brd 10.0.0.255 scope global noprefixroute eth0
ip add |sed –nr ‘3s#et .*(.*)brd.*#\1#gp’
ip add |awk –F”[ ]+” ‘NR==3{print $3}’
10、Linux现连接新的存储(/dev/sdb,容量3T),一个应用程序需要在/data目录使用此存储的500G的存储空间,请描述方法并给出相应命令?
parted /dev/sdb
mktable gpt
mkfs –t xfs /dev/sdb1
mount /dev/sdb1 /data
11、查找出系统中当前目录下大于1M的文件,把文件中的oldboy替换为oldgirl?
find –type f –size +1M |xargs sed –i ‘s#oldboy #oldgirl#gp’
12、如何给sshd服务设置开机自启动?
systemctl enable sshd .service
chkconfig sshd on
13、 批量创建oldboy01-oldboy10共10个用户,并统一设置密码123456?
seq –w 10|sed –nr ‘s#(.*)#useradd oldboy\1;echo “123456”|passwd –stdin oldboy\1#gp’|bash
echo {01..10}|xargs -n1|sed –nr ‘s#(.*)#useradd oldboy\1;echo “123456”|passwd –stdin oldboy\1#gp’|bash
脚本实现
#!/bin/bash
for i in {1..10}
do
useradd oldboy$i
echo "123456" |passwd --stdin oldboy$i
done
14、 编写Shell脚本,在文件结尾传入2个数字参数,实现比较两个整数大小?
if [ $a –gt $b ]
then
echo “$a>$b”
elif [ $a –eq $b ]
then
echo “$a=$b”
else
echo “$a<$b”
fi
15、如何授权oldgirl用户权限,使其只能实现添加和删除用户系统管理的务?
visudo
oldgirl ALL=(ALL) /usr/sbin/useradd,/usr/sbin/userdel
16、 b如何查看和设置Linux的默认网关?
vim /etc/sysconfig/network-scripts/ifcfg-eth0
route -n
netstat -nr
修改默认网关
route add default gw *****
[笔试考试试题理论部分] (总满分24分,每题4分)
1. 请根据容量、风险性、性能方面简述raid0、raid1、raid5、raid10的特点?
raid0:最少一块盘,容量无损失,对数据安全要求不高,读写都很快
raid1:最少2快盘,损失一半容量,冗余100% 读快写慢 镜像盘,用于很重要得数据
raid5:最少3快盘,损失一块盘得容量来做奇偶效验 风险小 读写还不错,一般企业常用,容量损失不多但还有一定得性能
raid10:最少4快盘,损失一半容量 很重要得数据,系统引导程序,数据库主库一般会选用,先纵向做镜像 在横向做条带 写慢读快
2. 请简述软硬链接的区别?
创建:硬链接 ln 软连接 ln-s
inode 索引节点 硬链接相同 软连接不同
硬链接只能对文件创建并不能跨文件系统
软连接可以对目录创建并能跨文件系统
删除
删除源文件对硬链接无影响 软连接失效
当硬链接数为0时文件就真删除了
删除软连接对源文件无影响
3. 一个ext3的文件分区,当使用touch test.file命令创建一个新文件时报错,报错的信息是提示磁盘已满‘no space left on device’,但是采用df -h命令查看磁盘大小时,只使用了60%的磁盘空间,为什么会出现这个情况?说说你的理由,如何解决?
大量小文件把inode用光了
df -i 查看inode使用情况
find ./ -type f -size -4k 查找小文件
find ./ -type d -size +1M
ls ./*|rm -rf 删除
4. Linux 下通过mkdir 命令创建一个新目录/oldboy/ett,它的硬链接数是多少,为什么?如果在/oldboy/ett 下面再创建一个目录test。再问/oldboy/ett 的硬链接数是多少?为什么?
/oldboy/ett 他的硬链接数是2,因为他本身是一个,还有一个他的上级目录一个
/oldboy/ett下还有一个目录 那么他的硬链接数就是3个一个它本身,一个上级目录一个下级目录
5. 请简述Centos6的开机启动流程?
BIOS自检=======>MBR引导程序=====>GRUB菜单=====>加载内核===>运行init进程====>设定运行级别====>系统初始化====>启动运行级别下得脚本====>加载开机自启动程序====>显示登陆界面
6. 简述tcp/ip三次握手和四次断开原理过程?
[笔试考试试题解释翻译部分] (总满分12分,每题6分)
1. 请写出以下各目录和文件的作用
/etc/fstab 开机自动挂载
/etc/hosts 本地DNS解析文件目录
/etc/hostname 主机名配置文件目录
/etc/resolv.conf 配置系统DNS解析文件目录路
/etc/rc.local 开机自启动文件目录
/etc/profile 系统环境变量/别名文件目录
##### 2\. 请翻译一下报错的含义
1、No such file or directory 没有这个文件或目录
2、command not found 没有这个命令
3、rm: cannot remove /oldboy/data/: Is a directory
不能删除 因为他是一个目录
4、ls: cannot open directory /root: Permission denied
不能打开 没有权限
5、Firewall is not running.
防火墙没有运行
6、Couldn't resolve host www oldboyedu.com
无法解析主机
一. 三剑客-基础部分题目
涉及到三剑客过滤,替换,取列操作
1. 选择
在给定文件中查找与条件相符字符串的命令及查找某个目录下相应文件的命令为:(多选)AC
- A:grep
- B:gzip
- C:find
sort在给定文件中查找与设定条件相符字符串的命令为(A)
- A:grep
- B:gzip
- C:find
- D:sort
___D____命令可以从文本文件的每一行中截取指定内容的数据。
- A:cp
- B:dd
- C:fmt
- D:cut
下面表述错误的是
- 表示开头,如abc表示以abc开头的 √
- 表示以abc为结尾的 √
- ?表示前一个字符出现0或1次,如ab?c之间c表示a与可有0或1个b存在 ×
-
- 表示前一个字符出现0或多次。如ab+c表示a与c之间可有0或多个b存在 √
2. 填空
Unix中在当前目录下所有.cc 的文件中找到含有“asiainfo”内容的文件,命令为_______
find ./ -type f -name "*.cc"|xargs grep 'asiainfo'
使用AWK指定分隔符的参数是___-F_____
3. 简答
找出当前目录下包含127.0.0.1关键字的文件?
grep -rl '127.0.0.1' ./*
删除/显示1.txt文件第3行到第10行的内容?
sed '3,10d' 1.txt
使用awk取出/etc/passwd第一列数据也就是取出用户名。
cat /etc/passwd|awk -F ":" '{print $1}'
用命令行更改config.txt文件,把里面所有的“name”更改为“address”
sed -nri 's#name#address#gp' ./config.txt
利用sed命令将test.txt中所有的回车替换成空格?
- sed -nr 's#\n# #gp' ./test.txt
写出查询file.txt以abc结尾的行
sed -n '/abc$/p' ./file.txt
删除file.txt文件中的空行
sed '/^$/d' ./file.txt
打印file.txt文件中的第10行
sed -n '10p' file.txt
删除/etc/fstab文件中所有以#开头的行的行首的# 号及#后面的所有空白字符;
cat /etc/fstab|sed -nr 's#[\# ]+##p' |sed -nr '/[^$]/p'
查找最后创建时间是3天前,后缀是*.log的文件并删除
find / -type f -mtime +3 -name "*.log"|xargs rm -fr
find / -type f -mtime +3 -name "*.log" -exec rm -fr {} \;
查找文件中1到20行之间,同时将"aaa"替换为"AAA","ddd"替换"DDD"
head -n 20 | tr 'aaaddd' 'AAADDD'
使用sed命令打印出文件的第一行到第三行
sed -n '1,3p'
在/var/ sync/log/cef_watchd-20080424.1og文件中查找大小写不敏感“mysql"字符串中的命令是
grep -i 'mysql' /var/ sync/log/cef_watchd-20080424.1og
为了在/var/sync/log 目录中查找更改时间在5日以前的文件井删除它们,linux命令是
find /var/sync/log/ -type f -mtime +5 |xargs rm -fr
把data目录及其子目录下所有以扩展名.txt结尾的文件中包含oldgirl的字符串全部替换为oldboy.
find /data/ -type f -name "*.txt"|sed -nr 's#oldgirl#oldboy#pg'
写出删除abc.txt文件中的空行
sed -nr 's#^$##pg' abc.txt
查看linux服务器ip的命令,同时只显示包含ip所在的行打印出来
ip add|awk -F " " 'NR==9{print $0}'
用awk获取文件中第三行的倒数第二列字段
awk -F " " 'NR==3{print $(NF-1)}'
有文件file1
- 请用shell查询file1里面空行的所在行号
#!/bin/bash grep -n '^$' file1
- 查询file1以abc结尾的行
grep 'abc$' file1
- 打印file文件第一行到第三行
sed -n '1,3p' file1
显示file文件里匹配foo字串那行以及上下5行、显示foo及前5行、显示foo及后5行
grep -C 5 'foo' file
echo "ABCDEF abtdefg" |sed -i s/c/t/g 这条命令是否正确?如若正确可能会显示什么样的结果?
错误
ABtDEF abtdefg
当前系统中没有任何文本编辑器(vi,emacs,vim,edit等),如何过来掉注释行和空行查看/etc/ssh/sshd_config文件
cat /etc/ssh/sshd_config|sed -nr 's#[\# ]+##p' |sed -nr '/[^$]/p'
例如:文件名为“filename”,文件内容如下:
#This is a comments-1
#This is a comments-2
This is a comments-1
This is a comments-2
This is a comments-3
This is a comments-4
egrep -v '#|^$' hjkl.txt
查找file.log文件中的包含关键字“helloworld”的内容,及其上下两行的内容从定向保存到1.txt。请写出命令
grep -C 2 'helloworld' file.log >1.txt
二. 进阶题目:
需要用到awk数组和函数知识点
找出ifconfig命令结果中的1-255之间的数值;
ifconfig |egrep -o '[0-2]{1}[0-5]{2}'
文件内容排序、文件行取唯一值的命令分别是?
用awk获取文件中第三行的倒数第二列字段
awk -F " " 'NR==3{print $(NF-1)}'
awk是一个很强大的文本处理工具,请使用awk统计当前主机的并发访问量
有一个文件nginx.log,请用awk提取时间(HH:MM),文件内容如下:
183.250.220.178|-l[20/jul/2017:10:35:14 +0800]|POST /audiosearch/search
HTTP/1.1|200|54|-lDalvik/1.6.0(linux;U;Android 4,4,4;Konka Android TV 638
Build/KTU84P)|-l-[5.069|5.001,0.005|www.kuyun.com|8771|172.21.19.67:8084,172.21.19.66:8084]
183.250.220.178|-l[20/jul/2017:10:35:14 +0800]|POST /audiosearch/search
HTTP/1.1|200|54|-lDalvik/1.6.0(linux;U;Android 4,4,4;Konka Android TV 638
Build/KTU84P)|-l-[5.069|5.001,0.005|www.kuyun.com|8771|172.21.19.67:8084,172.21.19.66:8084]
统计apache访问日志流量排名前10个IP
统计出apache的access.log 中访问最多的5个ip
这条linux命令的含义:netstat -n |awk '/^tcp/ {++[图片上传失败...(image-bc76b6-1554725764131)]
} print a,${a} }'