shell 发送邮件脚本(免密)

#!/bin/bash
ENV=$1
TARGET_VERSION=$2
TO=$3
# SMTP服务器设置
SMTP_SERVER="邮箱服务地址"
SMTP_PORT="25"

# 邮件信息
FROM="jenkins@y.com"
SUBJECT="Deployment Status Notification"
BODY=$ENV"发布完成,版本 :"$TARGET_VERSION

# 临时文件存储邮件内容
EMAIL_CONTENT_FILE=$(mktemp)

# 构建邮件内容
cat <<EOF > $EMAIL_CONTENT_FILE
From: $FROM
To: $TO
Subject: $SUBJECT

$BODY
EOF

# 使用curl发送邮件
curl -v --url "smtp://$SMTP_SERVER:$SMTP_PORT" \
  --mail-from "$FROM" \
  --mail-rcpt "$TO" \
  --upload-file $EMAIL_CONTENT_FILE

# 删除临时文件
rm -f $EMAIL_CONTENT_FILE

有3个参数,我写成动态的了。不要可以拿掉。

#!/bin/bash
TARGET_VERSION=$2

# SMTP服务器设置
SMTP_SERVER="服务地址"
SMTP_PORT="25"

# 邮件信息
FROM="jenkins.fsts@y.com"
TO="b@y.com"
SUBJECT="Deployment Status Notification"
BODY="发布完成,发布版本 :"$TARGET_VERSION

# 临时文件存储邮件内容
EMAIL_CONTENT_FILE=$(mktemp)

# 构建邮件内容
cat <<EOF > $EMAIL_CONTENT_FILE
From: $FROM
To: $TO
Subject: $SUBJECT

$BODY
EOF

# 使用curl发送邮件
curl -v --url "smtp://$SMTP_SERVER:$SMTP_PORT" \
  --mail-from "$FROM" \
  --mail-rcpt "$TO" \
  --upload-file $EMAIL_CONTENT_FILE

# 删除临时文件
rm -f $EMAIL_CONTENT_FILE

多人情况

#!/bin/bash

ENV=$1
TARGET_VERSION=$2
TO_EMAILS=$3  # 多个收件人用逗号分隔,例如 "email1@example.com,email2@example.com"

# 检查必需的参数
if [ -z "$ENV" ] || [ -z "$TARGET_VERSION" ] || [ -z "$TO_EMAILS" ]; then
  echo "Usage: $0 <environment> <target-version> <to-emails>"
  exit 1
fi

# 将逗号分隔的收件人地址转换为空格分隔
TO_EMAIL_LIST=$(echo $TO_EMAILS | tr ',' ' ')

# SMTP服务器设置
SMTP_SERVER="邮件服务"
SMTP_PORT="25"

# 邮件信息
FROM="fsts.jenkins@disney.com"
SUBJECT="Deployment Status Notification"
BODY="$ENV 发布完成,版本 :$TARGET_VERSION"

# 临时文件存储邮件内容
EMAIL_CONTENT_FILE=$(mktemp)

# 构建邮件内容
cat <<EOF > $EMAIL_CONTENT_FILE
From: $FROM
To: $TO_EMAILS
Subject: $SUBJECT

$BODY
EOF

# 使用curl发送邮件
if curl --url "smtp://$SMTP_SERVER:$SMTP_PORT" \
  --mail-from "$FROM" \
  $(for EMAIL in $TO_EMAIL_LIST; do echo "--mail-rcpt $EMAIL "; done) \
  --upload-file "$EMAIL_CONTENT_FILE" > /dev/null 2> curl_email.log; then
  echo "Email sent successfully."
else
  echo "Failed to send email. Check curl_email.log for details."
fi

# 删除临时文件
rm -f "$EMAIL_CONTENT_FILE"

