2019-05-07 不会的题以及知识点

[1] 多核CPU和单核CPU的优点和缺点,是否所有程序在多核CPU上运行速度都快?为什么?

优点:多线程 在一个时钟周期内能处理更多的任务
缺点:功耗较大 需要特定平台支持 需要大容量内存跟进
不一定
有的程序运行就只需要单核cpu,在这种情况下,多核cpu就不一定比单核的运行速度快

[2] 32位操作系统和64位操作系统的区别,并说明它们的优点和缺点?

1, 设计目标不同
2 支持的最大内存不同(32位最大支持4g的内存,64位可以支持更大的内存)
3 运行速度不同 (32位相当于4车道,64位相当于8车道)

64位的兼容性可能没32位好,但其实影响不大的。
64位处理能力比较好

[3] 给你6个150G硬盘,列出RAID排列方式,哪种方式容量最大,并解释。

raid 0 的容量最大
因为raid0 的容量是所有硬盘容量的总和,容量是最大的

[4] 固态硬盘和传统硬盘有什么区别,并说明它们的优点和缺点。

相对于传统机械硬盘,固态硬盘的优点:

1、读写速度快;2、防震抗摔性强;3、低功耗。4、无噪音。5、工作温度范围大。6、体积小,携带轻便。

相对于传统机械硬盘,固态硬盘的缺点:

1、容量比机械硬盘小2、寿命比机械硬盘短3、制造成本高所以价格比机械硬盘高。

[5] 说出你公司服务器的配置

戴尔R730
R:表示机架式服务器
7:与服务器的核数有关
3:标示第13代服务器

2U的服务器,2路,26核心,硬盘是8600G

【6】 简述常见Raid级别及应用场景

raid 0 ,至少一块硬盘, 容量是所有磁盘容量的总和,冗余安全为0,速写速度很快,应用场景是:只要求读写速度,不要求安全
raid 1 ,只有两块硬盘,容量是所有磁盘容量的一半,冗余安全为100%,写入速度慢,读取速度OK,应用场景是对速度没有要求,对安全要求比较高
raid 5 ,至少三块硬盘,容量是损失了一块磁盘的容量,冗余安全是最多可以损失一块磁盘的容量,写入速度慢,读取速度OK,应用场景是对速度没要求,对安全有要求

raid 10 ,至少四块硬盘,容量是损失了一半磁盘的容量,冗余安全是最多可以损失一半磁盘的容量,读写速度都快,应用场景是对速度和安全都有要求

【7】简述虚拟机上不了网的原因

1,检查ip地址是否正确
2,检查网卡配置是否正确
3,检查是否关闭CetOs7 NetworkManager
4, 检查vmware 虚拟网络编辑器
5,检查vmware 服务是否正常运行
6,检查vmware 网卡问题
7,检查windows 是否开启wifi 热点软件
8,检查windows 网卡是否被共享

【8】说出以下目录的内容

/dev 磁盘 光盘
/mnt 临时挂载点
/etc/group 用户组信息文件

【9】创建用户组old,指定gid为1024

groupadd -g 1024 old

创建用户boy指定uid为1024,指定用户组为old
useradd -u 1024 -g old boy

【10】 每周六凌晨2点15分将/etc/下以.conf结尾的文件打包到/backup目录下,并以时间命名,同时删除7天前的压缩包但是要保留每周一的

bak-del

15 02 * * 6 sh /server/scripts/bak-del.sh >/dev/null 2>&1
cat /server/scripts/bak-del.sh

!/bin/bash

tar zcf /backup/bak-date +%F_+%w.tar.gz $(find /etc/ -type f -name '.conf')
find /backup/ -type f -mtime +7 !-name '
._1.tar.gz' |xargs rm -f

【11】 什么是三次握手,什么是四次挥手

【12】 简述什么是nfs,什么是rsync,这两个服务的作用是什么

【13】 翻译

7.1 /dev/sda is mounted; will not make a filesystem here!
/dev/sda 已经挂载,不能再在这里创建一个文件系统

7.2 id: lidao: No such user
没有这个用户

7.3 mount: you must specify the filesystem type

7.4 useradd: UID is not unique
UID不唯一

7.5 You have new mail in /var/spool/mail/root
你有一封新邮件在/var/spool/mail/root

