Windows服务器文件自动上传至阿里云OSS

本文涉及的产品
对象存储 OSS,20GB 3个月
对象存储 OSS,恶意文件检测 1000次 1年
对象存储 OSS,内容安全 1000次 1年
简介:

Windows服务器数据文件自动上传至阿里云OSS

背景:

客户需求:实现将Windows服务器上的SQLServer数据库文件上传至阿里云OSS内,实现数据长期备份。

需求难点:网络波动对上次数据完整性的影响,如何在前期规划好后期新增的数据文件的归档分组与优化管理,如何确保数据文件上传的完整性检查。

解决方法1.windows下编写bat批量执行脚本配合定时任务时间数据传输。

     2.选取osscmd工具,支持G级数据的切片上次与解决网络波动时候的断点续传。                    3.打包压缩数据文件,减少传流量带宽,上传完成后删除压缩包(脚本内实现)。

      4.通过在Linux服务器同样使用osscmd的list方法来抓取oss上的文件信息,以便比对与告警。

一、备份服务器端部署

1.安装python,版本在2.5-2.7,建议2.7(已安装忽略)

2.c盘新建OSS目录,并在次目录下解压osscmd文件

下载URLhttps://docs-aliyun.cn-hangzhou.oss.aliyun-inc.com/internal/oss/0.0.4/assets/sdk/OSS_Python_API_20160419.zip?spm=5176.doc32171.2.3.lnaEuy&file=OSS_Python_API_20160419.zip

3.安装rar压缩文件(已安装忽略)

4.修改oss.bat脚本文件

OSS.bat文件内容如下:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
@ echo  off
rem mail:xuel@anchnet.com
set  MON=% date :~0,4%% date :~5,2%                 #定义创建的时间目录
set  DATE=% date :~0,4%% date :~5,2%% date :~8,2%     #定义时间
set  TIME=% date %-% time %
set  LOGDIR=C:\                                 #目录
set  DIR=D:\                                    #数据文件的盘符
echo  "%TIME% 脚本开始执行完毕!" >>%LOGDIR%\OSS\log\backup-oss.log      #输出日志
set  DIRNAME=SAP_BACKUP                                                #数据文件的目录
set  NAME=上海xx客户科技                                               #客户名称
set  PY=C:\Python27\python.exe                  #python可执行程序路径
set  OSSCMD=C:\OSS\osscmd                       #osscmd路径
set  RAR= "C:\Program Files\WinRAR\WinRAR.exe"   #rar路径
set  BUCKET=oss: //dacexinxi/                    #oss上bucket名称
set  ID=LTAIsSraOIxxxxxxxx                      #access ID
set  KEY=40u5sORa9JAVnlWwhekBJxxxxxxxxxx        #access key
set  HOST=oss-cn-shenzhen.aliyuncs.com          #oss所在区,内网可以根据具体来写
  
set  FILE=Data1                                 #压缩的数据文件目录名称
%RAR% a -k -r -s -m1 %DIR%%DATE%-%FILE%.rar %DIR%\%DIRNAME%\%FILE%      #压缩文件
set  TIME=
set  TIME=% date %-% time %
echo  "%TIME% %FILE% 压缩文件执行完毕!" >>%LOGDIR%\OSS\log\backup-oss.log
%PY% %OSSCMD%  mkdir  %BUCKET%%NAME%/%MON%/%DATE%-%DIRNAME% -- id =%ID% --key=%KEY% --host=%HOST%   #创建oss目录
%PY% %OSSCMD% mp %DIR%%DATE%-%FILE%.rar %BUCKET%%NAME%/%MON%/%DATE%-%DIRNAME%/%DATE%-%FILE%.rar -- id =%ID% --key=%KEY% --host=%HOST%    #使用multiupload上次文件
set  TIME=
set  TIME=% date %-% time %
echo  "%TIME% %FILE% 上传文件执行完毕!" >>%LOGDIR%\OSS\log\backup-oss.log
del %DIR%%DATE%-%FILE%.rar                     #删除压缩数据文件
set  TIME=
set  TIME=% date %-% time %
echo  "%TIME% %FILE% 删除文件执行完毕!" >>%LOGDIR%\OSS\log\backup-oss.log
  
