Powershell管理系列(十八)PowerShell操作之定时删除过时文件

简介:

开篇前,先说点新年感悟,2010开博5年来,前面两年没怎么动手写博客,真正开始写博客的时间是2013年,那时候Exchange server 2013刚出来不久,全新的软件,全新的界面,全新的体验,当然也带来全新的挑战,那就是我们这些追随微软脚步的工程师又得一次跟上巨人的脚步了,从Exchange server 2003,到后面的2007,2010,在到最新的2013,IT人比较痛苦的就是这点,永远都在不断地学习,不断地补充自己。忙而充实,当然今天的努力也是为了明天更大的成功,希望和大家一起共勉,共进。

当时看到网上有不少零零散散的Exchange server 2013部署和架构的文档,感觉比较林乱,不太系统化,东拼西凑的,于是冒出来个想法,我要把Exchange server 2013整个的部署和架构做成一个系列,给有需要的人学习,当时,好记性不如烂笔头,写下来以后自己用的时候也是可以借鉴的,写博客的一个原则就是求实,求真,于是自己搭建了一套基本和真实生产环境一样的场景,功能都基本一样,基本都是借鉴technet上,及一些外文的权威文章上的内容而写成的。博客发表后,慢慢的也有不少网友找我咨询相关的问题,也有在群里看到就说Exchange操作是看着我的博客慢慢学会的,这个我感到非常欣慰,知识就是用来交流和传播的,我也真心希望写出来的博客能被更多的人看到,学习到,当然也非常想听到读者的心声和回复,而不是只点赞。

2014年末,我又动起了写Powershell专题系列博客的念头,因为众所周知,powershell在新出的所有的微软主流产品中都得到了很大的应用,管理都基本可以通过Powershell来实现,于是开始着手写powershell的一个管理系列,记录自己管理过程的一些点点滴滴。废话讲了这么多,下面开始正式讲Powershell操作之定时删除过时文件。


1.解除系统对PowerShell脚本执行的禁止


由于默认系统中PowerShell脚本没有足够的权限运行,因此我们需要手动修改并赋予其执行权限,步骤如下:控制面板 - 管理工具 - Windows PowerShell Modules

PS C:\Users\administrator.CONTOSO> Get-ExecutionPolicy

RemoteSigned

PS C:\Users\administrator.CONTOSO> Set-ExecutionPolicy remotesigned

执行策略更改

执行策略可以防止您执行不信任的脚本。更改执行策略可能会使您面临 about_Execution_Policies帮助主题中所述的安全风险。是否要更改执行策略?

[Y] 是(Y)  [N] 否(N)  [S] 挂起(S)  [?] 帮助 (默认值为“Y”):

PS C:\Users\administrator.CONTOSO>

至此,便解除了系统对PowerShell脚本执行的禁止。

2.编写PowerShell脚本,打开powershell ise脚本编辑工具,windows server 2008R2系统请到服务器管理器---功能里面添加需要的功能"windows powershell 集成脚本环境(ISE)"。

新建一个文本文件,命名为 "删除过期文件.ps1"内容如下:

echo "以下过期文件将被删除:" 

$all = Get-ChildItem "C:\files backup"

#替换这里的 "C:\files backup" 为你的备份文件实际存放目录, 如需查找所有目录内子文件夹内的内容,需要修改成

#$all = Get-ChildItem "C:\files backup" -Recurse

foreach ($delete in $all)

{

$deldate = ((Get-Date) - $delete.LastWriteTime).Days

if ($deldate -gt 180 -and $delete.PsISContainer -ne $True)

#替换这里的180天为你需要保留的实际天数,及排除包含的文件夹

{

$delete.Delete() #删除过期文件

echo $delete     #显示删除文件

}

}

wKioL1TYFJiCbVU5AALQubnfl1U190.jpg

