老男孩教育每日一题-第60天-一道实用Linux运维问题的9种Shell解答方法!

简介:

2017-06-04

1.问题为:

已知:/etc/hosts的内容为

192.168.1.11  oldboy11.etiantian.org
192.168.1.21  oldboy21.etiantian.org
192.168.1.31  oldboy31.etiantian.org#192.168.1.111  oldboy111.etiantian.org

请用shell脚本实现,怎么才能在输入IP后找到/etc/hosts里对应的唯一的hostname?

2.解答:

法1)脚本过滤法

[root@old_boy scripts]# cat judgehost.sh    
#!/bin/bash   
echo "please input ip address:" 
read ip  
[ -n "`grep "$ip " /etc/hosts`" ] && \  #注意前面的过滤条件结尾带有空格。   
echo "The hostname is: `grep "$ip " /etc/hosts |awk '{print $2}'`" || \  
echo "The ip is invalid"

提示:
1)这是一个grep过滤加条件判断的实现语法:
2)条件判断语法为[ -n "ddd" ] && echo 1 || echo 0
3)[ -n "`grep "$ip " /etc/hosts`" ] && \#注意前面的过滤条件结尾带有空格。这里啊,是为了排除下面的重复情况

192.168.1.11  oldboy11.etiantian.org
192.168.1.111  oldboy111.etiantian.org

------------------我是每种方法分隔符----------------------

法2)脚本精确匹配法:

#!/bin/bash   #author oldboy   #qq 31333741   #judge input   if [ $# -ne 1 ]  
  then 
    echo "input error!" 
    exit 1  fi  
 flag=0  exec < /etc/hosts  
while read line  
do  
 if [ "$1" = "`echo $line|awk '{print $1}'`" ]  
   then 
       flag=1  
       echo "the $1 's hostname is `echo $line|awk '{print $2}'`"   
       break;  
 fi  done   [ $flag -eq 0 ] && echo " sorrry,not find $1 's hostname!"

提示:此题,请大家学习while的用法及设置flag的思路。
执行结果:

[root@old_boy scripts]# sh oldboy.sh 192.168.1.11
the 192.168.1.11 's hostname is oldboy11.etiantian.org 
[root@old_boy scripts]# sh oldboy.sh 192.168.1.21 
the 192.168.1.21 's hostname is oldboy21.etiantian.org
[root@old_boy scripts]# sh oldboy.sh 192.168.1.311
sorrry,not find 192.168.1.311 's hostname!

----------------我是每种方法分隔符---------------
特别提示:下面的方法中,老男孩老师大量的使用了awk的不同方法来实现同样的功能,来告诉大家,awk是很强大的, 希望同学们能按照老师的教学要求精通之。

法3)awk精确匹配:

准备:

[root@old_boy scripts]# tail -4 /etc/hosts192.168.1.11  oldboy11.etiantian.org
192.168.1.111  oldboy111.etiantian.org
192.168.1.21  oldboy21.etiantian.org
192.168.1.31  oldboy31.etiantian.org

脚本:

[root@old_boy scripts]# cat awkhost1.sh   awk 'BEGIN {a="'$1'"} {if($1==a) print $2; }' /etc/hosts

执行结果:

[root@old_boy scripts]# sh awkhost1.sh 192.168.1.21
oldboy21.etiantian.org
[root@old_boy scripts]# sh awkhost1.sh 192.168.1.31
oldboy31.etiantian.org
[root@old_boy scripts]# sh awkhost1.sh 192.168.1.11
oldboy11.etiantian.org

提示:注意a="'$1'"的用法,$1为命令行传参。awk程序中调用系统变量的方法a="'$1'"。
----------------我是每种方法分隔符---------------

法4)awk精确匹配法

[root@old_boy scripts]# cat awkhost2.sh   
awk '{if($1=="'$1'") print $2}' /etc/hosts

执行结果:

[root@old_boy scripts]# awkhost2.sh 192.168.1.11
oldboy11.etiantian.org
[root@old_boy scripts]# awkhost2.sh 192.168.1.21
oldboy21.etiantian.org
[root@old_boy scripts]# awkhost2.sh 192.168.1.311

----------------我是每种方法分隔符---------------

法5)awk过滤法

[root@old_boy scripts]# cat awkhost4.sh   awk '/'"${1} "'/''{print $2}' /etc/hosts

