Polysh命令实现多日志查询的方法示例
<p><span><strong>一、Polysh简介</strong></span></p>
<p>
Polysh 是一个交互式命令,可以在一台服务器上批量的对一批服务器进行处理,运行交互式命令。Polysh可以同时登录多个远程主机,而不需要通过relay一台一台的登录,并执行相同的指令,方便了问题的排查和定位,大大减少了我们的工作量。</p>
<div class="jb51code">
<div>
<div class="syntaxhighlighterplain" id="highlighter_959851">
<div class="toolbar">
<span>?</span>
</div>
<table border="0" cellpadding="0" cellspacing="0"><tbody><tr>
<td class="gutter">
<div class="line number1 index0 alt2">
1</div>
</td>
<td class="code">
<div class="container">
<div class="line number1 index0 alt2">
<code class="plain plain">Polysh is a tool to aggregate several remote shells into one. It is used to launch an interactive remote shell on many machines at once. It is written in Python and requires Python ≥ 2.4.</code>
</div>
</div>
</td>
</tr></tbody></table>
</div>
</div>
<div class="codetool" id="codetool">
<div class="code_n">
<textarea></textarea>
</div>
</div>
</div>
<p>
<span><strong>注:</strong></span> 官方解释:Polysh 是一个由几个远程脚本集合而成的工具,它被用于在许多服务器上运行一个交互式的远程脚本,由 Python 编写,最低要求为 Python 2.4 。</p>
<p>
<span><strong>二、polysh安装</strong></span></p>
<p>
通过relay登录staging机器,执行如下命令安装polysh。安装目录为用户目录: /opt/hl/。</p>
<p>
<strong>1.已安装python的安装</strong></p>
<div class="jb51code">
<div>
<div class="syntaxhighlighterbash" id="highlighter_209724">
<div class="toolbar">
<span>?</span>
</div>
<table border="0" cellpadding="0" cellspacing="0"><tbody><tr>
<td class="gutter">
<div class="line number1 index0 alt2">
1</div>
<div class="line number2 index1 alt1">
2</div>
<div class="line number3 index2 alt2">
3</div>
<div class="line number4 index3 alt1">
4</div>
</td>
<td class="code">
<div class="container">
<div class="line number1 index0 alt2">
<code class="bash plain">wget wget http:</code><code class="bash plain">//guichaz</code><code class="bash plain">.</code><code class="bash functions">free</code><code class="bash plain">.fr</code><code class="bash plain">/polysh/files/polysh-0</code><code class="bash plain">.4.</code><code class="bash functions">tar</code><code class="bash plain">.gz</code>
</div>
<div class="line number2 index1 alt1">
<code class="bash functions">tar</code> <code class="bash plain">-zxvf polysh-0.4.</code><code class="bash functions">tar</code><code class="bash plain">.gz</code>
</div>
<div class="line number3 index2 alt2">
</div>
<div class="line number4 index3 alt1">
<code class="bash plain">vim prod-polysh.sh</code>
</div>
</div>
</td>
</tr></tbody></table>
</div>
</div>
<div class="codetool" id="codetool">
<div class="code_n">
<textarea></textarea>
</div>
</div>
</div>
<p>
脚本内容如下:</p>
<div class="jb51code">
<div>
<div class="syntaxhighlighterbash" id="highlighter_264057">
<div class="toolbar">
<span>?</span>
</div>
<table border="0" cellpadding="0" cellspacing="0"><tbody><tr>
<td class="gutter">
<div class="line number1 index0 alt2">
1</div>
<div class="line number2 index1 alt1">
2</div>
</td>
<td class="code">
<div class="container">
<div class="line number1 index0 alt2">
<code class="bash comments">#10.252.176.33,10.252.176.35是你要链接的机器ip</code>
</div>
<div class="line number2 index1 alt1">
<code class="bash plain">python </code><code class="bash plain">/opt/hl/polysh-0</code><code class="bash plain">.4</code><code class="bash plain">/polysh</code><code class="bash plain">.py {10.252.176.33,10.252.176.35}</code>
</div>
</div>
</td>
</tr></tbody></table>
</div>
</div>
<div class="codetool" id="codetool">
<div class="code_n">
<textarea></textarea>
</div>
</div>
</div>
<p>
开放给其他用户可执行的权限</p>
<div class="jb51code">
<div>
<div class="syntaxhighlighterbash" id="highlighter_97886">
<div class="toolbar">
<span>?</span>
</div>
<table border="0" cellpadding="0" cellspacing="0"><tbody><tr>
<td class="gutter">
<div class="line number1 index0 alt2">
1</div>
</td>
<td class="code">
<div class="container">
<div class="line number1 index0 alt2">
<code class="bash functions">chmod</code> <code class="bash plain">777 prod-polysh.sh</code>
</div>
</div>
</td>
</tr></tbody></table>
</div>
</div>
<div class="codetool" id="codetool">
<div class="code_n">
<textarea></textarea>
</div>
</div>
</div>
<p>
<strong>2.未安装python的安装</strong></p>
<div class="jb51code">
<div>
<div class="syntaxhighlighterbash" id="highlighter_335801">
<div class="toolbar">
<span>?</span>
</div>
<table border="0" cellpadding="0" cellspacing="0"><tbody><tr>
<td class="gutter">
<div class="line number1 index0 alt2">
1</div>
<div class="line number2 index1 alt1">
2</div>
<div class="line number3 index2 alt2">
3</div>
<div class="line number4 index3 alt1">
4</div>
<div class="line number5 index4 alt2">
5</div>
<div class="line number6 index5 alt1">
6</div>
<div class="line number7 index6 alt2">
7</div>
</td>
<td class="code">
<div class="container">
<div class="line number1 index0 alt2">
<code class="bash plain">wget wget http:</code><code class="bash plain">//guichaz</code><code class="bash plain">.</code><code class="bash functions">free</code><code class="bash plain">.fr</code><code class="bash plain">/polysh/files/polysh-0</code><code class="bash plain">.4.</code><code class="bash functions">tar</code><code class="bash plain">.gz</code>
</div>
<div class="line number2 index1 alt1">
<code class="bash functions">tar</code> <code class="bash plain">-zxvf polysh-0.4.</code><code class="bash functions">tar</code><code class="bash plain">.gz</code>
</div>
<div class="line number3 index2 alt2">
<code class="bash functions">cd</code> <code class="bash plain">polysh-0.4 </code>
</div>
<div class="line number4 index3 alt1">
<code class="bash functions">su</code>
</div>
<div class="line number5 index4 alt2">
<code class="bash plain">python setup.py </code><code class="bash functions">install</code>
</div>
<div class="line number6 index5 alt1">
</div>
<div class="line number7 index6 alt2">
<code class="bash plain">vim prod-polysh.sh</code>
</div>
</div>
</td>
</tr></tbody></table>
</div>
</div>
<div class="codetool" id="codetool">
<div class="code_n">
<textarea></textarea>
</div>
</div>
</div>
<p>
脚本内容如下:</p>
<div class="jb51code">
<div>
<div class="syntaxhighlighterbash" id="highlighter_275586">
<div class="toolbar">
<span>?</span>
</div>
<table border="0" cellpadding="0" cellspacing="0"><tbody><tr>
<td class="gutter">
<div class="line number1 index0 alt2">
1</div>
<div class="line number2 index1 alt1">
2</div>
</td>
<td class="code">
<div class="container">
<div class="line number1 index0 alt2">
<code class="bash comments">#10.252.176.33,10.252.176.35是你要链接的机器ip</code>
</div>
<div class="line number2 index1 alt1">
<code class="bash plain">python </code><code class="bash plain">/opt/hl/polysh-0</code><code class="bash plain">.4</code><code class="bash plain">/polysh</code><code class="bash plain">.py {10.252.176.33,10.252.176.35}</code>
</div>
</div>
</td>
</tr></tbody></table>
</div>
</div>
<div class="codetool" id="codetool">
<div class="code_n">
<textarea></textarea>
</div>
</div>
</div>
<p>
开放给其他用户可执行的权限</p>
<div class="jb51code">
<div>
<div class="syntaxhighlighterbash" id="highlighter_87091">
<div class="toolbar">
<span>?</span>
</div>
<table border="0" cellpadding="0" cellspacing="0"><tbody><tr>
<td class="gutter">
<div class="line number1 index0 alt2">
1</div>
</td>
<td class="code">
<div class="container">
<div class="line number1 index0 alt2">
<code class="bash functions">chmod</code> <code class="bash plain">777 prod-polysh.sh</code>
</div>
</div>
</td>
</tr></tbody></table>
</div>
</div>
<div class="codetool" id="codetool">
<div class="code_n">
<textarea></textarea>
</div>
</div>
</div>
<p>
<span><strong>三、Xshell配置Xagent(mac可跳过这一步)</strong></span></p>
<p>
打开文件-属性,选择SSH选项,选择”使用密码处理的Xagent(SSH代理)”。然后将Xshell重启。</p>
<p>
<span><strong>四、polysh使用</strong></span></p>
<p>
<strong>4.1.使用方法一</strong></p>
<div class="jb51code">
<div>
<div class="syntaxhighlighterbash" id="highlighter_324763">
<div class="toolbar">
<span>?</span>
</div>
<table border="0" cellpadding="0" cellspacing="0"><tbody><tr>
<td class="gutter">
<div class="line number1 index0 alt2">
1</div>
</td>
<td class="code">
<div class="container">
<div class="line number1 index0 alt2">
<code class="bash plain">polysh 10.252.176.33 10.252.176.35</code>
</div>
</div>
</td>
</tr></tbody></table>
</div>
</div>
<div class="codetool" id="codetool">
<div class="code_n">
<textarea></textarea>
</div>
</div>
</div>
<p>
<strong>4.2.使用方法二</strong></p>
<div class="jb51code">
<div>
<div class="syntaxhighlighterbash" id="highlighter_80216">
<div class="toolbar">
<span>?</span>
</div>
<table border="0" cellpadding="0" cellspacing="0"><tbody><tr>
<td class="gutter">
<div class="line number1 index0 alt2">
1</div>
</td>
<td class="code">
<div class="container">
<div class="line number1 index0 alt2">
<code class="bash plain">.</code><code class="bash plain">/prod-polysh</code><code class="bash plain">.sh</code>
</div>
</div>
</td>
</tr></tbody></table>
</div>
</div>
<div class="codetool" id="codetool">
<div class="code_n">
<textarea></textarea>
</div>
</div>
</div>
<p>
则会出现如下提示信息</p>
<div class="jb51code">
<div>
<div class="syntaxhighlighterbash" id="highlighter_138961">
<div class="toolbar">
<span>?</span>
</div>
<table border="0" cellpadding="0" cellspacing="0"><tbody><tr>
<td class="gutter">
<div class="line number1 index0 alt2">
1</div>
<div class="line number2 index1 alt1">
2</div>
</td>
<td class="code">
<div class="container">
<div class="line number1 index0 alt2">
<code class="bash plain">[---hl-----]$ .</code><code class="bash plain">/prod-polysh</code><code class="bash plain">.sh</code>
</div>
<div class="line number2 index1 alt1">
<code class="bash plain">ready (8)</code>
</div>
</div>
</td>
</tr></tbody></table>
</div>
</div>
<div class="codetool" id="codetool">
<div class="code_n">
<textarea></textarea>
</div>
</div>
</div>
<p>
ready (8) 表示 8台机器已经连接完毕,可以执行查询命令。exit或Crtl+z都可以退出。</p>
<p>
<strong>4.3.执行命令</strong></p>
<div class="jb51code">
<div>
<div class="syntaxhighlighterbash" id="highlighter_510504">
<div class="toolbar">
<span>?</span>
</div>
<table border="0" cellpadding="0" cellspacing="0"><tbody><tr>
<td class="gutter">
<div class="line number1 index0 alt2">
1</div>
<div class="line number2 index1 alt1">
2</div>
</td>
<td class="code">
<div class="container">
<div class="line number1 index0 alt2">
<code class="bash plain">ready (8)></code><code class="bash functions">cd</code> <code class="bash plain">/opt/hl</code>
</div>
<div class="line number2 index1 alt1">
<code class="bash plain">ready (8)></code><code class="bash functions">pwd</code>
</div>
</div>
</td>
</tr></tbody></table>
</div>
</div>
<div class="codetool" id="codetool">
<div class="code_n">
<textarea></textarea>
</div>
</div>
</div>
<p>
显示如下:</p>
<div class="jb51code">
<div>
<div class="syntaxhighlighterbash" id="highlighter_835668">
<div class="toolbar">
<span>?</span>
</div>
<table border="0" cellpadding="0" cellspacing="0"><tbody><tr>
<td class="gutter">
<div class="line number1 index0 alt2">
1</div>
<div class="line number2 index1 alt1">
2</div>
</td>
<td class="code">
<div class="container">
<div class="line number1 index0 alt2">
<code class="bash plain">10.252.176.33: </code><code class="bash plain">/opt/hl</code>
</div>
<div class="line number2 index1 alt1">
<code class="bash plain">10.252.176.35 : </code><code class="bash plain">/opt/hl</code>
</div>
</div>
</td>
</tr></tbody></table>
</div>
</div>
<div class="codetool" id="codetool">
<div class="code_n">
<textarea></textarea>
</div>
</div>
</div>
<p>
<span><strong>五、源码</strong></span></p>
<p>
可以通过git获取polysh的源码</p>
<div class="jb51code">
<div>
<div class="syntaxhighlighterbash" id="highlighter_901024">
<div class="toolbar">
<span>?</span>
</div>
<table border="0" cellpadding="0" cellspacing="0"><tbody><tr>
<td class="gutter">
<div class="line number1 index0 alt2">
1</div>
</td>
<td class="code">
<div class="container">
<div class="line number1 index0 alt2">
<code class="bash plain">git clone git:</code><code class="bash plain">//repo</code><code class="bash plain">.or.cz</code><code class="bash plain">/polysh</code><code class="bash plain">.git</code>
</div>
</div>
</td>
</tr></tbody></table>
</div>
</div>
<div class="codetool" id="codetool">
<div class="code_n">
<textarea></textarea>
</div>
</div>
</div>
<p>
<span><strong>六、其他</strong></span></p>
<p>
以冒号开头的指令不会发送到远程主机,polysh会执行以冒号开头的指令,例如:</p>
<div class="jb51code">
<div>
<div class="syntaxhighlighterplain" id="highlighter_834828">
<div class="toolbar">
<span>?</span>
</div>
<table border="0" cellpadding="0" cellspacing="0"><tbody><tr>
<td class="gutter">
<div class="line number1 index0 alt2">
1</div>
<div class="line number2 index1 alt1">
2</div>
<div class="line number3 index2 alt2">
3</div>
<div class="line number4 index3 alt1">
4</div>
<div class="line number5 index4 alt2">
5</div>
<div class="line number6 index5 alt1">
6</div>
<div class="line number7 index6 alt2">
7</div>
<div class="line number8 index7 alt1">
8</div>
<div class="line number9 index8 alt2">
9</div>
<div class="line number10 index9 alt1">
10</div>
<div class="line number11 index10 alt2">
11</div>
<div class="line number12 index11 alt1">
12</div>
<div class="line number13 index12 alt2">
13</div>
<div class="line number14 index13 alt1">
14</div>
<div class="line number15 index14 alt2">
15</div>
<div class="line number16 index15 alt1">
16</div>
<div class="line number17 index16 alt2">
17</div>
<div class="line number18 index17 alt1">
18</div>
<div class="line number19 index18 alt2">
19</div>
<div class="line number20 index19 alt1">
20</div>
</td>
<td class="code">
<div class="container">
<div class="line number1 index0 alt2">
<code class="plain plain">ready (2)> :help </code>
</div>
<div class="line number2 index1 alt1">
<code class="plain plain">:add Add one or many remote shells. </code>
</div>
<div class="line number3 index2 alt2">
<code class="plain plain">:chdir Change the current directory of polysh (not the remote shells). </code>
</div>
<div class="line number4 index3 alt1">
<code class="plain plain">:disable Disable sending commands to remote shells. </code>
</div>
<div class="line number5 index4 alt2">
<code class="plain plain">:enable Enable sending commands to remote shells. </code>
</div>
<div class="line number6 index5 alt1">
<code class="plain plain">:export_vars Export some environment variables on enabled remote shells. </code>
</div>
<div class="line number7 index6 alt2">
<code class="plain plain">:help List control commands or show their documentations. </code>
</div>
<div class="line number8 index7 alt1">
<code class="plain plain">:hide_password Do not echo the next typed line. </code>
</div>
<div class="line number9 index8 alt2">
<code class="plain plain">:list List remote shells and their states. </code>
</div>
<div class="line number10 index9 alt1">
<code class="plain plain">:purge Delete disabled remote shells. </code>
</div>
<div class="line number11 index10 alt2">
<code class="plain plain">:quit Quit polysh. </code>
</div>
<div class="line number12 index11 alt1">
<code class="plain plain">:reconnect Try to reconnect to disconnected remote shells. </code>
</div>
<div class="line number13 index12 alt2">
<code class="plain plain">:rename Rename all enabled remote shells with the argument. </code>
</div>
<div class="line number14 index13 alt1">
<code class="plain plain">:replicate Copy a path from one remote shell to all others </code>
</div>
<div class="line number15 index14 alt2">
<code class="plain plain">:reset_prompt Change the prompt to be recognized by polysh. </code>
</div>
<div class="line number16 index15 alt1">
<code class="plain plain">:send_ctrl Send a control character to remote shells. </code>
</div>
<div class="line number17 index16 alt2">
<code class="plain plain">:set_debug Enable or disable debugging output for remote shells. </code>
</div>
<div class="line number18 index17 alt1">
<code class="plain plain">:set_log Duplicate every console I/O into the given local file. </code>
</div>
<div class="line number19 index18 alt2">
<code class="plain plain">:show_read_buffer Print the data read by remote shells. </code>
</div>
<div class="line number20 index19 alt1">
<code class="plain plain">:upload Upload the specified local path to enabled remote shells.</code>
</div>
</div>
</td>
</tr></tbody></table>
</div>
</div>
<div class="codetool" id="codetool">
<div class="code_n">
<textarea></textarea>
</div>
</div>
</div>
<p>
<span><strong>总结</strong></span></p>
<p>
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对的支持。</p>
<p>
原文链接:http://www.jianshu.com/p/2ed0ad5ccb3f</p>
頁:
[1]