Java在linux上调用shell脚本
javaweb项目环境搭建在linux上,现在这个项目需要对数据库进行操作,执行数据库的方式采用的是存储过程,但是由于某些因素,存储过程需要执行很久,会因超时而执行失败。...
java web项目环境搭建在linux上,现在这个项目需要对数据库进行操作,执行数据库的方式采用的是存储过程,但是由于某些因素,存储过程需要执行很久,会因超时而执行失败。 现在想采用一段shell脚本来唤醒存储过程,然后让它自己跑,java不管了,求linux 和java 高手 支个招。
感激不尽,求可运行的shell脚本例子、 展开
感激不尽,求可运行的shell脚本例子、 展开
5个回答
展开全部
用.sh 脚本call 第一不会超时的,第二只要你后台call进去了,就算前台超时了 后台还是一直在执行
建议把你的java program打包成jar 直接call 你的jar 包
列子
#!/bin/bash
java -cp ./config:/activation.jar:/axis.jar:test.jar com.Test.run param1,param2
-cp 是你文件 path
config 是你配置文件放置位置, jar 和 sh script 同一级目录(可以根据你具体自己修改)
最后只是你需要run 的class了, 在class 里面去call 你对应的procedure
建议把你的java program打包成jar 直接call 你的jar 包
列子
#!/bin/bash
java -cp ./config:/activation.jar:/axis.jar:test.jar com.Test.run param1,param2
-cp 是你文件 path
config 是你配置文件放置位置, jar 和 sh script 同一级目录(可以根据你具体自己修改)
最后只是你需要run 的class了, 在class 里面去call 你对应的procedure
更多追问追答
追问
不好意思,您提的方案过于笼统,能给个详细点能让人理解的例子吗?
还有就是你上面提出的例子,我可不可以这样理解?
将call存储过程的类放在另外一个项目中打成jar,然后引入目前这个java web工程 去调 即使超时了也照样能够跑存储过程对吗?
还是另外一种方式,采用shell脚本去调用打成jar的项目,让这个jar去call?
追答
只需要用jar 去call 后就行了
就有点类似于
你做java helloworld 实验, 写一个class , javac 编译, java run
现在你要做的就是 把前面的javac(编译一个class) 改成 jar (编译很多个class),然后 java run。 因为你要call DB , 需要引入别的jar 和 一些config,
所以 用 java -cp + 你需要引入的jar 包和 config 文件
展开全部
不知道添加计划任务能不能满足你的需要,就是在你指定的时间,或时间间隔 来执行 存储过程,可不可以满足你的需要 。 如果可以, 查一下 crontab 这个关键字。把shell 脚本添加进去。
至于shell 脚本, 就用你的“java web”的主程序名写进去就可以了
至于shell 脚本, 就用你的“java web”的主程序名写进去就可以了
追问
这种方案完全不符合我们要求的业务逻辑,不过还是谢谢你,
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
shell不太适合做这样的事情,数据库或者java应该都可以实现你的需求
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
你要shell脚本怎样唤醒你的存储过程呢?你的存储过程是一个进程调用呢?还是什么?
追问
只要能通过shell调用就行,启动shell的时候是不是会开启一个线程? 如果是这样的话,这个存储过程是被经过进程唤醒。
追答
那就在shell里面直接写你进程调用就行。不用起线程。直接调用就行。像linux下system就ok
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
不知道这个能不能解决你的问题。。
...
Process process = Runtime.getRuntime().exec("./test.sh");
process.waitfor( );
...
...
Process process = Runtime.getRuntime().exec("./test.sh");
process.waitfor( );
...
追问
这个是java层面的,我需要的是shell的例子。谢谢你了。
追答
oracle吗?
shell脚本第一行写 #!/bin/bash
剩下的就像windows下的dos命令一样写就可以,
比如:
sqlplus username/password@dbname as sysdba
@/路径/procedure.sql <- 这个是存储过程文件的路径
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询