<think>好的,用户想要一个定时自动获取远程计算机文件数据的脚本。首先,我需要确定用户的具体需求和场景。可能他们需要定期从远程服务器下载日志文件、备份数据或者同步某些资料。接下来,我得考虑使用哪些工具和技术来实现这个功能。 首先想到的是使用shell脚本,特别是结合scp或者rsync这样的工具来传输文件。scp简单直接,适合小文件;rsync则更适合增量同步,节省带宽和时间。另外,定时任务可以用cron来实现,这是Linux系统常用的方法。不过用户可能对Windows环境也有需求,这时候可能需要用计划任务配合PowerShell脚本。 然后,用户可能关心安全性,比如如何避每次输入码。这时候需要配置SSH钥认证,这样脚本可以无码登录远程机器。但要注意钥的安全性,不能泄露私钥。 另外,是否需要处理错误?比如网络中断或者文件不存在的情况,脚本应该有一定的容错机制,比如重试或者记录日志。用户可能希望有日志功能,方便后续排查问题。 还有,文件传输后的存储位置、是否需要保留历史版本、是否要压缩或加文件,这些可能需要进一步确认。但用户可能没有提到这些细节,所以作为初步介绍,应该涵盖基本实现,同时提到可能的扩展点。 可能用户是系统管理员或者开发人员,需要自动化日常任务,所以脚本的易用性和可维护性也很重要。可以建议使用配置文件来存储远程主机信息,避硬编码,方便修改。 总结下来,基本的步骤是:1. 选择文件传输工具(scp/rsync)。2. 编写脚本,包含传输命令。3. 配置SSH登录。4. 设置定时任务(cron或计划任务)。5. 添加日志和错误处理。6. 测试脚本确保可靠性。 还需要考虑跨平台情况,比如如果用户混合使用Linux和Windows,可能需要不同的方法。或者,使用Python脚本跨平台,利用paramiko库进行SFTP传输,这样更灵活,但需要用户有Python环境。 最后,给出一个简单明了的示例,让用户能快速上手,同时提醒注意事项,比如权限、安全性、日志等。可能用户需要进一步的定制,但示例应该展示核心功能,足够他们开始使用。</think>以下是一个实现定时自动获取远程计算机文件数据的方案介绍,适用于 Linux/Unix 系统和 Windows 系统: --- ### **核心原理** 1. **文件传输协议**:使用 `SCP`、`SFTP` 或 `rsync` 协议远程获取文件 2. **定时任务**:通过 `cron` (Linux) 或 计划任务 (Windows) 实现定时触发 3. **自动化认证**:配置 SSH 钥认证避手动输入码 --- ### **基础实现方案(Linux 示例)** #### 1. 创建脚本文件 `auto_fetch.sh` ```bash #!/bin/bash # 远程服务器配置 REMOTE_USER="username" REMOTE_HOST="192.168.1.100" REMOTE_PATH="/path/to/remote/file" LOCAL_DIR="/path/to/local/save" # 执行文件传输 scp -o StrictHostKeyChecking=no \ ${REMOTE_USER}@${REMOTE_HOST}:${REMOTE_PATH} \ ${LOCAL_DIR}/$(date +%Y%m%d_%H%M%S).dat # 记录日志 echo "[$(date)] 文件已同步至 ${LOCAL_DIR}" >> /var/log/auto_fetch.log ``` #### 2. 设置脚本权限 ```bash chmod +x auto_fetch.sh ``` #### 3. 配置 SSH 登录 ```bash ssh-keygen -t rsa ssh-copy-id ${REMOTE_USER}@${REMOTE_HOST} ``` #### 4. 设置 cron 定时任务 ```bash # 每天凌晨2点执行 crontab -e 0 2 * * * /path/to/auto_fetch.sh ``` --- ### **高级功能扩展** 1. **增量同步**:使用 `rsync -avz` 替代 scp 2. **异常处理**:添加网络重试机制 ```bash max_retries=3 for i in $(seq 1 $max_retries); do scp ... && break || sleep 60 done ``` 3. **邮件通知**:通过 `mailutils` 发送执行结果 4. **文件校验**:添加 MD5 校验保证完整性 --- ### **Windows 系统方案** 1. **使用 PowerShell 脚本**: ```powershell $session = New-PSSession -HostName 192.168.1.100 -UserName user Copy-Item -FromSession $session -Path "C:\remote\file.txt" -Destination "D:\local\" Remove-PSSession $session ``` 2. **通过任务计划程序**设置定时触发 --- ### **注意事项** 1. 确保防火墙开放 SSH 端口(默认22) 2. 敏感信息建议使用配置文件+权限控制 3. 生产环境建议添加日志轮转(logrotate) 4. 重要数据建议加传输(使用 SFTP 代替 SCP) 如果需要更具体的实现细节或定制化方案,可以告诉我您的具体使用场景(如文件类型、系统环境、安全要求等)。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值