Waiting for a job to be executed in Java Dataflow

2019-08-21 02:46发布

问题:

I'm using Cloud Dataflow API with Java Client Library to launch a Dataflow template. I want to know when the job that was launched has a status of JOB_STATE_DONE. Even though this is easy to do in node.js with callbacks, I really need to do it in Java, but it's being real hard to find examples of how to do it. I also not good at event-driven programming.

Node.js code:

var {google} = require('googleapis');

exports.runJob= (req, res) => {

  google.auth.getApplicationDefault(function (err, authClient, projectId) {
  if (err) {
    throw err;
  }

  const dataflow = google.dataflow({ version: 'v1b3', auth: authClient });

  dataflow.projects.templates.launch({
    projectId: 'xxxxx',
    gcsPath: 'gs://xxxx',    
    resource: {
      parameters: {
      },
      environment: {
        tempLocation: 'gs://xxx'
      },
    }
    }, function(err, response) {
     if (err) {
       console.error("Errorw: ", err);
     }
     console.log("Job executed: ", response);
     res.send('200');
    })
  });
};

Dependency:

compile group: 'com.google.apis', name: 'google-api-services-dataflow', version: 'v1b3-rev266-1.25.0'

Edit: I've noticed there is a setCallback(String) method in the documentation (link below), but I still don't know how to use it.

https://developers.google.com/resources/api-libraries/documentation/dataflow/v1b3/java/latest/com/google/api/services/dataflow/Dataflow.Projects.Templates.Launch.html#setCallback-java.lang.String-