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 ...
随机推荐
- L1、L2正则化详解
正则化是一种回归的形式,它将系数估计(coefficient estimate)朝零的方向进行约束.调整或缩小.也就是说,正则化可以在学习过程中降低模型复杂度和不稳定程度,从而避免过拟合的危险. 一. ...
- mongodb中对数组的操作命令
mongodb中对数组的操作命令有$push.$ne.$addtoset.$pop.$pull ###addtoset会碰到的问题addtoset解释: 往数组里面加入数据,如果数组里已经存在,则不会 ...
- C#使用MPI进行高性能计算
MPI.NET是用于Microsoft.NET环境的高性能.易于使用的消息传递接口(MPI)实现.mpi是编写在分布式内存系统(如计算集群)上运行的并行程序的事实上的标准,并且得到了广泛的实现.大多数 ...
- 【ARM-Linux开发】Linux下查看机器的CPU负载
负载(load)是Linux机器的一个重要指标,直观了反应了机器当前的状态.如果机器负载过高,那么对机器的操作将难以进行. Linux的负载高,主要是由于CPU使用.内存使用.IO消耗三部分构成.任意 ...
- JS之ajax实现注册页,小文件传输
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- Reactor系列(五)map映射
#java# #reactor# #flux# #map# #映射# 视频解视: https://www.bilibili.com/video/av79179444/ FluxMonoTestCase ...
- Mybatis插件之Mybatis-Plus的CRUD方法
使用Mybatis-plus进行基本的CRUD(增查改删)操作. 实体类(User)代码: import com.baomidou.mybatisplus.annotation.IdType; imp ...
- [转帖]linux之sed用法
linux之sed用法 https://www.cnblogs.com/dong008259/archive/2011/12/07/2279897.html docker images | awk ' ...
- Ural 1201 Which Day Is It? 题解
目录 Ural 1201 Which Day Is It? 题解 题意 输入 输出 题解 程序 Ural 1201 Which Day Is It? 题解 题意 打印一个月历. 输入 输入日\((1\ ...
- Colossal Fibonacci Numbers! UVA - 11582(快速幂,求解)
Problem Description The i’th Fibonacci number f(i) is recursively defined in the following way: •f(0 ...