java ssh linux 卡住,java 纠结了n久的问题终于解决啦 linux下部署SSH架构

就在刚刚,纠结了n久的那个为什么在windows下测试正常但部署到linux下却总报错的问题终于被我解决拉!硬着头皮看了一堆的英文论坛,总算找到了解决方案。

问题描述:

我们新开发的Botwarden系统,采用SSH结构,在windows下测试通过,直接发布到的debian服务器上对应的webapps目录(注意发布web应用的目录为/var/lib/tomcat6/webapps,在/usr/share/tomcat6目录下的是tomcat的安装目录)下,却不能正常访问,查看tomcat启动日志(tomcat的启动日志记录在/var/lib/tomcat6/logs目录下,tomcat6是采用按天记录的),发现报错如下(关键点我用蓝色标出):

SEVERE: Error deploying web

application directory Skyeye

java.lang.NoClassDefFoundError:

org/springframework/core/NestedExceptionUtilsat

org.springframework.core.NestedRuntimeException.getMessage(NestedRuntimeException.java:67)

at

java.lang.Throwable.getLocalizedMessage(Throwable.java:267)

at java.lang.Throwable.toString(Throwable.java:343)

at

org.springframework.beans.factory.BeanCreationException.toString(BeanCreationException.java:150)

at java.lang.String.valueOf(String.java:2827)

at java.io.PrintWriter.println(PrintWriter.java:710)

at

java.lang.Throwable.printStackTrace(Throwable.java:509)

at

org.springframework.beans.factory.BeanCreationException.printStackTrace(BeanCreationException.java:176)

at

java.util.logging.SimpleFormatter.format(SimpleFormatter.java:72)

at

org.apache.juli.FileHandler.publish(FileHandler.java:129)

at java.util.logging.Logger.log(Logger.java:458)

at java.util.logging.Logger.doLog(Logger.java:480)

at java.util.logging.Logger.logp(Logger.java:680)

at

org.apache.juli.logging.DirectJDKLog.log(DirectJDKLog.java:167)

at

org.apache.juli.logging.DirectJDKLog.error(DirectJDKLog.java:135)

at

org.apache.catalina.core.StandardContext.listenerStart(StandardContext.java:3847)

at

org.apache.catalina.core.StandardContext.start(StandardContext.java:4342)

at

org.apache.catalina.core.ContainerBase.addChildInternal(ContainerBase.java:791)

at

org.apache.catalina.core.ContainerBase.access$000(ContainerBase.java:123)

at

org.apache.catalina.core.ContainerBase$PrivilegedAddChild.run(ContainerBase.java:145)

at java.security.AccessController.doPrivileged(Native

Method)

at

org.apache.catalina.core.ContainerBase.addChild(ContainerBase.java:769)

at

org.apache.catalina.core.StandardHost.addChild(StandardHost.java:525)

at

org.apache.catalina.startup.HostConfig.deployDirectory(HostConfig.java:926)

at

org.apache.catalina.startup.HostConfig.deployDirectories(HostConfig.java:889)

at

org.apache.catalina.startup.HostConfig.deployApps(HostConfig.java:492)

at

org.apache.catalina.startup.HostConfig.start(HostConfig.java:1149)

at

org.apache.catalina.startup.HostConfig.lifecycleEvent(HostConfig.java:311)

at

org.apache.catalina.util.LifecycleSupport.fireLifecycleEvent(LifecycleSupport.java:117)

at

org.apache.catalina.core.ContainerBase.start(ContainerBase.java:1053)

at

org.apache.catalina.core.StandardHost.start(StandardHost.java:719)

at

org.apache.catalina.core.ContainerBase.start(ContainerBase.java:1045)

at

org.apache.catalina.core.StandardEngine.start(StandardEngine.java:443)

at

org.apache.catalina.core.StandardService.start(StandardService.java:516)

at

org.apache.catalina.core.StandardServer.start(StandardServer.java:710)

at

org.apache.catalina.startup.Catalina.start(Catalina.java:578)

at sun.reflect.NativeMethodAccessorImpl.invoke0(Native

Method)

at

sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)

at

sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)

at java.lang.reflect.Method.invoke(Method.java:597)

at

org.apache.catalina.startup.Bootstrap.start(Bootstrap.java:288)

at sun.reflect.NativeMethodAccessorImpl.invoke0(Native

Method)

at

sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)

at

sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)

at java.lang.reflect.Method.invoke(Method.java:597)

at

org.apache.commons.daemon.support.DaemonLoader.start(DaemonLoader.java:177)

Caused by: java.lang.ClassNotFoundException:

org.springframework.core.NestedExceptionUtils

at

org.apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1387)

at

org.apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1233)

at

java.lang.ClassLoader.loadClassInternal(ClassLoader.java:320)

... 46 more

解决过程:

开始漫长的google之旅,开始以为是对应的spring包没有加进去,检查发现没有问题,师弟建议说换个版本的spring-core包,最后我思考了一下觉得应该不是这个问题,就没有尝试这个解决方法,事实证明我是对的,呵呵。接着google一般的NoClassDefFoundError错误原因,都说是环境变量的配置问题,但我确认jdk和tomcat对应的环境变量都没错,于是此原因排除之。然后继续google,有人建议说直接在windows下打包成war包再发布到linux下,于是尝试,依旧老问题。

(郁闷啊郁闷,中午亲爱的吃饭时叫我,我都没有心思去吃饭,亲爱的安慰了我半天,后来想想没有必要虐待自己,保持好心情,嘿嘿)

太晚了,亲爱的来接我回宿舍了,明天继续写完,现在心情好好,哈哈

to be continued……

接着写完:

改变关键字接着google,晃到了一个国外的论坛,硬着头皮看完了那些英文的讨论,貌似是tomcat

security的问题,应该是要将debian下tomcat

security禁止掉,否则访问不了那些spring的包吧,看那个人好像修改的init.d的脚本,想了想/etc/init.d下应该有对应的tomcat的配置文件,于是vi

/etc/init.d/tomcat6,将默认的TOMCAT6_SECURITY=yes改为TOMCAT6_SECURITY=no。重启tomcat(/etc/init.d/tomcat6

restart),在浏览器下激动地输入网址,发现终于看到web界面了,那个激动啊~~刚好亲爱的排练完节目打电话给我,兴奋地跟他说了一下,开心啊开心……

其实呢,还是有问题的,貌似是访问数据库的问题,继续解决吧

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
你可以使用JSch库来实现JavaLinux服务器之间的SSH连接。以下是一个简单的示例代码,可以连接到Linux服务器并执行命令: ```java import com.jcraft.jsch.*; public class SSHConnection { public static void main(String args[]) { String host = "your_host_name"; String user = "your_user_name"; String password = "your_password"; try { JSch jsch = new JSch(); Session session = jsch.getSession(user, host, 22); session.setPassword(password); session.setConfig("StrictHostKeyChecking", "no"); session.connect(); String command = "ls -l"; Channel channel = session.openChannel("exec"); ((ChannelExec) channel).setCommand(command); channel.setInputStream(null); ((ChannelExec) channel).setErrStream(System.err); InputStream in = channel.getInputStream(); channel.connect(); byte[] tmp = new byte[1024]; while (true) { while (in.available() > 0) { int i = in.read(tmp, 0, 1024); if (i < 0) { break; } System.out.print(new String(tmp, 0, i)); } if (channel.isClosed()) { if (in.available() > 0) { continue; } System.out.println("exit-status: " + channel.getExitStatus()); break; } try { Thread.sleep(1000); } catch (Exception ee) { } } channel.disconnect(); session.disconnect(); } catch (JSchException e) { e.printStackTrace(); } catch (IOException e) { e.printStackTrace(); } } } ``` 在上面的示例代码中,我们首先创建一个`JSch`对象,并使用该对象创建一个`Session`对象。我们还需要设置连接的服务器主机名,用户名和密码。在此之后,我们使用`setConfig`方法禁用了严格主机密钥检查。这是因为当第一次连接到一个主机时,JSch会检查主机密钥,如果没有保存,则会弹出一个警告。通过禁用此功能,我们可以避免弹出这个警告。 接下来,我们创建一个`ChannelExec`对象来执行命令。我们已将要执行的命令设置为`ls -l`。然后,我们使用`channel.connect()`方法连接到服务器,并使用`getInputStream()`方法获取命令的输出流。接下来,我们循环读取输出流中的数据,并在控制台上打印出来。最后,我们检查通道是否关闭,并打印出退出状态码。最后,我们断开与服务器的连接。 请注意,这只是一个简单的示例代码,你需要根据你的实际情况进行修改。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值