• java连接服务器读取日志


    说明: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;
        }
  • 相关阅读:
    【WEB前端开发最佳实践系列】高可读的HTML
    【Web前端开发最佳实践系列】标准的HTML代码
    Web服务器配置Gzip压缩提升网站性能
    【Web前端开发最佳实践系列】前端代码推荐和建议
    【前端系列】移动前端开发之viewport的深入理解
    【Spring Boot && Spring Cloud系列】那些Spring Boot中踩过的坑
    【Spring Boot && Spring Cloud系列】Spring Boot的启动器Starter
    【Spring Boot&&Spring Cloud系列】提高数据库访问性能
    【Spring Boot&& Spring Cloud系列】单点登录SSO之OAuth2官方开发文档翻译
    【Spring Boot&& Spring Cloud系列】单点登录SSO概述
  • 原文地址:https://www.cnblogs.com/wangkc/p/10840277.html
Copyright © 2020-2023  润新知