工程师技术(五):Shell脚本的编写及测试、重定向输出的应用、使用特殊变量、编写一个判断脚本、编写一个批量添加用户脚本

一、Shell脚本的编写及测

目标:

本例要求两个简单的Shell脚本程序,任务目标如下:

1> 编写一个面世问候 /root/helloworld.sh 脚本,执行后显示出一段话“Hello World!!”
   2> 编写一个能输出系统信息的 /root/sysinfo 脚本,执行后依次输出当前红帽系统的版本信息、当前使用的内核版本、当前系统的主机名

方案:

规范Shell脚本的一般组成:

1> #! 环境声明(Sha-Bang)
    2> # 注释文本
    3> 可执行代码

步骤:

步骤一:编写helloworld.sh问候脚本

1)编写脚本代码

[[email protected] ~]# vim  /root/helloworld.sh
    #!/bin/bash
    echo  "Hello World !!"

2)添加x执行权限

[[email protected] ~]# chmod  +x  /root/helloworld.sh

3)运行脚本测试

[[email protected] ~]# /root/helloworld.sh
    Hello World !!

步骤二:编写sysinfo系统信息报告脚本

1)编写脚本代码

[[email protected] ~]# vim  /root/sysinfo
    #!/bin/bash
    cat  /etc/redhat-release
    uname  -r
    hostname

2)添加x执行权限

[[email protected] ~]# chmod  +x  /root/sysinfo

3)运行脚本测试

[[email protected] ~]# /root/sysinfo
    Red Hat Enterprise Linux Server release 7.0 (Maipo)
    3.10.0-123.el7.x86_64
    server0.example.com

二、重定向输出的应用

目标:

本例要求编写一个脚本 /root/out.sh,功能特性如下:

1> 执行此脚本显示 I love study !!
    2> 执行 /root/out.sh 2> err.log 应该没有显示,但是查看 err.log 文件的内容为 I love study !!

方案:

屏幕输出文本的类别:

1> 标准输出(1):命令行执行正常的显示结果
    2> 标准错误(2):命令行执行出错或异常时的显示结果

将屏幕显示信息保存到文件:

1> cmd > file 、 cmd >> file
    2> cmd 2> file 、 cmd 2>> file
    3> cmd &> file 、cmd 2> file 1>&2

使用1>&2或>&2操作,可以将命令行的标准输出编程标准错误。

步骤:

步骤:编写out.sh输出测试脚本

1)编写脚本代码

[[email protected] ~]# vim  /root/out.sh
    #!/bin/bash
    echo  "I  love  study !!"  >&2

2)添加x执行权限

[[email protected] ~]# chmod  +x  /root/out.sh

3)运行脚本测试

[[email protected] ~]# /root/out.sh
    I  love  study !!
    [[email protected] ~]# /root/out.sh  2>  err.log
    [[email protected] ~]# cat  err.log
    I  love  study !!

三、使用特殊变量

目标:

本例要求编写一个脚本 /root/myhead,功能特性如下:

1)此脚本可接收2个位置参数,能够按照下列格式执行:

/root/myhead  文件路径  行数

2)此脚本执行后,能显示“你一共提供了 $# 个参数”,然后在下一行显示“文件 $1 的前 $2 行: ”,紧跟下一行开始输出对应文件的前几行内容。

方案:

使用位置变量可以取得在执行脚本时提供的命令行参数:

  • 表示为 $n,n为序号
  • $1、$2、.. .. ${10}、${11}、.. ..

使用预定义变量$#可以统计执行脚本时提供的位置变量个数。

步骤:

步骤一:编写 /root/myuseradd 添加用户的脚本

1)编写脚本代码

[[email protected] ~]# vim  /root/myuseradd
    #!/bin/bash
    echo  "一共提供了 $# 个参数"
    echo  "用户名是 $1,密码是 $2 "
    useradd  $1
    echo  "$2"  |  passwd  --stdin  $1

2)添加x执行权限

[[email protected] ~]# chmod  +x  /root/myuseradd.sh

步骤二:测试 /root/myuseradd 脚本

1)测试添加用户 bob,密码设为 1234567

[[email protected] ~]# /root/myuseradd  bob  1234567
    一共提供了 2 个参数
    用户名是 bob,密码是 1234567
    更改用户 bob 的密码 。
    passwd:所有的身份验证令牌已经成功更新。
    [[email protected] ~]# id  bob
    uid=1002(bob) gid=1002(bob) 组=1002(bob)

2)测试添加用户 jerry,密码设为 1234567

