Windows环境powershell 运维之历史文件压缩清理

一、Power Shell概述
1.1 Windows Power Shell简介
Windows PowerShell 是微软发布的一种命令行外壳程序和脚本环境,使命令行用户和脚本编写者可以利用 .NET Framework的强大功能。

引入了许多非常有用的新概念,从而进一步扩展了在 Windows 命令提示符和 Windows Script Host 环境中获得的知识和创建的脚本。

1.2 PowerShell是什么
PowerShell,从名字可以知道,他首先是一个shell,shell的意思就是和Linux的bash等一样、和原来的cmd一样就是在里边敲命令(可执行文件)使用;而Power就意味他是一个功能强大的shell,从面向用户而言,个人觉得其功能强大体现在以下几方面:

(1) 微软态度。微软是真正的在推行PowerShell,包括Office等更多自家软件,底层都是调用PowerShell来实现。

(2) 兼容性cmd。PowerShell包含原先cmd的所有命令,原先命令使用形式不变,在是在其基础上添加命令。

(3) 对标Linux。PowerShell使用了Linux Shell的思想,也就是所有的系统操作、配置,都可以在shell中敲写命令实现。

(4) 统一的命令格式和自包含的文档。PowerShell的两个优点:第一点是PowerShell所有命令使用统一的cmdlet命令格式(也就是“动词-名词”的格式,比如get-process)会使人很容易记住;第二点这里所谓自包含是指你要干一件事你可以逐步找到要做的事所需的所有命令,即便你记不得命令你也可以很容易找到,你找到命令看文档就很容易知道怎么使用。

1.3 windows执行策略更改
右击开始找到 powershell 管理员

Windows环境powershell 运维之历史文件压缩清理

进入powershell命令行执行如下命令: 一定要执行!

执行如下命令,回车选择Y( 复制后鼠标 右击可粘贴,也可将执行的命令放到临时文本中再复制到命令行执行)

Set-ExecutionPolicy -ExecutionPolicy Bypass -Scope CurrentUser

执行如下命令,回车选择Y

Set-ExecutionPolicy -ExecutionPolicy Bypass -Scope localMachine

执行下面的命令查看 CurrentUser,LocalMachine 是否已改为 Bypass

get-executionpolicy -list
Windows环境powershell 运维之历史文件压缩清理

修改后的执行策略检查

Windows环境powershell 运维之历史文件压缩清理

检查通过后,关闭powershell 即可。

二、PowerShell使用


2.1 文件复制


文件有一个目录拷贝到另一个目录

write-host "copy file data start ..."
# 当前日期
$fileDate=Get-Date -Format 'yyyy-MM-dd'
write-host $fileDate
 
# 从当天的目录下拷贝文件到目标路径
Copy-Item  D:\test\00000\$fileDate\*   D:\test\00000\bak

执行结果

Windows环境powershell 运维之历史文件压缩清理

PowerShell ISE 提供模块方法查询,可以对ps脚本进行编辑运行和测试

Windows环境powershell 运维之历史文件压缩清理

2.2 文件压缩清理

获取文件夹下7天之前的天文件夹目录进行打包压缩,并删除7天之前的文件夹。压缩使用7-zip。


######################################################
#    Desc: File Compress 1.0                         #
#    Author: kangll                                  #
#    soft: Use 7-zip                                 #
#    Date: 2023-12-13                                #
######################################################
 
 
############################ 全局变量 ###################
 
# 设置7-zip命令程序路径
$zip7="D:\test\7-Zip\7z.exe"
 
# 当天日期
$backup_date=get-date -format "yyyy-MM-dd"
 
# 获取一周前的日期
$weekAgo=(get-date).adddays(-7)| get-date -format "yyyy-MM-dd"
 
########################## bak file #######################
# 定位到待压缩的文件夹
$bak_file="D:\test\reid_traj"
 
# 保存的路径
$bak_save_dir="D:\test\reid_traj"
 
 
# 文件夹除当天外的日期文件夹都打包
Get-ChildItem $bak_file | ForEach-Object -Process{
   if ($_.CreationTime -lt $backup_date)
   {
	   # 使用7zip将轨迹文件夹目录下文件夹件压缩为zip格式 
	   $dateStr=$_.name
	   & $zip7 a -tzip $bak_save_dir\$dateStr.zip $bak_file\$dateStr
   }
}
 
 
# 列出一周前的文件夹删除,除当天外的所有日期均打包完成
Get-ChildItem $bak_file | ForEach-Object -Process{
   if ($_.CreationTime -lt $weekAgo)
   {
		# $_.Fullname ,获取文件夹全路径删除,D:\test\reid_traj\2023-05-11
        Remove-Item $_.Fullname  -Recurse
   }
}

