Linux运维学习中shell有哪些重要知识点?Linux面试题分享
$HOME $PWD $PS1 $PS2
fold join tr read
A:&
B:@
C:#
D:$
A:管道
B:输入输出重定向
C:执行后台进程
D:处理程序命令
A: B:^q C:exit D:quit
bash
ruby
PHP
perl
Read pread write pwrite fseek lseek
-2-time _2$3 trust_no_1 2004file
为变量赋值:$FRUTT=apple 显示变量的值:fruit=apple
显示变量的值:echo FRUTT判断变量是否有值:[−f−−FRUTT 判断变量是否有值:[ -f --FRUTT判断变量是否有值:[−f−−FRUTT || ]
程序后携带了两个位数参数 宏替换
程序后面携带的第二个位置参数 携带位置参数的个数
company = gyyx
$company=gyyx
company=‘gyyx’
company=gyyx
sed -e ‘/man/d’ filename
sed -e ‘1,3d’ filename
sed -e ‘1,/man/d’ filename
sed -e ‘/man/3d’ filename
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-GGXD3AuC-1608104204296)(https://math.jianshu.com/math?formula=0%E8%A1%A8%E7%A4%BA%E7%A8%8B%E5%BA%8F%E7%9A%84%E6%89%A7%E8%A1%8C%E5%90%8D%E5%AD%97)]n 表示程序的第n个参数值
$* 表示程序的所有参数个数 $$表示程序的PID
for filename in $(ls) do cat $filename done
for((i&#61;0;i<10;i&#43;&#43;)) do echo $i done
x&#61;1 sum&#61;0 while [ x−le10]doletsum&#61;sum&#43;x -le 10 ] do let sum&#61;sum&#43;x−le10]doletsum&#61;sum&#43;x let x&#61;x&#43;1 done echo\ $sum
for $i in 1 2 3 4 5 do echo $i done
Fold join tr read
break continue exit kill
# // /**/ " "
-x -u -f -p
Var1&#61;abcdedf
Var2&#61;abcded
Echo “var1”∣grep−q“var1” |grep -q “var1”∣grep−q“var2” && echo “yes” ||echo “no”
无结果 语法错误 yes no
-ne -ge -eq -le
$0 $n $# $&#xff1f; $* $$ ${#aa}
IP_Address MAC_Address Interface Static
10.66.10.250 80:71:7A:33:CA:A7 br on
10.66.10.249 5C:50:15:7F:3B:F5 br on
将以上文件名称test.txt文件中IP_Address,MAC_Address, Interface三项下的内容取出来&#xff0c;值以“&#xff1a;”分割&#xff0c;并呈格式显示出来。注&#xff1a;
10.66.10.250:80:71:7A:33:CA:A7:br
10.66.10.249:5C:50:15:7F:3B:F5:br
直接复制 使用read命令 使用命令行传参 使用命令输出
要求&#xff1a;同一个IP暴力破解超过10次&#xff0c;自动屏蔽IP地址&#xff0c;指定办公室IP地址&#xff08;192.168.100.100&#xff09;为可信任IP地址&#xff0c;不受屏蔽规则限制&#xff0c;以下为日志格式&#xff1a;
日志样式&#xff1a;
May 4 03:43:07 tz-monitor sshd{14003}: Failed password for root from 124.232.135.84 port 25251 ssh2
Myy 4 03:43:07 tz-monitor sshd{14082}: invalid user postgres from 124.232.135.84
ofpf 100
route-id 139.11.0.1
area 0.0.0.0
network 139.11.0.1 0.0.0.0
network 140.11.0.0 0.0.0.3
network 140.11.0.8 0.0.0.3
network 140.11.0.16 0.0.0.3
network 140.11.0.24 0.0.0.3
network 140.11.0.32 0.0.0.3
interface LoopBack0
ip address 139.11.0.1 255.255.255.255
Interface Physical Protocol IP Adderss
Eth1/0/1 up up 199.11.250.1
Eth1/0/2 up up 200.11.250.5
Loop0 up up(s) 199.11.250.1
Vlan1 *down down unassigned
Vlan500 down down 139.100.1.157
Vlan900 up up 140.11.250.41
def f(x,1&#61;[]);
for i in range(x);
1.append(i*i)
print 1
f(2)
f(3,[3,2,1])
f(3)
&#xff08;1&#xff09; 第一个参数为URL&#xff0c;即可下载的文件&#xff1b;第二个参数为目录&#xff0c;即下载后保存位置&#xff1b;
&#xff08;2&#xff09; 如果用户给的目录不存在&#xff0c;则提示用户是否创建&#xff1b;如果创建就继续执行&#xff0c;否则函数返回一个51的错误值给调用脚本
&#xff08;3&#xff09; 如果给的目录存在&#xff0c;则下载文件&#xff1b;下载命令执行结束后测试文件下载成功&#xff0c;如果成功&#xff0c;则返回0给调用脚本&#xff0c;否则&#xff0c;返回52给调用脚本&#xff1b;
第一行为序列长度n(1≤ n≤ 50)
第二行为n个数scqucencel,以空格分隔
输出描述
输出消除重复元素之后的序列&#xff0c;以空格分隔&#xff0c;行末无空格
输入例子
100 100 100 99 99 99 100 100 100
输出例子
99 100
class Queue(objec ):
defenqueue(self,item):
“’’”“入队”"""
defdequcue(self):
“”"“出队”""
测试
q &#61; Queue()
9 enqucue (1)
输出q [1]
q.enqueue(4)
输出q [1,4]
q.dequeue()
输出14
aa&#xff0c;101
bb&#xff0c;302
cc&#xff0c;222
dd&#xff0c;44
a&#xff0e;显示当前目录的内容
b&#xff0e;以详细格式显示test用户的家目录内容&#xff0c;包含隐藏文件
c&#xff0e;进入根目录
d&#xff0e;显示/etc/passwd文本文件的内容
e&#xff0e;显示/etc/passwd文件的后十行内容
cat /etc/fstab\# /etc/fstabUUID&#61;94e4e384-Oace-437f-bc96-057dd64f42ee / ext4 defaults.barrier&#61;0 1 1tmpfs /dev/shm tmpfs defults 0 0
列出如下菜单给用户
disk) show disks info;
mem) show memory info;
cpu) show cpu info;
*) quit;
提示用户给出自己的选择&#xff0c;而后显示对应其选择的相应系统信息
n&#61;1
while [ $n -lt 1000 ]; docd /root/perl_test/testdirtouch sn.txtn&#61;expr $n &#43; 1
done
如果在/home/pushmail目录下不存在leadtone目录&#xff0c;则创建该目录&#xff0c;并将/var/sync/bin目录下的所有文件拷贝到leadtone目承下&#xff0c;但是不能够拷贝文件长
度大于1M的文件。
a&#xff0e;显示当前目录的内容
b&#xff0e;以详细格式显示test用户的家目录内容&#xff0c;包含隐藏文件
c&#xff0e;进入根目录
d&#xff0e;显示/etc/passwd文本文件的内容
e&#xff0e;显示/etc/passwd文件的后十行内容
#!/bin/bashDICNAME&#61;&#96;ls /root |grep bak&#96; #(1)if [ -z "$DICNAME" ] then #(2)mkdir /root/bak cd /root/bak #(3)fiYY&#61;&#96;date &#43;%y&#96; MM&#61;&#96;date &#43;%m&#96; DD&#61;&#96;date &#43;%d&#96; #(4)BACKETC&#61;$YY$MM$DD_etc.tar.gz #(5)tar zcvf $BACKETC /etc #(6)echo "fileback fiaished!"
config.properties文件格式如下&#xff1a;
zookeeper.server&#61;127.0.0.1:2181
jdbc.driver&#61;com.mysql.jdbc.Driver
jdbc.url&#61;jdbc:mysql://lx-db:3306/gudong
jdbc.username&#61;lanxin
jdbc.password&#61;OnLIDX5
1 2 3
4 5 6
7 8 9
打印出每一列的累加值
&#xff08;1&#xff09;查看服务器的硬盘占用量
&#xff08;2&#xff09;将/usr/test目录下大于100K的文件转移到/tmp目录下
&#xff08;3&#xff09;杀死所有启动的servicefx_asr进程
&#xff08;4&#xff09;假设某nginx server的日志access.log如下&#xff1a;
198.24.230.194 - - [10/Oct/2015:10:23:50 &#43;0800] “POST /asr/recognize HTTP/1.1 200 177 “-” ”-”
请查找在2015/10/10,10点这一个小时内&#xff0c;访问“/CheckAuth”接口的IP一共有几个&#xff0c;每个各访问了多少次
real 0m2.003s
user 0m0.004s
sys 0m0.000s
请说明real、user、sys三者具体代表的意思和区别
某目录下有两个文件a.txt和b.txt&#xff0c;文件格式为(ip username)&#xff0c;例如&#xff1a;
a.txt b.txt
127.0.0.1zhangsan 127.0.0…4lixiaoliu
127.0.0.1wangxiaoer 127.0.0.01lisi
127.0.0.2lisi
127.0.0.3wangwu
每个文件至少有100万行&#xff0c;请使用Linux命令完成下列工作
1&#xff09;两个文件各自的IP数&#xff0c;以及总IP数
2&#xff09;出现再b.txt而没有出现再a.txt的IP
3&#xff09;每个username出现的次数&#xff0c;以及每个username对应的IP数