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

[经验分享] Windows自动化运维——ansible控制Windows安装过程

[复制链接]

尚未签到

发表于 2018-6-10 15:59:15 | 显示全部楼层 |阅读模式
  目录
一、必须安装在ansible的Linux管控主机上安装控制Windows的组件
  1.安装pywinrm,kerberos
二、配置Windows主机
  1.安装安装Framework 4.5(最低3.0)
  2.修改注册列表:设置powershell本地脚本运行权限为remotesigned
  2.升级到powershell-3.0
  3.配置winrm
三、功能测试  

  下面开始...
  

  一、配置ansible管控机器
  使用Python的pip安装pywinrm及kerberos
$ sudo pip install http://github.com/diyan/pywinrm/archive/master.zip#egg=pywinrm
$ sudo pip install kerberos  在安装kerberos之前需要安装
$ sudo apt-get install libkrb5-dev  否则报错为
$ sudo pip install kerberos
running build_ext
building 'kerberos' extension
creating build
creating build/temp.linux-x86_64-2.7
creating build/temp.linux-x86_64-2.7/src
gcc -pthread -fno-strict-aliasing -DNDEBUG -g -fwrapv -O2 -Wall -Wstrict-prototypes -fPIC -I/usr/include/python2.7 -c src/base64.c -o build/temp.linux-x86_64-2.7/src/base64.o sh: 1: krb5-config: not found
gcc: error: sh:: No such file or directory
gcc: error: 1:: No such file or directory
gcc: error: krb5-config:: No such file or directory
gcc: error: not: No such file or directory
gcc: error: found: No such file or directory
error: command 'gcc' failed with exit status 1
----------------------------------------
Command /usr/bin/python -c "import setuptools;__file__='/etc/ansible/scripts/build/kerberos/setup.py';exec(compile(open(__file__).read().replace('\r\n', '\n'), __file__, 'exec'))" install --single-version-externally-managed --record /tmp/pip-Q3eBF1-record/install-record.txt failed with error code 1
Storing complete log in /home/ansible/.pip/pip.log  

  二、配置windows主机
  查看系统中.Net版本及powershell版本
  .Net版本为CLRVersion;powershell使用$host中Version
PS C:\Users\ABC> $psversiontable
Name                           Value
----                           -----
CLRVersion                       2.0.50727.5485
BuildVersion                      6.1.7601.17514
PSVersion                        2.0
WSManStackVersion                    2.0
PSCompatibleVersions                  1.0, 2.0}
SerializationVersion                  1.1.0.1
PSRemotingProtocolVersion                2.1
PS C:\Users\ABC> $host

Name               : ConsoleHost
Version              : 2.0
InstanceId            : 586e26ae-8630-4add-aa4c-d864726f5384
UI                : System.Management.Automation.Internal.Host.InternalHostUserInterface
CurrentCulture          : zh-CN
CurrentUICulture         : zh-CN
PrivateData            : Microsoft.PowerShell.ConsoleHost+ConsoleColorProxy
IsRunspacePushed         : False
Runspace             : System.Management.Automation.Runspaces.LocalRunspace  1.安装安装Framework 4.5(最低3.0)
  http://download.microsoft.com/download/B/A/4/BA4A7E71-2906-4B2D-A0E1-80CF16844F5F/dotNetFx45_Full_x86_x64.exe
  

  2.修改注册列表:设置powershell本地脚本运行权限为remotesigned

  HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\PowerShell\1\ShellIds\Microsoft\PowerShell
DSC0000.png

  

  2.升级到powershell-3.0及winrm
  

  官网上说下载并执行下述脚本,但是一直不成功,原因是一直下载不下来安装包(可能的情况是网络不可达,大家懂得)
  https://github.com/cchurch/ansible/blob/devel/examples/scripts/upgrade_to_ps3.ps1
  

  于是手动找通过微软官网找到下载地址win7_x64升级包如下
  https://www.microsoft.com/en-us/download/confirmation.aspx?id=34595
  下载powershell-3.0的更新补丁,此补丁同时集成WMF3.0,winrm等
  地址:
  https://download.microsoft.com/download/E/7/6/E76850B8-DA6E-4FF5-8CCE-A24FC513FD16/Windows6.1-KB2506143-x64.msu
  (注意:这个更新包依赖于.net3.0以上版本,如果未安装.net,会有提示“此更新不适应于您的计算机”)

  

  安装完成之后需要重启,重启后检验powershell版本
