本文目录一览:
- 1、Java Web应用中如何实现任务有效调度
- 2、java的多线程是OS调度还是JVM调度的呢
- 3、JAVA抢占式线程调度的问题
- 4、线程的调度分为几种模型,在java中是使用哪种调度模型
- 5、java里thread怎么实现定时调度
- 6、azkaban在调度java程序时要如何传递参数?
Java Web应用中如何实现任务有效调度
任务调度是大型J2EEweb应用中常见的工作。开发者希望以指定的间隔时间执行各类操作,并完成一些无需用户输入的任务。java中可有无数方法来做到这一点,但是在web应用中却并没有这方面的统一标准。当许多开发人员参与同一个项目,并且以各自不同的方式来实现任务调度时,就可能产生很大问题。内存和同步问题就是必须首先考虑的两件事。事实上,一些开发者试图调用操作系统层面的任务调度机制,如Unix平台上的cron。这种编程实践也许并不是太坏,但它将直接导致可移植性被抛到九霄云外。
java的多线程是OS调度还是JVM调度的呢
现在java线程和操作系统线程之间的对应关系有三种:
多对一、一对一、多对多
多对一就是所说的“Green thread”,一个java应用程序
被当作一个任务被操作系统调度,而这个java应用程序里
的多个线程则由虚拟机调度执行。也可以说由虚拟机选出
一个多线程java程序里的一个线程作为活动线程,这个线
程再作为操作系统的一个任务被操作系统调度。
一对一就是一个java线程对应一个操作系统线程了,即同
一个多线程java程序里的所有线程都由操作系统统一调度。
多对多还不是很明白。。。
JAVA抢占式线程调度的问题
1线程的调度并不是由java决定的,而是os,os可以保证所有线程都有机会得到执行。即时某个线程正在忙。也会被休眠。具体的你要看os相关的线程调度这一块,这叫抢占式任务调度。
2即使线程t的优先级高,在调用start时,也不会保证线程已经真实的启动。os只是把他放到了线程队列中去排队。而当前线程继续执行。
线程的调度分为几种模型,在java中是使用哪种调度模型
Java程序属于抢占式调度,哪个线程的优先级高,哪个线程抢到的CPU时间片的概率就高;如果两个线程同一个优先级,则CPU随机选择一个执行。
java里thread怎么实现定时调度
java Thread类实现定时调度,可以延迟几秒之后再执行,代码如下:
public class ceshi {
public static void main(String[] args) throws Exception {
// run in a second
final long timeInterval = 1000;
Runnable runnable = new Runnable() {
@Override
public void run() {
while (true) {
// ------- code for task to run
System.out.println("Hello !!");
// ------- ends here
try {
Thread.sleep(timeInterval);
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}
};
Thread thread = new Thread(runnable);//线程创建
thread.start();//线程启动
}
}
运行结果:
azkaban在调度java程序时要如何传递参数?
azkaban的工作流中的参数可以分为如下几个类型:azkaban UI 页面输入参数, 环境变量参数, job作业文件中定义的参数,工作流的用户定义的属性文件,上游作业传递给下游的参数,工作流运行时产生的系统参数,job的common参数等. 参数的作业范围分类,对当前job有效局部有效,对整个工作流全局有效. 1. Job配置中的参数全局参数,在整个工作流的作业文件配置中,都可以通过 ${参数名} 的方式引用使用. common参数配置 除了type,command,decpenden