(15) Linux网卡配置文件路径是什么?要使服务器上外网,必须满足的条件有哪些?需要配置什么?

/etc/sysconfig/network-scripts/ifcfg-eth0

上外网需要连接intenet的网线或有网卡

需要配置ip dns gateway

(16)在超级用户下显示Linux系统中正在运行的全部进程,应使用的命令及参数是________。

ps -a

(17).修改机器名为exam,ip更改为192.168.1.227

hostnamectl set-hostname exam
vim /etc/sysconfig/network-scripts/ifcfg-eth0

(18).Linux所有服务器的启动脚本都存放在(C)目录中

/etc/rc.d/init.d
/etc/init.d
/etc/rc.d/rc
/etc/rc.d

(19)以下哪些命令可以查看当前系统的启动时间(D)
w
top
ps
uptime

(20)Linux启动的第一个进程init启动的第一个脚本程序是( D)

/etc/rc.d/init.d
/etc/rc.d/re/sysinit
/etc/rc.d/rc5.d
/etc/rc.d/rc3.d

(21) 如何查看系统的负荷及内存使用状况?

/proc/loadavg

(22) 什么是绝对路径?什么是相对路径

绝对路径:一切从根开始。 相对路径:从当前路径开始

(23) 至少说出三个centos7中常用的快捷键

CTRL+c取消当前操作
CTRL+d退出登陆用户
CTRL+l清屏
CTRL+a光标移到行最前
CTRL+e光标移到行最后
ctrl+u 光标移到行首的内容删除/剪切
ctrl+k 光标移到行尾的内容删除/剪切
ctrl+y 粘贴
tab 自动补齐
(24)简述以下cd命令的含义

cd . 到当前目录
cd .. 到上一级目录
cd - 到上一次目录
cd /tmp 到/tmp目录

(25)简述以下ls命令参数的含义

ls -a 查看所有文件
ls -l 显示文件及目录详细信息
ls -ld 显示当前目录详细信息
ls -t 将当前目录下所有文件按创建时间倒序显示

(26):使用一条命令在/tmp/oldboy01--05这五个目录下分别创建一个名为oldgirl01.txt的文件

touch /tmp/oldboy{01..5}/oldgirl01.txt

(27)使用一条命令,将/tmp/oldboy02/oldgirl01.txt文件移动到/tmp/oldboy06/test/目录下,并该,改名为oldgirl02.txt

mv /tmp/oldboy02/oldgirl01.txt /tmp/oldboy06/test/oldgir02.txt

(28)以树状结构显示/tmp目录,要求可以看出文件类型(不同类型加上不同标记)(3分)

tree -F

(29)翻译

1 mkdir: cannot create directory ‘/lidao’: File exists 无法 创建 目录 因为这个目录已经存在
2 -bash: cd: oldboy: No such file or directory 没有这个目录:文件或路径书写错误
3 -bash: tree: command not found 没有这个命令
4 touch: invalid option -- 'p'Try 'touch --help' for more information. 无效的参数(不可用的参数),可以使用help帮助
5 cp: overwrite ‘/tmp/oldboy.txt’? 是否覆盖文件
6 rm: remove regular empty file ‘/oldboy/oldboy.txt’? 是否删除文件
7 rm: cannot remove ‘/data/’: Is a directory 不能删除目录
8 tree: Invalid level, must be greater than 0. 无效层数
9 ping: baidu.com: Name or service not known 域名无法解析
10 w: 56 column window is too narrow 空间太小施展不开

(30)

进入vim /etc/profile 最后一行添加 alias rm=‘rm -i’
让配置生效source /etc/profile

2:如何临时取消别名

unalias +别名

3:输入ip,显示网卡配置文件

进入vim /etc/profile 最后一行添加 alias ip='cat /etcsysconfig/network-scripts/ifcfg-eth0'
让配置生效source /etc/profile 然后输入ip显示网卡配置文件

4:将网卡配置文件输入到/tmp/test.txt 文件中

cat /etc/sysconfig/network-scripts/ifcfg-eth0 >> /tmp/test.txt

5:接4 题,筛选出带有10 的行

grep '10' /tmp/test.txt

6:接4 题,筛选出带有IPADDR 字符的行

grep -w 'ipaddr' /tmp/test.txt

7:接4 题,筛选出带有254 的行,并显示行号
grep -n '254' /tmp/test.txt

