用java把服务器某个目录日志实时打印出来

1.引入第三方包

java 复制代码
<dependency>
    <groupId>com.jcraft</groupId>
    <artifactId>jsch</artifactId>
    <version>0.1.55</version>
</dependency>

2.代码如下

java 复制代码
import com.jcraft.jsch.ChannelExec;
import com.jcraft.jsch.JSch;
import com.jcraft.jsch.Session;

import java.io.BufferedReader;
import java.io.InputStream;
import java.io.InputStreamReader;

public class MySQLPortForwarding {
    public static void main(String[] args) throws Exception{
        String sshHost = ""; //服务器ip
        String sshUsername = ""; //用户名称
        String sshPassword = ""; //用户密码
        String remoteHost = "localhost";
        int localPort = 3307; // 本地端口
        int remotePort = 3306; // 远程MySQL服务器端口

        JSch jsch = new JSch();
        Session session = jsch.getSession(sshUsername, sshHost, 22);
        session.setPassword(sshPassword);
        session.setConfig("StrictHostKeyChecking", "no");
        System.out.println("建立SSH连接...");
        session.connect();
       /*  //这步是做端口转发的,与文章无关,目的:服务器安装的有mysql,然后防火墙没开3306,本地无法直接连接mysql,
        // 这一步本地可以用过localhost:3307连接服务器的mysql
        int assignedPort = session.setPortForwardingL(localPort, remoteHost, remotePort);
        System.out.println("本地端口 " + assignedPort + " 被转发到 " + remoteHost + ":" + remotePort);*/
        String command = "tail -f " + "/tmp/debug.log";
        ChannelExec channel = (ChannelExec) session.openChannel("exec");
        channel.setCommand(command);

        InputStream in = channel.getInputStream();
        channel.connect();

        BufferedReader reader = new BufferedReader(new InputStreamReader(in));
        String line;
        while ((line = reader.readLine()) != null) {
            System.out.println(line); // 实时打印日志内容
        }

        channel.disconnect();
        session.disconnect();
    }

}
相关推荐
程柯梦想1 小时前
Maven修改默认编码格式UTF-8
java·maven
涛ing1 小时前
【5. C++ 变量作用域及其深入探讨】
java·linux·c语言·开发语言·c++·ubuntu·vim
莫名有雪1 小时前
BUUCTF_[网鼎杯 2020 朱雀组]phpweb(反序列化绕过命令)
android
曾经的三心草1 小时前
小程序项目-购物-首页与准备
运维·服务器·小程序·项目·购物
字节全栈_mMD2 小时前
Flink Connector 写入 Iceberg 流程源码解析_confluent icebergsinkconnector
java·大数据·flink
小园子的小菜2 小时前
RocketMQ中的NameServer主要数据结构
java·中间件·rocketmq·java-rocketmq
平凡君3 小时前
缓存的今生今世
java·spring·缓存
纠结哥_Shrek3 小时前
Java 有很多常用的库
java·开发语言
爱是小小的癌4 小时前
Java-数据结构-优先级队列(堆)
java·前端·数据结构
天乐敲代码4 小时前
JAVASE入门十五脚-网络TCP,UDP,,Lambda
java