3.使用Windows计划任务来定期执行脚本[具体设置方法参考博客:用 PowerShell收集服务器日检报告,并发邮件给管理员,http://yuntcloud.blog.51cto.com/1173839/1605561]

控制面板-管理工具-任务计划程序-创建任务

配置如下:

常规:输入 名称,描述 - 勾选“不管用户是否登录都要运行” -输入密码 - 勾选“使用最高权限运行”

触发器:新建 - 选择“制定计划时” - 选择 执行时间如“7:30:00” - 选择执行周期如“每天 每隔1天发生一次” - 勾选"启用",也可以根据需要选择每小时,每半小时或者更高的频率运行脚本。

操作:新建 - 选择“启动程序” - "powershell -file "C:\删除过期文件.ps1" - 点击“确定”

wKioL1TYFYuy7R5wAAEaL1fv1aw407.jpg

至此,计划任务就配置完成了,如果想要测试计划任务是否能正常执行,直接手动立即运行一次即可。



本文转自 zhou_ping 51CTO博客,原文链接:http://blog.51cto.com/yuntcloud/1612891,如需转载请自行联系原作者

相关文章
|
网络协议 网络安全
Powershell免杀(无文件落地免杀)
无文件落地 顾名思义,无需将恶意文件传到目标服务器/机器上,直接利用powershell的特性加载到内存执行。为了在红队行动中更隐蔽的实施攻击以及横向移动,同时还可以解决目标不出网只能通过dns上线时的棘手问题,利用powershell可以避免一行行echo。 通过两种方式进行无文件落地的免杀,一种是出网的情况,另一种为不出网情况。 声明: 文章内容仅供网络安全爱好者学习使用,请勿用文章中提到的技术或工具做违法的事情,否则后果自负。
1181 0
|
5月前
|
存储 JSON JavaScript
|
5月前
PowerShell快速修改多个文件的名称
【8月更文挑战第28天】在PowerShell中批量重命名文件可通过以下方法实现:1)使用`Rename-Item`命令逐一重命名;2)通过循环批量处理特定模式的文件名更改;3)利用正则表达式进行复杂模式匹配与替换。操作前请确保验证命令并备份文件。
339 1
|
8月前
|
定位技术 Python
PowerShell批量修改、替换大量文件的文件名
PowerShell批量修改、替换大量文件的文件名
190 1
|
8月前
|
前端开发 微服务 Windows
PowerShell 命令窗口执行 pnpm 命令报错 无法加载文件 pnpm.ps1,因为在此系统上禁止运行脚本
PowerShell 命令窗口执行 pnpm 命令报错 无法加载文件 pnpm.ps1,因为在此系统上禁止运行脚本
|
Windows
powershell配置anaconda及解决【无法加载文件C:\Users\xxx\Documents\WindowsPowerShell\profile.ps1,因为在此系统上禁止运行脚本】的问题
powershell配置anaconda及解决【无法加载文件C:\Users\xxx\Documents\WindowsPowerShell\profile.ps1,因为在此系统上禁止运行脚本】的问题
2667 0
|
安全 Linux 网络安全
新一代--Powershell 无文件挖矿病毒
Powershell 无文件挖矿病毒
|
存储 运维 Linux
【运维】PowerShell编程 目录文件相关方法的封装与案例详解
本文实现一个目录管理类,归纳了 Powershell 中常用的文件路径方法。这些方法可以迅速方便的用于 Powershell 编写大型运维脚本中。以简单使用为目的封装常用目录文件操作。完成源代码在作者的github上可以找到。
204 0
|
弹性计算 关系型数据库 数据库
使用ROS部署ECS+SqlServer资源并通过PowerShell操作数据库
本文介绍如何通过ROS部署ECS+RDS+SqlServer资源,以及如何通过PowerShell操作SqlServer数据库。 注意:附录模板和截图中的commandtext部分仅为演示作用,请根据需求修改后使用。
使用ROS部署ECS+SqlServer资源并通过PowerShell操作数据库
|
Web App开发 前端开发 JavaScript
vbs学习,书籍,看书笔记(5) 客户端web脚本 .Power shell 使用 脚本文件的类型2
vbs学习,书籍,看书笔记(5) 客户端web脚本 .Power shell 使用 脚本文件的类型2
vbs学习,书籍,看书笔记(5) 客户端web脚本 .Power shell 使用 脚本文件的类型2