无法从play框架2.4

时间:2016-03-19 21:20:56

标签: java playframework playframework-2.4

我创建了一个在应用程序重启期间启动的cron作业,但是当我尝试创建数据库连接时,我正在调整空指针异常。我可以使用相同的配置从其他模块创建和使用db。

以下是我的Application.conf

db.abc.driver=com.mysql.jdbc.Driver
db.abc.url="jdbc:mysql://localhost:3306/db_name?useSSL=false"
db.abc.username=root
db.abc.password=""
db.abc.autocommit=false
db.abc.isolation=READ_COMMITTED

尝试访问db的代码是

public class SchduleJob extends AbstractModule{
    @Override
    protected void configure() {
        bind(JobOne.class)
        .to(JobOneImpl.class)
        .asEagerSingleton();
    }    }

@ImplementedBy(JobOneImpl.class)
public interface JobOne {}

@Singleton
public class JobOneImpl implements JobOne {
    final ActorSystem actorSystem = ActorSystem.create("name");
    final ActorRef alertActor = actorSystem.actorOf(AlertActor.props);

    public JobOneImpl() {
        scheduleJobs();
    }

    private Cancellable scheduleJobs() {
        return actorSystem.scheduler().schedule(
                Duration.create(0, TimeUnit.MILLISECONDS), //Initial delay 0 milliseconds
                Duration.create(6, TimeUnit.MINUTES),     //Frequency 30 minutes
                alertActor,
                "alert",
                actorSystem.dispatcher(),
                null
                );
    }
}

public class AlertActor  extends UntypedActor{

public static Props props = Props.create(AlertActor.class);
final ActorSystem actorSystem = ActorSystem.create("name");
final ActorRef messageActor = actorSystem.actorOf(MessageActor.props());

@Override
public void onReceive(Object message) throws Exception {
    if(message != null && message instanceof String) {
        RequestDAO requestDAO = new RequestDAO();
        try {
            List<DBRow> rows = requestDAO.getAllRow();  
        } catch(Exception exception) {
            exception.printStackTrace();
        }
    }
}

}

public class RequestDAO {
public List<DBRow> getAllRow() throws Exception {
        List<DBRow> rows = new ArrayList<DBRow>();
        Connection connection = null;    
        try {
            connection = DB.getDataSource("abc").getConnection();
            connection.setAutoCommit(false);
} catch(Exception exception) {
            exception.printStackTrace();
            if(connection != null) {
                connection.rollback();
            } else {
                System.out.println("in else***********");
            }
            return null;
        } finally {
            if(connection != null)
                connection.close();
        }
        return schools; 
    }

当我调用RequestDAO类的方法getAllRow()时,它正在抛出

java.lang.NullPointerException
    at play.api.Application$$anonfun$instanceCache$1.apply(Application.scala:235)
    at play.api.Application$$anonfun$instanceCache$1.apply(Application.scala:235)
    at play.utils.InlineCache.fresh(InlineCache.scala:69)
    at play.utils.InlineCache.apply(InlineCache.scala:55)
    at play.api.db.DB$.db(DB.scala:22)
    at play.api.db.DB$.getDataSource(DB.scala:41)
    at play.api.db.DB.getDataSource(DB.scala)
    at play.db.DB.getDataSource(DB.java:33)

但是相同的代码在没有cron工作的情况下工作。我该怎么做才能消除这个错误

1 个答案:

答案 0 :(得分:0)

Play使用Typesafe config library进行配置。

我怀疑您当前的cron脚本工作目录未设置,因此可能找不到您的application.confapplication.properties)文件。

然而,Config很不错,因为它允许您指定文件的查找位置,可以通过其基本名称(在.conf | .properties | .json扩展名中进行选择)或者包含java命令行扩展名的文件名:

  • 要指定基本名称,请使用-Dconfig.resource=/path/to/application
  • 要指定全名,请使用-Dconfig.file=/path/to/application.properties