说明:1、工具在使用中可能存在BUG,可以自己修改或者告诉我哦~~~
2、本文内容在最后有文档~
<!-- https://mvnrepository.com/artifact/ch.ethz.ganymed/ganymed-ssh2 -->
<dependency>
<groupId>ch.ethz.ganymed</groupId>
<artifactId>ganymed-ssh2</artifactId>
<version>build210</version>
</dependency>
一、服务器登陆公钥秘钥设置
步骤如下:
1、本机生成私钥公钥文件
本机进入到.ssh目录下,c:/Users/zhufengyan/.ssh, 在该目录下执行
$ ssh-keygen -t rsa
然后一路回车即可。
说明:如果原先./ssh目录下有id_rsa id_rsa.pub这两个文件,以上的一路回车操作会生成新的id_rsa id_rsa.pub来覆盖原来的key文件。
或者想生成不同命名的key文件可以如下操作
说明:命令后面的“-C ‘zhufengyan@58ganji.com’”也是可以去掉的
2、将本地生成的公钥信息放到服务器
将本地生成的公钥信息放置到需要访问的服务器,操作如下:
本地获取公钥信息,复制信息
Xshell登录服务器,加入你有root权限,
Cd /root/.ssh
Vi authorized_keys
将以上复制的内容粘贴到文件尾部。Ok完成。
说明:假设你的服务器上没有authorized_keys这个文件,那么就自己创建一个,创建完后将公钥信息粘贴到这个文件中,保存,还需要进行授权,chmod 600 authorized_keys。
另外:ssh公钥生效需满足至少下面两个条件:
1 .ssh目录的权限必须是700;
2 .ssh/authorized_keys文件权限必须是600;
二、连接服务器
步骤如下
1、 将私钥文件放到项目的resources目录下
则代码中访问的路径是
private String privateKeypath = "src/main/resources/sshkey/id_rsa";
2、 代码实现连接服务器
/**
* 建立与服务器的连接
* @param host 服务器IP String host = "192.168.178.1";
* @param port 端口 int port = 22;
* @param userName 登录服务器的用户名
* @param password 登录服务器的密码
* @param privateKeyFile 与服务器公钥对应的私钥文件 String pubkeypath = "src/main/resources/sshkey/id_rsa";
* @return 返回登录的连接, 在使用的最后一定记得关闭connect资源
* @throws IOException
*/
public static Connection getSSHConnection(String host, int port, String userName, String password, String privateKeyFile) throws IOException {
Connection connection = new Connection(host, port);
connection.connect();
File file = new File(privateKeyFile);
boolean b = connection.authenticateWithPublicKey(userName, file, password);
if (b){
return connection;
}else {
System.out.println("登录连接失败,请检查用户名、密码、私钥文件");
return null;
}
}
三、获取日志信息
/**
* 获取指定log文件的指定关键字的日志信息
* @param connection SSH的连接
* @param logFile 需要读取的log文件 全路径 /opt/dubbo_server/risk-server-provider-xjd/logs/server-info.log
* @param key 关键字 例如 节点3150调用策略引擎开始
* @param timeKey 時間关键字 例如 09-21 14:42:1
* @return 返回需要的日志信息行 如果有多天日志信息满足条件,只返回最后一天日志信息
* @throws IOException
*/
public static String getLogInfo(Connection connection, String logFile, String key, String timeKey) throws IOException {
String cmd = "tail -1000 " + logFile + " | grep '" + key + "'" + " | grep '" + timeKey + "'";
System.out.println("====cmd===" + cmd);
// "tail -1000 /opt/dubbo_server/risk-server-provider-xjd/logs/server-info.log | grep '节点3150调用策略引擎开始,' | grep '09-21 14:42:1'";
Session session = connection.openSession();
session.execCommand(cmd);//执行shell命令
//处理获取的shell命令的输出信息
InputStream stdout = session.getStdout();
InputStreamReader inputStreamReader = new InputStreamReader(stdout);
BufferedReader bufferedReader = new BufferedReader(inputStreamReader);
String s = bufferedReader.readLine();
String lastLineLog = null;
System.out.println("==========以下是获取日志的全部信息============");
while(s != null){
if (s != null){
lastLineLog = s;
System.out.println(s);
}
s = bufferedReader.readLine();
}
System.out.println("==========以上是获取日志的全部信息============");
System.out.println("========以下是日志的最后一行数据=======");
System.out.println(lastLineLog);
//最后关闭session资源
if (session != null){
session.close();
}
return lastLineLog;
}
四、正则匹配需要的数据
/**
* 通过正则表达式获取需要的子串
* @param logStr
* 例如 [09-21 14:42:17 534 INFO ] [pool-3-thread-16] com.bj58.fbu.ark.server.risk.server.provider.process.util.ProcessExecutor - 流程18442节点3150调用策略引擎开始,参数={"58XF":{"deviceIdApplyCnt":{"VALUE":4.0,"TYPE":"1"},
* @param regex
* 例如 "\\{\"58XF\".*\\}$" 就是匹配logStr中的json串 匹配风控节点3150策略引擎的参数体
* "\\{.*\\}$" 匹配征信对应接口返回查询数据体
* @return 返回 日志中的消息json串
*/
public static String useRegexGetStr(String logStr, String regex){
Pattern p = Pattern.compile(regex); //匹配参数体
// Pattern p = Pattern.compile("\\{\"58XF\".*\\}$"); //匹配参数体
Matcher m = p.matcher(logStr);
boolean b = m.find();
String params = null;
if(b){
params = m.group();
System.out.println(params);
}
return params;
}