从SCCM中创建并运行Powershell脚本卸载软件
最近碰到一个需求:针对所有电脑卸载某个小软件,但这个软件并不是SCCM部署,有的是用户自己安装的,有的是系统部署时就已经封装好的,版本繁多,安装路径也不一样!
首先想到的当然是用Powershell来做,先后测试了用Get-apppacke\get-appxpacke, Get-WmiObject -Class win32_product等几种方法都不行,最后用找注册表中的UninstallString的方式解决!
方法如下:
1、 先用PowerShell定位到注册表位置,
X86 Script:
Set-Location HKLM:\software\microsoft\Windows\Currentversion\uninstall
X64 Script:
Set-Location HKLM:\software\WOW6432Node\microsoft\Windows\Currentversion\uninstall
2、 查询到软件安装后在注册表Uninstall中的名称,如:Chrome,在Uninstall中的Childitem名为:Google Chrome,其中Uninstallstring有卸载的运行文件具体路径、此文件名及参数:
"C:\Program Files (x86)\Google\Chrome\Application\74.0.3729.131\Installer\setup.exe" --uninstall --system-level --verbose-logging
这就是我们要运行的卸载命令,有些软件只有执行文件,并不带参数,如Teamviewer 只有一个Uninstall.exe,我们可以使用Uninstall.exe /S进行静默卸载!
3、 完整的PS脚本如下:
Set-Location
HKLM:\software\WOW6432Node\microsoft\Windows\Currentversion\uninstall
#指定注册表的位置
$UninstallTeamviewer = get-childitem -path *Teamviewer* | get-itemproperty | %{$_.Uninstallstring}
#查找卸载命令并赋值给变量:$UninstallTeamviewer
start $UninstallTeamviewer /S
#Powershell中运行卸载命令:$UninstallTeamviewer
针对注册表中已有卸载程序和参数的,上面不用再加参数数:“/S”
4、 创建脚本:在SoftWare Library\Overview\Scripts中右键、Create Script:
5、 将PowerShell脚本贴到脚本,下一步,完成!
TeamViewer
$OS = (Get-WmiObject Win32_OperatingSystem).OSArchitecture
#检查操作系统版本
if ((gwmi win32_operatingsystem | select osarchitecture).osarchitecture -eq "32-bit"){
#32 Bit 运行以下步骤
Set-Location HKLM:\software\microsoft\Windows\Currentversion\uninstall
#指定以下注册表位置
$UninstallTeamviewer = get-childitem -path *Teamviewer* | get-itemproperty | %{$_.Uninstallstring}
#查找卸载命令并赋值给变量:$UninstallTeamviewer
start $UninstallTeamviewer /S
#Powershell中运行卸载命令:$UninstallTeamviewer
$UninstallTeamviewer
#输出变量结果,方便查询分析
}
else{
#64 Bit 运行以下步骤
Set-Location HKLM:\software\WOW6432Node\microsoft\Windows\Currentversion\uninstall
#指定以下注册表位置
$UninstallTeamviewer = get-childitem -path *Teamviewer* | get-itemproperty | %{$_.Uninstallstring}
#查找卸载命令并赋值给变量:$UninstallTeamviewer
start $UninstallTeamviewer /S
#Powershell中运行卸载命令:$UninstallTeamviewer
$UninstallTeamViewer
#输出变量结果,方便查询分析
}
6、 核准脚本:在刚创建的脚本上点右键、批准
在生产环境中,为了安全,用户创建的脚本需要第二人来批准(即自己不能批准自己创建的脚本),如果想自己批准自己的创建的脚本,请在进到:Administration\Site Configuration\Sites\Hierarchy Settings,
将“Script authors require additional script approver前面的勾取消。
7、 运行脚本:在需要运行的电脑或集全中点右键,选择:Run Script\Next,即开始运行。
8、 在Monitoring中也可以查看已运行的脚本汇总结果 ,在“脚本状态”列表中,可以查看在客户端设备上运行的每个脚本的结果。 脚本退出代码为“0”通常表示脚本已成功运行。
9、 也可以晚点再去软件报告里进行查询!
10、 如果针对某个软件是使用MIS封装包安装的,Uninstall值会是“MsiExec.exe /I {23170F69-40C1-2701-1602-000001000000}“,就要改另一种PowerShell方式,例:
if ((gwmi win32_operatingsystem | select osarchitecture).osarchitecture -eq "32-bit"){
#32 Bit 7zip X32 1602 {23170F69-40C1-2701-1602-000001000000}
$script = { invoke-expression "msiexec /qn /x '{23170F69-40C1-2701-1602-000001000000}' "}
Invoke-Command -ScriptBlock $script
$script
}else{
#64 Bit 7zip X64 1602 {23170F69-40C1-2702-1602-000001000000}
$script = { invoke-expression "msiexec /qn /x '{23170F69-40C1-2702-1602-000001000000}' "}
Invoke-Command -ScriptBlock $script
$script
}
当然,如果没有SCCM环境,也可以尝试用在AD中调用上面的脚本!
低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。
持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。
- 上一篇
利用Helm部署高可用rancher集群
一、背景 Rancher HA有多种部署方式: Helm HA安装,将Rancher部署在已有的Kubernetes集群中,Rancher将使用集群的etcd存储数据,并利用Kubernetes调度实现高可用性。 RKE HA安装,使用RKE工具安装独立的Kubernetes集群,专门用于Rancher HA部署运行,RKE HA安装仅支持Rancher v2.0.8以及之前的版本,Rancher v2.0.8之后的版本使用helm安装Rancher。本方案将基于已有的Kubernetes集群,利用Helm安装Rancher HA,并采用四层负载均衡方式。 二、添加Chart仓库地址 使用helm repo add命令添加Rancher chart仓库地址Rancher tag和Chart版本选择参考:https://www.cnrancher.com/docs/rancher/v2.x/cn/installation/server-tags/ #替换<CHART_REPO>为您要使用的Helm仓库分支(即latest或stable)。 helm repo add ranc...
- 下一篇
ReentrantReadWriteLock(可以重入的读写锁)源码浅析
一、ReentrantReadWriteLock简介 上一篇文章我们将讲到的ReentrantLock和Synchronized锁,都属于排他锁,也就是说只会有一个线程获取锁;而我们今天讲的ReentrantReadWriteLock(读写锁)是支持多个线程同时获取锁的在获取读锁时;但是在获取到写锁时,其它的写锁和读锁都会阻塞;其实可以看出读写锁,维护了一对锁,一个写锁,其实是个排他锁,一个读锁,是共享锁;通过分离读锁和写锁,使得并发性相比一般的排他锁有很大的提升;读写锁的性能比排他锁好,因为在大多数场景中读是多于写的;读写锁提供了,公平性的选择、重新进入(该锁支持重进入,以读写锁线程为例:读线程在获取读锁之后,能够再次获取读锁。而写线程在获取了写锁之后能够再次获取写锁,同时也可以获取读锁)和锁降级(遵循获取写锁、获取读锁在释放写锁的次序,写锁能够降级成为读锁)等特性。 二、ReentrantReadWriteLock基本成员我们先来看一张ReentrantReadWriteLock类图Sync是一个内部类,继承AQS,主要实现AQS的一些方法。基本成员简介 static final ...
相关文章
文章评论
共有0条评论来说两句吧...
文章二维码
点击排行
推荐阅读
最新文章
- CentOS关闭SELinux安全模块
- SpringBoot2编写第一个Controller,响应你的http请求并返回结果
- Mario游戏-低调大师作品
- CentOS6,CentOS7官方镜像安装Oracle11G
- SpringBoot2配置默认Tomcat设置,开启更多高级功能
- Windows10,CentOS7,CentOS8安装Nodejs环境
- Docker安装Oracle12C,快速搭建Oracle学习环境
- Windows10,CentOS7,CentOS8安装MongoDB4.0.16
- CentOS8编译安装MySQL8.0.19
- MySQL8.0.19开启GTID主从同步CentOS8