8:接4 题,筛选出/tmp/test.txt 文件中带有a 的行(不区分大小写)
grep -i 'a' /tmp/test.txt

9:接4 题,将/tmp/test.txt 文件中的10.0.0 替换为192.168.10
进入vim /tmp/test.txt中 输入:%s#10.0.0#192.168.10#g

10:接4 题,显示出/tmp/test.txt 文件中不带有数字的行
grep -v [0-9] /tmp/test.txt

11:简述ll 查看文件属性后每一列的含义

33687021 -rw-r--r--. 1 root root 0 Apr 3 17:50 old.txt
33687022 -rw-r--r--. 1 root root 0 Apr 3 17:50 boy.txt
33687023 -rw-r--r--. 1 root root 0 Apr 3 17:50 edu.txt

inode号码 索引节点
第1位 文件类型
第2-10位 权限
. SELinux相关
硬链接的数量 1个不同的入口
所拥有者
所属用户组
文件大小
文件修改的时间
文件名和目录 不是文件属性

在/tmp 目录下创建名为etc1 的 /etc 的软连接

ln -s /etc/ /tmp/etc1

在/tmp/目录下创建名为net 的,/etc/sysconfig/network-scripts/ifcfg-eth0 或ens33 文件的软连接

ln -s /etc/sysconfig/network-scripts/ifcfg-eth0 /tmp/net

将网卡配置文件复制到/tmp 目录下,并改名为ifcfg

cp /etc/sysconfig/network-scripts/ifcfg-eth0 /tmp/ifcfg

将/tmp/ifcfg 文件中的所有小写字母替换成大写字母

tr 'a-z' 'A-Z' < /tmp/ifcfg

将/tmp/ifcfg 文件中的所有数字删除

tr -d '0-9' < /tmp/ifcfg

查找cat 命令与reboot 命令的位置

[root@oldboy59 tmp]# which cat reboot
/usr/bin/cat
/usr/sbin/reboot

查找根下所有名中带有oldboy 的文件与目录(不区分大小写)

find / -iname 'oldboy'

查找根下所有大于1M 的目录

find / -type d -size +1M

查找/etc/目录下三级目录以内,以.txt 结尾的文件(不区分大小写)

find /etc/ -maxdepth 3 -type f -iname '*.txt'

查看/tmp/ifcfg,每行显示2 列

xargs -n 2 </tmp/ifcfg

将/etc/目录压缩到/tmp/目录下,压缩包名为etc.tar.gz(显示过程)

tar zcvf /tmp/etc.tar.gz /etc/

查看/tmp/etc.tar.gz 这个压缩包中都有什么文件

tar tf /tmp/etc.tar.gz

将/tmp/etc.tar.gz 目录解压到/root/目录下(不显示过程)

tar xf /tmp/etc.tar.gz -C /root/

复习(困难难度)

查找/etc/下所有不是以.txt 结尾的文件

find /etc/ -type f ! -iname '*.txt'

查找根下最近一天所修改的文件

find / -type f -mtime 1

复习+预习

查看系统当前的年月日

[root@oldboy59 tmp]# date +%Y-%m-%d
2019-04-10

查看系统当前的时分秒

[root@oldboy59 tmp]# date +%H:%M:%S
17:00:51

显示十天前的时间

[root@oldboy59 tmp]# date -d '-10day' +%F_%T
2019-03-31_17:01:38

显示十年后的时间

[root@oldboy59 tmp]# date -d '+10year' +%F_%T
2029-04-10_17:02:15

将时间修改成2019 年5 月1 日19 时0 分

[root@oldboy59 tmp]# date -s '20190501 19:00:00'
Wed May 1 19:00:00 CST 2019

同步网络时间

[root@oldboy59 tmp]# ntpdate ntp1.aliyun.com
10 Apr 17:10:54 ntpdate[77877]: adjust time server 120.25.115.20 offset 0.001572 sec

复习

排除/oldboy/目录下的old文件,打包到/tmp下,并命名为oldboy.tar.gz

tar zcvf /tmp/oldboy.tar.gz /oldboy/ --exclude /oldboy/old

什么是inode,什么是block:

inode:索引节点的inode号码,存放文件属性信息,包括大小、所有者、权限、文件类型、硬链接数、时间,还有block的位置,但是文件名没有存放在这里
block:用来存放文件内容

