windows BAT脚本2个服务器间传递文件
1. 脚本功能:
实现2个服务器间文件的传递,例如从A服务器往B服务器上传文件
2. 实现步骤:
2.1 服务器连结,找到指定路径,读取所需要上传的文件,将文件名称复制到一个文件下
(此处考虑可能需要筛选特定的文件,或者判断文件个数,这样处理会比较方便)
2.2 执行copy文件
2.3 删除不需要的文件
(这里考虑,可能是联机备份,只保留部分数据文件,需要删除不需要的数据文件,在这处理)
3. 代码展示
@echo off
REM *** copy文件参数设定
set Passwd="password"
set User="username"
set LogPath="日志存放路径"
set FullbakPath="A服务器需要复制到B服务器的文件路径"
REM *** 数据库连结设定
(这里做数据库连结是因为本脚本需要保留部分天数的文件,需要删除前7天文件
因为bat单做日期加减比较麻烦,所以采用数据库取值方法)
set DB_SERVER="数据库rul"
set DB_NAME="数据库实例"
set DB_USER="数据库用户"
set DB_PASS="数据库密码"
REM *** 数据库前7日设定
REM *** 因为这里使用sqlserver 相应其他数据库请自己调整oracle mysql等
set sql="SELECT CONVERT(NVARCHAR,DATEADD(DAY,-7,CONVERT(DATETIME,CAST(YMD AS NVARCHAR),101)),112) FROM M_DATE_CONTROL WHERE KEY_CD=2"
REM *** 服务连结
net use \\127.0.0.1\backfull %Passwd% /user:%User%
REM *** 设定日期,设定Log日志文件名称
set date=%date:~0,4%%date:~5,2%%date:~8,2%
set JOBLOG=DBBACK.log
echo ********** START (%date:~0,10% %time:~0,8%) ********** >> %LogPath%\%date%\%JOBLOG%
这里将符合的附件读取到一个文本文档中,以便后续使用
(for /f "tokens=*" %%i in ('dir /a-d /b /s %FullbakPath%\*.* ') do (
echo %%~nxi
))>fullbak.log
这里是copy文件的主要执行步骤,从文本文档读取,然后进行copy,这里有一个文件数量的判断,可以进行自我调整
for /f "tokens=2 delims=:" %%a in ('find /c /v "" fullbak.log') do (
if %%a equ 7 for /f %%i in (fullbak.log) do xcopy %FullbakPath%\%%i \\127.0.0.1\backfull\%date%\ /s /e /i /y
)
这里进行文件删除的操作,将7天前文件删除
for /f "skip=2" %%i in ('osql.exe -S %DB_SERVER% -U %DB_USER% -P %DB_PASS% -d %DB_NAME% -Q %sql%') do (
set RESULT=%%i
goto :RESULT
)
判断文件是否存在,存在就执行删除
:RESULT
if exist \\127.0.0.1\backfull\%RESULT% rd /s /q \\127.0.0.1\backfull\%RESULT%
echo ********** END (%date:~0,10% %time:~0,8%) ********** >> %LogPath%\%date%\%JOBLOG%
pause
以上为文本文档编写,大家还请见谅。
windows BAT脚本2个服务器间传递文件的更多相关文章
- windows bat脚本编写
windows批处理 (cmd/bat) 编程详解 开始之前先简单说明下cmd文件和bat文件的区别:在本质上两者没有区别,都是简单的文本编码方式,都可以用记事本创建.编辑和查看.两者所用的命令行代码 ...
- Windows bat脚本的for语句
Windows bat脚本的for语句基本形态如下: 在cmd窗口中:for %I in (command1) do command2 在批处理文件中:for %%I in (command1) do ...
- 【原创】Linux基础之linux服务器服务器间拷贝文件
linux服务器服务器间拷贝文件,有几种方式: 1 如果是定时任务,可以用rsync 2 如果是基于ssh登录,可以用scp,优点是可以实现远程到远程的拷贝,缺点是需要账号密码 upload: scp ...
- 进程间传递文件描述符——sendmsg和recvmsg函数
先引入一个例子,该程序的目的是子进程向父进程传递文件描述符,并通过该文件描述符读取buf. #include <func.h> int main(){ int fds[2]; pipe(f ...
- 进程间传递文件描述符fd
众所周知,子进程会继承父进程已经打开的文件描述符fd,但是fork之后的是不会被继承的,这个时候是否无能无力了?答应是NO.Linux提供了一个系统调用sendmsg,借助它,可以实现进程间传递文件描 ...
- Linux 进程间传递文件描述符
文章目录 文件描述符 文件数据结构 共享文件 UNIX域socket实现传递文件描述符 进程间传递打开的文件描述符,并不是传递文件描述符的值.先说一下文件描述符. 文件描述符 对内核来说,所有打开的文 ...
- bat脚本删除一周前的文件
bat脚本删除7天前的文件 @echo off forfiles /p D:\logstash-1.4.2\bin\ /m *.log -d -7 /C "cmd /c del /f @pa ...
- windows bat脚本实现ftp自动下载 删除
现在有一个需求就是把远程某个文件下面的图片,下载到本地,并且删除下载成功的的文件,而且远程目录下的那个图片会随时增加.假设一下如果所有的脚本都写好了,那么就需要调用windows上的计划任务定时执行脚 ...
- java 调用windows bat脚本
当我们需要在java程序中调用外部程序,我们可用通过Runtime.exec()调用来完成. The class java.lang.Runtime features a static method ...
随机推荐
- IDEA在引入Maven项目后Dependencies中在出现红色波浪线
解决方法: 移除pom.xml中相关依赖,再重新添加即可. 情况及具体解决方法如下: 1.在Maven Project中 Dependencies 出现红色波浪线,如图所示 2.查询本地仓库:jar包 ...
- 最新 映客java校招面经 (含整理过的面试题大全)
从6月到10月,经过4个月努力和坚持,自己有幸拿到了网易雷火.京东.去哪儿.映客等10家互联网公司的校招Offer,因为某些自身原因最终选择了映客.6.7月主要是做系统复习.项目复盘.LeetCode ...
- Django边角料
模型层表名自定义: class Record(models.Model): content=models.CharField(max_length=32,db_column='record_conte ...
- 《C专家编程》读书笔记之第1~4章
一.C:穿越时空的迷雾 1. C标准中定义了描述编译器的特点的一些术语: (1) 由编译器定义的(imprementation-defined) 由编译器设计者决定如何处理.例如:整型数右移时要不要扩 ...
- [转帖]Asp.net MVC 与 Asp.net Web API 区别
Asp.net MVC 与 Asp.net Web API 区别 https://www.cnblogs.com/viktor988/ https://www.cnblogs.com/terry283 ...
- #【Python】【demo实验34】【练习实例】【设置文本的颜色】
原题: 文本颜色设置. 我的代码 #!/usr/bin/python # encoding=utf-8 # -*- coding: UTF-8 -*- # 文本颜色设置. class bcolors: ...
- 注解@PostConstruct与@PreDestroy详解及实例
Java EE5 引入了@PostConstruct和@PreDestroy这两个作用于Servlet生命周期的注解,实现Bean初始化之前和销毁之前的自定义操作.此文主要说明@PostConstru ...
- RocketMQ源码学习--消息存储篇
转载. https://blog.csdn.net/mr253727942/article/details/55805876 1.序言 今天来和大家探讨一下RocketMQ在消息存储方面所作出的努力, ...
- COGS 2633. [HZOI 2016] 数列操作e
[题目描述] 一个长度为n的序列,一开始序列数的权值都是0,有m次操作 支持两种操作, 1 L R x,给区间[L,R]内,第一个数加x,第二个数加2^2⋅x,第三个数加3^2⋅x...第R-L+1个 ...
- 实现文件上下文管理(__enter__和___exit__)
实现文件上下文管理(__enter__和__exit__) 我们知道在操作文件对象的时候可以这么写 with open('a.txt') as f: '代码块' 上述叫做上下文管理协议,即with语句 ...