设为首页 收藏本站
查看: 952|回复: 0

基于事件触发PowerShell重置文件权限

[复制链接]

尚未签到

发表于 2018-9-1 11:25:43 | 显示全部楼层 |阅读模式
问题
  最近,公司把文件服务器挪到了一个云端服务商Nasuni上面。这个平台的刚开始的使用反馈还可以,性能啊,自动备份等等都还不错,不过最近两周,出现了一个bug,当OSX用户创建新文件夹的时候,他会时不时地自动创建新的权限,从而导致用户无法访问该文件夹的内容。
  例如,一个新建的文件夹继承的权限自动被篡改,还被自动添加了Special的限制
DSC0000.jpg

  OSX系统和smb的兼容性估计是一个原因,这个平台自己的设计估计也是一个问题。但是无论罪魁祸首是哪个,都不是一个短期内能解决的问题,所以豆子必须给出一个临时解决的方案。

解决方案
  和同事讨论了一下,可以通过脚本来重置新建文件夹的权限。简而言之,这个需要实时监控整个文件系统(或者某个文件夹),一旦下面创建了新的文件夹或者文件,就对这个文件或者文件夹的权限进行重置。
  这个东西如何实现呢?我们可以考虑基于事件的PowerShell脚本。基于事件的脚本和传统的基于过程的不太一样,可以理解为传统的写法,我们需要告诉系统做事情,而基于事件的方式则是事件发生了,他会触发一个回调函数来执行某个行为。

  这个基于事件的方式主要涉及到3个概念Subscriptions(订阅), registrations(注册), 和 actions (行为)。我们可以通过订阅一个事件,当他发生的时候获得通知,这个事件需要在指定的source>  比如说,首先创建一个文件系统操作的对象
  $fw=New-Object IO.FileSystemwatcher
  注意观察这个对象他有的事件,方法和属性
DSC0001.jpg

  我们可以手动地指定我们打算观察的事件和属性
  比如
  $fw.Filter='*'
  或者一个更直接的方法是创建的时候就全部指定
  

$folder = 'c:\temp'  
$filter = '*.*'
  
$fsw = New-Object IO.FileSystemWatcher $folder, $filter -Property @{IncludeSubdirectories = $true;NotifyFilter = [IO.NotifyFilters]'DirectoryName,FileName, LastWrite'}
  

  上面出现的属性里面,比较重要的是下面几个:


  •   filter: 指定哪些类型的文件或者文件夹需要关注

  •   includesubdirectories: 是否递归地查询所有的子文件夹

  • notifyfilter: 指定哪些类型的属性需要关注,包括以下内容
DSC0002.jpg

  然后我们就可以注册这个事件,并指定对应的行为了
  

Register-ObjectEvent -inputObject  $fsw -EventName created -SourceIdentifier FileCreated -Action {  ...
  }
  

  当我们注册了一个事件之后,他会默认创建一个后台的job,当这个job捕获到第一个结果的时候,他就会执行对应的行为了

测试脚本
  下面是一个演示的脚本
  

# 指定目录  
$folder = 'c:\temp'
  
# 通配符,表示所有的item都需要关注.
  
$filter = '*.*'
  

  
#初始化对象,指定属性,路径等等
  
$fsw = New-Object IO.FileSystemWatcher $folder, $filter -Property @{IncludeSubdirectories = $true;NotifyFilter = [IO.NotifyFilters]'DirectoryName,FileName, LastWrite'}
  

  
# 取消已经存在的注册
  

  
Unregister-Event FileCreated
  

  
# 注册事件,绑定行为
  
Register-ObjectEvent -inputObject  $fsw -EventName created -SourceIdentifier FileCreated -Action {
  $Event | out-host
  $name = $Event.SourceEventArgs.Name
  $folderpath = $Event.SourceEventArgs.FullPath
  $changeType = $Event.SourceEventArgs.ChangeType
  $actionby = (get-item $folderpath).getaccesscontrol().Owner
  $timeStamp = $Event.TimeGenerated
  

  Write-Host "The file '$folderpath' was $changeType at $timeStamp by $actionby" -fore green
  Write-Host "Resetting Permission"
  icacls $folderpath.ToString() /reset /t
  Write-Host "Finish Resetting"
  Out-File -FilePath c:\Utils\filechange-outlog.txt -Append -InputObject "The file '$folderpath' was $changeType at $timeStamp by $actionby"
  

  
}
  

  执行一下可以看见他创建了一个后台的job,目前状态是未执行,一旦他捕获了第一个结果,状态就会变成running
DSC0003.jpg

  当我新建一个文件,他会检测到,然后自动执行对应的脚本操作,如下所示
DSC0004.jpg

  这个方法的缺点:
  后台job如果执行过久,有的时候会不起作用或者消耗过多内存?!这个时候可能就需要人为地干预重启一下程序了。



运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-561057-1-1.html 上篇帖子: Powershell-获取DHCP地址租用信息 下篇帖子: 使用Powershell改变Azure经典虚拟机Size
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表