哪种链接的inode与源文件相同:
硬链接,inode的节点和源文件相同

软连接与硬链接的区别:
首先是不能对目录创建硬链接,但可以创建软链接
还有是软链接可以跨文件系统,硬链接不能跨文件系统

困哪难度

压缩/etc/目录到/tmp下,并以时间命名

tar zcf /tmp/date +%F-%T /etc

查找根下名字中带有oldboy的文件,并查看它的详细信息

find / -type f -name 'oldboy'|xargs -

什么是超级用户、普通用户、虚拟用户,他们的UID分别是多少

超级用户:拥有最高权限 UID 0
普通用户:能登录系统,但只能操作自己目录的内容
UID:centos6是500以上 centos7是1000以上
虚拟用户:无法创建,系统自身拥有,不具有登录系统的能力
UID centos6是1-499 centos7是1-999

创建一个属于old用户组的用户boy

groupadd old
useradd -g old boy

Linux启动流程(CentOS6和CentOS7)
CentOS 6 CentOS 7
0 关机 0 关机
1单用户 1救援模式
2多用户没网 2多用户模式
3完全多用户 3多用户模式
4待开发用户设定 4多用户模式
5图形界面 5图形界面
6重启 6重启

链接分为—软链接—和—硬链接—

Linux提供远程连接服务是ssh远程控制卡_

默认端口_____22____,在___/etc/ssh/sshd_config____文件中进行修改端口

从当前系统中卸载一个已装载的文件系统的命令:____umount _____

下列关于链接描述,错误的是_B

硬链接就是让链接文件的i节点号指向被链接文件的i节点
硬链接和符号连接都是产生一个新的i节点
链接分为硬链接和符号链接
硬链接不能链接目录文件

在Linux系统中root用户的UID号是__0___GID是0

在Linux系统以 —文件方式—方式访问设备

如何知道操作系统的位数?(32位或64位)

查看操作系统位数 getconf LONG_BIT
查看Linux版本信息 lsb_release -a

[root@oldboy59 tmp]# uname -m 查看位数信息
x86_64
[root@oldboy59 tmp]# uname -r 内核版本信息和位数信息
3.10.0-957.10.1.el7.x86_64
[root@oldboy59 tmp]# uname 查看系统
Linux

写出至少5 个Linux 快捷键(5)

Linux下快捷键

解释

tab

自动补齐

Ctrl+ c

取消当前操作

clear

清屏

Ctrl+l

清屏

Ctrl++a

把光标移动到行首

Ctrl++e

把光标移动到行尾

Ctrl++u

光标移到行首的内容删除/剪切

Ctrl++k

光标移到行尾的内容删除/剪切

ctrl+y

粘贴

Ctrl+b

光标左移

Ctrl+f

光标右移

Ctrl+w

删除之前一个空格分割的内容

Ctrl+z

暂停正在执行的任务

bg

使暂停的任务继续工作

Ctrl+insert

复制

Ctrl+insert

粘贴

Esc+.

返回上次结尾内容

jobs

查看当前后台运行的任务

Ctrl+s

锁屏

Ctrl+q

解锁屏幕

!*

可以调出上次以*开头的命令并执行

!!

可以调出上次执行的命令并执行

8:给rm 命令加一个别名,让每次删除都强制提醒command not found,给出配

置过程(要求配置后永久生效)(3)
第一种方法:
vim /etc/profile
到文件尾行添加
alias rm='echo command not found'
:wq 保存退出
让配置生效
source /etc/profile

第二种方法:
echo 'alias rm='echo command not found' ' >>/etc/profile
查看
tail -1 /etc/profile
alias rm='echo command not found'
让配置生效
source /etc/profile

(二) 填空(每空1 分)

1 某文件的组外成员的权限为只读:所有者有全部权限,组内的权限为读与写,

则该文件的权限为-rwxrw-r-- (764)

2 Vi 编辑器中要想定位到文件中的第十行按10gg&10G 键,删除一个字母后按 u 键

可以恢复

4 Linux 中,文件权限读、写、执行的三种标志符号依次rwx

5 如果执行命令# chmod 746 file.txt , 那么该文件的权限是-rwxr--rw-

6 用 >>符号将输出重定向内容附加在原文的后面