执行完成 按照天路径打包

Windows环境powershell 运维之历史文件压缩清理

我们可以看下bat脚本,bat执行sqlServer存储过程。

:: 带"-"的日期
set today=%date:~0,4%-%date:~5,2%-%date:~8,2%
set today2=%date:~0,4%%date:~5,2%%date:~8,2%
 
:: 数据库连接信息
set execOSQL="osql" -S localhost\ipva   -U sa -P 123456 -d test -Q
 
:: 存储过程, windows环境执行存储过程将文件插入到表中
set "hhh=loadFile 'D:\test\reid_trace\%today%','%today2%'"
 
:: 存储过程执行
%loadFile.sql%
%execOSQL% "exec %hhh%"
if %errorlevel% == 0 (echo  -------------------- Procedure %hhh% executer successfully! --------------------) else (echo Procedure %hhh% executer failed!)

bat 和PS个人使用下来 感谢PS脚本更加强大和简单,BAT看起来就有点臃肿并复杂难懂。

文章来源:https://www.cnaaa.net,转载请注明出处:https://www.cnaaa.net/archives/10783

(0)
凯影的头像凯影
上一篇 2023年12月27日 下午4:32
下一篇 2023年12月29日 下午4:01

相关推荐

  • NtLmSsp攻击的解决办法

    问题描述 服务器无法连接或者服务器经常自动重启 问题排查 查看系统日志,在安全类目发现大量的登录审核失败的记录。 解决方法 进行NTLM策略控制,彻底阻止NTLM响应 修改以下2个设置: 网络安全:Lan管理器身份验证级别:仅发送 NTLMv2 响应/拒绝 LM 和 NTLM 网络安全:限制NTLM:传入NTLM流量 修改成拒绝所有账户

    2022年9月3日
    3.3K00
  • Linux 实用工具 Screen —— 再也不怕因为网络连接中断杀死任务了!

    不知道小伙伴们是否遇到过这样的场景: 有时候,我们本地通过 SSH 连接到远程服务器并不是很稳定,经常会断开连接。如果此时我们正在做类似更新系统、DD 系统、远程传输 / 下载文件等需要一定时间的操作,就会非常难受,好不容易传了半天的文件,中断了,又得重新来传一次,还得祈祷这次别传一半断开了。 今天我们介绍的这个工具 ——screen,就是为了来解决上面这些…

    2023年11月9日
    96200
  • Ceph集群日常使用命令

    一、Ceph 集群服务维护 之前文章说了一下ceph的安装,安装其实比较简单,但是后续维护起来我们需要知道常用的维护命令 如果我们机器上osd、mon、rgw等服务都安装在一个节点,可以通过下面的命令直接管理所有服务 ceph target allowing to start/stop all ceph*@.service instances at once…

    2023年4月19日
    1.1K00
  • Windows下编译部署PHP

    1. 下载并解压PHP 下载地址:PHP:Download,找到Windows系统的安装包 2. 修改php配置文件 复制php.ini-development,改名为php.ini 修改扩展文件的路径,并取消注释 extension_dir=”php解压地址/ext” 修改需要加载的扩展文件,即将相应dll语句前的分号”;”删除 修改时区 搜索date.t…

    2022年6月8日
    1.6K00
  • 演唱会门票抢不到?不要慌,教你用python实现自动化抢票

    前言之前一直在更新从零开始学python系列的系列文,最近有点忙停更了两天,今天来插一篇其他的文章。 之前有小伙伴留言说女朋友快生日了,喜欢某某某但是手动买票根本就是买不到,又不想当大冤种从黄牛手里加钱,于是乎在疯狂星期四的晚上遭到’‘贿赂’’的我连夜搞定了 一丶安装环境和配置文件要用python实现,下载和安装python自然是不用说了,还有p…

    2024年2月21日
    2.2K00

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

在线咨询: QQ交谈

邮件:712342017@qq.com

工作时间:周一至周五,8:30-17:30,节假日休息

关注微信