set  FILE=
set  FILE=Data2
%RAR% a -k -r -s -m1 %DIR%%DATE%-%FILE%.rar %DIR%\%DIRNAME%\%FILE%
set  TIME=
set  TIME=% date %-% time %
echo  "%TIME% %FILE% 压缩文件执行完毕!" >>%LOGDIR%\OSS\log\backup-oss.log
%PY% %OSSCMD%  mkdir  %BUCKET%%NAME%/%MON%/%DATE%-%DIRNAME% -- id =%ID% --key=%KEY% --host=%HOST%
%PY% %OSSCMD% mp %DIR%%DATE%-%FILE%.rar %BUCKET%%NAME%/%MON%/%DATE%-%DIRNAME%/%DATE%-%FILE%.rar -- id =%ID% --key=%KEY% --host=%HOST%
set  TIME=
set  TIME=% date %-% time %
echo  "%TIME% %FILE% 上传文件执行完毕!" >>%LOGDIR%\OSS\log\backup-oss.log
del %DIR%%DATE%-%FILE%.rar
set  TIME=
set  TIME=% date %-% time %
echo  "%TIME% %FILE% 删除文件执行完毕!" >>%LOGDIR%\OSS\log\backup-oss.log
echo  "-----------%TIME% 脚本执行完毕!---------" >>%LOGDIR%\OSS\log\backup-oss.log

5.Window创建定时任务

创建定时任务

“程序”/“附件”/“系统工具”/“任务计划程序”命令

wKiom1mD5dmwiUjBAAHnLBMOnP0233.png

点击“创建任务”后如图所示:填写好相应的名称和勾选好必要的条件

wKiom1mD5h_DEFz8AAEuz30TiPY828.png

选择“触发器”选项,点击“新建”,创建任务执行时间,“重复任务间隔”这个选择后,后面有时间选择,是每小时,还是每分,可自己选择后再修改时间,再确定。

wKiom1mD5rKTS8KsAAHguKBr2Uw133.png

wKioL1mD55-g8pCDAAG7SV1iEpc969.png

再来配置需要执行的“操作”,就是选择所写的程序或是BAT文件,这里很重要的配置是选择BAT文件后,在“起始于(可选)”这里一定要填写相应执行程序或是BAT文件的所在目录,要不然是执行不成功的。

wKiom1mD59eRZQ9EAACfUoBqnz0791.png

wKioL1mD5_ajv6LWAANFMloffII270.png

wKiom1mD6umjuRiFAAMsb4uWtXo001.png

wKioL1mD6xrQbFwnAAFN3i848Jg808.png


二、阿里云OSS开通

创建Access key,用于使用osscmd上传时bucket认证标识

wKiom1mD62qwQsN1AADOfGXaQyQ226.png

创建bucket

wKiom1mD66zzzgGrAADJs-P3-Yw968.png


二、监控OSS上传数据

1.下载osscmd工具并放置/oss目录下

wKiom1mD7Cbx08I8AAEbIndsm48816.png

oss_check.sh检测脚本如下:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
#!/bin/bash
DATE=` date  +%Y%m`
OSSCMD= /oss/osscmd
NAME=上海xx公司
PYCMD= /usr/bin/python
BUCKET=oss: //dacexinxi/
TIME=` date  +%Y%m%d`
DATANAME= "${TIME}-SAP_BACKUP"
ID=LTAIsSraOIHyxxx
KEY=40u5sORa9JAVnlWwhekBJzxxxxx
HOST=oss-cn-shenzhen.aliyuncs.com
WEIXIN= /oss/GFweixin .sh
MAILTIME=` date  +%F ' ' %H:%M`
  
if  [ -d  /oss/log  ]; then
mkdir  -p  /oss/log/ ${TIME} 
fi
$PYCMD $OSSCMD  ls  ${BUCKET}${NAME}/${DATE}/${DATANAME} -- id =$ID --key=$KEY --host=$HOST> /oss/log/ ${TIME} /oss-check- ${TIME}.log
NUM=`$PYCMD $OSSCMD  ls  ${BUCKET}${NAME}/${DATE}/${DATANAME} -- id =$ID --key=$KEY --host=$HOST | grep  rar| wc  -l`
echo  $NUM
if  "${NUM}"  !=  "4"  ]; then
    /bin/bash  /oss/GFweixin .sh xuel dace  "上海xx公司-oss_check is fail! TIME:${MAILTIME}"
else
    /bin/bash  /oss/GFweixin .sh xuel dace  "上海xx公司-oss_check is ok! TIME:${MAILTIME}"
fi
ls  /oss/log/ ${TIME} /oss-check- ${TIME}.log
if  "$?"  !=  "0"  ]; then
/bin/bash  /oss/GFweixin .sh xuel dace  "上海xx公司-oss_check is fail! TIME:${MAILTIME}"
else
/bin/mail  -r xuel@51idc.com -s  "达上海xx公司-oss_check"  serviceadmin@51idc.com < /oss/log/ ${TIME} /oss-check- ${TIME}.log
fi

五、结果展示

1.上传日志查看

wKiom1mD7Lui4V9rAABku3ya49k220.png

1.阿里云oss文件查看

wKioL1mD7SCBlW0dAAEtaqkZYnI988.png


可以在oss上是先以客户名称命名的一个目录,其次是一年月来归档数据文件,其次是数据上传备份目录,最终是打包好的数据压缩文件,如何后期需要定时删除,则只需在脚本内写入根据时间来删除即可,极大增强了扩展性,以日期归档方便后续管理操作。

