| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124 | [[java-rest-high-x-pack-ml-put-datafeed]]=== Put Datafeed APIThe Put Datafeed API can be used to create a new {ml} datafeedin the cluster. The API accepts a `PutDatafeedRequest` objectas a request and returns a `PutDatafeedResponse`.[[java-rest-high-x-pack-ml-put-datafeed-request]]==== Put Datafeed RequestA `PutDatafeedRequest` requires the following argument:["source","java",subs="attributes,callouts,macros"]--------------------------------------------------include-tagged::{doc-tests}/MlClientDocumentationIT.java[x-pack-ml-put-datafeed-request]--------------------------------------------------<1> The configuration of the {ml} datafeed to create[[java-rest-high-x-pack-ml-put-datafeed-config]]==== Datafeed ConfigurationThe `DatafeedConfig` object contains all the details about the {ml} datafeedconfiguration.A `DatafeedConfig` requires the following arguments:["source","java",subs="attributes,callouts,macros"]--------------------------------------------------include-tagged::{doc-tests}/MlClientDocumentationIT.java[x-pack-ml-create-datafeed-config]--------------------------------------------------<1> The datafeed ID and the job ID<2> The indices that contain the data to retrieve and feed into the job==== Optional ArgumentsThe following arguments are optional:["source","java",subs="attributes,callouts,macros"]--------------------------------------------------include-tagged::{doc-tests}/MlClientDocumentationIT.java[x-pack-ml-create-datafeed-config-set-chunking-config]--------------------------------------------------<1> Specifies how data searches are split into time chunks.["source","java",subs="attributes,callouts,macros"]--------------------------------------------------include-tagged::{doc-tests}/MlClientDocumentationIT.java[x-pack-ml-create-datafeed-config-set-frequency]--------------------------------------------------<1> The interval at which scheduled queries are made while the datafeed runs in real time.["source","java",subs="attributes,callouts,macros"]--------------------------------------------------include-tagged::{doc-tests}/MlClientDocumentationIT.java[x-pack-ml-create-datafeed-config-set-query]--------------------------------------------------<1> A query to filter the search results by. Defaults to the `match_all` query.["source","java",subs="attributes,callouts,macros"]--------------------------------------------------include-tagged::{doc-tests}/MlClientDocumentationIT.java[x-pack-ml-create-datafeed-config-set-query-delay]--------------------------------------------------<1> The time interval behind real time that data is queried.["source","java",subs="attributes,callouts,macros"]--------------------------------------------------include-tagged::{doc-tests}/MlClientDocumentationIT.java[x-pack-ml-create-datafeed-config-set-script-fields]--------------------------------------------------<1> Allows the use of script fields.["source","java",subs="attributes,callouts,macros"]--------------------------------------------------include-tagged::{doc-tests}/MlClientDocumentationIT.java[x-pack-ml-create-datafeed-config-set-scroll-size]--------------------------------------------------<1> The `size` parameter used in the searches.[[java-rest-high-x-pack-ml-put-datafeed-execution]]==== ExecutionThe Put Datafeed API can be executed through a `MachineLearningClient`instance. Such an instance can be retrieved from a `RestHighLevelClient`using the `machineLearning()` method:["source","java",subs="attributes,callouts,macros"]--------------------------------------------------include-tagged::{doc-tests}/MlClientDocumentationIT.java[x-pack-ml-put-datafeed-execute]--------------------------------------------------[[java-rest-high-x-pack-ml-put-datafeed-response]]==== ResponseThe returned `PutDatafeedResponse` returns the full representation ofthe new {ml} datafeed if it has been successfully created. This willcontain the creation time and other fields initialized usingdefault values:["source","java",subs="attributes,callouts,macros"]--------------------------------------------------include-tagged::{doc-tests}/MlClientDocumentationIT.java[x-pack-ml-put-datafeed-response]--------------------------------------------------<1> The created datafeed[[java-rest-high-x-pack-ml-put-datafeed-async]]==== Asynchronous ExecutionThis request can be executed asynchronously:["source","java",subs="attributes,callouts,macros"]--------------------------------------------------include-tagged::{doc-tests}/MlClientDocumentationIT.java[x-pack-ml-put-datafeed-execute-async]--------------------------------------------------<1> The `PutDatafeedRequest` to execute and the `ActionListener` to use whenthe execution completesThe asynchronous method does not block and returns immediately. Once it iscompleted the `ActionListener` is called back using the `onResponse` methodif the execution successfully completed or using the `onFailure` method ifit failed.A typical listener for `PutDatafeedResponse` looks like:["source","java",subs="attributes,callouts,macros"]--------------------------------------------------include-tagged::{doc-tests}/MlClientDocumentationIT.java[x-pack-ml-put-datafeed-execute-listener]--------------------------------------------------<1> Called when the execution is successfully completed. The response isprovided as an argument<2> Called in case of failure. The raised exception is provided as an argument
 |