Linux运维面试题(三)之shell编程类
- 文本截取
- 有一个b.txt文本,要求将所有域名截取出来,并统计重复域名出现的次数
- 统计当前服务器正在连接的IP地址,并按连接次数排序(cut不能以空格做分隔符)
- 随机字符串
- 网站检测
文本截取
有一个b.txt文本,要求将所有域名截取出来,并统计重复域名出现的次数
- 默认从小到大
统计当前服务器正在连接的IP地址,并按连接次数排序(cut不能以空格做分隔符)
- netstat -an查询所有连接,监听,连接已经建立
- awk截取,除非“空格”作为分隔符。
- “:”作为分隔符,截取第一列。
随机字符串
随机字符串生成:- /dev/random 依赖系统中断生成随机字符串,可以保证数据的随机性但生成数据慢,会占用系统进程资源。
/dev/urandom 快,但随机性不足,常用。(含二进制乱码) - 例如:echo “aa…+1 b2c/*$dd 3 ls 4” | tr -dc ‘0-9\n’
1 2 3 4
#!/bin/bash
if [ ! -d /atguigu ] #判断测试目录是否建立
then
mkdir /atguigu
fi
cd /atguigu #进入测试目录
for (( i=1 ; i<=10; i++ )) #循环10次,每次循环建立6位随机数文件
do
filename=$(tr -dc 'A-Za-z0-9' < /dev/urandom | head -c 6)
touch "$filename"_gg.txt
done
(2)生成随机数字:
网站检测
- ping 消耗资源最少,但不准确,只能检查双方网络是通的。
- 但有可能80端口死机或者apache死机。
- (1)
- http://www.baidu.com
- netstat只能查询本机,而不能查询对方。而nmap 主动探测扫描端口,连接端口,返回数据。
- 数组声明: array_n=(1 2 3) 调用echo ${array_n[*]}
- curl: 字符网页访问工具。开源的用于数据传输的命令行工具。可以用于http访问,上传下载、用户认证、代理访问等。
格式: curl [选项] url或IP地址 - 选项:
-o 将命令输出保存在指定文件,不返回网页内容
-s Silent模式。不输出任务内容
-w 按指定格式输出内容,如:-w %{http_code}:输出http状态码
–connect-timeout:连接超时时间
…
code= ( c u r l − o / d e v / n u l l − s − − c o n n e c t − t i m e o u t 5 − w ′ (curl -o /dev/null -s --connect-timeout 5 -w '%{http_code}' (curl−o/dev/null−s−−connect−timeout5−w′i | grep -E “200|300”)
if [“ c o d e " ! = " " ] t h e n e c h o " code" != ""] then echo " code"!=""]thenecho"i is ok”>> /root/ok.log
else
sleep 10
code= ( c u r l − o / d e v / n u l l − s − − c o n n e c t − t i m e o u t 5 − w ′ (curl -o /dev/null -s --connect-timeout 5 -w '%{http_code}' (curl−o/dev/null−s−−connect−timeout5−w′i | grep -E “200|300”)
…
- 尝试连接时间不超过五秒,grep -E扩展正则/egrep
- 只要code变量不为空,网页可以访问。
- 防止有网络延迟。