ansible控制windows安装及运行error与解决方法
Q1:因pip版本问题无法安装kerberos
$ sudo pip install kerberosrunning build_extbuilding 'kerberos' extensioncreating buildcreating build/t....................can`t upgrade pip to the newest version 9.0.1
A1:安装提示需要先安装pip升级包
下载pip9.0.1升级包:
$ wget https://pypi.python.org/packages/b6/ac/7015eb97dc749283ffdec1c3a88ddb8ae03b8fad0f0e611408f196358da3/pip-9.0.1-py2.py3-none-any.whl$ pip install pip-9.0.1-py2.py3-none-any.whl
Q2:安装kerberos报错
$ sudo pip install kerberosrunning build_extbuilding 'kerberos' extensioncreating buildcreating build/temp.linux-x86_64-2.7creating build/temp.linux-x86_64-2.7/srcgcc -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 foundgcc: error: sh:: No such file or directorygcc: error: 1:: No such file or directorygcc: error: krb5-config:: No such file or directorygcc: error: not: No such file or directorygcc: error: found: No such file or directoryerror: 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 1Storing complete log in /home/ansible/.pip/pip.log
A2:需要先安装libkrb5开发包
$ sudo apt-get install libkrb5-dev
安装后解决
Q3:安装.Net 3.0以上,升级powershell-3.0后ansible依旧报错
$ ansible windows -m win_ping -vvvUsing /etc/ansible/ansible.cfg as config fileUsing module file /usr/local/lib/python2.7/dist-packages/ansible-2.2.0-py2.7.egg/ansible/modules/core/windows/win_ping.ps1<192.168.1.11> ESTABLISH WINRM CONNECTION FOR USER: Administrator on PORT 5986 TO 192.168.1.11192.168.1.11 | UNREACHABLE! => { "changed": false, "msg": "ssl: HTTPSConnectionPool(host='192.168.1.11', port=5986): Max retries exceeded with url: /wsman (Caused by ConnectTimeoutError(, 'Connection to 192.168.1.11 timed out. (connect timeout=30)'))", "unreachable": true}
A3:原因没有配置winrm
必须将winrm的配置文件设置成下面配置,
> winrm set winrm/config/service
'@{AllowUnencrypted="true"}'
> winrm set winrm/config/service/auth
'@{Basic="true"}'
Q4:ansible控制Windows主机error1
$ ansible windows -m win_ping -vvvUsing /etc/ansible/ansible.cfg as config fileUsing module file /usr/local/lib/python2.7/dist-packages/ansible-2.2.0-py2.7.egg/ansible/modules/core/windows/win_ping.ps1<192.168.30.150> ESTABLISH WINRM CONNECTION FOR USER: Administrator on PORT 5986 TO 192.168.30.150192.168.30.150 | UNREACHABLE! => { "changed": false, "msg": "ssl: [Errno 1] _ssl.c:504: error:14090086:SSL routines:SSL3_GET_SERVER_CERTIFICATE:certificate verify failed", "unreachable": true}
A4:
将配置文件/etc/ansible/hosts端口5986改成5985,即可解决。
[windows:vars]ansible_ssh_port=5985
原因:
DefaultPorts
HTTP = 5985
HTTPS = 5986
上述错误是因为ssl选项是关着的
Q5:Win_7_x64 安装Windows6.1-KB2506143-x64.msu 提示"此更新不适应于您的计算机"
A5:安装.Net Framework 4.0(3.0以上)即可解决
Q6:执行ansible命令出现OutOfMemory错误
可以执行win_ping,但是传文件会报错:
ansible windows -m win_copy -a 'src=/opt/test/123.txt dest=F:\logs'
192.168.1.173 | UNREACHABLE! => {
"changed": false,
"msg": "Authentication or permission failure. In some cases, you may have been able to authenticate and did not have permissions on the remote directory. Consider changing the remote temp path in ansible.cfg to a path rooted in \"/tmp\". Failed command was: PowerShell -NoProfile -NonInteractive -ExecutionPolicy Unrestricted -EncodedCommand UwBlAHQALQBTAHQAcgBpAGMAdABNAG8AZABlACAALQBWAGUAcgBzAGkAbwBuACAATABhAHQAZQBzAHQACgAoAE4AZQB3AC0ASQB0AGUAbQAgAC0AVAB5AHAAZQAgAEQAaQByAGUAYwB0AG8AcgB5ACAALQBQAGEAdABoACAAJABlAG4AdgA6AHQAZQBtAHAAIAAtAE4AYQBtAGUAIAAiAGEAbgBzAGkAYgBsAGUALQB0AG0AcAAtADEANQAwADUANwA4ADcANgA3ADMALgAwADIALQA2ADEAMwAzADcAMgA2ADgAMwAyADAANQA4ADcAIgApAC4ARgB1AGwAbABOAGEAbQBlACAAfAAgAFcAcgBpAHQAZQAtAEgAbwBzAHQAIAAtAFMAZQBwAGEAcgBhAHQAbwByACAAJwAnADsACgBJAGYAIAAoAC0AbgBvAHQAIAAkAD8AKQAgAHsAIABJAGYAIAAoAEcAZQB0AC0AVgBhAHIAaQBhAGIAbABlACAATABBAFMAVABFAFgASQBUAEMATwBEAEUAIAAtAEUAcgByAG8AcgBBAGMAdABpAG8AbgAgAFMAaQBsAGUAbgB0AGwAeQBDAG8AbgB0AGkAbgB1AGUAKQAgAHsAIABlAHgAaQB0ACAAJABMAEEAUwBUAEUAWABJAFQAQwBPAEQARQAgAH0AIABFAGwAcwBlACAAewAgAGUAeABpAHQAIAAxACAAfQAgAH0A, exited with result 1",
"unreachable": true
}
执行命令也报错:
ansible windows -m win_shell -a "java -version"
192.168.1.173 | FAILED | rc=-532462766 >>
An error has occurred that was not properly handled. Additional information is shown below. The Windows PowerShell process will exit.
Unhandled Exception: OutOfMemoryException.
A6:对被控windows主机打一个关于WMF 3.0 的hotfix,链接如下:
https://support.microsoft.com/en-us/help/2842230/-out-of-memory-error-on-a-computer-that-has-a-customized-maxmemorypers