执行结果:  

[root@old_boy scripts]# awkhost4.sh 192.168.1.21  oldboy21.etiantian.org  
[root@old_boy scripts]# awkhost4.sh 192.168.1.11  oldboy11.etiantian.org  
[root@old_boy scripts]# awkhost4.sh 192.168.1.31  oldboy31.etiantian.org

提示:除了语法外,这道题有个学问,就是过滤时传参结尾要带个空格,这样才能过滤重复IP的情况

如:  

 192.168.1.11  oldboy11.etiantian.org  
 192.168.1.111  oldboy111.etiantian.org 
 ```
----------------我是每种方法分隔符---------------
###法6)awk过滤法
```bash
[root@old_boy scripts]# cat awkhost5.sh   
awk '{if($1~/'$1'/) print $2}'  /etc/hosts ##如果文件第一列包含命令行第一个参数字符则打印第二列


执行结果:  

[root@old_boy scripts]# awkhost5.sh 192.168.1.31  oldboy31.etiantian.org  
[root@old_boy scripts]# awkhost5.sh 192.168.1.11  oldboy11.etiantian.org  
oldboy111.etiantian.org ------>这里有bug了。  
[root@old_boy scripts]# awkhost5.sh 192.168.1.21  oldboy21.etiantian.org

改进下来排除bug:  

[root@old_boy scripts]# cat awkhost5-1.sh  
 awk '{if($1~/'$1' /) print $2}'  /etc/hosts ==>用上面加空格的思路不对。  
[root@old_boy scripts]# cat awkhost5-1.sh   
awk '{if($1~/'$1'$/) print $2}'  /etc/hosts #增加一个正则表达式$

执行结果:  

[root@old_boy scripts]# awkhost5-1.sh 192.168.1.21  
oldboy21.etiantian.org  
[root@old_boy scripts]# awkhost5-1.sh 192.168.1.11  
oldboy11.etiantian.org  
[root@old_boy scripts]# awkhost5-1.sh 192.168.1.31  
oldboy31.etiantian.org


----------------我是每种方法分隔符---------------

法7)awk -v精确匹配法

命令行测试:  

[root@old_boy scripts]# awk -v p=192.168.1.21 '$1 == p{print $2}' /etc/hosts  oldboy21.etiantian.org  
[root@old_boy scripts]# awk -v p=192.168.1.11 '$1 == p{print $2}' /etc/hosts  oldboy11.etiantian.org  
[root@old_boy scripts]# awk -v p=192.168.1.11 '$1 == p {print $2}' /etc/hosts  oldboy11.etiantian.org

实际脚本:

[root@old_boy scripts]# cat awkhost6.sh    
#!/bin/bash   
#p=$1   
#awk -v p="$p" '$1 == p{print $2}' /etc/hosts  
awk -v p="$1" '$1 == p{print $2}' /etc/hosts

执行结果:

[root@old_boy scripts]# sh  awkhost6.sh  192.168.1.11
oldboy11.etiantian.org
[root@old_boy scripts]# sh  awkhost6.sh  192.168.1.21
oldboy21.etiantian.org


提示:
1)传参非awk程序,因此写法p="$1"
2)man awk
      -v var=val
      --assign var=val
             Assign the value val to the variable var, before execution of the program begins.   Such  vari-
             able values are available to the BEGIN block of an AWK program.
----------------我是每种方法分隔符---------------

法8:精确匹配简单的写法

[root@old_boy scripts]# cat awkhost9.sh   
awk  '$1 == "'$1'" {print $2}' /etc/hosts

执行结果:  

[root@old_boy scripts]# sh awkhost9.sh  192.168.1.11  
oldboy11.etiantian.org  
[root@old_boy scripts]# sh awkhost9.sh  192.168.1.21  
oldboy21.etiantian.org  
[root@old_boy scripts]# sh awkhost9.sh  192.168.1.31  
oldboy31.etiantian.org


特别提示:这里老男孩老师大量的使用了awk的不同方法来实现同样的功能,很强大吧,

希望同学们能按照老师的教学要求精通之。 
----------------我是每种方法分隔符---------------

法9:学生的一个不成熟的实现法

