expect交互式脚本

简介:

Solaris_change_passwd使用注意事项及说明


1. 

脚本只测试了Solaris10的英文及中文版(oracle公司出品)


2. 

Solaris10中文版系统需要将系统字符集改为zh_CN.UTF-8


3. 

以bash执行此脚本



bash Solaris_change_passwd 用户名($1) IP地址($2) 用户密码($3) 需要更改密码的用户名($4) 更改的用户密码($5)

脚本变量定义:



#!/bin/bash

USER=$1          #用户名

IP=$2            #IP地址

PW=$3            #用户密码

CHE_USER=$4     #需要更改密码的用户名

CHE_PW=$5       #更改的密码

ping -c 3 ${IP} >/dev/null                                      #ping 3次 $IP地址不输出显示

if [ "$?" -ge "1" ] ;then                                       #如果输出结果大于等于1,则

echo "The network impassability"                                #输出“The network impassability”

exit 1                                                          #退出此次循环

fi                                                              #结束if循环

expect -c "                                                     #调用expect脚本

   set timeout 30                                               #设置超时间为30秒

   match_max 100000                                             #设置匹配最大长度为100000

   spawn ssh $USER@$IP                                          #调用ssh程序登录

      expect {                

         \"yes\/no\" { send \"yes\n\" ; exp_continue }          #匹配到yes/no时,输入yes.继续向下执行

         \"assword: \" {                                        #匹配到“assword”时

            send \"${PW}\n\"                                    #输入$PW

            expect \"Permission denied\" {                      #匹配到“Permission denied”时

            send_user \"\nUser name password mistake, or no permissions.\n\"  

                                                                #输出“nUser name password mistake, or no permissions.”

            exit 2                                              #退出2循环

            }

            }

         \"口令: \" {                                            # 匹配到“assword”时

         send \"${PW}\n\"                                       # 输入$PW

            expect \"Permission denied\" {                      #匹配到“Permission denied”时

            send_user \"\nUser name password mistake, or no permissions.\n\"   

                                                                #输出“nUser name password mistake, or no permissions.”

            exit 3                                              #退出3循环

            } 

         }

         

         \"Connection refused\" {                               #匹配到“Connection refused”

         send_user \"\nSSH Service is not open\n\"              #输出“nSSH Service is not open”

         exit 4                                                 #退出4循环

         }

         }        

      expect \"*#*\" { send \"passwd $CHE_USER\n\" }            #匹配到#号时,输入“passwd $CHE_USER”      

      expect {        

         \"assword:\" { send \"$CHE_PW\n\" ; exp_continue }     #匹配到assword时,输入 $CHE_PW,继续向下执行

         \"口令:\" { send \"$CHE_PW\n\"; exp_continue }         #匹配到口令:时,输入 $CHE_PW,继续向下执行

         }

      expect\"#\" { send \"exit\n\" }                           #输入exit退出   (实在不行就干掉)

expect eof                                                      #结束expect调用脚本

"



用法:bash gaimi.sh root 192.168.0.2 redhat aa 123123










本文转自 Edenwy  51CTO博客,原文链接:http://blog.51cto.com/edeny/1763051,如需转载请自行联系原作者
目录
相关文章
|
11月前
|
机器学习/深度学习 人工智能 算法框架/工具
什么是CANN和Ascend C
CANN(Compute Architecture for Neural Networks)是华为推出的AI异构计算架构,支持多种AI框架如MindSpore、PyTorch等,适用于AI处理器与编程,旨在提升昇腾AI处理器的计算效率。CANN提供强大的图引擎、算子开发语言Ascend C、算子加速库AOL、集合通信库HCCL、毕昇编译器及Runtime运行时,支持快速构建AI应用,涵盖推理应用开发、模型训练和算子开发等关键功能。
|
Linux Shell 开发工具
Linux tail & cat & grep 命令详解
Linux tail & cat & grep 命令详解
960 0
|
运维 监控 安全
系统日志规范及最佳实践(1)
系统日志规范及最佳实践
3358 0
|
虚拟化 数据安全/隐私保护
【EulerOS】华为欧拉服务器操作系统安装与使用教程
【EulerOS】华为欧拉服务器操作系统安装与使用教程
6302 0
|
3天前
|
搜索推荐 编译器 Linux
一个可用于企业开发及通用跨平台的Makefile文件
一款适用于企业级开发的通用跨平台Makefile,支持C/C++混合编译、多目标输出(可执行文件、静态/动态库)、Release/Debug版本管理。配置简洁,仅需修改带`MF_CONFIGURE_`前缀的变量,支持脚本化配置与子Makefile管理,具备完善日志、错误提示和跨平台兼容性,附详细文档与示例,便于学习与集成。
269 116