hadoop05

函数使用
2.6.1 函数定义

#!/bin/sh
# func1.sh
#hello
hello()    ## 函数定义
{
        echo "Hello there today's date is `date +%Y-%m-%d`"
        return  2      ###返回值其实是状态码,只能在[0-255]范围内
}  
echo "now going to the function hello"
hello
echo $?  #获取函数的return值(即:返回上一条命令执行的后的值。true返回0,false返回1)  
echo "back from the function"

函数调用:
function hello()
或 function hello
或 hello

注意:
1.必须在调用函数地方之前,先声明函数,shell脚本是逐行运行。不会像其它语言一样先预编译
2.函数返回值,只能通过$? 系统变量获得,可以显示加:return 返回,如果不加,将以最后一条命令运行结果,作为返回值。 return后跟数值n(0-255)

脚本调试:
sh -vx helloWorld.sh
或者在脚本中增加set -x

2.6.2 函数参数

# fun1.sh

funWithParam(){
    echo "第一个参数为 $1 !"
    echo "第二个参数为 $2 !"
    echo "第十个参数为 $10 !"
    echo "第十个参数为 ${10} !"
    echo "第十一个参数为 ${11} !"
    echo "参数总数有 $# 个!"
    echo "作为一个字符串输出所有参数 $* !"
}
funWithParam 1 2 3 4 5 6 7 8 9 34 73

#!/bin/bash

注意, 10 不 能 获 取 第 十 个 参 数 , 获 取 第 十 个 参 数 需 要 10 不能获取第十个参数,获取第十个参数需要 10{10}。当n>=10时,需要使用${n}来获取参数。
2.6.3 函数返回值

#!/bin/bash
# fun2.sh
funWithReturn(){
    echo "这个函数会对输入的两个数字进行相加运算..."
    echo "输入第一个数字: "
    read aNum
    echo "输入第二个数字: "
    read anotherNum
    echo "两个数字分别为 $aNum 和 $anotherNum !"
    return $(($aNum+$anotherNum))
}
funWithReturn
echo "输入的两个数字之和为 $? !"

2.6.4 跨脚本调用函数
假如上述的脚本文件fun2.sh保存在此路径: /root/fun2.sh
则可在脚本fun_other.sh中调用脚本fun2.sh中的函数

#!/bin/bash
# fun_other.sh
. /root/fun1.sh    ## 注:  . 和 / 之间有空格
# 或者 source /root/fun1.sh
funWithParam 11 22 33 44 55 66 77 88 99 100 101

03/ shell编程综合练习
自动化软件部署脚本

3.1 需求
1、需求描述
公司内有一个N个节点的集群,需要统一安装一些软件(jdk)
需要开发一个脚本,实现对集群中的N台节点批量自动下载、安装jdk

2、思路
1/ 编写一个启动脚本,用来发送一个软件安装脚本到每一台机器
2/ 然后启动每台机器上的软件安装脚本来执行软件下载和安装
在这里插入图片描述

3、expect的使用
痛点:使用scp命令远程拷贝文件时,会有人机交互的过程,如何让脚本完成人机交互?
妙药: expect
用法示例:
先观察 ssh localhost 的过程
再看expect的功能

#!/bin/bash/expect
## exp_test.sh
set timeout -1;
spawn ssh localhost;
expect {
    "(yes/no)" {send "yes\r";exp_continue;}
    "password:" {send "hadoop\r";exp_continue;}
    eof        {exit 0;}
}

执行: expect -f exp_test.sh

3.2 准备内网软件下载服务器
选择一台服务器(比如mini)作为软件源服务器

1、安装httpd (如果已有,可跳过)
yum install -y httpd
service httpd start
chkconfig --level 35 httpd on

2、制作局域网yum源
1/ 挂载centos安装光盘到/mnt/cdrom (如果已有,可跳过)
mkdir /mnt/cdrom
mount -t iso9660 -o loop /dev/cdrom /mnt/cdrom

2/ 将本地yum库放入httpd服务器
ln -s /mnt/cdrom /var/www/html/centos

检查点:用浏览器访问 http://mini/centos 看能否看到光盘内容
3、编写repo配置
vi /etc/yum.repos.d/centos.repo

[c6-httpd]
name=CentOS-httpd
baseurl=http://192.168.33.3/centos
gpgcheck=0
enabled=1

4、分发repo配置到局域网
从母鸡shizhan01上把centos.repo拷贝给所有需要自动安装软件的服务器(仔鸡mini1/mini2)
cd /etc/yum.repos.d/
scp /etc/yum.repos.d/innet.repo mini1: P W D s c p / e t c / y u m . r e p o s . d / i n n e t . r e p o m i n i 2 : PWD scp /etc/yum.repos.d/innet.repo mini2: PWDscp/etc/yum.repos.d/innet.repomini2:PWD

5、准备一个jdk安装包放在内网web服务器上

3.3 脚本开发
1、启动脚本
vi boot.sh

#!/bin/bash

SERVERS="hadoop02 hadoop03"
PASSWORD=hadoop
BASE_SERVER=192.168.33.91

 实现免密登陆配置的函数
## yum install expect
auto_ssh_copy_id() {
    expect -c "set timeout -1;
        spawn ssh-copy-id $1;
        expect {
            *(yes/no)* {send -- yes\r;exp_continue;}
            *assword:* {send -- $2\r;exp_continue;}
            eof        {exit 0;}
        }";

}
ssh_copy_id_to_all() {
    for SERVER in $SERVERS
    do
        auto_ssh_copy_id $SERVER $PASSWORD
    done
}

## 调用免密登陆配置函数,实现母鸡到各仔鸡的免密登陆配置
ssh_copy_id_to_all


## 完成分发install.sh到各仔鸡的操作
## 并让仔鸡启动install.sh
for SERVER in $SERVERS
do
    scp install.sh root@$SERVER:/root
    ssh root@$SERVER /root/install.sh
done

2、安装执行脚本
vi install.sh

#!/bin/bash
BASE_SERVER=192.168.33.91
##  为本机安装wget命令
yum install -y wget
## 使用wget从母鸡的web服务器上下载jdk压缩包
wget $BASE_SERVER/soft/jdk-7u67-linux-x64.gz
## 将下载的压缩包解压
tar -zxvf jdk-7u67-linux-x64.gz -C /usr/local
## 修改profile配置文件
cat >> /etc/profile << EOF
export JAVA_HOME=/usr/local/jdk1.7.0_67
export PATH=\$PATH:\$JAVA_HOME/bin
EOF

3、启动脚本
只要在baseServer即mini上启动boot.sh即可
作业:
批量部署脚本,存在一些不太完美的地方,比如,目标机器名需要写死在脚本中,请改造这一点:
可以将所有需要安装软件的机器名写在一个文件:比如slaves中
让脚本自动读取slaves文件中的机器名来批量安装
cat slaves | while read host
do
echo $host
expect -c “set timeout -1
spawn ssh-copy-id $host”
done

2/目前脚本在软件安装的时候,是逐台进行的,可以改造成并行进行

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值