#!/bin/bash   b=/$PWD/wang.txt  
echo -n "plase input ip : " read a  
if [ $a == "192.168.1.11" ]  
        then cat $b | grep $a | awk -F ' ' '{print $2}' 
 elif [ $a  == "192.168.1.21" ]   
        then cat $b | grep $a | awk -F ' ' '{print $2}' 
 elif [ $a  == "192.168.1.31" ]  
        then cat $b | grep $a | awk -F ' ' '{print $2}' 
        else echo "plase input the correct IP address " && exit 1  fi

提示:大家看看问题在哪?脚本不通用。  

----------老男孩老师改进后

#!/bin/bash   
#author oldboy   
#qq 31333741   
hosts_file="$PWD/oldboy.txt" 
#judge file  
 [ ! -f $hosts_file ] && echo "no test file!" && exit 1  
 echo -n "plase input ip : " 
 read ip  
#judge ip format   
[ "${#a}" -lt 8 ] && [ "`echo $ip|sed 's/[0-9]//g'`" != "..." ] && \  
echo "Plase input the correct IP address" && exit 1  
#start  
 result1=$(grep "$ip" $hosts_file|awk '{print $1}')  
 if [ "$ip" == "$result1" ]  
 then   
        grep "$ip" $hosts_file|awk '{print $2}' 
        exit 0  else 
        echo  "Not find the hostname of $ip" 
        exit 1  
 fi

提示:此法不可取,画蛇添足了。


本文转自 李导 51CTO博客,原文链接:http://blog.51cto.com/lidao/1932142

相关文章
|
2月前
|
Ubuntu Linux 网络安全
在Linux上安装软件有多种方法
在Linux上安装软件有多种方法
114 64
|
1月前
|
Shell Linux 测试技术
6种方法打造出色的Shell脚本
6种方法打造出色的Shell脚本
59 2
6种方法打造出色的Shell脚本
|
20天前
|
运维 监控 安全
盘点Linux服务器运维管理面板
随着云计算和大数据技术的迅猛发展,Linux服务器在运维管理中扮演着越来越重要的角色。传统的Linux服务器管理方式已经无法满足现代企业的需求,因此,高效、安全、易用的运维管理面板应运而生。
|
2月前
|
运维 监控 网络协议
|
28天前
|
缓存 运维 监控
【运维必备知识】Linux系统平均负载与top、uptime命令详解
系统平均负载是衡量Linux服务器性能的关键指标之一。通过使用 `top`和 `uptime`命令,可以实时监控系统的负载情况,帮助运维人员及时发现并解决潜在问题。理解这些工具的输出和意义是确保系统稳定运行的基础。希望本文对Linux系统平均负载及相关命令的详细解析能帮助您更好地进行系统运维和性能优化。
50 3
|
1月前
|
Linux Shell 数据库
文件查找是Linux用户日常工作的重要技能介绍了几种不常见的文件查找方法
文件查找是Linux用户日常工作的重要技能。本文介绍了几种不常见的文件查找方法,包括使用`find`和`column`组合、`locate`和`mlocate`快速查找、编写Shell脚本、使用现代工具`fd`、结合`grep`搜索文件内容,以及图形界面工具如`Gnome Search Tool`和`Albert`。这些方法能显著提升文件查找的效率和准确性。
48 2
|
2月前
|
存储 运维 搜索推荐
|
2月前
|
运维 Linux
Linux查找占用的端口,并杀死进程的简单方法
通过上述步骤和命令,您能够迅速识别并根据实际情况管理Linux系统中占用特定端口的进程。为了获得更全面的服务器管理技巧和解决方案,提供了丰富的资源和专业服务,是您提升运维技能的理想选择。
59 1
|
2月前
|
运维 安全 Linux
Linux文件清空的五种方法总结分享
每种方法各有优势,选择最合适的一种或几种,可以极大提高您的工作效率。更多有关Linux系统管理的技巧与资源,欢迎访问,持续提升您的运维技能。
79 1
|
2月前
|
运维 Java Linux
【运维基础知识】Linux服务器下手写启停Java程序脚本start.sh stop.sh及详细说明
### 启动Java程序脚本 `start.sh` 此脚本用于启动一个Java程序,设置JVM字符集为GBK,最大堆内存为3000M,并将程序的日志输出到`output.log`文件中,同时在后台运行。 ### 停止Java程序脚本 `stop.sh` 此脚本用于停止指定名称的服务(如`QuoteServer`),通过查找并终止该服务的Java进程,输出操作结果以确认是否成功。
59 1