Shell脚本练习
企业面试题京东
问题1:使用Linux命令查询file1中空行所在的行号。
# cat file1
问题1:使用Linux命令查询file1中空行所在的行号。
# awk '/^$/{print NR}' file1
2问题2:有文件chengji.txt内容如下''
张三 40
李四 50
王五 60
使用Linux命令计算第二列的和并输出。
# cat chengji.txt
张三 40
李四 50
王五 60
# awk '{sum+=$2}END{print sum}' chengji.txt
150搜狐 讯网
问题1:Shell脚本里如何检查一个文件是否存在?如果不存在该如何处理?
# cat 3.sh
#!/bin/bash
read -p "please input filename:" filename
if [ -f $filename ]
then
echo "file exist"
else
echo "file is not exist"
touch $filename
fi新浪
问题1:用shell写一个脚本,对文本中无序的一列数字排序
# vim test.txt
# vim sort.sh +
# chmod 755sort.sh
# ./sort.sh
12
21
45
56
89
169
256
646
659
6595
7879
65965
# cat sort.sh
#!/bin/bash
sort -n test.txt金和网络
问题1:请用shell脚本写出查找当前文件夹(/home)下所有的文本文件内容中包含有字符”shen”的文件名称
小米
问题1:
一个文本文件info.txt的内容如下:
aa,201
zz,502
bb,1
ee,42
每行都是按照逗号分隔,其中第二列都是数字,请对该文件按照第二列数字从大到小排列
# sort-t "," -k 2 -nr info.txt美团
问题1:编写脚本实现以下功能;
每天早上5点开始做备份
要备份的是/var/mylog里所有文件和目录可以压缩进行备份
备份可以保存到别一台器上192.168.1.2 FTP帐号 aaa 密码 bbb
要求每天的备份文件要带有当天的日期标记
# vim bak.sh
#!/bin/bash
bakfir=log
date='date +%F'
cd /var
tar zcf ${bakdir}_${date}.tar.gz ${bakdir}
sleep 1
ftp -n <<- EOF
open 192.168.142.129 #远程ftp服务器IP
user aaa bbb
put mylog_*.tar.gz
bye
EOF
# vim /etc/crontab
# For details see man 4 crontabs
# Example of job definition:
# .---------------- minute (0 - 59)
# |.------------- hour (0 - 23)
# ||.---------- day of month (1 - 31)
# |||.------- month (1 - 12) OR jan,feb,mar,apr ...
# ||||.---- day of week (0 - 6) (Sunday=0 or 7) OR sun,mon,tue,wed,thu,fri,sat
# |||||
# ***** user-namecommand to be executed
00 05 * * * /bin/bash /root/bak.sh百度
· ## 处理以下文件内容,将域名取出并进行计数排序,如处理:
http://www.baidu.com/more/
http://www.baidu.com/guding/more.html
http://www.baidu.com/events/20060105/photomore.html
http://hi.baidu.com/browse/
http://www.sina.com.cn/head/www20021123am.shtml
http://www.sina.com.cn/head/www20041223am.shtml
#!/bin/bash
id -g class &>/dev/null || groupadd class
user=std
for i in {01..30}
do
id -u ${user}$i &>/dev/null || useradd -G class ${user}$i
done奇虎360
1、写一个脚本查找最后创建时间是3天前,后缀是*.log的文件并删除。**
cut -d'/' -f3 test.txt | sort | uniq -c | sort -nr2、写一个脚本将某目录下大于100k的文件移动至/tmp下。
find / -name “*.log” -ctime +3 -exec rm -f {} \;3、写一个脚本进行nginx日志统计,得到访问ip最多的前10个(nginx日志路
径:/home/logs/nginx/default/access.log
for i in `find /test -type f -size +100k`;do cd /test && mv $i /tmp;done4、写一个脚本把指定文件里的/usr/local替换为别的目录。
awk '{a[$1]++}END{for (j in a) print a,j}' /home/logs/nginx/default/access.log|sort -nr|head滴滴出行
1、指令:ls | grep “*.conf” 命令解释正确的是:
正确答案: B
A 显示包含a 或者d 为开头,后接任何字符,再后面是.conf字符的文件(或目录)
B 显示包含a 或者d 出现0 次或无数次,后面是.conf字符的文件(或目录)
C 显示包含字母a 或者d出现0次或1次,后面是.conf字符的文件(或目录)
D 显示从字母a 到d ,后接任何字符,再后面是.conf字符的文件(或目录)
2、找出IO重定向执行结果与其他三个不同的:
正确答案: B
A ./run.sh >run.log 2>&1;
B ./run.sh 2>&1 >run.log;
C ./run.sh &>run.log;
D ./run.sh 2>run.log >&2
3、一个文件,大概1亿行,每行一个ip,将出现次数最多的top10输出到一个新的文件中
sed 's:/user/local:/tmp:g' filename练习
案例1:监控硬件信息
awk -F" " '{IP[$1]++}END{for (i in IP) print IP,i}'/var/log/filename.log|sort -k2-rn |head -10>text.txt
awk -F" " '{print $1}' /var/log/filename.log |sort -n|uniq -c |sort -rn-k1 |head -10> text.txt 案例2:数据计算
# cat info.sh
#!/bin/bash
#显示服务器硬件信息.
echo -e "\033[34m---------服务器硬件信息---------\033[0m"
echo -e "\033[32m网卡信息如下:\033[0m"
ifconfig ens33 | grep "inet "
# ifconfig 需要装包net-tools 注意网卡名称
echo -e "\033[32m剩余内存容量信息如下:\033[0m"
grep MemAvailable /proc/meminfo
echo -e "\033[32m磁盘容量信息如下:\033[0m"
df -h /
echo -e "\033[32mCPU信息如下:\033[0m"
grep "model name" /proc/cpuinfo
# ./info.sh
---------服务器硬件信息---------
网卡信息如下:
inet 192.168.11.112netmask 255.255.255.0broadcast 192.168.11.255
剩余内存容量信息如下:
MemAvailable: 596376 kB
磁盘容量信息如下:
Filesystem SizeUsed Avail Use% Mounted on
/dev/mapper/centos-root 17G1.5G 16G 9% /
CPU信息如下:
model name : AMD Ryzen 7 4800H with Radeon Graphics
model name : AMD Ryzen 7 4800H with Radeon Graphics
model name : AMD Ryzen 7 4800H with Radeon Graphics
model name : AMD Ryzen 7 4800H with Radeon Graphics案例3:自动配置yum源
# cat calc.sh
#!/bin/bash
#计算1+2+3,...,+n的和,可以使用n*(n+1)/2公式快速计算结果
read -p "请输入一个正整数:" num
sum=$
echo -e "\033[32m$num以内整数的总和是:$sum\033[0m"
#使用三角形的底边和高计算面积:A=1/2bh
read -p "请输入三角形底边长度:" bottom
read -p "请输入三角形高度:" hight
A=$(echo "scale=1;1/2*$bottom*$hight" | bc)
echo -e "\033[32m三角形面积是:$A\033[0m"
#梯形面积:(上底边长度+下底边长度)*高/2
read -p "请输入梯形上底边长度:" a
read -p "请输入梯形下底边长度:" b
read -p "请输入梯形高度:" h
A=$(echo "scale=2;($a+$b)*$h/2" | bc)
echo -e "\033[32m梯形面积是:$A\033[0m"
#使用A=πr2公式计算圆的面积,取2位小数点精度,π=3.14
read -p "请输入圆的半径:" r
A=$(echo "scale=2;3.14*$r^2" | bc)
echo -e "\033[32m圆的面积是:$A\033[0m"
# ./calc.sh
请输入一个正整数:6
6以内整数的总和是:21
请输入三角形底边长度:2
请输入三角形高度:3
三角形面积是:3.0
请输入梯形上底边长度:3
请输入梯形下底边长度:4
请输入梯形高度:2
梯形面积是:7.00
请输入圆的半径:5
圆的面积是:78.50案例4:监控系统信息
# cat yum.sh
#!/bin/bash
#定义YUM源路径
URL=ftp://192.168.4.1/centos
#创建YUM源配置文件
echo "
name=centos
baseurl=$URL
gpgcheck=0" > /etc/yum.repos.d/yum.repo
# cat /etc/yum.repos.d/yum.repo
name=centos
baseurl=ftp://192.168.4.1/centos
gpgcheck=0案例5:判断用户名与密码是否为空
# cat info2.sh
#!/bin/bash
#本脚本获取系统各项性能参数指标,并与预设阈值进行比较
#time:时间,loalip:eth0网卡IP,free_mem:剩余内存大小,free_disk:剩余磁盘大小
#cpu_load:15min平均负载,login_user:登录系统的用户,procs:当前进程数量
local_time=$(date +"%Y%m%d %H:%M:%S")
#注意网卡名称,ifconfig需要安装net-tools
local_ip=$(ifconfig ens33 | grep netmask | tr -s " " | cut -d" " -f3)
free_mem=$(cat /proc/meminfo |grep Avai | tr -s " " | cut -d" " -f2)
free_disk=$(df | grep "/$" | tr -s " " | cut -d' ' -f4)
cpu_load=$(cat /proc/loadavg | cut -d' ' -f3)
login_user=$(who | wc -l)
procs=$(ps aux | wc -l)
#当剩余内存不足1GB时发送邮件给root进行报警
[ $free_mem -lt 1048576 ] && \
echo "$local_time Free memory not enough.
Free_mem:$free_mem on $local_ip" | \
#安装mailx工具
mail -s Warning root@localhost
#当剩余磁盘不足10GB时发送邮件给root进行报警
[ $free_disk -lt 10485760 ] && \
echo "$local_time Free disk not enough.
root_free_disk:$free_disk on $local_ip" | \
mail -s Warning root@localhost
#当CPU的15min平均负载超过4时发送邮件给root进行报警
result=$(echo "$cpu_load > 4" | bc)
[ $result -eq 1 ] && \
echo "$local_time CPU load to high
CPU 15 averageload:$cpu_load on $local_ip" | \
mail -s Warning root@localhost
#当系统实时在线人数超过3人时发送邮件给root进行报警
[ $login_user -gt 3 ] && \
echo "$local_time Too many user.
$login_user users login to $local_ip" | \
mail -s Warning root@localhost
#当实时进程数量大于500时发送邮件给root进行报警
[ $procs -gt 500 ] && \
echo "$local_time Too many procs.
$procs proc are runing on $local_ip" | \
mail -s Warning root@localhost案例6:测试主机是否ping通
版本1:
# cat user_v1.sh
#!/bin/bash
read -p "请输入用户名:" user
read -s -p "请输入密码:" pass
if [ ! -z "$user" ];then
useradd"$user"
fi
if [ ! -z "$pass" ];then
echo "$pass" | passwd --stdin "$user"
fi
echo
版本2:
# cat user_v2.sh
#!/bin/bash
read -p "请输入用户名:" user
read -s -p "请输入密码:" pass
if [ ! -z "$user" ] && [ ! -z "$pass" ];then
useradd "$user"
echo "$pass" | passwd --stdin "$user"
fi案例7:猜数字
# cat if_ping.sh
#!/bin/bash
#ping通脚本返回up,否则返回down
if [ -z "$1" ];then
echo -n "用法: 脚本 "
echo -e "\033[32m域名或IP\033[0m"
exit
fi
#-c(设置ping的次数),-i(设置ping的间隔描述),-W(设置超时时间)
ping -c2 -i0.1 -W1 "$1" &>/dev/null
if [ $? -eq 0 ];then
echo "$1 is up"
else
echo "$1 is down"
fi案例8:打印九九乘法表
# cat guess_num.sh
#!/bin/bash
#脚本自动生成10以内的随机数,根据用户的输入,输出判断结果.
clear
num=$
read -p "请输入1-10之间的整数:" guess
if [ $guess -eq $num ];then
echo "恭喜,猜对了,就是:$num"
elif [ $guess -lt $num ];then
echo "Oops,猜小了."
else
echo "Oops,猜大了."
fi案例11:监控网络流量
# cat 99.sh
#!/bin/bash
for((i=1;i<=9;i++))
do
for((j=1;j<=i;j++))
do
echo -n "$i*$j=$ "
done
echo
done案例12:统计闰年
# cat guess_random.sh
#!/bin/bash
num=$
while :
do
read -p "请输入1-10之间的整数:" guess
if [ $guess -eq $num ];then
echo "恭喜,猜对了,就是:$num"
exit
elif [ $guess -lt $num ];then
echo "Oops,猜小了."
else
echo "Oops,猜大了."
fi
done案例13:计算等差数列之和
# cat install_vsftp.sh
#!/bin/bash
#安装ftpd软件,修改配置文件,设置匿名用户可以上传文件.
if rpm -q vsftpd &> /dev/null ;then
echo "vsftpd已安装."
else
yum -y install vsftpd &> /dev/null
fi
systemctl restart vsftpd案例14:判断用户输入
# cat net.sh
#!/bin/bash
while :
do
clear
echo'本地网卡ens33流量信息如下: '
ifconfig ens33 | grep "RX pack" | tr -s " " | cut -d" " -f6
ifconfig ens33 | grep "TX pack" | tr -s " " | cut -d" " -f6
sleep 1
done出处:http://www.cnblogs.com/sre-chan/-------------------------------------------
个性签名:今天做了别人不想做的事,明天你就做得到别人做不到的事,尝试你都不敢,你拿什么赢!
如果觉得这篇文章对你有小小的帮助的话,记得在右下角点个“推荐”哦,博主在此感谢!
来源:https://www.cnblogs.com/sre-chan/p/17177316.html
免责声明:由于采集信息均来自互联网,如果侵犯了您的权益,请联系我们【E-Mail:cb@itdo.tech】 我们会及时删除侵权内容,谢谢合作!
页:
[1]