3.邮件日志

wKioL1mD7YHAMIc0AAMiekB9j7A486.png

4.微信通知

wKioL1mD7cTQ6Y3tAABqZ4tB8Ro388.png










本文转自 KaliArch 51CTO博客,原文链接:http://blog.51cto.com/kaliarch/1953744,如需转载请自行联系原作者
相关实践学习
借助OSS搭建在线教育视频课程分享网站
本教程介绍如何基于云服务器ECS和对象存储OSS,搭建一个在线教育视频课程分享网站。
目录
相关文章
|
3天前
|
弹性计算 运维 监控
解密阿里云弹性计算:探索云服务器ECS的核心功能
阿里云ECS是核心计算服务,提供弹性云服务器资源,支持实例按需配置、集群管理和监控,集成安全防护,确保服务稳定、安全,助力高效业务运营。
29 0
|
4天前
|
网络协议
​LabVIEW从另一个VI或通过VI服务器访问正在运行的可执行文件
​LabVIEW从另一个VI或通过VI服务器访问正在运行的可执行文件
|
12天前
|
存储 弹性计算 固态存储
阿里云服务器CPU内存配置详细指南,如何选择合适云服务器配置?
阿里云服务器配置选择涉及CPU、内存、公网带宽和磁盘。个人开发者或中小企业推荐使用轻量应用服务器或ECS经济型e实例,如2核2G3M配置,适合低流量网站。企业用户则应选择企业级独享型ECS,如通用算力型u1、计算型c7或通用型g7,至少2核4G配置,公网带宽建议5M,系统盘可选SSD或ESSD云盘。选择时考虑实际应用需求和性能稳定性。
124 6
|
14天前
|
域名解析 弹性计算 Linux
阿里云购买云服务器、注册域名、备案及绑定图文教程参考
本文为大家介绍了2024年购买阿里云服务器和注册域名,绑定以及备案的教程,适合需要在阿里云购买云服务器、注册域名并备案的用户参考,新手用户可通过此文您了解在从购买云服务器到完成备案的流程。
阿里云购买云服务器、注册域名、备案及绑定图文教程参考
|
15天前
|
分布式计算 大数据 MaxCompute
MaxCompute产品使用合集之使用pyodps读取OSS(阿里云对象存储)中的文件的步骤是什么
MaxCompute作为一款全面的大数据处理平台,广泛应用于各类大数据分析、数据挖掘、BI及机器学习场景。掌握其核心功能、熟练操作流程、遵循最佳实践,可以帮助用户高效、安全地管理和利用海量数据。以下是一个关于MaxCompute产品使用的合集,涵盖了其核心功能、应用场景、操作流程以及最佳实践等内容。
|
3天前
|
负载均衡 固态存储 Linux
阿里云轻量应用服务器、云服务器、gpu云服务器最新收费标准参考
轻量应用服务器、云服务器、gpu云服务器是阿里云服务器产品中,比较热门的云服务器产品类型,不同类型的云服务器产品收费模式与收费标准是不一样的,本文为大家展示这几个云服务器产品的最新收费标准情况,以供参考。
阿里云轻量应用服务器、云服务器、gpu云服务器最新收费标准参考
|
3天前
|
弹性计算 负载均衡 容灾
应用阿里云弹性计算:打造高可用性云服务器ECS架构
阿里云弹性计算助力构建高可用云服务器ECS架构,通过实例分布、负载均衡、弹性IP、数据备份及多可用区部署,确保业务连续稳定。自动容错和迁移功能进一步增强容灾能力,提供全方位高可用保障。
16 0
|
3天前
|
存储 弹性计算 监控
探索阿里云弹性计算:如何优化云服务器ECS的性能与成本
在云时代,【阿里云ECS】的性能优化与成本控制至关重要。利用实例规格选择、自动伸缩、网络和存储配置,可增强性能、减少成本。结合监控工具和优化建议,用户能解决性能问题,提升应用稳定性,实现高效且经济的云计算运营。
12 1
|
4天前
|
安全 Linux 对象存储
数据备份到阿里云oss上,以防勒索病毒的破坏
数据备份到阿里云oss上,以防勒索病毒的破坏
15 0
|
6天前
|
编解码 缓存 安全
阿里云目前活动内各云服务器实例规格适用场景与价格参考
目前阿里云的活动中,云服务器有多种不同实例规格可选,实例规格定义了实例的基本属性:CPU和内存(包括CPU型号、主频等),但是不同实例规格所适用的场景是不一样的,价格也有很大差别,有的用户初次选购阿里云服务器可能并不知道这些实例规格的具体适用场景,下面是小编整理汇总的2024年截止目前阿里云的活动中云服务器实例规格适用场景与活动价格,以供参考。
阿里云目前活动内各云服务器实例规格适用场景与价格参考