> get-host
DSC0001.png

  

  3.配置winrm
  3.1 下载下面脚本,使用powershell运行,自动配置好winrm
  
  https://github.com/ansible/ansible/blob/devel/examples/scripts/ConfigureRemotingForAnsible.ps1
  (注意:官网教程直到上面结束,但是一般执行完之后检验winrm是否已经运行,因为ansible管控机需要通过端口进行访问winrm)
  

  3.2 在计算机上运行winrm服务
  powershell 3.0中执行
> winrm qc
DSC0002.png

  这个提示,请将网络设置将工作网络 改成 家庭网络 就可以了,特殊情况可能需要重启,
DSC0003.png

  配置好网络类型重新启动服务,结果如下:
DSC0004.png

  开启后,需要查看配置是否已经开启
  

  3.3  主要是下图Auth中Basic设置为true,service中AllowUnencrypted设置为true
> winrm set winrm/config/service '@{AllowUnencrypted="true"}'
> winrm set winrm/config/service/auth '@{Basic="true"}'
DSC0005.png

  

  三、功能测试
  配置ansible控制机
  配置方法有两种:
  第一种:
  在/etc/ansible/hosts
[windows]
192.168.1.11
[windows:vars]
ansible_ssh_user="Administrator"
ansible_ssh_pass="123456"
ansible_ssh_port=5986
ansible_connection="winrm"$ ansible windows -m win_ping
192.168.1.11 | SUCCESS => {
    "changed": false,
    "ping": "pong"
}  

  第二种
  在/etc/ansible/hosts中
[windows]
192.168.1.11 ansible_ssh_user="Administrator" ansible_ssh_pass="123456" ansible_ssh_port=5986 ansible_connection="winrm"  

  要注意的是 端口方面ssl即https方式的使用5986,http使用5985。
  

区别于控制Linux主机,win主机的命令,需要加上win_,具体支持情况请见官网
http://docs.ansible.com/ansible/list_of_windows_modules.html


我这里做部分常用测试

  • 传文件
  • 删文件
  • 创建用户(创建用户,更改密码,创建可以进行远程桌面登录的用户)
  • 执行cmd命令(重启电脑)


  1. 传文件到windows系统
$ ansible windows -m win_copy -a "src=/etc/passwd dest=e:\share"
192.168.1.11 | SUCCESS => {
    "changed": true,
    "checksum": "a82c2bd7de3d9a5c5adddd5e4fc7cbf1703720b7",
    "operation": "file_copy",
    "original_basename": "passwd",
    "size": 1755
}
DSC0006.png

  2. 删除文件
$ ansible windows -m win_file -a "dest=e:\share\passwd state=absent"
192.168.1.11 | SUCCESS => {
    "changed": true
}
DSC0007.png

  3.创建用户
$ ansible windows -m win_user -a "name=aa passwd=123456"
192.168.1.11 | SUCCESS => {
    "account_disabled": false,
    "account_locked": false,
    "changed": true,
    "description": "",
    "fullname": "aa",
    "groups": [],
    "name": "aa",
    "password_expired": true,
    "password_never_expires": false,
    "path": "WinNT://WORKGROUP/ABC-PC/aa",
    "sid": "S-1-5-21-37586581-19248684-93829760-1006",
    "state": "present",
    "user_cannot_change_password": false
}  场景需求:
  创建一个名叫user1的管理员用户,要求能够远程访问
$ ansible windows -m win_user -a "name=user1 password=123 groups='Administrators,Remote Desktop Users'"
192.168.1.11 | SUCCESS => {
    "account_disabled": false,
    "account_locked": false,
    "changed": true,
    "description": "",
    "fullname": "user1",
    "groups": [
        {
            "name": "Administrators",
            "path": "WinNT://WORKGROUP/ABC-PC/Administrators"
        },
        {
            "name": "Remote Desktop Users",
            "path": "WinNT://WORKGROUP/ABC-PC/Remote Desktop Users"
        }
    ],
    "name": "user1",
    "password_expired": false,
    "password_never_expires": false,
    "path": "WinNT://WORKGROUP/ABC-PC/user1",
    "sid": "S-1-5-21-375864581-19248684-93852960-1009",
    "state": "present",
    "user_cannot_change_password": false
}  

  4. 执行cmd命令
  重启的第一种方式
$ ansible windows -m win_shell -a "shutdown -r -t 1"  第二种方式,不加参数等同于第一种方式
$ ansible windows -m win_reboot  

  未完待续,持续更新......

运维网声明 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.iyunv.com/thread-521897-1-1.html 上篇帖子: windows下安装emacs 下篇帖子: Windows下常用的100个CMD指令以及常见的操作
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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

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

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

扫描微信二维码查看详情

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


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


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


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



合作伙伴: 青云cloud

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