09.异步Jobs

09.异步Jobs

因为play是一个web应用程序,因此许多应用程序逻辑都是由控制器返回给http请求的。

但有些时候,我们需要在http请求外执行一些应用逻辑。比如非常有用的初始化任务,维护任务或运行不能被http请求池中断的长时运行的任务等等。

Jobs可以被框架全面进行管理。意思是play负责管理所有的数据库连接原料stuff,JPA实体管理器负责管理数据同步和事务管理。要想创建一个job,只需要继承play.jobs.Job即可。

package jobs;

 

import play.jobs.*;

 

public class MyJob extends Job {

   

    public voiddoJob() {

        //在这儿执行某些逻辑

    }

   

}

有些时候需要任务返回结果,这时就需要重载doJobWithResult()方法。

package jobs;

 

import play.jobs.*;

 

public class MyJob extends Job<String> {

   

    public String doJobWithResult() {

        //在这儿执行某些逻辑

        returnresult;

    }

   

}

本示例仅使用了String作为返回类型,当然可以返回任何对象类型。

引导程序任务Bootstrap jobs

引导程序任务会在play应用启动时执行。要想实现该任务,只需要在你的任务上添加@OnApplicationStart注释:

importplay.jobs.*;

 

@OnApplicationStart

public classBootstrap extends Job {

   

    public void doJob() {

        if(Page.count() == 0) {

            new Page("root").save();

            Logger.info("A root page hasbeen created.");

        }

    }

   

}

注意:在这里不需要返回结果,即使这样做了,结果也会丢失。

默认情况下,所有标识为@OnApplicationStart的任务都将以队列方式执行。当所有的job执行结束后,应用程序才正式启动并开始处理请求。

如果你打算让你的任务在应用程序启动时执行,但你又想立即管理进行请求处理,那么可以使用@OnApplicationStart(async=true)注释。然后,你的job将在后台启动。

警告!


当运行于DEV模式时,应用程序将在第一个请求到达时才启动。此外,在DEV模式时,在需要的时候,应用程序会自动重启。

当运行于PROD模式时,应用程序将和服务器一起同步启动。

预定义任务Scheduled jobs

预定义任务由框架周期性执行。你可以使用@Every注释要求play在一个特定的周期内运行job。

importplay.jobs.*;

 

@Every("1h")

public classBootstrap extends Job {

   

    public void doJob() {

        List<User> newUsers =User.find("newAccount = true").fetch();

        for(User user : newUsers) {

            Notifier.sayWelcome(user);

        }

    }

   

}

如果@Every注释还不足以满足需要,你可使用带有CRON表达式的@On注释来运行你的job。

importplay.jobs.*;

 

/** Fire at 12pm(noon) every day **/

@On("0 0 12 ** ?")

public classBootstrap extends Job {

   

    public void doJob() {

        Logger.info("Maintenance job...");

        ...

    }

   

}

小建议

我们是使用Quartzlibrary来解析CRON表达式的。

你不能返回结果,即使这样做了,结果也会被丢弃。

触发任务job

调用Job实例的now()方法可以在任何时候触发job来执行一段特定的任务。这个时候,job将以非阻塞方式立即执行。

public static voidencodeVideo(Long videoId) {

    new VideoEncoder(videoId).now();

    renderText("Encoding started");

}

调用job的now()方法以返回一个Promise值。

停止应用程序

使用@OnApplicationStop注释可以在应用程序关闭时执行某些操作。

import play.jobs.*;

 

@OnApplicationStop

public class Bootstrap extends Job {

 

    public voiddoJob() {

       Fixture.deleteAll();

    }

}


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值