cat >>file. txt<<EOF

(三) 命令(每题2 分)

1 如何查看文件内容,命令有哪些?查看文件第1 行到第3 行,查看文件最后

一行
cat less more head tail vi/vim
查看第1 行到第3 行
head -n 3 文件名
查看最后一行
tail -n 1 文件名

2 查找根下所有名中带有oldboy 的文件与目录(不区分大小写)

find / -iname 'oldboy'

3 查找根下所有以.txt 结尾、最近一天修改过、大于1M 的文件

find / -mtime -1 -size +1M -name '*.txt'

4 将/etc/目录压缩到/tmp/目录下,压缩包名为etc.tar.gz

tar zcf /tmp/etc.tar.gz /etc

5 查看/tmp/etc.tar.gz 这个压缩包中都有什么文件

tar tf /tmp/etc.tar.gz

6 将/tmp/etc.tar.gz 目录解压到/root/目录下(不显示过程)

tar xf /tmp/etc.tar.gz -C /root/

7 筛选出网卡配置文件中带有a 的行(不区分大小写)
grep -i 'a' /etc/sysconfig/network-scripts/ifcfg-eth0

8 将网卡配置文件中的所有小写字母替换成大写字母

tr 'a-z' 'A-Z' </etc/sysconfig/network-scripts/ifcfg-eth0

9 将文本文件a.txt,想将该文件名称改为txt.a

mv a.txt txt.a

10 在/tmp 目录下创建名为etc.soft 的/etc 的软连接

ln -s /etc /tmp/etc.soft

11 将时间修改成2019 年5 月1 日19 时0 分

date -s '20190501 19:00'

12 查看系统当前的详细时间(年月日-时-周几)

date +%F_%H-%w

13.没有十三题~~

14 什么是超级用户,虚拟用户,普通用户。

超级用户 拥有最高权限(皇帝) UID=0
普通用户 属组用户(老百姓) CentOS 6的UID >=500 CentOS 7的UID>=1000
虚拟用户 系统自带(傀儡) CentOS 6的UID =1-499 CentOS 7的UID=1-999

15 写出4 个可以查看文件内容的命令

cat less more head tail vi/vim

16 创建oldboy 用户,然后切换为oldboy 用户给出命令

useradd oldboy
su - oldboy

(四) 重要文件(每题1 分)

1 /etc/sysconfig/network-scripts/ifcfg-eth0 ------>配置网卡
2 /etc/fstab ------>挂载 系统开机自动加载的列表文件
3 /var/log/messages ------>系统日志
4 /var/log/secure------> 用户登录日志
5 /etc/resolv.conf------>客户端的DNS配置文件
6 /proc/meminfo------> 内存信息
7 /etc/hosts------> 本地DNS解析
8 /etc/profile------>环境变量
9 /etc/inittab------>运行级别的配置文件
10 /etc/rc.local------>系统自启动的程序或者脚本列表

(五) 报错翻译(每题2 分)

1 Could not connect to '10.0.0.200' (port 233): Connection failed.
无法连接到“10.0.0.200”(端口233):连接失败。

2 mkdir: cannot create directory ‘/lidao’: File exists
:无法创建目录“/lidao”:文件存在

