Shell脚本-控制多主机操作
环境介绍
首先要做到各个主机之间无密ssh连接。这样会最大可能方便的控制。
脚本
命名为status
#!/bin/bash
params=$@
i=166
for((i=166;i<=169;i++));do
echo -------s$i $params -------
ssh s$i "$params"
done
测试
[root@s166 bin]# status java -version
-------s166 java -version -------
bash: java: command not found
-------s167 java -version -------
bash: java: command not found
-------s168 java -version -------
bash: java: command not found
-------s169 java -version -------
bash: java: command not found
What?就给我看这个,它找不到这个命令,那我把它放到/usr/local/bin
下
[root@s166 bin]# which java
/home/fantj/jdk/bin/java
[root@s166 bin]# ln -s /home/fantj/jdk/bin/java
java javadoc javah javapackager javaws
javac javafxpackager javap java-rmi.cgi
[root@s166 bin]# ln -s /home/fantj/jdk/bin/java ./java
[root@s166 bin]# ls
java jps status xcall.sh
[root@s166 bin]# status java -version
-------s166 java -version -------
java version "1.8.0_171"
Java(TM) SE Runtime Environment (build 1.8.0_171-b11)
Java HotSpot(TM) 64-Bit Server VM (build 25.171-b11, mixed mode)
-------s167 java -version -------
bash: java: command not found
-------s168 java -version -------
bash: java: command not found
-------s169 java -version -------
bash: java: command not found
好了,jps同理,我们只需要把命令创建软连接到/usr/local/bin
下即可,每个主机都需要设置的。
效果
[root@s166 bin]# status jps
-------s166 jps -------
12641 Jps
1397 NameNode
1559 SecondaryNameNode
1727 ResourceManager
-------s167 jps -------
1764 DataNode
11610 Jps
1823 NodeManager
-------s168 jps -------
11572 Jps
1815 NodeManager
1756 DataNode
-------s169 jps -------
1813 NodeManager
1754 DataNode
11548 Jps
[root@s166 bin]# status ls ~/.ssh
-------s166 ls /root/.ssh -------
authorized_keys
id_rsa
id_rsa.pub
known_hosts
-------s167 ls /root/.ssh -------
authorized_keys
id_rsa
id_rsa.pub
known_hosts
-------s168 ls /root/.ssh -------
authorized_keys
id_rsa
id_rsa.pub
-------s169 ls /root/.ssh -------
authorized_keys
id_rsa
id_rsa.pub

低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。
持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。
-
上一篇
Java 8 Stream--开发手册
什么是Java8 Stream,为什么需要Stream? Stream是Java8一大亮点,它与 java.io 包里的 InputStream 和 OutputStream 是完全不同的概念。 首先Java 8 Stream不是数据结构,它没有内部存储。它是为高效的集合(数组、List、Set……)操作而存在的。 Java中的集合Collection,具体包含:数组、List、Set等数据结构,都是由JDK提供的,难道在Java8之前的集合操作,有什么不便/局限吗? 下面给出一个需求进行对比,体验一下Java8 Stream:从一个List中,获取集合中每个对象的ID,返回一个新的ID List。 在Java8之前,我们需要这样做: List<Food> foods = new ArrayList<>(); // id price num foods.add(new Food(1, 5.5, 3)); foods.add(new Food(2, 4.5, 8)); foods.add(new Food(3, 56.5, 13)); foods.add(new ...
-
下一篇
java -----------------LeetCode——电话号码的字母组合
回溯算法是不是很是陌生啊,我敢开始也是一脸你蒙蔽,后来我终于忍不住了,就去查查什么是回溯,原来是这个情况,回溯和递归有点类似,但是又不是递归,比如我现在计算数据从0开始到2,当到达状态值2我就回溯,我从1开始回溯,我在回到0,就是for循环我不按套路从小到打,去输出了,我采用回溯, public class Main { public static void main(String[] args) { List<String> stringList = begin("23"); System.out.println(stringList.toString()); } // 定义每个数字对应的字符 static String[] a = new String[] {"","","abc","def", "ghi","jkl","mno","pqrs","tuv","wxyz"}; // 这个是输出的字符串 static StringBuffer sb = new StringBuffer(); private static List<String> begin(S...
相关文章
文章评论
共有0条评论来说两句吧...