北京某大厂Linux系统管理和Shell脚本笔试题

1. 写一个sed命令,修改/tmp/input.txt文件的内容,要求:(1) 删除所有空行;(2) 在非空行前面加一个"AAA",在行尾加一个"BBB",即将内容为11111的一行改为:AAA11111BBB

#创建一个测试文件
[root@node1 ~]# echo -e "Hello\nWorld\nThis is a test\n\nAnother line\n\nLast line" > /tmp/input.txt 
[root@node1 ~]# cat /tmp/input.txt 
Hello
World
This is a test

Another line

Last line
[root@node1 ~]# sed -i '/^$/d;s/^/AAA/;s/$/BBB/' /tmp/input.txt 
AAAHelloBBB
AAAWorldBBB
AAAThis is a testBBB
AAAAnother lineBBB
AAALast lineBBB

2. 每周一下午三点将/tmp/logs目录下面的后缀为*.log的所有文件rsync同步到备份服务器192.168.1.100中同样的目录下面,crontab配置项该如何写:

#创建测试文件
[root@node1 ~]# mkdir /tmp/logs

[root@node1 ~]# touch /tmp/logs/{1..5}.log

#node2  IPV4:192.168.110.143
[root@node2 ~]# mkdir -p /tmp/logs

#配置免密访问192.168.110.143服务器
[root@node1 ~]# ssh-keygen -f ~/.ssh/id_rsa -N '' -q

[root@node1 ~]# ssh-copy-id root@192.168.110.143
/usr/bin/ssh-copy-id: INFO: Source of key(s) to be installed: "/root/.ssh/id_rsa.pub"
/usr/bin/ssh-copy-id: INFO: attempting to log in with the new key(s), to filter out any that are already installed
/usr/bin/ssh-copy-id: INFO: 1 key(s) remain to be installed -- if you are prompted now it is to install the new keys

Authorized users only. All activities may be monitored and reported.
root@192.168.110.143's password: 

Number of key(s) added: 1

Now try logging into the machine, with:   "ssh 'root@192.168.110.143'"
and check to make sure that only the key(s) you wanted were added.

#测试

``
[root@node1 ~]# rsync -avz /tmp/logs/ *.log 192.168.110.143:/tmp/logs

Authorized users only. All activities may be monitored and reported.
sending incremental file list
1.log
2.log
3.log
4.log
5.log

sent 303 bytes  received 111 bytes  276.00 bytes/sec
total size is 0  speedup is 0.00

#node2:192.168.110.143
[root@node2 ~]# ll /tmp/logs/
total 0
-rw-r--r--. 1 root root 0 Jan 27  2024 1.log
-rw-r--r--. 1 root root 0 Jan 27  2024 2.log
-rw-r--r--. 1 root root 0 Jan 27  2024 3.log
-rw-r--r--. 1 root root 0 Jan 27  2024 4.log
-rw-r--r--. 1 root root 0 Jan 27  2024 5.log

#配置计划任务内容为0 15 * * 1 rsync -avz /tmp/logs/ *.log 192.168.110.143:/tmp/logs
[root@node1 ~]# crontab -e 
no crontab for root - using an empty one
crontab: installing new crontab

[root@node1 ~]# crontab -l
0 15 * * 1 rsync -avz /tmp/logs/ *.log 192.168.110.143:/tmp/logs

3. 找到/tmp/目录下面的所有名称以"_s1.jpg"结尾的普通文件,如果其修改日期在一天内,则将其打包到/tmp/back.tar.gz文件中

#创建测试文件
[root@node1 ~]# touch /tmp/test{1..3}_s1.jpg
[root@node1 ~]# vim find.sh
#!/bin/bash

#检查/tmp/back.tar.gz文件是否存在,如果存在则删除
[ -f /tmp/back.tar.gz ] && rm -f /tmp/back.tar.gz

#查找以_s1.jpg结尾的文件并压缩归档到/tmp/back.tar.gz,这里r为来将文件添加到已经存在的归档文件中,如果用c的话就归档一个文件就无法再添加
find /tmp/ -type f -name '*_s1.jpg' -mtime -1 -exec tar rf /tmp/back.tar.gz {} \; 2>/dev/null

#查看压缩文件的内容
tar tvf /tmp/back.tar.gz
[root@node1 ~]# bash find.sh 
-rw-r--r-- root/root         0 2024-01-27 19:50 tmp/test3_s1.jpg
-rw-r--r-- root/root         0 2024-01-27 19:50 tmp/test2_s1.jpg
-rw-r--r-- root/root         0 2024-01-27 19:50 tmp/test1_s1.jpg

4. 写出SHELL函数RevertInput,函数必须获取三个参数,然后将三个参数倒序echo打印出来,函数必须检查参数个数的合法性,如果参数非法,打印”Illegal parameters”,对于下面的输入:

RevertInput “this is para1” para2 para3 应该输出:
para3
para2
this is para1 (注:需要注意第一个参数中的空格)