[[email protected] ~]# /root/myuseradd  jerry  1234567
    一共提供了 2 个参数
    用户名是 jerry,密码是 1234567
    更改用户 jerry 的密码 。
    passwd:所有的身份验证令牌已经成功更新。
    [[email protected] ~]# id  jerry
    uid=1003(jerry) gid=1003(jerry) 组=1003(jerry)

四、编写一个判断脚本

目标:

本例要求在虚拟机 server0 上创建 /root/foo.sh 脚本,任务目标如下:

1> 当运行/root/foo.sh redhat,输出为fedora
   2> 当运行/root/foo.sh fedora,输出为redhat
   3> 当没有任何参数或者参数不是 redhat 或者 fedora时,其错误输出产生以下信息: /root/foo.sh redhat|fedora

方案:

Shell脚本中执行条件测试的方式:

1> 任何一条命令行
   2> test 测试表达式
   3> [ 测试表达式 ]

常用的test测试选项:

1> 文件状态检测 -f、-d、-e、-r、-w、-x
   2> 整数值比较 -gt、-ge、-eq、-ne、-lt、-le
   3> 字符串比较 ==、!=
   4> 取反操作 !

多分支if选择结构:

if  条件测试操作1
    then
         命令序列1....
    elif  条件测试操作2
    then
         命令序列2....
    else
         命令序列3....
    fi

步骤:

步骤一:编写foo.sh判断脚本

1)编写脚本代码

[[email protected] ~]# vim  /root/foo.sh
    #!/bin/bash
    if [ "$1" = "redhat" ]  
    then
           echo "fedora"
    elif [ "$1" = "fedora" ]
    then
           echo "redhat"
    else
           echo "/root/foo.sh redhat|fedora" >&2
    fi
2)添加x执行权限

[[email protected] ~]# chmod  +x  /root/foo.sh

步骤二:测试foo.sh判断脚本

1)测试提供正确参数的情况

[[email protected] ~]# /root/foo.sh  redhat
    fedora
    [[email protected] ~]# /root/foo.sh  fedora
    Redhat

2)测试提供非预期参数的情况

[[email protected] ~]# /root/foo.sh  ubuntu
    /root/foo.sh redhat|fedora

3)测试不提供参数的情况

[[email protected] ~]# /root/foo.sh
    /root/foo.sh redhat|fedora

五、编写一个批量添加用户脚本

目标:

本例要求在虚拟机 server0 上创建 /root/batchusers 脚本,任务目标如下:

1> 此脚本要求提供用户名列表文件作为参数
   2> 如果没有提供参数,此脚本应该给出提示 Usage: /root/batchusers,退出并返回相应值
   3> 如果提供一个不存在的文件,此脚本应该给出提示 Input file not found,退出并返回相应值
   4> 新用户的登录Shell为 /bin/false,无需设置密码
   5> 列表测试文件:http://classroom/pub/materials/userlist

方案:

单分支if选择结构:

if  条件测试操作
    then
         命令序列....
    fi

脚本的退出状态:取决于退出前最后一条命令的 $? 值,或者“exit 整数值”指定。

列表式for循环结构:

for  变量名  in  值1  值2  值3 .. ..
    do
            命令序列($变量名)
    done

使用命令替换来获取命令结果:$(命令行)

步骤:

步骤一:编写batchusers批量添加用户脚本

1)编写脚本代码

[[email protected] ~]# vim  /root/batchusers
    #!/bin/bash
    if [ $# -eq 0 ] ; then
        echo "Usage: /root/batchusers <userfile>"
        exit 1
    fi
    if [ ! -f $1 ] ; then
        echo "Input file not found"
        exit 2
    fi
    for name in $(cat $1)
    do
        useradd  -s  /bin/false  $name
    done

2)添加x执行权限

[[email protected] ~]# chmod  +x  /root/batchusers

步骤二:测试batchusers批量添加用户脚本

1)下载用户列表测试文件:

[[email protected] ~]# wget  http://classroom/pub/materials/userlist -O  /root/userlist
    .. ..
    2016-11-27 17:23:32 (2.83 MB/s) - ‘/root/userlist’ saved [27/27]
    [[email protected] ~]# cat  /root/userlist                      //检查下载文件
    duanwu
    zhongqiu
    zhsan
    lisi

2)实现批量添加用户:

[[email protected] ~]# /root/batchusers  /root/userlist
    [[email protected] ~]# id  duanwu
    uid=1006(duanwu) gid=1006(duanwu) groups=1006(duanwu)

3)测试其他异常处理:

[[email protected] ~]# /root/batchusers                          //未提供列表文件
    Usage: /root/batchusers <userfile>
    [[email protected] ~]# echo  $?
    1
    [[email protected] ~]# /root/batchusers  /root/userlist.txt        //提供的列表文件找不到
    Input file not found
    [[email protected] ~]# echo  $?
    2

