热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

Linux下后台程序完成自动输入密码等交互行为的例

今天要开发一个定时任务,然后加入cron列表中。但是有个问题摆在30524;前,脚本的执行中需要输入数据库密码:mysql-uroot-pSQLusedb;setnamesutf8

今天要开发一个定时任务,然后加入cron列表中。但是有个问题摆在眼前,脚本的执行中需要输入 数据库 密码:

mysql -u root -p <use db;
set names utf8;
`cat task.sql`
SQL

运行上述代码后,会提示:

Enter password:  

经过搜索,发现expect可以帮助我们完成这件事情:

将上述代码保存到一个文件中:db.sh,并且编写如下代码: 

#!/usr/bin/expect -f
spawn db.sh
expect "Enter password: "
send -- "password\n"
interact
那么我们运行之后,就会进入数据库交互接口。 

第一行指示了这个脚本要用哪个程序来运行;

第二行是重点,在EXPECT下启动了一个我们要执行的程序;

第三行也是重点,我们要告诉expect,当什么信息出现时需要expect帮助我们完成交互;

第四行就是出现输入密码的提示时,要发送的内容;

第五行的意思是保持交互,不要退出。如果没有这一句,脚本成功登录数据库后,会立即退出。



推荐阅读
author-avatar
大美女雪梨醒目
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有