3 tar: Removing leading `/' from member names

压缩的路径包含了'/'的绝对路径

4 ping: baidu.com: Name or service not known
域名无法解析

5 tree: Invalid level, must be greater than 0.

无效的级别必须大于0

6 You have mail in /var/spool/mail/root
您有一封邮件来自/var/spool/mail/root

7 Can't open file for writing

无法打开修改

8 descend into directory

无权限进入此目录

9 Nothing to do
空闲

10 Could not resolve host

无法解析主机名

(六) 扩展

1 如何查看/etc 目录所占容量(6)

du -sh /etc

2 筛选出网卡配置文件中带有数字的行(6)

grep -r '[0-9]' /etc/sysconfig/network-scripts/ifcfg-eth0

3 创建一个属于old 用户组的用户boy(8)

创建old: groupadd old
创建用户boy: useradd -g lll boy

一. 三剑客-基础部分题目

涉及到三剑客过滤,替换,取列操作

  1. 选择

在给定文件中查找与条件相符字符串的命令及查找某个目录下相应文件的命令为:(多选)A C
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 (剪切)

下面表述错误的是D
表示开头,如abc表示以abc开头的
表示结尾如abc表示以abc为结尾的
?表示前一个字符出现0或1次,如ab?c表示a与c之间可有0或1个b存在

  • 表示前一个字符出现0或多次。如ab+c表示a与c之间可有0或多个b存在
    填空
    Unix中在当前目录下所有.cc 的文件中找到含有“oldboy”内容的文件,命令为___
    find -type f -name '.cc'|xargs grep 'asiainfo'
    find -type f -name '
    .cc' -exec grep 'asiainfo' {} ;
    grep 'asiainfo' `find . -type f -name '*.cc'`

如果没有指定扩展名则直接使用
grep -rl 'oldboy' ./*
-r 递归查询
-l (小写字母L)只显示grep查找出来的文件

使用AWK指定分隔符的参数是___-F或-vFS=____

找出当前目录下包含127.0.0.1关键字的文件?

grep '127.0.0.1' find . -type f
2.三剑客+反引号
sed -n '/127.0.0.1/p' find . -type f
awk '/127.0.0.1/' find . -type f
3.find+|xargs+三剑客
find . -type f|xargs grep '127.0.0.1'
find . -type f|xargs sed -n '/127.0.0.1/p'
find . -type f|xargs awk '/127.0.0.1/'
4.find -exec +三剑客
find .-type f -exec grep '127.0.0.1' {} ;
find .-type f -exec sed -n '/127.0.0.1/p' {} ;
find .-type f -exec awk '/127.0.0.1/' {} ;

删除/显示1.txt文件第3行到第10行的内容?
删除:
sed -n '3,10p' 1.txt
sed -i '3,10d' 1.txt
awk '(NR>=3&&NR<=10)' 1.txt \把第三行到第十行排除
awk '(NR<3||NR>10)' oldboy.txt \ 小于第三行或者大于十行

显示:
sed -n '3,10p' 1.txt
awk 'NR==3,NR==7' 1.txt
awk 'NR>=3 && NR<=10' 1.txt
head -10 num.txt|tail -8

使用awk取出/etc/passwd第一列数据也就是取出用户名。
基础必备:
awk -F: '{print 1}' /etc/passwd sed 's#:.*##g' /etc/passwd
egrep -o '^[0-Z_-]+' /etc/passwd \[0-Z]==[a-zA-Z0-9]

提高:
egrep -o '[:]+' /etc/passwd
sed -r 's#([:]+).*#\1#g' /etc/passwd awk '{gsub(/:.*/,"");print}' /etc/passwd
\print 在 awk 中后面什么都不加表示 print 0 awk '{gsub(/:.*/,"")}1' /etc/passwd

用命令行更改config.txt文件,把里面所有的“name”更改为“address”
sed 's#name#address#g' config.txt
awk '{gsub(/name/,"address")}1' config.txt

利用vi/vim也可以替换:
:%s#name#address#g

写出查询file.txt以abc结尾的行
grep 'abc' file.txt sed -n ‘/abc/p’ file.txt
awk '/abc$/' file.txt

删除file.txt文件中的空行
模拟环境:
echo -e 'oldboy\noldboy\n\nalex\n \nalex\lidao lidao alex\n
oldboy\n\noldboyedu group 598972270' >file.txt

仅删除文件中的空行:
grep -v '^' file.txt sed '/^/d' file.txt
awk '!/^$/' file.txt

文件中的空行可能是只有空格的行
egrep -v '| +' file.txt
grep -v '^ *' file.txt sed -n '/^ */p' file.txt
awk '/^ *$/' file.txt

^ *表示两种情况: *表示前1个字符出现0次的时候:^
*表示前1个字符出现1次及1次以上的时候:^ +$

打印file.txt文件中的第10行
sed -n '10p' 4.txt
awk 'NR==10' 4.txt
head -10 file.txt|tail -1

删除/etc/fstab文件中所有以#开头的行,行首的#号及#后面的所有空白字符
空白字符:空格,多个空格,tab键

sed -r '/^#/s## *##g' /etc/fstab|cat -A \查看一下行尾是否还有空白行
awk 'gsub (/^# */,"");{print $1}' /etc/fstab|cat -A

此题可以分为两个题目:

  1. 删除/etc/fstab 文件中所有以#开头的行的行首的# 号及#后面的所有空白字符
  2. 删除/etc/fstab 文件中所有以#开头的行的行首的#号及#后面的连续的空白字符

可以分为两步:哪个是条件,哪个是动作
❑第 1 步找出以#开头的行
awk '/#/{gsub(/#|[ \t]+/,"")}1' /etc/fstab
sed -r '/#/s@#|[ \t]+@@g' /etc/fstab

❑第 2 步在删除这一行中的空白字符和行首的井号
删除/etc/fstab 文件中所有以#开头的行的行首的# 号及#后面的连续的空白字符
awk '{gsub(/^#[ \t]+/,"")}1' /etc/fstab
sed -r 's@^#[ \t]+@@g' /etc/fstab

查找最后修改时间是3天前,后缀是.log的文件并删除
find /tmp/ -type f -mtime +3 -name '
.log' |xargs rm -f

find /tmp/ -type f -mtime +3 -name '*.log' -exec rm -f {} ;

\rm -rf find /tmp/ -type f -mtime +3 -name '*.log'

find /tmp/ -type f -mtime +3 -name '*.log' -exec rm {} +

find /oldboy -mtime +3 -type f -name "*.log" -delete \ -delete删除

\ ; -exec find 命令找出 1 个文件就把文件放在{}的位置
\ +;如果-exec后面使用+ find会把前面找到的所有文件1次性的放在{}所在位置

查找文件中1到20行之间,同时将"aaa"替换为"AAA","ddd"替换"DDD"
sed -ne 's#a#A#g;s#d#D#g;1,20p' 2.txt

sed '1,20y/ad/AD/' 2.txt \ y类似于tr的 1对1 替换 不能使用 a-z A-Z 范围

sed 's#[ad]#\U&#g' 2.txt \

tr 'ad' 'AD' <2.txt

awk '{gsub(/a/,"A");gsub(/d/,"D");print}' 2.txt

awk 'NR>=1&&NR<=20{print toupper($0)}' 2.txt

awk 'NR==1,NR==20{print toupper($0)}' 2.txt

使用sed命令打印出文件的第一行到第三行
head -3 lidao.txt

sed -n '1,3p' lidao.txt

awk 'NR>=1&&NR<=3' lidao.txt

awk 'NR==1;NR==2;NR==3' lidao.txt

在/var/sync/log/cef_watchd-20080424.1og文件中查找大小写不敏感“mysql"字符串中的命令是
grep -iw 'mysql' /var/sync/log/cef_watchd-20080424.1og

sed -nr '/(mysql|MYSQL)/p' /var/sync/log/cef_watchd-20080424.1og

sed -nr '/(mysql|MYSQL)/Ip' /var/sync/log/cef_watchd-20080424.1og \sed中 I表示不区分大小写,极少用

awk -vIGNORECASE=1 '/[a-z]/' /var/sync/log/cefwatchd-20080424.log

为了在/var/sync/log 目录中查找更改时间在5日以前的文件井删除它们,linux命令是
find /var/sync/log -type f -mtime +5 |xargs rm -rf

find /var/sync/log -type f -mtime +5 -exec rm -rf {} ;

rm -rf find /var/sync/log -type f -mtime +5

把data目录及其子目录下所有以扩展名.txt结尾的文件中包含oldgirl的字符串全部替换为oldboy.

sed -i 's#oldgirl#oldboy#g' find /data/ -type f -name '*.txt'

find /data/ -type f -name '*.txt'|xargs sed -ni 's#oldboy#oldgirl#gp'

写出删除abc.txt文件中的空行
sed '/^/d' abc.txt sed -n '/^/!p' 1.txt
grep -v '^$' 1.txt

查看linux服务器ip的命令,同时只显示包含ip所在的行打印出来
ip a s eth0|sed -n '3p'|sed -r 's#^.t ([0-9].)/.#\1#g' #sed多管道 ip a s eth0|sed -nr '3s#^.*t (.*)/.*#\1#gp' #用sed
ip a s eth0|awk -F'[/ ]+' 'NR==3{print 3}' #用awk ip a s eth0|sed -n '3p'|awk -F'[ /]+' '{print3}' #sed+awk
ip a s eth0|awk 'NR==3'|sed -r 's#^.
t (.)/.#\1#g' #awk+sed ip a s eth0|grep 'inet '|sed -r 's#^.*t (.*)/.*#\1#g' #grep+sed ip a s eth0|grep 'inet '|awk -F'[ /]+' '{print3}' #grep+awk

用awk获取文件中第三行的倒数第二列字段
awk 'NR==3{print $(NF-1)}' 2.txt

有文件file1
请用shell查询file1里面空行的所在行号
grep -n '^$' file1.txt

awk '/^/{print NR,0}' file1.txt

sed -n '/^$/{=;p}' file.txt|sed 'N;s#\n# #g'

查询file1以abc结尾的行
grep 'abc' file.txt sed -n ‘/abc/p’ file.txt
awk '/abc$/' file.txt

打印file文件第一行到第三行
head -3 lidao.txt
sed -n '1,3p' lidao.txt
awk 'NR>=1&&NR<=3' lidao.txt
awk 'NR==1;NR==2;NR==3' lidao.txt

显示file文件里匹配foo字串那行以及上下5行、显示foo及前5行、显示foo及后5行
grep -A5 'foo' file.txt
grep -B5 'foo' file.txt
grep -C5 'foo' file.txt

echo "ABCDEF abtdefg" |sed -i s/c/t/g 这条命令是否正确?如若正确可能会显示什么样的结果?
不正确
-i 修改文件内容
no input files
sed 无法找到要修改的文件

当前系统中没有任何文本编辑器(vi,emacs,vim,edit等),如何过滤掉注释行和空行查看/etc/ssh/sshd_config文件
sed -r '/#|/d' /etc/ssh/sshd_config sed -nr '/^|^#/!p' /etc/ssh/sshd_config
awk '!/^|^#/' /etc/ssh/sshd_config grep '^[a-Z]' /etc/ssh/sshd_config egrep -v '^|^#' /etc/ssh/sshd_config

查找file.log文件中的包含关键字“helloworld”的内容,及其上下两行的内容重定向保存到1.txt。请写出命令
grep -C2 'helloworld' file.log >> 5.txt

二. 进阶题目:
需要用到awk数组和函数知识点

利用sed命令将test.txt中所有的回车替换成空格?
模拟环境:
echo -e 'oldboy\noldboy\n\nalex\n \nalex\lidao lidao alex\n oldboy\n\noldboyedu group 598972270' >file.txt

仅删除文件中的空行
grep -v '^' file.txt sed '/^/d' file.txt
awk '!/^$/' file.txt

文件中的空行可能是只有空格的行
egrep -v '| +' file.txt
grep -v '^ *' file.txt sed -n '/^ */p' file.txt
awk '/^ *$/' file.txt

^ *表示两种情况: 表示前1个字符出现0次的时候:^
表示前1个字符出现1次及1次以上的时候:^ +$

从a.log文件中提取包含“WARNING”或“FATAL”,同时不包含“IGNOR”行,然后,提取以“:”分割的第五个字段
awk -F: '/WARNING|FATAL/&&!/IGNOR/{print $5}'

找出ifconfig命令结果中的1-255之间的数值;
net-tools
ifconfig| egrep -o '[0-9]+'|awk '0>=1 &&0<=255'

文件内容排序、文件行取唯一值的命令分别是?
sort
uniq

用awk获取文件中第三行的倒数第二列字段
awk 'NR==3{print $(NF-1)}' file.txt

awk是一个很强大的文本处理工具,请使用awk统计当前主机的并发访问量
netstat -ant | awk '/^tcp/ {++state[$NF]} END {for(key in state) print key,"\t",state[key]}'

三. 老牛逼题目 15k+

有一个文件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
awk '{h[$1]++}END{for(po in h) print po,h[po]}' access.log |awk '{print 1}' |sort -rn|head -5 sort -rn 以相反的顺序依照数值大小排序

这条linux命令的含义:netstat -n |awk '/^tcp/ {++} print a,${a} }'
该命令执行不了

使用awk分析日志(最后一个字段是IP,统计访问量前十的IP,并进行排序)
awk -F: '/WARNING|FATAL/&& !/IGNOR/{print $5}' a.log

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,039评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,223评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,916评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,009评论 1 291
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,030评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,011评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,934评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,754评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,202评论 1 309
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,433评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,590评论 1 346
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,321评论 5 342
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,917评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,568评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,738评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,583评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,482评论 2 352