原文地址:https://www.cnblogs.com/baichuanhuihai/p/8260523.html

时间: 2024-08-02 06:55:23

工程师技术(五):Shell脚本的编写及测试、重定向输出的应用、使用特殊变量、编写一个判断脚本、编写一个批量添加用户脚本的相关文章

shell脚本编程-例子_批量添加用户脚本

用户管理是Linux系统维护的工作之一,其中设计用户添加.删除等简单操作. 需求:一次添加很多用户.在一个文本文件中. 格式:以行为单位,每行是一条用户信息.用户名和密码之间使用特定的分隔符分开,可是是空格,逗号,Tab键等.这里用空格区分 eg: [[email protected] ~]$ cat addusers.txt username001 password001 username002 password002 username003 password003 username004 p

批量添加用户脚本

#!/bin/bash for i in `seq 1 3` do useradd userl-$i echo "0"|passwd userl-$i --stdin 批量添加密码 done [[email protected]alhost ~]# sh -x create_user.sh ++ seq 1 3 + for i in '`seq 1 3`' + useradd userl-1 + echo 0 + passwd userl-1 --stdin Changing pass

linux学习笔记--工程师技术:shell脚本基础

 Shell脚本 脚本:可以执行文件,运行后可以实现某种功能(命令的堆积,非交互) 规范Shell脚本的一般组成 #! 环境声明(Sha-Bang) # 注释文本 可执行代码 #!/bin/bash   #环境声明,声明写的脚本是bash这个程序翻译的 一.书写第一脚本程序 [[email protected] ~]# vim /root/1.sh #!/bin/bash echo hello world hostname cat  /etc/redhat-release ifconfig |

shell脚本之批量添加用户

没错,这是一个简单的脚本,不写不知道,写了才发现自己有多少不足. 下面的脚本主要用于批量添加用户的脚本,本来很简单的脚本,但是添加了一些判断,验证自己学习. 1.判断用户输入是否有误 2.判断用户是否存在,存在就跳过不再处理 代码如下: #/bin/bash #批量添加用户脚本   #判断用户是否存在函数 function panduan()     {         for nametmp in $(cat /tmp/user.txt)             do             

shell 脚本实战笔记(9)--linux自动批量添加用户

前言: 添加linux用户帐号,这个相对简单, 在面对集群, 许多机器的时候, 我们该如何去做和实现? 这篇短文, 简单讲解一些思路, 尽可能地涉及周边的一些知识点. 不光是运维人员会面临这个问题, 对一个基于linux平台的集群服务或软件(比如hadoop集群), 有时也会涉及到这块. 应用场景: 是以centos 6.4作为演示的系统, 其他的系统有类同, 也有差异, 且以实战演练, 一步步的讲述下流程. *) 实战演练 查阅useradd的使用和参数选项useradd --help -d,

SHELL脚本批量添加用户

在Linux服务中添加相应的用户账号,初始密码均为"123456".可以先指定所有用户的列表文件,然后编写一个名为uadduser.sh的脚本 [[email protected] ~]# vim /root/users.txt                       //新建一个指定所有用户的列表文件xiaomingxiaoqingxiaofangxiaodong [[email protected] ~]# vim uadduser.sh         //创建批量添加用户的

(转)通过shell脚本实现批量添加用户和设置随机密码以及生产环境如何批量添加

通过shell脚本实现批量添加用户和设置随机密码以及生产环境如何批量添加 原文:http://www.21yunwei.com/archives/4773 有一个朋友问我如何批量创建用户和设置密码 ,我就简单给他写了两个脚本,让他自己参考下并自己根据实际情况进行修改,毕竟他需要的用户名和密码都是实际生产环境的. 这里分两种情况,一种是测试for循环批量添加用户,一个是根据实际生产环境进行批量添加.分别写一下案例如下:1,for添加指定类型用户以及设置随机密码.脚本作用:批量添加user1-10用

openladp 添加用户脚本

#!/bin/sh user="seqkit" myDomain="hyldap" passwd="******" echo -n "">./passwd.ldif echo -n "">./group.ldif for i in $user do     echo "Start write user info to passwd.ldif group.ldif"     g

为Discuz! X3.2批量添加用户的python脚本

为Discuz! X3.2批量添加用户的python脚本 搭建了一个Discuz! X3.2环境用于工作,需要添加用户时没有找到合适的工具,虽然同事最终用按键精灵解决了问题,不过还是决定写一段代码留下来,也许用得上. 之所以是Python而不是PHP,只是最近在接触Python,发现在这种场合更加方便. 添加用户代码: # encoding: utf-8 ''' Created on 2015年7月1日 @author: ZhongPing ''' import urllib import ur