[root@node1 ~]# vim RevertInput.sh
#!/bin/bash
RevertInput() {
        #检测参数设否合法$#为参数长度
        if [ $# -ne 3 ]
        then
                echo 'Illegal parameters'
        else
                echo "$3"
                echo "$2"
                echo "$1"
        fi
}
RevertInput "this is para1" para2 para3
:wq

[root@node1 ~]# sh RevertInput.sh 
para3
para2
this is para1

5.如果一个系统使用LVM进行分区管理,请写出调整一个逻辑卷分区大小的命令:

[root@node1 ~]# vgcreate VG1 /dev/sdb   #创建逻辑卷组
  Volume group "VG1" successfully extended

[root@node1 ~]# lvcreate -n LV1 -L 5g VG1  #创建逻辑卷大小为5G
  Logical volume "LV1" created.

[root@node1 ~]# lsblk 
NAME                     MAJ:MIN RM  SIZE RO TYPE MOUNTPOINTS
sda                        8:0    0   20G  0 disk 
├─sda1                     8:1    0    1G  0 part /boot
└─sda2                     8:2    0   19G  0 part 
  ├─openeuler_node1-root 253:0    0   17G  0 lvm  /
  └─openeuler_node1-swap 253:1    0    2G  0 lvm  [SWAP]
sdb                        8:16   0   20G  0 disk 
└─VG1-LV1                253:2    0    5G  0 lvm  
sr0                       11:0    1 17.1G  0 rom  
[root@node1 ~]# lvextend -L +1G /dev/VG1/LV1    #扩容,这里不写"+"意思为扩大到多少,但不能比本身小
  Size of logical volume VG1/LV1 changed from 5.00 GiB (1280 extents) to 6.00 GiB (1536 extents).
  Logical volume VG1/LV1 successfully resized.

[root@node1 ~]# lsblk
NAME                     MAJ:MIN RM  SIZE RO TYPE MOUNTPOINTS
sda                        8:0    0   20G  0 disk 
├─sda1                     8:1    0    1G  0 part /boot
└─sda2                     8:2    0   19G  0 part 
  ├─openeuler_node1-root 253:0    0   17G  0 lvm  /
  └─openeuler_node1-swap 253:1    0    2G  0 lvm  [SWAP]
sdb                        8:16   0   20G  0 disk 
└─VG1-LV1                253:2    0    6G  0 lvm  
sr0                       11:0    1 17.1G  0 rom 
[root@node1 ~]# lvreduce -L -2G /dev/VG1/LV1   #缩容,这里不写"-"意思为缩小到多少,但不能比本身大
  WARNING: Reducing active logical volume to 4.00 GiB.
  THIS MAY DESTROY YOUR DATA (filesystem etc.)
Do you really want to reduce VG1/LV1? [y/n]: y
  Size of logical volume VG1/LV1 changed from 6.00 GiB (1536 extents) to 4.00 GiB (1024 extents).
  Logical volume VG1/LV1 successfully resized.

[root@node1 ~]# lsblk
NAME                     MAJ:MIN RM  SIZE RO TYPE MOUNTPOINTS
sda                        8:0    0   20G  0 disk 
├─sda1                     8:1    0    1G  0 part /boot
└─sda2                     8:2    0   19G  0 part 
  ├─openeuler_node1-root 253:0    0   17G  0 lvm  /
  └─openeuler_node1-swap 253:1    0    2G  0 lvm  [SWAP]
sdb                        8:16   0   20G  0 disk 
└─VG1-LV1                253:2    0    4G  0 lvm  
sr0                       11:0    1 17.1G  0 rom  

6.如何找出当前系统中磁盘I/O读写占用最高的程序:

#通过iotop命令检测
[root@node1 ~]# yum install iotop -y #默认没有这个命令
[root@node1 ~]# iotop -o  #动态检测系统示正在进行I/O操作的进程或线程默认从大到小排序


iotop命令详细参数
iotop是一个实时系统监视工具,它可以显示系统中哪些进程在I/O操作上消耗最多的CPU时间。以下是一些常见的选项:
	• -h, --help: 显示帮助信息并退出。
	• -o, --only: 只显示正在进行I/O操作的进程或线程。
	• -b, --batch: 非交互模式。
	• -n NUM, --iter=NUM: 结束前的迭代次数(无限)。
	• -d SEC, --delay=SEC: 迭代之间的延迟(1秒)。
	• -p PID, --pid=PID: 要监视的进程或线程的ID(所有)。
	• -u USER, --user=USER: 要监视的用户(所有)。
	• -P, --processes: 只显示进程,不显示所有线程。
	• -a, --accumulated: 显示累计I/O而不是带宽。
	• -k, --kilobytes: 使用千字节而不是人类友好的单位。
	• -t, --time: 在每行添加时间戳(隐含--batch)。
	• -q, --quiet: 抑制一些头部行(隐含--batch)。
  • 13
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值