Java实现获取服务器日志并进行处理解析

一、服务器登陆公钥秘钥设置

步骤如下:

1、本机生成私钥公钥文件

本机进入到.ssh目录下,c:/Users/**/.ssh, 在该目录下执行

$ ssh-keygen -t rsa

然后一路回车即可。

说明:如果原先./ssh目录下有id_rsa  id_rsa.pub这两个文件,以上的一路回车操作会生成新的id_rsa  id_rsa.pub来覆盖原来的key文件。

或者想生成不同命名的key文件可以如下操作

说明:命令后面的“-C ‘**@**.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";

  1. 代码实现连接服务器
/**

 * 建立与服务器的连接

 * @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/**/logs/server-info.log

     * @param key  关键字     例如  节点

     * @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);

        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

     * @param regex

     *      例如 "\\{\"89XF\".*\\}$"  就是匹配logStr中的json串  

     *          "\\{.*\\}$"    匹配对应接口返回查询数据体

     * @return 返回 日志中的消息json串

     */

    public static String  useRegexGetStr(String logStr, String regex){

        Pattern p = Pattern.compile(regex);  //匹配参数体

//        Pattern p = Pattern.compile("\\{\"89XF\".*\\}$");  //匹配参数体

        Matcher m = p.matcher(logStr);

        boolean b = m.find();

        String params = null;

        if(b){

            params = m.group();

            System.out.println(params);

        }

        return params;

    }

正则仅供参考,可以根据自己的需要写不同的正则来匹配需要的数据

猜你喜欢

转载自blog.csdn.net/zhufengyan521521/article/details/82871437
今日推荐