jsch ssh服务器调用Linux命令或脚本的小问题

代码如下:

    public static boolean execshell(String command, String user, String passwd, String host) throws JSchException, IOException {  
        connect(user, passwd, host);
        BufferedReader reader = null;
        boolean flag = true;
        Channel channel = null;  
        String charset ="UTF-8";
        try {  
            //执行linux命令
            channel = session.openChannel("exec"); 
            ((ChannelExec) channel).setCommand(command);  
            ((ChannelExec) channel).setErrStream(System.err);  
            channel.connect(); 
            InputStream in = channel.getInputStream();
            reader = new BufferedReader(new InputStreamReader(in,
            Charset.forName(charset)));
            String buf = null;
            while ((buf = reader.readLine()) != null) {
            log.info(buf);
            }            
             }catch (Exception e) {
                 e.printStackTrace();
             }finally {   
                 reader.close();
                 channel.disconnect();  
                 session.disconnect();  
        }
        return flag;
    }

这里发现了一个问题,如果使用红色字体中的方法,用来输出执行linux命令或sh文件时系统错误的输出,这样的话会造成一个问题,就是使用log4j的方法无效,后面的log.info以及返回后其他类中的log都将失效,最终tomcat的catalina.out的日志就永远停止了。。。。所以使用时,一定要注释掉哦~或者不用哦~使用下面reader读取linux中的输出信息就行了哦~

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏熊二哥

快速入门系列--CLR--03泛型集合

.NET中的泛型集合 在这里主要介绍常见的泛型集合,很多时候其并发时的线程安全性常常令我们担忧。因而简述下.NET并发时线程安全特性,其详情请见MSDN。 ...

1777
来自专栏noteless

XML概念定义以及如何定义xml文件编写约束条件java解析xml DTD XML Schema JAXP java xml解析 dom4j 解析 xpath dom sax

本文主要涉及:xml概念描述,xml的约束文件,dtd,xsd文件的定义使用,如何在xml中引用xsd文件,如何使用java解析xml,解析xml方式dom s...

1313
来自专栏Python小屋

Python处理文本文件案例一则

问题描述:当前文件夹中有一文件data.txt,其中包含一些自然数,每行一个。要求编写程序,读取data.txt中的所有自然数,将其升序排序之后写入新文件dat...

1283
来自专栏小狼的世界

Linux下不同文件编码的转换

字符编码(Character Encoding)可以说就是让某一字符序列匹配一个指定集合中的某一东西,常见的例子包括长短电键组合起来表示的摩斯电码(Morse ...

1062
来自专栏大闲人柴毛毛

Java异常体系中的秘密

相信大家每天都在使用Java异常机制,也相信大家对try-catch-finally执行流程烂熟于胸。本文将介绍Java异常机制的一些细节问题,这些问题虽然很...

36410
来自专栏光变

3.3 ASM-方法-工具类

‘org.objectweb.asm.commons’包含了一些预定义的方法适配器,可以用来定义自己的适配器。 本节介绍三个工具类,并且会展示它们如何和3.2....

2700
来自专栏Java技术分享

线程管理之获取和设置线程信息

获取和设置线程信息 Thread类的对象中保存了一些属性信息能够帮助我们来辨别每一个线程,知道它的状态,调整控制其优先级。 这些属性是: ID: 每个线程的独特...

20910
来自专栏Java帮帮-微信公众号-技术文章全总结

Java面试系列8

? 一、heap和stack有什么区别 栈是一种线形集合,其添加和删除元素的操作应在同一段完成。 栈按照后进先出的方式进行处理。 堆是栈的一个组成元素 ...

3075
来自专栏崔庆才的专栏

Python 3 中 PyMongo 的用法

MongoDB存储在这里我们来看一下Python3下MongoDB的存储操作,在本节开始之前请确保你已经安装好了MongoDB并启动了其服务,另外安装好了Pyt...

2.8K1
来自专栏cnblogs

knockout源码分析之执行过程

一、执行流程 ? 二、主要类分析 2.1. 在applyBindings中,创建bindingContext,然后执行applyBindingsToNodeAn...

21510

扫码关注云+社区

领取腾讯云代金券