在信息化浪潮席卷全球的当下,数字化转型已成为各行各业的核心驱动力,而作为这一进程守护者的运维工作,其重要性与日俱增。面对瞬息万变的IT环境,复杂多元的系统架构,以及日益严苛的服务质量要求,高效的自动化工具与脚本已成为运维人员提升工作效率、确保系统稳定性不可或缺的“秘密武器”。有鉴于此,我倾力编撰了这份精心筛选与整理的Shell脚本合集,旨在为广大的运维同行献上一份诚意满满的“运维人福利”,助您在应对日常运维挑战时如虎添翼,从容不迫。
这份脚本合集,犹如一座蕴藏着丰富矿藏的知识宝库,凝结了我在实战运维工作中积累的点滴智慧与宝贵经验。它深度聚焦服务器监控、故障排查、数据备份与恢复、性能调优、自动化部署等运维核心领域,旨在为每一位身处其中的专业人士提供全方位的支持。无论是初涉运维领域的新人,渴望快速掌握实战技巧,还是久经沙场的资深专家,寻求优化现有流程、提升运维效能的新思路,都能在这份合集中找寻到契合自身需求的解决方案。
每一款脚本均经过真实业务场景的反复打磨与严格测试,秉持着简洁高效、易于理解和使用的理念设计。它们不仅具备高度的灵活性与适应性,能够轻松应对各种复杂运维环境下的多样化需求,而且注释详尽,逻辑清晰,旨在成为您日常工作中随时查阅、快速上手的实用指南。无论是自动化执行例行任务,迅速响应突发事件,还是深入挖掘系统瓶颈,优化资源分配,这些脚本都将化身为您的得力助手,使繁复的运维工作变得有条不紊,事半功倍。
我热忱欢迎所有运维同仁自由取阅、广泛分享这份宝贵的Shell脚本资源,将其融入个人的工作实践中,或是作为团队协作、技能培训的参考资料。它们不仅是提升个人技能、优化工作流程的有效工具,更是增进同行间技术交流、知识共享的优质载体。让我们携手共进,充分运用这份脚本合集所蕴含的技术力量,积极推动运维工作的智能化、自动化进程,共同为构建稳定、高效、可靠的信息化系统保驾护航,为企业的数字化转型之路奠定坚实基础。在这个瞬息万变的数字化时代,让我们以匠心独运的运维智慧,驾驭科技之舟,破浪前行,共创辉煌!
今天我们要分析的是:
本地expect登陆拷贝scp_exec.sh脚本
#!/bin/expect
set timeout 30
set host 192.168.1.1
set user root
spawn scp /home/lyn/Documents/work-data/download_data/ $user@$host:/opt/lib/exec
#spawn ssh $user@$host
expect {
"*yes/no*"
{
send "yes\r"
expect "*password:*" { send "123456\r" }
}
"*password:*"
{
send "123456\r"
}
}
expect eof
脚本结构与变量定义
Bash
1#!/bin/expect 2set timeout 30 3set host 192.168.1.1 4set user root
#!/bin/expect
:这是“shebang”行,指定使用expect
语言解释器执行此脚本。set timeout 30
:设置超时时间为30秒,防止因网络延迟等原因导致的长时间等待。set host 192.168.1.1
:定义变量host
,表示远程主机的IP地址。set user root
:定义变量user
,表示登录远程主机使用的用户名。
启动SCP命令并交互式处理响应
Bash
1spawn scp /home/lyn/Documents/work-data/download_data/ $user@$host:/opt/lib/exec
- 使用
spawn scp
命令启动scp
进程,将本地文件/home/lyn/Documents/work-data/download_data/
复制到远程主机$host
的/opt/lib/exec
目录。 $user@$host
:使用之前定义的用户名和主机名组合成SSH连接字符串。
编写expect交互逻辑
Bash
1expect { 2"*yes/no*" 3{ 4send "yes\r" 5expect "*password:*" { send "123456\r" } 6} 7"*password:*" 8{ 9send "123456\r" 10} 11}
expect
块用于监听scp
命令的输出,并根据不同的响应执行相应的操作。
"*yes/no*"
:当输出包含“yes/no”(询问是否接受主机密钥)时:
send "yes\r"
:发送“yes”及回车(\r
),同意接受远程主机的密钥。expect "*password:*"
:等待出现“password:”提示。{ send "123456\r" }
:发送密码“123456”及回车,完成登录认证。
"*password:*"
:当输出直接包含“password:”(无需接受主机密钥)时:
send "123456\r"
:发送密码“123456”及回车,完成登录认证。
结束脚本
Bash
1expect eof
- 使用
expect eof
等待scp
命令执行完毕(即EOF,End Of File),确保整个复制过程顺利完成。
如何使用
- 确保远程主机可达:检查远程主机
192.168.1.1
的网络连接是否畅通,且允许来自本地主机的SSH连接。 - 确认用户名和密码:确保
user
变量设置的用户名(此处为root
)在远程主机上有效,且密码为123456
。 - 赋予脚本执行权限:
- Bash
1chmod +x scp_exec.sh
- 运行脚本:
- Bash
1./scp_exec.sh
脚本将通过SSH协议从本地主机将指定文件/home/lyn/Documents/work-data/download_data/
复制到远程主机192.168.1.1
的/opt/lib/exec
目录。在执行过程中,脚本会自动处理可能出现的主机密钥确认和密码输入步骤。通过运行此脚本,您可以方便地实现自动化文件传输任务。
如果想上手操作练代码的同学们可以通过阿里云ecs服务器免费试用参与!
入口:新老同学免费试用