Merge remote-tracking branch 'elastic/master' into feature/sql
Original commit: elastic/x-pack-elasticsearch@273e0a110e
This commit is contained in:
commit
fdd98f01ed
|
@ -8,10 +8,11 @@
|
||||||
{xpack} includes commands that help you configure security:
|
{xpack} includes commands that help you configure security:
|
||||||
|
|
||||||
* <<certgen>>
|
* <<certgen>>
|
||||||
//* <<setup-passwords>>
|
* <<setup-passwords>>
|
||||||
* <<users-command>>
|
* <<users-command>>
|
||||||
|
|
||||||
--
|
--
|
||||||
|
|
||||||
include::certgen.asciidoc[]
|
include::certgen.asciidoc[]
|
||||||
|
include::setup-passwords.asciidoc[]
|
||||||
include::users-command.asciidoc[]
|
include::users-command.asciidoc[]
|
||||||
|
|
|
@ -0,0 +1,47 @@
|
||||||
|
[role="xpack"]
|
||||||
|
[[setup-passwords]]
|
||||||
|
== setup-passwords
|
||||||
|
|
||||||
|
The `setup-passwords` command sets the passwords for the built-in `elastic`,
|
||||||
|
`kibana`, and `logstash_system` users.
|
||||||
|
|
||||||
|
[float]
|
||||||
|
=== Synopsis
|
||||||
|
|
||||||
|
[source,shell]
|
||||||
|
--------------------------------------------------
|
||||||
|
bin/x-pack/setup-passwords auto|interactive [-u "<URL>"]
|
||||||
|
--------------------------------------------------
|
||||||
|
|
||||||
|
[float]
|
||||||
|
=== Description
|
||||||
|
|
||||||
|
This command is intended for use only during the initial configuration of
|
||||||
|
{xpack}. It uses the
|
||||||
|
{xpack-ref}/setting-up-authentication.html#bootstrap-elastic-passwords[`elastic` bootstrap password]
|
||||||
|
to run user management API requests. After you set a password for the `elastic`
|
||||||
|
user, the bootstrap password is no longer active and you cannot use this command.
|
||||||
|
Instead, you can change passwords by using the *Management > Users* UI in {kib}
|
||||||
|
or the <<security-api-change-password,Change Password API>>.
|
||||||
|
|
||||||
|
[float]
|
||||||
|
=== Parameters
|
||||||
|
|
||||||
|
`auto`:: Outputs randomly-generated passwords to the console.
|
||||||
|
|
||||||
|
`interactive`:: Prompts you to manually enter passwords.
|
||||||
|
|
||||||
|
`-u "<URL>"`:: Specifies the URL that the tool uses to submit the user management API
|
||||||
|
requests. The default value is determined from the settings in your
|
||||||
|
`elasticsearch.yml` file.
|
||||||
|
|
||||||
|
[float]
|
||||||
|
=== Examples
|
||||||
|
|
||||||
|
The following example uses the `-u` parameter to tell the tool where to submit
|
||||||
|
its user management API requests:
|
||||||
|
|
||||||
|
[source,shell]
|
||||||
|
--------------------------------------------------
|
||||||
|
bin/x-pack/setup-passwords auto -u "http://localhost:9201"
|
||||||
|
--------------------------------------------------
|
|
@ -197,19 +197,27 @@ bin/elasticsearch
|
||||||
----------------------------------------------------------
|
----------------------------------------------------------
|
||||||
--
|
--
|
||||||
|
|
||||||
.. Set the passwords for all built-in users. You can update passwords from the
|
.. Set the passwords for all built-in users. The +setup-passwords+ command is
|
||||||
**Management > Users** UI in {kib}, use the `setup-passwords` tool, or use the
|
the simplest method to set the built-in users' passwords for the first time.
|
||||||
security user API. For example:
|
|
||||||
+
|
+
|
||||||
--
|
--
|
||||||
|
For example, you can run the command in an "interactive" mode, which prompts you
|
||||||
|
to enter new passwords for the `elastic`, `kibana`, and `logstash_system` users:
|
||||||
|
|
||||||
[source,shell]
|
[source,shell]
|
||||||
--------------------------------------------------
|
--------------------------------------------------
|
||||||
bin/x-pack/setup-passwords interactive
|
bin/x-pack/setup-passwords interactive
|
||||||
--------------------------------------------------
|
--------------------------------------------------
|
||||||
If you prefer to have randomly generated passwords, specify `auto` instead of
|
|
||||||
`interactive`. If the node is not listening on "http://localhost:9200", use the
|
For more information about the command options, see <<setup-passwords>>.
|
||||||
`-u` parameter to specify the appropriate URL. For more information,
|
|
||||||
see {xpack-ref}/setting-up-authentication.html[Setting Up User Authentication].
|
IMPORTANT: The `setup-passwords` command uses a transient bootstrap password
|
||||||
|
that is no longer valid after the command runs successfully. You cannot run the
|
||||||
|
`setup-passwords` command a second time. Instead, you can update passwords from
|
||||||
|
the **Management > Users** UI in {kib} or use the security user API.
|
||||||
|
|
||||||
|
For more information, see
|
||||||
|
{ref}/setting-up-authentication.html#set-built-in-user-passwords[Setting Built-in User Passwords].
|
||||||
--
|
--
|
||||||
|
|
||||||
. {kibana-ref}/installing-xpack-kb.html[Install {xpack} on {kib}].
|
. {kibana-ref}/installing-xpack-kb.html[Install {xpack} on {kib}].
|
||||||
|
|
|
@ -19,13 +19,10 @@ These users have a fixed set of privileges and cannot be authenticated until the
|
||||||
passwords have been set. The `elastic` user can be used to
|
passwords have been set. The `elastic` user can be used to
|
||||||
<<set-built-in-user-passwords,set all of the built-in user passwords>>.
|
<<set-built-in-user-passwords,set all of the built-in user passwords>>.
|
||||||
|
|
||||||
.{security} Built-in Users
|
`elastic`:: A built-in _superuser_. See <<built-in-roles>>.
|
||||||
|========
|
`kibana`:: The user Kibana uses to connect and communicate with Elasticsearch.
|
||||||
| Name | Description
|
`logstash_system`:: The user Logstash uses when storing monitoring information in Elasticsearch.
|
||||||
| `elastic` | A built-in _superuser_. See <<built-in-roles>>.
|
|
||||||
| `kibana` | The user Kibana uses to connect and communicate with Elasticsearch.
|
|
||||||
| `logstash_system` | The user Logstash uses when storing monitoring information in Elasticsearch.
|
|
||||||
|========
|
|
||||||
|
|
||||||
[float]
|
[float]
|
||||||
[[built-in-user-explanation]]
|
[[built-in-user-explanation]]
|
||||||
|
@ -43,74 +40,84 @@ realm will not have any effect on the built-in users. The built-in users can
|
||||||
be disabled individually, using the
|
be disabled individually, using the
|
||||||
{ref}/security-api-users.html[user management API].
|
{ref}/security-api-users.html[user management API].
|
||||||
|
|
||||||
|
[float]
|
||||||
|
[[bootstrap-elastic-passwords]]
|
||||||
|
==== The Elastic Bootstrap Password
|
||||||
|
|
||||||
|
When you install {xpack}, if the `elastic` user does not already have a password,
|
||||||
|
it uses a default bootstrap password. The bootstrap password is a transient
|
||||||
|
password that enables you to run the tools that set all the built-in user passwords.
|
||||||
|
|
||||||
|
By default, the bootstrap password is derived from a randomized `keystore.seed`
|
||||||
|
setting, which is added to the keystore when you install {xpack}. You do not need
|
||||||
|
to know or change this bootstrap password. If you have defined a
|
||||||
|
`bootstrap.password` setting in the keystore, however, that value is used instead.
|
||||||
|
For more information about interacting with the keystore, see
|
||||||
|
{ref}/secure-settings.html[Secure Settings].
|
||||||
|
////
|
||||||
|
//TBD: Is the following still true?
|
||||||
|
As the `elastic` user is stored in the native realm, the password will be
|
||||||
|
synced to all the nodes in a cluster. It is safe to bootstrap the password with
|
||||||
|
multiple nodes as long as the password is the same. If different passwords are
|
||||||
|
set with different nodes, it is unpredictable which password will be bootstrapped.
|
||||||
|
////
|
||||||
|
|
||||||
|
NOTE: After you <<set-built-in-user-passwords,set passwords for the built-in users>>,
|
||||||
|
in particular for the `elastic` user, there is no further use for the bootstrap
|
||||||
|
password.
|
||||||
|
|
||||||
[float]
|
[float]
|
||||||
[[set-built-in-user-passwords]]
|
[[set-built-in-user-passwords]]
|
||||||
==== Set Built-in User Passwords
|
==== Setting Built-in User Passwords
|
||||||
[IMPORTANT]
|
|
||||||
=============================================================================
|
|
||||||
You must set the passwords for all built-in users.
|
You must set the passwords for all built-in users.
|
||||||
You can update passwords from the *Management > Users* UI in Kibana, using the
|
|
||||||
setup-passwords tool, or with the security user api.
|
|
||||||
|
|
||||||
The setup-passwords tool is a command line tool that is provided to assist with
|
The +setup-passwords+ tool is the simplest method to set the built-in users'
|
||||||
setup. When it is run, it will use the `elastic` user to execute API requests
|
passwords for the first time. It uses the `elastic` user's bootstrap password to
|
||||||
that will change the passwords of the `elastic`, `kibana`, and
|
run user management API requests. For example, you can run the command in
|
||||||
`logstash_system` users. In "auto" mode the passwords will be generated randomly and
|
an "interactive" mode, which prompts you to enter new passwords for the
|
||||||
printed to the console.
|
`elastic`, `kibana`, and `logstash_system` users:
|
||||||
|
|
||||||
[source,shell]
|
|
||||||
--------------------------------------------------
|
|
||||||
bin/x-pack/setup-passwords auto
|
|
||||||
--------------------------------------------------
|
|
||||||
|
|
||||||
There is also an "interactive" mode that will prompt you to manually enter passwords.
|
|
||||||
|
|
||||||
[source,shell]
|
[source,shell]
|
||||||
--------------------------------------------------
|
--------------------------------------------------
|
||||||
bin/x-pack/setup-passwords interactive
|
bin/x-pack/setup-passwords interactive
|
||||||
--------------------------------------------------
|
--------------------------------------------------
|
||||||
|
|
||||||
If the node is not listening at "http://localhost:9200", you will need to pass the url parameter
|
For more information about the command options, see
|
||||||
to tell the tool where to submit the requests.
|
{ref}/setup-passwords.html[setup-passwords].
|
||||||
|
|
||||||
|
IMPORTANT: After you set a password for the `elastic` user, the bootstrap
|
||||||
|
password is no longer valid; you cannot run the `setup-passwords` command a
|
||||||
|
second time.
|
||||||
|
|
||||||
|
Alternatively, you can set the initial passwords for the built-in users by using
|
||||||
|
the *Management > Users* page in {kib} or the
|
||||||
|
{ref}/security-api-change-password.html[Change Password API]. These methods are
|
||||||
|
more complex. You must supply the `elastic` user and its bootstrap password to
|
||||||
|
log into {kib} or run the API. This requirement means that you cannot use the
|
||||||
|
default bootstrap password that is derived from the `keystore.seed` setting.
|
||||||
|
Instead, you must explicitly set a `bootstrap.password` setting in the keystore
|
||||||
|
before you start {es}. For example, the following command prompts you to enter a
|
||||||
|
new bootstrap password:
|
||||||
|
|
||||||
[source,shell]
|
[source,shell]
|
||||||
--------------------------------------------------
|
----------------------------------------------------
|
||||||
bin/x-pack/setup-passwords auto -u "http://localhost:9201"
|
bin/elasticsearch-keystore add "bootstrap.password"
|
||||||
--------------------------------------------------
|
----------------------------------------------------
|
||||||
|
|
||||||
The {ref}/security-api-users.html#security-api-reset-user-password[Reset Password API] can
|
You can then start {es} and {kib} and use the `elastic` user and bootstrap
|
||||||
also be used to change the passwords manually.
|
password to log into {kib} and change the passwords. Alternatively, you can
|
||||||
|
submit Change Password API requests for each built-in user. These methods are
|
||||||
|
better suited for changing your passwords after the initial setup is complete,
|
||||||
|
since at that point the bootstrap password is no longer required.
|
||||||
|
|
||||||
[source,js]
|
[float]
|
||||||
---------------------------------------------------------------------
|
[[add-built-in-user-passwords]]
|
||||||
PUT _xpack/security/user/elastic/_password
|
==== Adding Built-in User Passwords To {kib} and Logstash
|
||||||
{
|
|
||||||
"password": "elasticpassword"
|
|
||||||
}
|
|
||||||
---------------------------------------------------------------------
|
|
||||||
// CONSOLE
|
|
||||||
|
|
||||||
[source,js]
|
After the `kibana` user password is set, you need to update the {kib} server
|
||||||
---------------------------------------------------------------------
|
with the new password by setting `elasticsearch.password` in the `kibana.yml`
|
||||||
PUT _xpack/security/user/kibana/_password
|
configuration file:
|
||||||
{
|
|
||||||
"password": "kibanapassword"
|
|
||||||
}
|
|
||||||
---------------------------------------------------------------------
|
|
||||||
// CONSOLE
|
|
||||||
|
|
||||||
[source,js]
|
|
||||||
---------------------------------------------------------------------
|
|
||||||
PUT _xpack/security/user/logstash_system/_password
|
|
||||||
{
|
|
||||||
"password": "logstashpassword"
|
|
||||||
}
|
|
||||||
---------------------------------------------------------------------
|
|
||||||
// CONSOLE
|
|
||||||
|
|
||||||
Once the `kibana` user password is reset, you need to update the Kibana server
|
|
||||||
with the new password by setting `elasticsearch.password` in the
|
|
||||||
`kibana.yml` configuration file:
|
|
||||||
|
|
||||||
[source,yaml]
|
[source,yaml]
|
||||||
-----------------------------------------------
|
-----------------------------------------------
|
||||||
|
@ -138,16 +145,15 @@ Once the password has been changed, you can enable the user via the following AP
|
||||||
PUT _xpack/security/user/logstash_system/_enable
|
PUT _xpack/security/user/logstash_system/_enable
|
||||||
---------------------------------------------------------------------
|
---------------------------------------------------------------------
|
||||||
// CONSOLE
|
// CONSOLE
|
||||||
=============================================================================
|
|
||||||
|
|
||||||
[float]
|
[float]
|
||||||
[[disabling-default-password]]
|
[[disabling-default-password]]
|
||||||
==== Disable Default Password Functionality
|
==== Disabling Default Password Functionality
|
||||||
[IMPORTANT]
|
[IMPORTANT]
|
||||||
=============================================================================
|
=============================================================================
|
||||||
This setting is deprecated. The elastic user no longer has a default password. The password must
|
This setting is deprecated. The elastic user no longer has a default password.
|
||||||
be set before the user can be used.
|
The password must be set before the user can be used.
|
||||||
|
See <<bootstrap-elastic-passwords>>.
|
||||||
=============================================================================
|
=============================================================================
|
||||||
|
|
||||||
[float]
|
[float]
|
||||||
|
|
|
@ -16,23 +16,12 @@ To get started with {security}:
|
||||||
|
|
||||||
. <<installing-xpack, Install X-Pack>>.
|
. <<installing-xpack, Install X-Pack>>.
|
||||||
|
|
||||||
. On at least one of the nodes in your cluster, set the "bootstrap.password" secure setting in the keystore.
|
. Start {es} and {kib}.
|
||||||
+
|
|
||||||
--
|
|
||||||
[source,shell]
|
|
||||||
--------------------------------------------------
|
|
||||||
bin/elasticsearch-keystore create
|
|
||||||
bin/elasticsearch-keystore add "bootstrap.password"
|
|
||||||
--------------------------------------------------
|
|
||||||
|
|
||||||
--
|
. Set the passwords of the built in `elastic`, `kibana`, and `logstash_system` users.
|
||||||
|
In most cases, you can simply run the `bin/x-pack/setup-passwords` tool on one of the nodes in your cluster.
|
||||||
. Start Elasticsearch and Kibana. The Elasticsearch node with the "bootstrap.password" setting will use that
|
Run that command with the same user that is running your {es} process.
|
||||||
setting to set the `elastic` user password on node startup.
|
In "auto" mode this tool will randomly generate passwords and print them to the console.
|
||||||
|
|
||||||
|
|
||||||
. Set the passwords of the built in `elastic`, `kibana`, and `logstash_system` users using the provided setup
|
|
||||||
passwords tool. In "auto" mode this tool will randomly generate passwords and print them to the console.
|
|
||||||
+
|
+
|
||||||
--
|
--
|
||||||
[source,shell]
|
[source,shell]
|
||||||
|
@ -40,9 +29,10 @@ passwords tool. In "auto" mode this tool will randomly generate passwords and pr
|
||||||
bin/x-pack/setup-passwords auto
|
bin/x-pack/setup-passwords auto
|
||||||
--------------------------------------------------
|
--------------------------------------------------
|
||||||
|
|
||||||
|
For more information, see <<set-built-in-user-passwords>>.
|
||||||
--
|
--
|
||||||
|
|
||||||
. Set up roles and users to control access to Elasticsearch and Kibana.
|
. Set up roles and users to control access to {es} and {kib}.
|
||||||
For example, to grant _John Doe_ full access to all indices that match
|
For example, to grant _John Doe_ full access to all indices that match
|
||||||
the pattern `events*` and enable him to create visualizations and dashboards
|
the pattern `events*` and enable him to create visualizations and dashboards
|
||||||
for those indices in Kibana, you could create an `events_admin` role and
|
for those indices in Kibana, you could create an `events_admin` role and
|
||||||
|
@ -76,7 +66,7 @@ curl -XPOST -u elastic 'localhost:9200/_xpack/security/user/johndoe' -H "Content
|
||||||
|
|
||||||
[[enable-auditing]]
|
[[enable-auditing]]
|
||||||
. Enable Auditing to keep track of attempted and successful interactions with
|
. Enable Auditing to keep track of attempted and successful interactions with
|
||||||
your Elasticsearch cluster:
|
your {es} cluster:
|
||||||
+
|
+
|
||||||
--
|
--
|
||||||
.. Add the following setting to `elasticsearch.yml` on all nodes in your cluster:
|
.. Add the following setting to `elasticsearch.yml` on all nodes in your cluster:
|
||||||
|
@ -85,10 +75,10 @@ curl -XPOST -u elastic 'localhost:9200/_xpack/security/user/johndoe' -H "Content
|
||||||
----------------------------
|
----------------------------
|
||||||
xpack.security.audit.enabled: true
|
xpack.security.audit.enabled: true
|
||||||
----------------------------
|
----------------------------
|
||||||
.. Restart Elasticsearch.
|
.. Restart {es}.
|
||||||
|
|
||||||
By default, events are logged to a dedicated `elasticsearch-access.log` file in
|
By default, events are logged to a dedicated `elasticsearch-access.log` file in
|
||||||
`ES_HOME/logs`. You can also store the events in an Elasticsearch index for
|
`ES_HOME/logs`. You can also store the events in an {es} index for
|
||||||
easier analysis and control what events are logged. For more information, see
|
easier analysis and control what events are logged. For more information, see
|
||||||
{xpack-ref}/auditing.html[Configuring Auditing].
|
{xpack-ref}/auditing.html[Configuring Auditing].
|
||||||
--
|
--
|
||||||
|
|
|
@ -30,13 +30,9 @@ Set to `false` to disable {es} {monitoring} for Elasticsearch.
|
||||||
The `xpack.monitoring.collection` settings control how data is collected from
|
The `xpack.monitoring.collection` settings control how data is collected from
|
||||||
your Elasticsearch nodes.
|
your Elasticsearch nodes.
|
||||||
|
|
||||||
`xpack.monitoring.collection.cluster.state.timeout`::
|
|
||||||
|
|
||||||
Sets the timeout for collecting the cluster state. Defaults to `10m`.
|
|
||||||
|
|
||||||
`xpack.monitoring.collection.cluster.stats.timeout`::
|
`xpack.monitoring.collection.cluster.stats.timeout`::
|
||||||
|
|
||||||
Sets the timeout for collecting the cluster statistics. Defaults to `10m`.
|
Sets the timeout for collecting the cluster statistics. Defaults to `10s`.
|
||||||
|
|
||||||
`xpack.monitoring.collection.indices`::
|
`xpack.monitoring.collection.indices`::
|
||||||
|
|
||||||
|
@ -50,11 +46,11 @@ You can update this setting through the Cluster Update Settings API.
|
||||||
|
|
||||||
`xpack.monitoring.collection.index.stats.timeout`::
|
`xpack.monitoring.collection.index.stats.timeout`::
|
||||||
|
|
||||||
Sets the timeout for collecting index statistics. Defaults to `10m`.
|
Sets the timeout for collecting index statistics. Defaults to `10s`.
|
||||||
|
|
||||||
`xpack.monitoring.collection.indices.stats.timeout`::
|
`xpack.monitoring.collection.indices.stats.timeout`::
|
||||||
|
|
||||||
Sets the timeout for collecting total indices statistics. Defaults to `10m`.
|
Sets the timeout for collecting total indices statistics. Defaults to `10s`.
|
||||||
|
|
||||||
`xpack.monitoring.collection.index.recovery.active_only`::
|
`xpack.monitoring.collection.index.recovery.active_only`::
|
||||||
|
|
||||||
|
@ -63,7 +59,7 @@ collect only active recoveries. Defaults to `false`.
|
||||||
|
|
||||||
`xpack.monitoring.collection.index.recovery.timeout`::
|
`xpack.monitoring.collection.index.recovery.timeout`::
|
||||||
|
|
||||||
Sets the timeout for collecting the recovery information. Defaults to `10m`.
|
Sets the timeout for collecting the recovery information. Defaults to `10s`.
|
||||||
|
|
||||||
`xpack.monitoring.collection.interval`::
|
`xpack.monitoring.collection.interval`::
|
||||||
|
|
||||||
|
|
|
@ -160,8 +160,7 @@ class LicensesMetaData extends AbstractNamedDiffable<MetaData.Custom> implements
|
||||||
streamOutput.writeBoolean(true); // has a license
|
streamOutput.writeBoolean(true); // has a license
|
||||||
license.writeTo(streamOutput);
|
license.writeTo(streamOutput);
|
||||||
}
|
}
|
||||||
// TODO Eventually this should be 6.0. But it is 7.0 temporarily for bwc
|
if (streamOutput.getVersion().onOrAfter(Version.V_6_1_0)) {
|
||||||
if (streamOutput.getVersion().onOrAfter(Version.V_7_0_0_alpha1)) {
|
|
||||||
if (trialVersion == null) {
|
if (trialVersion == null) {
|
||||||
streamOutput.writeBoolean(false);
|
streamOutput.writeBoolean(false);
|
||||||
} else {
|
} else {
|
||||||
|
@ -177,8 +176,7 @@ class LicensesMetaData extends AbstractNamedDiffable<MetaData.Custom> implements
|
||||||
} else {
|
} else {
|
||||||
license = LICENSE_TOMBSTONE;
|
license = LICENSE_TOMBSTONE;
|
||||||
}
|
}
|
||||||
// TODO Eventually this should be 6.0. But it is 7.0 temporarily for bwc
|
if (streamInput.getVersion().onOrAfter(Version.V_6_1_0)) {
|
||||||
if (streamInput.getVersion().onOrAfter(Version.V_7_0_0_alpha1)) {
|
|
||||||
boolean hasExercisedTrial = streamInput.readBoolean();
|
boolean hasExercisedTrial = streamInput.readBoolean();
|
||||||
if (hasExercisedTrial) {
|
if (hasExercisedTrial) {
|
||||||
this.trialVersion = Version.readVersion(streamInput);
|
this.trialVersion = Version.readVersion(streamInput);
|
||||||
|
|
|
@ -10,7 +10,7 @@ import org.elasticsearch.common.logging.LoggerMessageFormat;
|
||||||
import org.elasticsearch.common.settings.Settings;
|
import org.elasticsearch.common.settings.Settings;
|
||||||
import org.elasticsearch.license.License.OperationMode;
|
import org.elasticsearch.license.License.OperationMode;
|
||||||
import org.elasticsearch.xpack.XPackPlugin;
|
import org.elasticsearch.xpack.XPackPlugin;
|
||||||
import org.elasticsearch.xpack.monitoring.MonitoringSettings;
|
import org.elasticsearch.xpack.monitoring.Monitoring;
|
||||||
|
|
||||||
import java.util.Collections;
|
import java.util.Collections;
|
||||||
import java.util.LinkedHashMap;
|
import java.util.LinkedHashMap;
|
||||||
|
@ -159,7 +159,7 @@ public class XPackLicenseState {
|
||||||
newMode, newMode, newMode),
|
newMode, newMode, newMode),
|
||||||
LoggerMessageFormat.format(
|
LoggerMessageFormat.format(
|
||||||
"Automatic index cleanup is locked to {} days for clusters with [{}] license.",
|
"Automatic index cleanup is locked to {} days for clusters with [{}] license.",
|
||||||
MonitoringSettings.HISTORY_DURATION.getDefault(Settings.EMPTY).days(), newMode)
|
Monitoring.HISTORY_DURATION.getDefault(Settings.EMPTY).days(), newMode)
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
|
@ -82,7 +82,6 @@ import org.elasticsearch.xpack.ml.MachineLearning;
|
||||||
import org.elasticsearch.xpack.ml.MachineLearningFeatureSet;
|
import org.elasticsearch.xpack.ml.MachineLearningFeatureSet;
|
||||||
import org.elasticsearch.xpack.monitoring.Monitoring;
|
import org.elasticsearch.xpack.monitoring.Monitoring;
|
||||||
import org.elasticsearch.xpack.monitoring.MonitoringFeatureSet;
|
import org.elasticsearch.xpack.monitoring.MonitoringFeatureSet;
|
||||||
import org.elasticsearch.xpack.monitoring.MonitoringSettings;
|
|
||||||
import org.elasticsearch.xpack.notification.email.Account;
|
import org.elasticsearch.xpack.notification.email.Account;
|
||||||
import org.elasticsearch.xpack.notification.email.EmailService;
|
import org.elasticsearch.xpack.notification.email.EmailService;
|
||||||
import org.elasticsearch.xpack.notification.email.attachment.DataAttachmentParser;
|
import org.elasticsearch.xpack.notification.email.attachment.DataAttachmentParser;
|
||||||
|
@ -415,7 +414,7 @@ public class XPackPlugin extends Plugin implements ScriptPlugin, ActionPlugin, I
|
||||||
public List<Setting<?>> getSettings() {
|
public List<Setting<?>> getSettings() {
|
||||||
ArrayList<Setting<?>> settings = new ArrayList<>();
|
ArrayList<Setting<?>> settings = new ArrayList<>();
|
||||||
settings.addAll(Security.getSettings(transportClientMode, extensionsService));
|
settings.addAll(Security.getSettings(transportClientMode, extensionsService));
|
||||||
settings.addAll(MonitoringSettings.getSettings());
|
settings.addAll(monitoring.getSettings());
|
||||||
settings.addAll(watcher.getSettings());
|
settings.addAll(watcher.getSettings());
|
||||||
settings.addAll(machineLearning.getSettings());
|
settings.addAll(machineLearning.getSettings());
|
||||||
settings.addAll(licensing.getSettings());
|
settings.addAll(licensing.getSettings());
|
||||||
|
@ -451,7 +450,7 @@ public class XPackPlugin extends Plugin implements ScriptPlugin, ActionPlugin, I
|
||||||
filters.add("xpack.notification.pagerduty.account.*." + PagerDutyAccount.SERVICE_KEY_SETTING);
|
filters.add("xpack.notification.pagerduty.account.*." + PagerDutyAccount.SERVICE_KEY_SETTING);
|
||||||
filters.add("xpack.notification.hipchat.account.*.auth_token");
|
filters.add("xpack.notification.hipchat.account.*.auth_token");
|
||||||
filters.addAll(security.getSettingsFilter(extensionsService));
|
filters.addAll(security.getSettingsFilter(extensionsService));
|
||||||
filters.addAll(MonitoringSettings.getSettingsFilter());
|
filters.addAll(monitoring.getSettingsFilter());
|
||||||
if (transportClientMode == false) {
|
if (transportClientMode == false) {
|
||||||
for (XPackExtension extension : extensionsService.getExtensions()) {
|
for (XPackExtension extension : extensionsService.getExtensions()) {
|
||||||
filters.addAll(extension.getSettingsFilter());
|
filters.addAll(extension.getSettingsFilter());
|
||||||
|
|
|
@ -283,7 +283,7 @@ public class MachineLearning implements ActionPlugin {
|
||||||
// This will only only happen when path.home is not set, which is disallowed in production
|
// This will only only happen when path.home is not set, which is disallowed in production
|
||||||
throw new ElasticsearchException("Failed to create native process controller for Machine Learning");
|
throw new ElasticsearchException("Failed to create native process controller for Machine Learning");
|
||||||
}
|
}
|
||||||
autodetectProcessFactory = new NativeAutodetectProcessFactory(jobProvider, env, settings, nativeController, internalClient);
|
autodetectProcessFactory = new NativeAutodetectProcessFactory(env, settings, nativeController, internalClient);
|
||||||
normalizerProcessFactory = new NativeNormalizerProcessFactory(env, settings, nativeController);
|
normalizerProcessFactory = new NativeNormalizerProcessFactory(env, settings, nativeController);
|
||||||
} catch (IOException e) {
|
} catch (IOException e) {
|
||||||
// This also should not happen in production, as the MachineLearningFeatureSet should have
|
// This also should not happen in production, as the MachineLearningFeatureSet should have
|
||||||
|
|
|
@ -15,7 +15,6 @@ import org.elasticsearch.common.logging.Loggers;
|
||||||
import org.elasticsearch.common.util.concurrent.AbstractRunnable;
|
import org.elasticsearch.common.util.concurrent.AbstractRunnable;
|
||||||
import org.elasticsearch.common.xcontent.NamedXContentRegistry;
|
import org.elasticsearch.common.xcontent.NamedXContentRegistry;
|
||||||
import org.elasticsearch.common.xcontent.XContentType;
|
import org.elasticsearch.common.xcontent.XContentType;
|
||||||
import org.elasticsearch.xpack.ml.action.OpenJobAction.JobTask;
|
|
||||||
import org.elasticsearch.xpack.ml.job.config.DataDescription;
|
import org.elasticsearch.xpack.ml.job.config.DataDescription;
|
||||||
import org.elasticsearch.xpack.ml.job.config.Job;
|
import org.elasticsearch.xpack.ml.job.config.Job;
|
||||||
import org.elasticsearch.xpack.ml.job.config.JobUpdate;
|
import org.elasticsearch.xpack.ml.job.config.JobUpdate;
|
||||||
|
@ -56,7 +55,6 @@ public class AutodetectCommunicator implements Closeable {
|
||||||
private static final Duration FLUSH_PROCESS_CHECK_FREQUENCY = Duration.ofSeconds(1);
|
private static final Duration FLUSH_PROCESS_CHECK_FREQUENCY = Duration.ofSeconds(1);
|
||||||
|
|
||||||
private final Job job;
|
private final Job job;
|
||||||
private final JobTask jobTask;
|
|
||||||
private final AutodetectProcess autodetectProcess;
|
private final AutodetectProcess autodetectProcess;
|
||||||
private final StateStreamer stateStreamer;
|
private final StateStreamer stateStreamer;
|
||||||
private final DataCountsReporter dataCountsReporter;
|
private final DataCountsReporter dataCountsReporter;
|
||||||
|
@ -66,12 +64,11 @@ public class AutodetectCommunicator implements Closeable {
|
||||||
private final NamedXContentRegistry xContentRegistry;
|
private final NamedXContentRegistry xContentRegistry;
|
||||||
private volatile boolean processKilled;
|
private volatile boolean processKilled;
|
||||||
|
|
||||||
AutodetectCommunicator(Job job, JobTask jobTask, AutodetectProcess process, StateStreamer stateStreamer,
|
AutodetectCommunicator(Job job, AutodetectProcess process, StateStreamer stateStreamer,
|
||||||
DataCountsReporter dataCountsReporter, AutoDetectResultProcessor autoDetectResultProcessor,
|
DataCountsReporter dataCountsReporter, AutoDetectResultProcessor autoDetectResultProcessor,
|
||||||
Consumer<Exception> onFinishHandler, NamedXContentRegistry xContentRegistry,
|
Consumer<Exception> onFinishHandler, NamedXContentRegistry xContentRegistry,
|
||||||
ExecutorService autodetectWorkerExecutor) {
|
ExecutorService autodetectWorkerExecutor) {
|
||||||
this.job = job;
|
this.job = job;
|
||||||
this.jobTask = jobTask;
|
|
||||||
this.autodetectProcess = process;
|
this.autodetectProcess = process;
|
||||||
this.stateStreamer = stateStreamer;
|
this.stateStreamer = stateStreamer;
|
||||||
this.dataCountsReporter = dataCountsReporter;
|
this.dataCountsReporter = dataCountsReporter;
|
||||||
|
@ -261,10 +258,6 @@ public class AutodetectCommunicator implements Closeable {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public JobTask getJobTask() {
|
|
||||||
return jobTask;
|
|
||||||
}
|
|
||||||
|
|
||||||
public ZonedDateTime getProcessStartTime() {
|
public ZonedDateTime getProcessStartTime() {
|
||||||
return autodetectProcess.getProcessStartTime();
|
return autodetectProcess.getProcessStartTime();
|
||||||
}
|
}
|
||||||
|
|
|
@ -17,7 +17,6 @@ import org.elasticsearch.common.settings.Settings;
|
||||||
import org.elasticsearch.common.util.concurrent.AbstractRunnable;
|
import org.elasticsearch.common.util.concurrent.AbstractRunnable;
|
||||||
import org.elasticsearch.common.util.concurrent.EsRejectedExecutionException;
|
import org.elasticsearch.common.util.concurrent.EsRejectedExecutionException;
|
||||||
import org.elasticsearch.common.util.concurrent.ThreadContext;
|
import org.elasticsearch.common.util.concurrent.ThreadContext;
|
||||||
import org.elasticsearch.common.util.set.Sets;
|
|
||||||
import org.elasticsearch.common.xcontent.NamedXContentRegistry;
|
import org.elasticsearch.common.xcontent.NamedXContentRegistry;
|
||||||
import org.elasticsearch.common.xcontent.XContentBuilder;
|
import org.elasticsearch.common.xcontent.XContentBuilder;
|
||||||
import org.elasticsearch.common.xcontent.XContentType;
|
import org.elasticsearch.common.xcontent.XContentType;
|
||||||
|
@ -50,7 +49,6 @@ import org.elasticsearch.xpack.ml.job.process.normalizer.NormalizerFactory;
|
||||||
import org.elasticsearch.xpack.ml.job.process.normalizer.Renormalizer;
|
import org.elasticsearch.xpack.ml.job.process.normalizer.Renormalizer;
|
||||||
import org.elasticsearch.xpack.ml.job.process.normalizer.ScoresUpdater;
|
import org.elasticsearch.xpack.ml.job.process.normalizer.ScoresUpdater;
|
||||||
import org.elasticsearch.xpack.ml.job.process.normalizer.ShortCircuitingRenormalizer;
|
import org.elasticsearch.xpack.ml.job.process.normalizer.ShortCircuitingRenormalizer;
|
||||||
import org.elasticsearch.xpack.ml.job.results.Forecast;
|
|
||||||
import org.elasticsearch.xpack.ml.notifications.Auditor;
|
import org.elasticsearch.xpack.ml.notifications.Auditor;
|
||||||
import org.elasticsearch.xpack.ml.utils.ExceptionsHelper;
|
import org.elasticsearch.xpack.ml.utils.ExceptionsHelper;
|
||||||
import org.elasticsearch.xpack.persistent.PersistentTasksCustomMetaData.PersistentTask;
|
import org.elasticsearch.xpack.persistent.PersistentTasksCustomMetaData.PersistentTask;
|
||||||
|
@ -59,7 +57,6 @@ import java.io.IOException;
|
||||||
import java.io.InputStream;
|
import java.io.InputStream;
|
||||||
import java.time.Duration;
|
import java.time.Duration;
|
||||||
import java.time.ZonedDateTime;
|
import java.time.ZonedDateTime;
|
||||||
import java.util.Arrays;
|
|
||||||
import java.util.Date;
|
import java.util.Date;
|
||||||
import java.util.Iterator;
|
import java.util.Iterator;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
@ -105,8 +102,7 @@ public class AutodetectProcessManager extends AbstractComponent {
|
||||||
private final JobResultsPersister jobResultsPersister;
|
private final JobResultsPersister jobResultsPersister;
|
||||||
private final JobDataCountsPersister jobDataCountsPersister;
|
private final JobDataCountsPersister jobDataCountsPersister;
|
||||||
|
|
||||||
private final ConcurrentMap<Long, AutodetectCommunicator> autoDetectCommunicatorByOpenJob = new ConcurrentHashMap<>();
|
private final ConcurrentMap<Long, ProcessContext> processByAllocation = new ConcurrentHashMap<>();
|
||||||
private final ConcurrentMap<Long, AutodetectCommunicator> autoDetectCommunicatorByClosingJob = new ConcurrentHashMap<>();
|
|
||||||
|
|
||||||
private final int maxAllowedRunningJobs;
|
private final int maxAllowedRunningJobs;
|
||||||
|
|
||||||
|
@ -134,53 +130,37 @@ public class AutodetectProcessManager extends AbstractComponent {
|
||||||
}
|
}
|
||||||
|
|
||||||
public synchronized void closeAllJobsOnThisNode(String reason) throws IOException {
|
public synchronized void closeAllJobsOnThisNode(String reason) throws IOException {
|
||||||
int numJobs = autoDetectCommunicatorByOpenJob.size();
|
int numJobs = processByAllocation.size();
|
||||||
if (numJobs != 0) {
|
if (numJobs != 0) {
|
||||||
logger.info("Closing [{}] jobs, because [{}]", numJobs, reason);
|
logger.info("Closing [{}] jobs, because [{}]", numJobs, reason);
|
||||||
|
|
||||||
for (AutodetectCommunicator communicator : autoDetectCommunicatorByOpenJob.values()) {
|
for (ProcessContext process : processByAllocation.values()) {
|
||||||
closeJob(communicator.getJobTask(), false, reason);
|
closeJob(process.getJobTask(), false, reason);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public void killProcess(JobTask jobTask, boolean awaitCompletion, String reason) {
|
public void killProcess(JobTask jobTask, boolean awaitCompletion, String reason) {
|
||||||
String extraInfo;
|
ProcessContext processContext = processByAllocation.remove(jobTask.getAllocationId());
|
||||||
AutodetectCommunicator communicator = autoDetectCommunicatorByOpenJob.remove(jobTask.getAllocationId());
|
if (processContext != null) {
|
||||||
if (communicator == null) {
|
processContext.newKillBuilder()
|
||||||
extraInfo = " while closing";
|
.setAwaitCompletion(awaitCompletion)
|
||||||
// if there isn't an open job, check for a closing job
|
.setFinish(true)
|
||||||
communicator = autoDetectCommunicatorByClosingJob.remove(jobTask.getAllocationId());
|
.setReason(reason)
|
||||||
} else {
|
.kill();
|
||||||
extraInfo = "";
|
|
||||||
}
|
|
||||||
if (communicator != null) {
|
|
||||||
if (reason == null) {
|
|
||||||
logger.info("Killing job [{}]{}", jobTask.getJobId(), extraInfo);
|
|
||||||
} else {
|
|
||||||
logger.info("Killing job [{}]{}, because [{}]", jobTask.getJobId(), extraInfo, reason);
|
|
||||||
}
|
|
||||||
killProcess(communicator, jobTask.getJobId(), awaitCompletion, true);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public void killAllProcessesOnThisNode() {
|
public void killAllProcessesOnThisNode() {
|
||||||
// first kill open jobs, then closing jobs
|
Iterator<ProcessContext> iterator = processByAllocation.values().iterator();
|
||||||
for (Iterator<AutodetectCommunicator> iter : Arrays.asList(autoDetectCommunicatorByOpenJob.values().iterator(),
|
while (iterator.hasNext()) {
|
||||||
autoDetectCommunicatorByClosingJob.values().iterator())) {
|
ProcessContext processContext = iterator.next();
|
||||||
while (iter.hasNext()) {
|
processContext.newKillBuilder()
|
||||||
AutodetectCommunicator communicator = iter.next();
|
.setAwaitCompletion(false)
|
||||||
iter.remove();
|
.setFinish(false)
|
||||||
killProcess(communicator, communicator.getJobTask().getJobId(), false, false);
|
.setSilent(true)
|
||||||
}
|
.kill();
|
||||||
}
|
iterator.remove();
|
||||||
}
|
|
||||||
|
|
||||||
private void killProcess(AutodetectCommunicator communicator, String jobId, boolean awaitCompletion, boolean finish) {
|
|
||||||
try {
|
|
||||||
communicator.killProcess(awaitCompletion, finish);
|
|
||||||
} catch (IOException e) {
|
|
||||||
logger.error("[{}] Failed to kill autodetect process for job", jobId);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -205,7 +185,7 @@ public class AutodetectProcessManager extends AbstractComponent {
|
||||||
*/
|
*/
|
||||||
public void processData(JobTask jobTask, InputStream input, XContentType xContentType,
|
public void processData(JobTask jobTask, InputStream input, XContentType xContentType,
|
||||||
DataLoadParams params, BiConsumer<DataCounts, Exception> handler) {
|
DataLoadParams params, BiConsumer<DataCounts, Exception> handler) {
|
||||||
AutodetectCommunicator communicator = autoDetectCommunicatorByOpenJob.get(jobTask.getAllocationId());
|
AutodetectCommunicator communicator = getOpenAutodetectCommunicator(jobTask);
|
||||||
if (communicator == null) {
|
if (communicator == null) {
|
||||||
throw ExceptionsHelper.conflictStatusException("Cannot process data because job [" + jobTask.getJobId() + "] is not open");
|
throw ExceptionsHelper.conflictStatusException("Cannot process data because job [" + jobTask.getJobId() + "] is not open");
|
||||||
}
|
}
|
||||||
|
@ -223,7 +203,7 @@ public class AutodetectProcessManager extends AbstractComponent {
|
||||||
*/
|
*/
|
||||||
public void flushJob(JobTask jobTask, FlushJobParams params, ActionListener<FlushAcknowledgement> handler) {
|
public void flushJob(JobTask jobTask, FlushJobParams params, ActionListener<FlushAcknowledgement> handler) {
|
||||||
logger.debug("Flushing job {}", jobTask.getJobId());
|
logger.debug("Flushing job {}", jobTask.getJobId());
|
||||||
AutodetectCommunicator communicator = autoDetectCommunicatorByOpenJob.get(jobTask.getAllocationId());
|
AutodetectCommunicator communicator = getOpenAutodetectCommunicator(jobTask);
|
||||||
if (communicator == null) {
|
if (communicator == null) {
|
||||||
String message = String.format(Locale.ROOT, "Cannot flush because job [%s] is not open", jobTask.getJobId());
|
String message = String.format(Locale.ROOT, "Cannot flush because job [%s] is not open", jobTask.getJobId());
|
||||||
logger.debug(message);
|
logger.debug(message);
|
||||||
|
@ -250,7 +230,7 @@ public class AutodetectProcessManager extends AbstractComponent {
|
||||||
*/
|
*/
|
||||||
public void forecastJob(JobTask jobTask, ForecastParams params, Consumer<Exception> handler) {
|
public void forecastJob(JobTask jobTask, ForecastParams params, Consumer<Exception> handler) {
|
||||||
logger.debug("Forecasting job {}", jobTask.getJobId());
|
logger.debug("Forecasting job {}", jobTask.getJobId());
|
||||||
AutodetectCommunicator communicator = autoDetectCommunicatorByOpenJob.get(jobTask.getAllocationId());
|
AutodetectCommunicator communicator = getOpenAutodetectCommunicator(jobTask);
|
||||||
if (communicator == null) {
|
if (communicator == null) {
|
||||||
String message = String.format(Locale.ROOT, "Cannot forecast because job [%s] is not open", jobTask.getJobId());
|
String message = String.format(Locale.ROOT, "Cannot forecast because job [%s] is not open", jobTask.getJobId());
|
||||||
logger.debug(message);
|
logger.debug(message);
|
||||||
|
@ -271,7 +251,7 @@ public class AutodetectProcessManager extends AbstractComponent {
|
||||||
|
|
||||||
public void writeUpdateProcessMessage(JobTask jobTask, List<JobUpdate.DetectorUpdate> updates, ModelPlotConfig config,
|
public void writeUpdateProcessMessage(JobTask jobTask, List<JobUpdate.DetectorUpdate> updates, ModelPlotConfig config,
|
||||||
Consumer<Exception> handler) {
|
Consumer<Exception> handler) {
|
||||||
AutodetectCommunicator communicator = autoDetectCommunicatorByOpenJob.get(jobTask.getAllocationId());
|
AutodetectCommunicator communicator = getOpenAutodetectCommunicator(jobTask);
|
||||||
if (communicator == null) {
|
if (communicator == null) {
|
||||||
String message = "Cannot process update model debug config because job [" + jobTask.getJobId() + "] is not open";
|
String message = "Cannot process update model debug config because job [" + jobTask.getJobId() + "] is not open";
|
||||||
logger.debug(message);
|
logger.debug(message);
|
||||||
|
@ -298,6 +278,7 @@ public class AutodetectProcessManager extends AbstractComponent {
|
||||||
}
|
}
|
||||||
|
|
||||||
logger.info("Opening job [{}]", jobId);
|
logger.info("Opening job [{}]", jobId);
|
||||||
|
processByAllocation.putIfAbsent(jobTask.getAllocationId(), new ProcessContext(jobTask));
|
||||||
jobProvider.getAutodetectParams(job, params -> {
|
jobProvider.getAutodetectParams(job, params -> {
|
||||||
// We need to fork, otherwise we restore model state from a network thread (several GET api calls):
|
// We need to fork, otherwise we restore model state from a network thread (several GET api calls):
|
||||||
threadPool.executor(MachineLearning.UTILITY_THREAD_POOL_NAME).execute(new AbstractRunnable() {
|
threadPool.executor(MachineLearning.UTILITY_THREAD_POOL_NAME).execute(new AbstractRunnable() {
|
||||||
|
@ -308,19 +289,29 @@ public class AutodetectProcessManager extends AbstractComponent {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected void doRun() throws Exception {
|
protected void doRun() throws Exception {
|
||||||
|
ProcessContext processContext = processByAllocation.get(jobTask.getAllocationId());
|
||||||
|
if (processContext == null) {
|
||||||
|
logger.debug("Aborted opening job [{}] as it has been closed", jobId);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
if (processContext.getState() != ProcessContext.ProcessStateName.NOT_RUNNING) {
|
||||||
|
logger.debug("Cannot open job [{}] when its state is [{}]", jobId, processContext.getState().getClass().getName());
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
try {
|
try {
|
||||||
AutodetectCommunicator communicator = autoDetectCommunicatorByOpenJob.computeIfAbsent(jobTask.getAllocationId(),
|
createProcessAndSetRunning(processContext, params, handler);
|
||||||
id -> create(jobTask, params, handler));
|
processContext.getAutodetectCommunicator().init(params.modelSnapshot());
|
||||||
communicator.init(params.modelSnapshot());
|
|
||||||
setJobState(jobTask, JobState.OPENED);
|
setJobState(jobTask, JobState.OPENED);
|
||||||
} catch (Exception e1) {
|
} catch (Exception e1) {
|
||||||
// No need to log here as the persistent task framework will log it
|
// No need to log here as the persistent task framework will log it
|
||||||
try {
|
try {
|
||||||
// Don't leave a partially initialised process hanging around
|
// Don't leave a partially initialised process hanging around
|
||||||
AutodetectCommunicator communicator = autoDetectCommunicatorByOpenJob.remove(jobTask.getAllocationId());
|
processContext.newKillBuilder()
|
||||||
if (communicator != null) {
|
.setAwaitCompletion(false)
|
||||||
communicator.killProcess(false, false);
|
.setFinish(false)
|
||||||
}
|
.kill();
|
||||||
|
processByAllocation.remove(jobTask.getAllocationId());
|
||||||
} finally {
|
} finally {
|
||||||
setJobState(jobTask, JobState.FAILED, e2 -> handler.accept(e1));
|
setJobState(jobTask, JobState.FAILED, e2 -> handler.accept(e1));
|
||||||
}
|
}
|
||||||
|
@ -333,13 +324,28 @@ public class AutodetectProcessManager extends AbstractComponent {
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private void createProcessAndSetRunning(ProcessContext processContext, AutodetectParams params, Consumer<Exception> handler) {
|
||||||
|
try {
|
||||||
|
// At this point we lock the process context until the process has been started.
|
||||||
|
// The reason behind this is to ensure closing the job does not happen before
|
||||||
|
// the process is started as that can result to the job getting seemingly closed
|
||||||
|
// but the actual process is hanging alive.
|
||||||
|
processContext.tryLock();
|
||||||
|
AutodetectCommunicator communicator = create(processContext.getJobTask(), params, handler);
|
||||||
|
processContext.setRunning(communicator);
|
||||||
|
} finally {
|
||||||
|
// Now that the process is running and we have updated its state we can unlock.
|
||||||
|
// It is important to unlock before we initialize the communicator (ie. load the model state)
|
||||||
|
// as that may be a long-running method.
|
||||||
|
processContext.unlock();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
AutodetectCommunicator create(JobTask jobTask, AutodetectParams autodetectParams, Consumer<Exception> handler) {
|
AutodetectCommunicator create(JobTask jobTask, AutodetectParams autodetectParams, Consumer<Exception> handler) {
|
||||||
// Closing jobs can still be using some or all threads in MachineLearning.AUTODETECT_THREAD_POOL_NAME
|
// Closing jobs can still be using some or all threads in MachineLearning.AUTODETECT_THREAD_POOL_NAME
|
||||||
// that an open job uses, so include them too when considering if enough threads are available.
|
// that an open job uses, so include them too when considering if enough threads are available.
|
||||||
// There's a slight possibility that the same key is in both sets, hence it's not sufficient to simply
|
int currentRunningJobs = processByAllocation.size();
|
||||||
// add the two map sizes.
|
if (currentRunningJobs > maxAllowedRunningJobs) {
|
||||||
int currentRunningJobs = Sets.union(autoDetectCommunicatorByOpenJob.keySet(), autoDetectCommunicatorByClosingJob.keySet()).size();
|
|
||||||
if (currentRunningJobs >= maxAllowedRunningJobs) {
|
|
||||||
throw new ElasticsearchStatusException("max running job capacity [" + maxAllowedRunningJobs + "] reached",
|
throw new ElasticsearchStatusException("max running job capacity [" + maxAllowedRunningJobs + "] reached",
|
||||||
RestStatus.TOO_MANY_REQUESTS);
|
RestStatus.TOO_MANY_REQUESTS);
|
||||||
}
|
}
|
||||||
|
@ -390,7 +396,7 @@ public class AutodetectProcessManager extends AbstractComponent {
|
||||||
}
|
}
|
||||||
throw e;
|
throw e;
|
||||||
}
|
}
|
||||||
return new AutodetectCommunicator(job, jobTask, process, new StateStreamer(client), dataCountsReporter, processor, handler,
|
return new AutodetectCommunicator(job, process, new StateStreamer(client), dataCountsReporter, processor, handler,
|
||||||
xContentRegistry, autodetectWorkerExecutor);
|
xContentRegistry, autodetectWorkerExecutor);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -429,31 +435,34 @@ public class AutodetectProcessManager extends AbstractComponent {
|
||||||
String jobId = jobTask.getJobId();
|
String jobId = jobTask.getJobId();
|
||||||
long allocationId = jobTask.getAllocationId();
|
long allocationId = jobTask.getAllocationId();
|
||||||
logger.debug("Attempting to close job [{}], because [{}]", jobId, reason);
|
logger.debug("Attempting to close job [{}], because [{}]", jobId, reason);
|
||||||
// don't remove the communicator immediately, because we need to ensure it's in the
|
// don't remove the process context immediately, because we need to ensure
|
||||||
// map of closing communicators before it's removed from the map of running ones
|
// it is reachable to enable killing a job while it is closing
|
||||||
AutodetectCommunicator communicator = autoDetectCommunicatorByOpenJob.get(allocationId);
|
ProcessContext processContext = processByAllocation.get(allocationId);
|
||||||
if (communicator == null) {
|
if (processContext == null) {
|
||||||
logger.debug("Cannot close: no active autodetect process for job [{}]", jobId);
|
logger.debug("Cannot close job [{}] as it has already been closed", jobId);
|
||||||
return;
|
|
||||||
}
|
|
||||||
// keep a record of the job, so that it can still be killed while closing
|
|
||||||
autoDetectCommunicatorByClosingJob.putIfAbsent(allocationId, communicator);
|
|
||||||
communicator = autoDetectCommunicatorByOpenJob.remove(allocationId);
|
|
||||||
if (communicator == null) {
|
|
||||||
// if we get here a simultaneous close request beat us to the remove() call
|
|
||||||
logger.debug("Already closing autodetect process for job [{}]", jobId);
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
processContext.tryLock();
|
||||||
|
processContext.setDying();
|
||||||
|
processContext.unlock();
|
||||||
|
|
||||||
if (reason == null) {
|
if (reason == null) {
|
||||||
logger.info("Closing job [{}]", jobId);
|
logger.info("Closing job [{}]", jobId);
|
||||||
} else {
|
} else {
|
||||||
logger.info("Closing job [{}], because [{}]", jobId, reason);
|
logger.info("Closing job [{}], because [{}]", jobId, reason);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
AutodetectCommunicator communicator = processContext.getAutodetectCommunicator();
|
||||||
|
if (communicator == null) {
|
||||||
|
logger.debug("Job [{}] is being closed before its process is started", jobId);
|
||||||
|
jobTask.markAsCompleted();
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
try {
|
try {
|
||||||
communicator.close(restart, reason);
|
communicator.close(restart, reason);
|
||||||
autoDetectCommunicatorByClosingJob.remove(allocationId);
|
processByAllocation.remove(allocationId);
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
logger.warn("[" + jobId + "] Exception closing autodetect process", e);
|
logger.warn("[" + jobId + "] Exception closing autodetect process", e);
|
||||||
setJobState(jobTask, JobState.FAILED);
|
setJobState(jobTask, JobState.FAILED);
|
||||||
|
@ -462,15 +471,29 @@ public class AutodetectProcessManager extends AbstractComponent {
|
||||||
}
|
}
|
||||||
|
|
||||||
int numberOfOpenJobs() {
|
int numberOfOpenJobs() {
|
||||||
return autoDetectCommunicatorByOpenJob.size();
|
return (int) processByAllocation.values().stream()
|
||||||
|
.filter(p -> p.getState() != ProcessContext.ProcessStateName.DYING)
|
||||||
|
.count();
|
||||||
}
|
}
|
||||||
|
|
||||||
boolean jobHasActiveAutodetectProcess(JobTask jobTask) {
|
boolean jobHasActiveAutodetectProcess(JobTask jobTask) {
|
||||||
return autoDetectCommunicatorByOpenJob.get(jobTask.getAllocationId()) != null;
|
return getAutodetectCommunicator(jobTask) != null;
|
||||||
|
}
|
||||||
|
|
||||||
|
private AutodetectCommunicator getAutodetectCommunicator(JobTask jobTask) {
|
||||||
|
return processByAllocation.getOrDefault(jobTask.getAllocationId(), new ProcessContext(jobTask)).getAutodetectCommunicator();
|
||||||
|
}
|
||||||
|
|
||||||
|
private AutodetectCommunicator getOpenAutodetectCommunicator(JobTask jobTask) {
|
||||||
|
ProcessContext processContext = processByAllocation.get(jobTask.getAllocationId());
|
||||||
|
if (processContext.getState() == ProcessContext.ProcessStateName.RUNNING) {
|
||||||
|
return processContext.getAutodetectCommunicator();
|
||||||
|
}
|
||||||
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
public Optional<Duration> jobOpenTime(JobTask jobTask) {
|
public Optional<Duration> jobOpenTime(JobTask jobTask) {
|
||||||
AutodetectCommunicator communicator = autoDetectCommunicatorByOpenJob.get(jobTask.getAllocationId());
|
AutodetectCommunicator communicator = getAutodetectCommunicator(jobTask);
|
||||||
if (communicator == null) {
|
if (communicator == null) {
|
||||||
return Optional.empty();
|
return Optional.empty();
|
||||||
}
|
}
|
||||||
|
@ -516,7 +539,7 @@ public class AutodetectProcessManager extends AbstractComponent {
|
||||||
}
|
}
|
||||||
|
|
||||||
public Optional<Tuple<DataCounts, ModelSizeStats>> getStatistics(JobTask jobTask) {
|
public Optional<Tuple<DataCounts, ModelSizeStats>> getStatistics(JobTask jobTask) {
|
||||||
AutodetectCommunicator communicator = autoDetectCommunicatorByOpenJob.get(jobTask.getAllocationId());
|
AutodetectCommunicator communicator = getAutodetectCommunicator(jobTask);
|
||||||
if (communicator == null) {
|
if (communicator == null) {
|
||||||
return Optional.empty();
|
return Optional.empty();
|
||||||
}
|
}
|
||||||
|
@ -597,6 +620,5 @@ public class AutodetectProcessManager extends AbstractComponent {
|
||||||
awaitTermination.countDown();
|
awaitTermination.countDown();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -14,7 +14,6 @@ import org.elasticsearch.common.util.concurrent.EsRejectedExecutionException;
|
||||||
import org.elasticsearch.env.Environment;
|
import org.elasticsearch.env.Environment;
|
||||||
import org.elasticsearch.xpack.ml.job.config.Job;
|
import org.elasticsearch.xpack.ml.job.config.Job;
|
||||||
import org.elasticsearch.xpack.ml.job.config.MlFilter;
|
import org.elasticsearch.xpack.ml.job.config.MlFilter;
|
||||||
import org.elasticsearch.xpack.ml.job.persistence.JobProvider;
|
|
||||||
import org.elasticsearch.xpack.ml.job.process.NativeController;
|
import org.elasticsearch.xpack.ml.job.process.NativeController;
|
||||||
import org.elasticsearch.xpack.ml.job.process.ProcessCtrl;
|
import org.elasticsearch.xpack.ml.job.process.ProcessCtrl;
|
||||||
import org.elasticsearch.xpack.ml.job.process.ProcessPipes;
|
import org.elasticsearch.xpack.ml.job.process.ProcessPipes;
|
||||||
|
@ -39,19 +38,16 @@ public class NativeAutodetectProcessFactory implements AutodetectProcessFactory
|
||||||
|
|
||||||
private static final Logger LOGGER = Loggers.getLogger(NativeAutodetectProcessFactory.class);
|
private static final Logger LOGGER = Loggers.getLogger(NativeAutodetectProcessFactory.class);
|
||||||
private static final NamedPipeHelper NAMED_PIPE_HELPER = new NamedPipeHelper();
|
private static final NamedPipeHelper NAMED_PIPE_HELPER = new NamedPipeHelper();
|
||||||
private static final Duration PROCESS_STARTUP_TIMEOUT = Duration.ofSeconds(10);
|
public static final Duration PROCESS_STARTUP_TIMEOUT = Duration.ofSeconds(10);
|
||||||
|
|
||||||
private final Client client;
|
private final Client client;
|
||||||
private final Environment env;
|
private final Environment env;
|
||||||
private final Settings settings;
|
private final Settings settings;
|
||||||
private final JobProvider jobProvider;
|
|
||||||
private final NativeController nativeController;
|
private final NativeController nativeController;
|
||||||
|
|
||||||
public NativeAutodetectProcessFactory(JobProvider jobProvider, Environment env, Settings settings,
|
public NativeAutodetectProcessFactory(Environment env, Settings settings, NativeController nativeController, Client client) {
|
||||||
NativeController nativeController, Client client) {
|
|
||||||
this.env = Objects.requireNonNull(env);
|
this.env = Objects.requireNonNull(env);
|
||||||
this.settings = Objects.requireNonNull(settings);
|
this.settings = Objects.requireNonNull(settings);
|
||||||
this.jobProvider = Objects.requireNonNull(jobProvider);
|
|
||||||
this.nativeController = Objects.requireNonNull(nativeController);
|
this.nativeController = Objects.requireNonNull(nativeController);
|
||||||
this.client = client;
|
this.client = client;
|
||||||
}
|
}
|
||||||
|
|
|
@ -0,0 +1,195 @@
|
||||||
|
/*
|
||||||
|
* Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one
|
||||||
|
* or more contributor license agreements. Licensed under the Elastic License;
|
||||||
|
* you may not use this file except in compliance with the Elastic License.
|
||||||
|
*/
|
||||||
|
package org.elasticsearch.xpack.ml.job.process.autodetect;
|
||||||
|
|
||||||
|
import org.apache.logging.log4j.Logger;
|
||||||
|
import org.elasticsearch.ElasticsearchException;
|
||||||
|
import org.elasticsearch.common.logging.Loggers;
|
||||||
|
import org.elasticsearch.xpack.ml.action.OpenJobAction.JobTask;
|
||||||
|
import org.elasticsearch.xpack.ml.utils.ExceptionsHelper;
|
||||||
|
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.util.concurrent.TimeUnit;
|
||||||
|
import java.util.concurrent.locks.ReentrantLock;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The process context that encapsulates the job task, the process state and the autodetect communicator.
|
||||||
|
*/
|
||||||
|
final class ProcessContext {
|
||||||
|
|
||||||
|
private static final Logger LOGGER = Loggers.getLogger(ProcessContext.class);
|
||||||
|
|
||||||
|
private final ReentrantLock lock = new ReentrantLock();
|
||||||
|
private final JobTask jobTask;
|
||||||
|
private volatile AutodetectCommunicator autodetectCommunicator;
|
||||||
|
private volatile ProcessState state;
|
||||||
|
|
||||||
|
ProcessContext(JobTask jobTask) {
|
||||||
|
this.jobTask = jobTask;
|
||||||
|
this.state = new ProcessNotRunningState();
|
||||||
|
}
|
||||||
|
|
||||||
|
JobTask getJobTask() {
|
||||||
|
return jobTask;
|
||||||
|
}
|
||||||
|
|
||||||
|
AutodetectCommunicator getAutodetectCommunicator() {
|
||||||
|
return autodetectCommunicator;
|
||||||
|
}
|
||||||
|
|
||||||
|
private void setAutodetectCommunicator(AutodetectCommunicator autodetectCommunicator) {
|
||||||
|
this.autodetectCommunicator = autodetectCommunicator;
|
||||||
|
}
|
||||||
|
|
||||||
|
ProcessStateName getState() {
|
||||||
|
return state.getName();
|
||||||
|
}
|
||||||
|
|
||||||
|
private void setState(ProcessState state) {
|
||||||
|
this.state = state;
|
||||||
|
}
|
||||||
|
|
||||||
|
void tryLock() {
|
||||||
|
try {
|
||||||
|
if (lock.tryLock(NativeAutodetectProcessFactory.PROCESS_STARTUP_TIMEOUT.getSeconds(), TimeUnit.SECONDS) == false) {
|
||||||
|
LOGGER.error("Failed to acquire process lock for job [{}]", jobTask.getJobId());
|
||||||
|
throw ExceptionsHelper.serverError("Failed to acquire process lock for job [" + jobTask.getJobId() + "]");
|
||||||
|
}
|
||||||
|
} catch (InterruptedException e) {
|
||||||
|
throw new ElasticsearchException(e);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void unlock() {
|
||||||
|
lock.unlock();
|
||||||
|
}
|
||||||
|
|
||||||
|
void setRunning(AutodetectCommunicator autodetectCommunicator) {
|
||||||
|
assert lock.isHeldByCurrentThread();
|
||||||
|
state.setRunning(this, autodetectCommunicator);
|
||||||
|
}
|
||||||
|
|
||||||
|
void setDying() {
|
||||||
|
assert lock.isHeldByCurrentThread();
|
||||||
|
state.setDying(this);
|
||||||
|
}
|
||||||
|
|
||||||
|
KillBuilder newKillBuilder() {
|
||||||
|
return new ProcessContext.KillBuilder();
|
||||||
|
}
|
||||||
|
|
||||||
|
class KillBuilder {
|
||||||
|
private boolean awaitCompletion;
|
||||||
|
private boolean finish;
|
||||||
|
private boolean silent;
|
||||||
|
private String reason;
|
||||||
|
|
||||||
|
KillBuilder setAwaitCompletion(boolean awaitCompletion) {
|
||||||
|
this.awaitCompletion = awaitCompletion;
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
KillBuilder setFinish(boolean finish) {
|
||||||
|
this.finish = finish;
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
KillBuilder setSilent(boolean silent) {
|
||||||
|
this.silent = silent;
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
KillBuilder setReason(String reason) {
|
||||||
|
this.reason = reason;
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
void kill() {
|
||||||
|
if (autodetectCommunicator == null) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
String jobId = jobTask.getJobId();
|
||||||
|
|
||||||
|
if (silent == false) {
|
||||||
|
String extraInfo = (state.getName() == ProcessStateName.DYING) ? " while closing" : "";
|
||||||
|
if (reason == null) {
|
||||||
|
LOGGER.info("Killing job [{}]{}", jobId, extraInfo);
|
||||||
|
} else {
|
||||||
|
LOGGER.info("Killing job [{}]{}, because [{}]", jobId, extraInfo, reason);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
autodetectCommunicator.killProcess(awaitCompletion, finish);
|
||||||
|
} catch (IOException e) {
|
||||||
|
LOGGER.error("[{}] Failed to kill autodetect process for job", jobId);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
enum ProcessStateName {
|
||||||
|
NOT_RUNNING, RUNNING, DYING
|
||||||
|
}
|
||||||
|
|
||||||
|
private interface ProcessState {
|
||||||
|
void setRunning(ProcessContext processContext, AutodetectCommunicator autodetectCommunicator);
|
||||||
|
void setDying(ProcessContext processContext);
|
||||||
|
ProcessStateName getName();
|
||||||
|
}
|
||||||
|
|
||||||
|
private static class ProcessNotRunningState implements ProcessState {
|
||||||
|
@Override
|
||||||
|
public void setRunning(ProcessContext processContext, AutodetectCommunicator autodetectCommunicator) {
|
||||||
|
processContext.setAutodetectCommunicator(autodetectCommunicator);
|
||||||
|
processContext.setState(new ProcessRunningState());
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void setDying(ProcessContext processContext) {
|
||||||
|
processContext.setState(new ProcessDyingState());
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public ProcessStateName getName() {
|
||||||
|
return ProcessStateName.NOT_RUNNING;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private static class ProcessRunningState implements ProcessState {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void setRunning(ProcessContext processContext, AutodetectCommunicator autodetectCommunicator) {
|
||||||
|
LOGGER.debug("Process set to [running] while it was already in that state");
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void setDying(ProcessContext processContext) {
|
||||||
|
processContext.setState(new ProcessDyingState());
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public ProcessStateName getName() {
|
||||||
|
return ProcessStateName.RUNNING;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private static class ProcessDyingState implements ProcessState {
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void setRunning(ProcessContext processContext, AutodetectCommunicator autodetectCommunicator) {
|
||||||
|
LOGGER.debug("Process set to [running] while it was in [dying]");
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void setDying(ProcessContext processContext) {
|
||||||
|
LOGGER.debug("Process set to [dying] while it was already in that state");
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public ProcessStateName getName() {
|
||||||
|
return ProcessStateName.DYING;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -14,8 +14,10 @@ import org.elasticsearch.common.inject.Module;
|
||||||
import org.elasticsearch.common.inject.util.Providers;
|
import org.elasticsearch.common.inject.util.Providers;
|
||||||
import org.elasticsearch.common.settings.ClusterSettings;
|
import org.elasticsearch.common.settings.ClusterSettings;
|
||||||
import org.elasticsearch.common.settings.IndexScopedSettings;
|
import org.elasticsearch.common.settings.IndexScopedSettings;
|
||||||
|
import org.elasticsearch.common.settings.Setting;
|
||||||
import org.elasticsearch.common.settings.Settings;
|
import org.elasticsearch.common.settings.Settings;
|
||||||
import org.elasticsearch.common.settings.SettingsFilter;
|
import org.elasticsearch.common.settings.SettingsFilter;
|
||||||
|
import org.elasticsearch.common.unit.TimeValue;
|
||||||
import org.elasticsearch.license.LicenseService;
|
import org.elasticsearch.license.LicenseService;
|
||||||
import org.elasticsearch.license.XPackLicenseState;
|
import org.elasticsearch.license.XPackLicenseState;
|
||||||
import org.elasticsearch.plugins.ActionPlugin;
|
import org.elasticsearch.plugins.ActionPlugin;
|
||||||
|
@ -55,6 +57,7 @@ import java.util.function.Supplier;
|
||||||
|
|
||||||
import static java.util.Collections.emptyList;
|
import static java.util.Collections.emptyList;
|
||||||
import static java.util.Collections.singletonList;
|
import static java.util.Collections.singletonList;
|
||||||
|
import static org.elasticsearch.common.settings.Setting.timeSetting;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* This class activates/deactivates the monitoring modules depending if we're running a node client, transport client or tribe client:
|
* This class activates/deactivates the monitoring modules depending if we're running a node client, transport client or tribe client:
|
||||||
|
@ -66,6 +69,27 @@ public class Monitoring implements ActionPlugin {
|
||||||
|
|
||||||
public static final String NAME = "monitoring";
|
public static final String NAME = "monitoring";
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The minimum amount of time allowed for the history duration.
|
||||||
|
*/
|
||||||
|
public static final TimeValue HISTORY_DURATION_MINIMUM = TimeValue.timeValueHours(24);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The default retention duration of the monitoring history data.
|
||||||
|
* <p>
|
||||||
|
* Expected values:
|
||||||
|
* <ul>
|
||||||
|
* <li>Default: 7 days</li>
|
||||||
|
* <li>Minimum: 1 day</li>
|
||||||
|
* </ul>
|
||||||
|
*
|
||||||
|
* @see #HISTORY_DURATION_MINIMUM
|
||||||
|
*/
|
||||||
|
public static final Setting<TimeValue> HISTORY_DURATION = timeSetting("xpack.monitoring.history.duration",
|
||||||
|
TimeValue.timeValueHours(7 * 24), // default value (7 days)
|
||||||
|
HISTORY_DURATION_MINIMUM, // minimum value
|
||||||
|
Setting.Property.Dynamic, Setting.Property.NodeScope);
|
||||||
|
|
||||||
private final Settings settings;
|
private final Settings settings;
|
||||||
private final XPackLicenseState licenseState;
|
private final XPackLicenseState licenseState;
|
||||||
private final boolean enabled;
|
private final boolean enabled;
|
||||||
|
@ -106,7 +130,6 @@ public class Monitoring implements ActionPlugin {
|
||||||
}
|
}
|
||||||
|
|
||||||
final ClusterSettings clusterSettings = clusterService.getClusterSettings();
|
final ClusterSettings clusterSettings = clusterService.getClusterSettings();
|
||||||
final MonitoringSettings monitoringSettings = new MonitoringSettings(settings, clusterSettings);
|
|
||||||
final CleanerService cleanerService = new CleanerService(settings, clusterSettings, threadPool, licenseState);
|
final CleanerService cleanerService = new CleanerService(settings, clusterSettings, threadPool, licenseState);
|
||||||
final SSLService dynamicSSLService = sslService.createDynamicSSLService();
|
final SSLService dynamicSSLService = sslService.createDynamicSSLService();
|
||||||
|
|
||||||
|
@ -116,16 +139,16 @@ public class Monitoring implements ActionPlugin {
|
||||||
final Exporters exporters = new Exporters(settings, exporterFactories, clusterService, licenseState, threadPool.getThreadContext());
|
final Exporters exporters = new Exporters(settings, exporterFactories, clusterService, licenseState, threadPool.getThreadContext());
|
||||||
|
|
||||||
Set<Collector> collectors = new HashSet<>();
|
Set<Collector> collectors = new HashSet<>();
|
||||||
collectors.add(new IndexStatsCollector(settings, clusterService, monitoringSettings, licenseState, client));
|
collectors.add(new IndexStatsCollector(settings, clusterService, licenseState, client));
|
||||||
collectors.add(new ClusterStatsCollector(settings, clusterService, monitoringSettings, licenseState, client, licenseService));
|
collectors.add(new ClusterStatsCollector(settings, clusterService, licenseState, client, licenseService));
|
||||||
collectors.add(new ShardsCollector(settings, clusterService, monitoringSettings, licenseState));
|
collectors.add(new ShardsCollector(settings, clusterService, licenseState));
|
||||||
collectors.add(new NodeStatsCollector(settings, clusterService, monitoringSettings, licenseState, client));
|
collectors.add(new NodeStatsCollector(settings, clusterService, licenseState, client));
|
||||||
collectors.add(new IndexRecoveryCollector(settings, clusterService, monitoringSettings, licenseState, client));
|
collectors.add(new IndexRecoveryCollector(settings, clusterService, licenseState, client));
|
||||||
collectors.add(new JobStatsCollector(settings, clusterService, monitoringSettings, licenseState, client));
|
collectors.add(new JobStatsCollector(settings, clusterService, licenseState, client));
|
||||||
|
|
||||||
final MonitoringService monitoringService = new MonitoringService(settings, clusterSettings, threadPool, collectors, exporters);
|
final MonitoringService monitoringService = new MonitoringService(settings, clusterSettings, threadPool, collectors, exporters);
|
||||||
|
|
||||||
return Arrays.asList(monitoringService, monitoringSettings, exporters, cleanerService);
|
return Arrays.asList(monitoringService, exporters, cleanerService);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -145,4 +168,25 @@ public class Monitoring implements ActionPlugin {
|
||||||
}
|
}
|
||||||
return singletonList(new RestMonitoringBulkAction(settings, restController));
|
return singletonList(new RestMonitoringBulkAction(settings, restController));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public List<Setting<?>> getSettings() {
|
||||||
|
return Collections.unmodifiableList(
|
||||||
|
Arrays.asList(HISTORY_DURATION,
|
||||||
|
MonitoringService.INTERVAL,
|
||||||
|
Exporters.EXPORTERS_SETTINGS,
|
||||||
|
Collector.INDICES,
|
||||||
|
ClusterStatsCollector.CLUSTER_STATS_TIMEOUT,
|
||||||
|
IndexRecoveryCollector.INDEX_RECOVERY_TIMEOUT,
|
||||||
|
IndexRecoveryCollector.INDEX_RECOVERY_ACTIVE_ONLY,
|
||||||
|
IndexStatsCollector.INDEX_STATS_TIMEOUT,
|
||||||
|
JobStatsCollector.JOB_STATS_TIMEOUT,
|
||||||
|
NodeStatsCollector.NODE_STATS_TIMEOUT)
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
public List<String> getSettingsFilter() {
|
||||||
|
final String exportersKey = Exporters.EXPORTERS_SETTINGS.getKey();
|
||||||
|
return Collections.unmodifiableList(Arrays.asList(exportersKey + "*.auth.*", exportersKey + "*.ssl.*"));
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -10,6 +10,7 @@ import org.apache.logging.log4j.util.Supplier;
|
||||||
import org.elasticsearch.action.ActionListener;
|
import org.elasticsearch.action.ActionListener;
|
||||||
import org.elasticsearch.common.component.AbstractLifecycleComponent;
|
import org.elasticsearch.common.component.AbstractLifecycleComponent;
|
||||||
import org.elasticsearch.common.settings.ClusterSettings;
|
import org.elasticsearch.common.settings.ClusterSettings;
|
||||||
|
import org.elasticsearch.common.settings.Setting;
|
||||||
import org.elasticsearch.common.settings.Settings;
|
import org.elasticsearch.common.settings.Settings;
|
||||||
import org.elasticsearch.common.unit.TimeValue;
|
import org.elasticsearch.common.unit.TimeValue;
|
||||||
import org.elasticsearch.common.util.concurrent.AbstractRunnable;
|
import org.elasticsearch.common.util.concurrent.AbstractRunnable;
|
||||||
|
@ -36,6 +37,24 @@ import java.util.concurrent.atomic.AtomicBoolean;
|
||||||
*/
|
*/
|
||||||
public class MonitoringService extends AbstractLifecycleComponent {
|
public class MonitoringService extends AbstractLifecycleComponent {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Minimum value for sampling interval (1 second)
|
||||||
|
*/
|
||||||
|
static final TimeValue MIN_INTERVAL = TimeValue.timeValueSeconds(1L);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Sampling interval between two collections (default to 10s)
|
||||||
|
*/
|
||||||
|
public static final Setting<TimeValue> INTERVAL = new Setting<>("xpack.monitoring.collection.interval", "10s",
|
||||||
|
(s) -> {
|
||||||
|
TimeValue value = TimeValue.parseTimeValue(s, null, "xpack.monitoring.collection.interval");
|
||||||
|
if (TimeValue.MINUS_ONE.equals(value) || value.millis() >= MIN_INTERVAL.millis()) {
|
||||||
|
return value;
|
||||||
|
}
|
||||||
|
throw new IllegalArgumentException("Failed to parse monitoring interval [" + s + "], value must be >= " + MIN_INTERVAL);
|
||||||
|
},
|
||||||
|
Setting.Property.Dynamic, Setting.Property.NodeScope);
|
||||||
|
|
||||||
/** State of the monitoring service, either started or stopped **/
|
/** State of the monitoring service, either started or stopped **/
|
||||||
private final AtomicBoolean started = new AtomicBoolean(false);
|
private final AtomicBoolean started = new AtomicBoolean(false);
|
||||||
|
|
||||||
|
@ -55,8 +74,8 @@ public class MonitoringService extends AbstractLifecycleComponent {
|
||||||
this.threadPool = Objects.requireNonNull(threadPool);
|
this.threadPool = Objects.requireNonNull(threadPool);
|
||||||
this.collectors = Objects.requireNonNull(collectors);
|
this.collectors = Objects.requireNonNull(collectors);
|
||||||
this.exporters = Objects.requireNonNull(exporters);
|
this.exporters = Objects.requireNonNull(exporters);
|
||||||
this.interval = MonitoringSettings.INTERVAL.get(settings);
|
this.interval = INTERVAL.get(settings);
|
||||||
clusterSettings.addSettingsUpdateConsumer(MonitoringSettings.INTERVAL, this::setInterval);
|
clusterSettings.addSettingsUpdateConsumer(INTERVAL, this::setInterval);
|
||||||
}
|
}
|
||||||
|
|
||||||
void setInterval(TimeValue interval) {
|
void setInterval(TimeValue interval) {
|
||||||
|
@ -71,7 +90,7 @@ public class MonitoringService extends AbstractLifecycleComponent {
|
||||||
boolean isMonitoringActive() {
|
boolean isMonitoringActive() {
|
||||||
return isStarted()
|
return isStarted()
|
||||||
&& interval != null
|
&& interval != null
|
||||||
&& interval.millis() >= MonitoringSettings.MIN_INTERVAL.millis();
|
&& interval.millis() >= MIN_INTERVAL.millis();
|
||||||
}
|
}
|
||||||
|
|
||||||
private String threadPoolName() {
|
private String threadPoolName() {
|
||||||
|
|
|
@ -1,258 +0,0 @@
|
||||||
/*
|
|
||||||
* Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one
|
|
||||||
* or more contributor license agreements. Licensed under the Elastic License;
|
|
||||||
* you may not use this file except in compliance with the Elastic License.
|
|
||||||
*/
|
|
||||||
package org.elasticsearch.xpack.monitoring;
|
|
||||||
|
|
||||||
import org.elasticsearch.common.component.AbstractComponent;
|
|
||||||
import org.elasticsearch.common.settings.ClusterSettings;
|
|
||||||
import org.elasticsearch.common.settings.Setting;
|
|
||||||
import org.elasticsearch.common.settings.Settings;
|
|
||||||
import org.elasticsearch.common.unit.TimeValue;
|
|
||||||
import org.elasticsearch.xpack.XPackPlugin;
|
|
||||||
|
|
||||||
import java.util.Arrays;
|
|
||||||
import java.util.Collections;
|
|
||||||
import java.util.List;
|
|
||||||
import java.util.function.Function;
|
|
||||||
|
|
||||||
import static org.elasticsearch.common.settings.Setting.Property;
|
|
||||||
import static org.elasticsearch.common.settings.Setting.boolSetting;
|
|
||||||
import static org.elasticsearch.common.settings.Setting.groupSetting;
|
|
||||||
import static org.elasticsearch.common.settings.Setting.listSetting;
|
|
||||||
import static org.elasticsearch.common.settings.Setting.timeSetting;
|
|
||||||
|
|
||||||
// TODO Remove this class and put the settings in Monitoring class
|
|
||||||
public class MonitoringSettings extends AbstractComponent {
|
|
||||||
|
|
||||||
public static final String HISTORY_DURATION_SETTING_NAME = "history.duration";
|
|
||||||
/**
|
|
||||||
* The minimum amount of time allowed for the history duration.
|
|
||||||
*/
|
|
||||||
public static final TimeValue HISTORY_DURATION_MINIMUM = TimeValue.timeValueHours(24);
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Minimum value for sampling interval (1 second)
|
|
||||||
*/
|
|
||||||
static final TimeValue MIN_INTERVAL = TimeValue.timeValueSeconds(1L);
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Sampling interval between two collections (default to 10s)
|
|
||||||
*/
|
|
||||||
public static final Setting<TimeValue> INTERVAL = new Setting<>(collectionKey("interval"), "10s",
|
|
||||||
(s) -> {
|
|
||||||
TimeValue value = TimeValue.parseTimeValue(s, null, collectionKey("interval"));
|
|
||||||
if (TimeValue.MINUS_ONE.equals(value) || value.millis() >= MIN_INTERVAL.millis()) {
|
|
||||||
return value;
|
|
||||||
}
|
|
||||||
throw new IllegalArgumentException("Failed to parse monitoring interval [" + s + "], value must be >= " + MIN_INTERVAL);
|
|
||||||
},
|
|
||||||
Property.Dynamic, Property.NodeScope);
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Timeout value when collecting index statistics (default to 10s)
|
|
||||||
*/
|
|
||||||
public static final Setting<TimeValue> INDEX_STATS_TIMEOUT =
|
|
||||||
timeSetting(collectionKey("index.stats.timeout"), TimeValue.timeValueSeconds(10), Property.Dynamic, Property.NodeScope);
|
|
||||||
|
|
||||||
/**
|
|
||||||
* List of indices names whose stats will be exported (default to all indices)
|
|
||||||
*/
|
|
||||||
public static final Setting<List<String>> INDICES =
|
|
||||||
listSetting(collectionKey("indices"), Collections.emptyList(), Function.identity(), Property.Dynamic, Property.NodeScope);
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Timeout value when collecting the cluster state (default to 10s)
|
|
||||||
*/
|
|
||||||
public static final Setting<TimeValue> CLUSTER_STATE_TIMEOUT =
|
|
||||||
timeSetting(collectionKey("cluster.state.timeout"), TimeValue.timeValueSeconds(10), Property.Dynamic, Property.NodeScope);
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Timeout value when collecting the recovery information (default to 10s)
|
|
||||||
*/
|
|
||||||
public static final Setting<TimeValue> CLUSTER_STATS_TIMEOUT =
|
|
||||||
timeSetting(collectionKey("cluster.stats.timeout"), TimeValue.timeValueSeconds(10), Property.Dynamic, Property.NodeScope);
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Timeout value when collecting ML job statistics (default to 10s)
|
|
||||||
*/
|
|
||||||
public static final Setting<TimeValue> JOB_STATS_TIMEOUT =
|
|
||||||
timeSetting(collectionKey("ml.job.stats.timeout"), TimeValue.timeValueSeconds(10), Property.Dynamic, Property.NodeScope);
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Timeout value when collecting the nodes statistics (default to 10s)
|
|
||||||
*/
|
|
||||||
public static final Setting<TimeValue> NODE_STATS_TIMEOUT =
|
|
||||||
timeSetting(collectionKey("node.stats.timeout"), TimeValue.timeValueSeconds(10), Property.Dynamic, Property.NodeScope);
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Timeout value when collecting the recovery information (default to 10s)
|
|
||||||
*/
|
|
||||||
public static final Setting<TimeValue> INDEX_RECOVERY_TIMEOUT =
|
|
||||||
timeSetting(collectionKey("index.recovery.timeout"), TimeValue.timeValueSeconds(10), Property.Dynamic, Property.NodeScope);
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Flag to indicate if only active recoveries should be collected (default to false: all recoveries are collected)
|
|
||||||
*/
|
|
||||||
public static final Setting<Boolean> INDEX_RECOVERY_ACTIVE_ONLY =
|
|
||||||
boolSetting(collectionKey("index.recovery.active_only"), false, Property.Dynamic, Property.NodeScope) ;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* The default retention duration of the monitoring history data.
|
|
||||||
* <p>
|
|
||||||
* Expected values:
|
|
||||||
* <ul>
|
|
||||||
* <li>Default: 7 days</li>
|
|
||||||
* <li>Minimum: 1 day</li>
|
|
||||||
* </ul>
|
|
||||||
*
|
|
||||||
* @see #HISTORY_DURATION_MINIMUM
|
|
||||||
*/
|
|
||||||
public static final Setting<TimeValue> HISTORY_DURATION =
|
|
||||||
timeSetting(key(HISTORY_DURATION_SETTING_NAME),
|
|
||||||
TimeValue.timeValueHours(7 * 24), // default value (7 days)
|
|
||||||
HISTORY_DURATION_MINIMUM, // minimum value
|
|
||||||
Property.Dynamic, Property.NodeScope);
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Settings/Options per configured exporter
|
|
||||||
*/
|
|
||||||
public static final Setting<Settings> EXPORTERS_SETTINGS =
|
|
||||||
groupSetting(key("exporters."), Property.Dynamic, Property.NodeScope);
|
|
||||||
|
|
||||||
public static List<Setting<?>> getSettings() {
|
|
||||||
return Arrays.asList(INDICES,
|
|
||||||
INTERVAL,
|
|
||||||
INDEX_RECOVERY_TIMEOUT,
|
|
||||||
INDEX_STATS_TIMEOUT,
|
|
||||||
INDEX_RECOVERY_ACTIVE_ONLY,
|
|
||||||
CLUSTER_STATE_TIMEOUT,
|
|
||||||
CLUSTER_STATS_TIMEOUT,
|
|
||||||
JOB_STATS_TIMEOUT,
|
|
||||||
NODE_STATS_TIMEOUT,
|
|
||||||
HISTORY_DURATION,
|
|
||||||
EXPORTERS_SETTINGS);
|
|
||||||
}
|
|
||||||
|
|
||||||
public static List<String> getSettingsFilter() {
|
|
||||||
return Arrays.asList(key("exporters.*.auth.*"), key("exporters.*.ssl.*"));
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
private volatile TimeValue indexStatsTimeout;
|
|
||||||
private volatile TimeValue clusterStateTimeout;
|
|
||||||
private volatile TimeValue clusterStatsTimeout;
|
|
||||||
private volatile TimeValue recoveryTimeout;
|
|
||||||
private volatile TimeValue jobStatsTimeout;
|
|
||||||
private volatile TimeValue nodeStatsTimeout;
|
|
||||||
private volatile boolean recoveryActiveOnly;
|
|
||||||
private volatile String[] indices;
|
|
||||||
|
|
||||||
public MonitoringSettings(Settings settings, ClusterSettings clusterSettings) {
|
|
||||||
super(settings);
|
|
||||||
|
|
||||||
setIndexStatsTimeout(INDEX_STATS_TIMEOUT.get(settings));
|
|
||||||
clusterSettings.addSettingsUpdateConsumer(INDEX_STATS_TIMEOUT, this::setIndexStatsTimeout);
|
|
||||||
setIndices(INDICES.get(settings));
|
|
||||||
clusterSettings.addSettingsUpdateConsumer(INDICES, this::setIndices);
|
|
||||||
setClusterStateTimeout(CLUSTER_STATE_TIMEOUT.get(settings));
|
|
||||||
clusterSettings.addSettingsUpdateConsumer(CLUSTER_STATE_TIMEOUT, this::setClusterStateTimeout);
|
|
||||||
setClusterStatsTimeout(CLUSTER_STATS_TIMEOUT.get(settings));
|
|
||||||
clusterSettings.addSettingsUpdateConsumer(CLUSTER_STATS_TIMEOUT, this::setClusterStatsTimeout);
|
|
||||||
setJobStatsTimeout(JOB_STATS_TIMEOUT.get(settings));
|
|
||||||
clusterSettings.addSettingsUpdateConsumer(JOB_STATS_TIMEOUT, this::setJobStatsTimeout);
|
|
||||||
setNodeStatsTimeout(NODE_STATS_TIMEOUT.get(settings));
|
|
||||||
clusterSettings.addSettingsUpdateConsumer(NODE_STATS_TIMEOUT, this::setNodeStatsTimeout);
|
|
||||||
setRecoveryTimeout(INDEX_RECOVERY_TIMEOUT.get(settings));
|
|
||||||
clusterSettings.addSettingsUpdateConsumer(INDEX_RECOVERY_TIMEOUT, this::setRecoveryTimeout);
|
|
||||||
setRecoveryActiveOnly(INDEX_RECOVERY_ACTIVE_ONLY.get(settings));
|
|
||||||
clusterSettings.addSettingsUpdateConsumer(INDEX_RECOVERY_ACTIVE_ONLY, this::setRecoveryActiveOnly);
|
|
||||||
}
|
|
||||||
|
|
||||||
public TimeValue indexStatsTimeout() {
|
|
||||||
return indexStatsTimeout;
|
|
||||||
}
|
|
||||||
|
|
||||||
public String[] indices() {
|
|
||||||
return indices;
|
|
||||||
}
|
|
||||||
|
|
||||||
public TimeValue clusterStateTimeout() {
|
|
||||||
return clusterStateTimeout;
|
|
||||||
}
|
|
||||||
|
|
||||||
public TimeValue clusterStatsTimeout() {
|
|
||||||
return clusterStatsTimeout;
|
|
||||||
}
|
|
||||||
|
|
||||||
public TimeValue jobStatsTimeout() {
|
|
||||||
return jobStatsTimeout;
|
|
||||||
}
|
|
||||||
|
|
||||||
public TimeValue nodeStatsTimeout() {
|
|
||||||
return nodeStatsTimeout;
|
|
||||||
}
|
|
||||||
|
|
||||||
public TimeValue recoveryTimeout() {
|
|
||||||
return recoveryTimeout;
|
|
||||||
}
|
|
||||||
|
|
||||||
public boolean recoveryActiveOnly() {
|
|
||||||
return recoveryActiveOnly;
|
|
||||||
}
|
|
||||||
|
|
||||||
private void setIndexStatsTimeout(TimeValue indexStatsTimeout) {
|
|
||||||
this.indexStatsTimeout = indexStatsTimeout;
|
|
||||||
}
|
|
||||||
|
|
||||||
private void setClusterStateTimeout(TimeValue clusterStateTimeout) {
|
|
||||||
this.clusterStateTimeout = clusterStateTimeout;
|
|
||||||
}
|
|
||||||
|
|
||||||
private void setClusterStatsTimeout(TimeValue clusterStatsTimeout) {
|
|
||||||
this.clusterStatsTimeout = clusterStatsTimeout;
|
|
||||||
}
|
|
||||||
|
|
||||||
private void setJobStatsTimeout(TimeValue jobStatsTimeout) {
|
|
||||||
this.jobStatsTimeout = jobStatsTimeout;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void setNodeStatsTimeout(TimeValue nodeStatsTimeout) {
|
|
||||||
this.nodeStatsTimeout = nodeStatsTimeout;
|
|
||||||
}
|
|
||||||
|
|
||||||
private void setRecoveryTimeout(TimeValue recoveryTimeout) {
|
|
||||||
this.recoveryTimeout = recoveryTimeout;
|
|
||||||
}
|
|
||||||
|
|
||||||
private void setRecoveryActiveOnly(boolean recoveryActiveOnly) {
|
|
||||||
this.recoveryActiveOnly = recoveryActiveOnly;
|
|
||||||
}
|
|
||||||
|
|
||||||
private void setIndices(List<String> indices) {
|
|
||||||
this.indices = indices.toArray(new String[0]);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Prefix the {@code key} with the Monitoring prefix and "collection." .
|
|
||||||
*
|
|
||||||
* @param key The key to prefix
|
|
||||||
* @return The key prefixed by the product prefixes + "collection." .
|
|
||||||
* @see #key(String)
|
|
||||||
*/
|
|
||||||
static String collectionKey(String key) {
|
|
||||||
return key("collection." + key);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Prefix the {@code key} with the Monitoring prefix.
|
|
||||||
*
|
|
||||||
* @param key The key to prefix
|
|
||||||
* @return The key prefixed by the product prefixes.
|
|
||||||
*/
|
|
||||||
static String key(String key) {
|
|
||||||
return XPackPlugin.featureSettingPrefix(Monitoring.NAME) + "." + key;
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
|
@ -5,10 +5,6 @@
|
||||||
*/
|
*/
|
||||||
package org.elasticsearch.xpack.monitoring.cleaner;
|
package org.elasticsearch.xpack.monitoring.cleaner;
|
||||||
|
|
||||||
import java.util.List;
|
|
||||||
import java.util.concurrent.CopyOnWriteArrayList;
|
|
||||||
import java.util.concurrent.ScheduledFuture;
|
|
||||||
|
|
||||||
import org.elasticsearch.common.component.AbstractLifecycleComponent;
|
import org.elasticsearch.common.component.AbstractLifecycleComponent;
|
||||||
import org.elasticsearch.common.settings.ClusterSettings;
|
import org.elasticsearch.common.settings.ClusterSettings;
|
||||||
import org.elasticsearch.common.settings.Settings;
|
import org.elasticsearch.common.settings.Settings;
|
||||||
|
@ -18,10 +14,14 @@ import org.elasticsearch.common.util.concurrent.EsRejectedExecutionException;
|
||||||
import org.elasticsearch.common.util.concurrent.FutureUtils;
|
import org.elasticsearch.common.util.concurrent.FutureUtils;
|
||||||
import org.elasticsearch.license.XPackLicenseState;
|
import org.elasticsearch.license.XPackLicenseState;
|
||||||
import org.elasticsearch.threadpool.ThreadPool;
|
import org.elasticsearch.threadpool.ThreadPool;
|
||||||
import org.elasticsearch.xpack.monitoring.MonitoringSettings;
|
import org.elasticsearch.xpack.monitoring.Monitoring;
|
||||||
import org.joda.time.DateTime;
|
import org.joda.time.DateTime;
|
||||||
import org.joda.time.chrono.ISOChronology;
|
import org.joda.time.chrono.ISOChronology;
|
||||||
|
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.concurrent.CopyOnWriteArrayList;
|
||||||
|
import java.util.concurrent.ScheduledFuture;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* {@code CleanerService} takes care of deleting old monitoring indices.
|
* {@code CleanerService} takes care of deleting old monitoring indices.
|
||||||
*/
|
*/
|
||||||
|
@ -41,11 +41,11 @@ public class CleanerService extends AbstractLifecycleComponent {
|
||||||
this.licenseState = licenseState;
|
this.licenseState = licenseState;
|
||||||
this.threadPool = threadPool;
|
this.threadPool = threadPool;
|
||||||
this.executionScheduler = executionScheduler;
|
this.executionScheduler = executionScheduler;
|
||||||
this.globalRetention = MonitoringSettings.HISTORY_DURATION.get(settings);
|
this.globalRetention = Monitoring.HISTORY_DURATION.get(settings);
|
||||||
this.runnable = new IndicesCleaner();
|
this.runnable = new IndicesCleaner();
|
||||||
|
|
||||||
// the validation is performed by the setting's object itself
|
// the validation is performed by the setting's object itself
|
||||||
clusterSettings.addSettingsUpdateConsumer(MonitoringSettings.HISTORY_DURATION, this::setGlobalRetention);
|
clusterSettings.addSettingsUpdateConsumer(Monitoring.HISTORY_DURATION, this::setGlobalRetention);
|
||||||
}
|
}
|
||||||
|
|
||||||
public CleanerService(Settings settings, ClusterSettings clusterSettings, ThreadPool threadPool, XPackLicenseState licenseState) {
|
public CleanerService(Settings settings, ClusterSettings clusterSettings, ThreadPool threadPool, XPackLicenseState licenseState) {
|
||||||
|
@ -91,7 +91,7 @@ public class CleanerService extends AbstractLifecycleComponent {
|
||||||
return globalRetention;
|
return globalRetention;
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
return MonitoringSettings.HISTORY_DURATION.getDefault(Settings.EMPTY);
|
return Monitoring.HISTORY_DURATION.getDefault(Settings.EMPTY);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -106,8 +106,7 @@ public class CleanerService extends AbstractLifecycleComponent {
|
||||||
public void setGlobalRetention(TimeValue globalRetention) {
|
public void setGlobalRetention(TimeValue globalRetention) {
|
||||||
// notify the user that their setting will be ignored until they get the right license
|
// notify the user that their setting will be ignored until they get the right license
|
||||||
if (licenseState.isUpdateRetentionAllowed() == false) {
|
if (licenseState.isUpdateRetentionAllowed() == false) {
|
||||||
logger.warn("[{}] setting will be ignored until an appropriate license is applied",
|
logger.warn("[{}] setting will be ignored until an appropriate license is applied", Monitoring.HISTORY_DURATION.getKey());
|
||||||
MonitoringSettings.HISTORY_DURATION.getKey());
|
|
||||||
}
|
}
|
||||||
|
|
||||||
this.globalRetention = globalRetention;
|
this.globalRetention = globalRetention;
|
||||||
|
|
|
@ -10,32 +10,50 @@ import org.apache.logging.log4j.util.Supplier;
|
||||||
import org.elasticsearch.ElasticsearchTimeoutException;
|
import org.elasticsearch.ElasticsearchTimeoutException;
|
||||||
import org.elasticsearch.cluster.node.DiscoveryNode;
|
import org.elasticsearch.cluster.node.DiscoveryNode;
|
||||||
import org.elasticsearch.cluster.service.ClusterService;
|
import org.elasticsearch.cluster.service.ClusterService;
|
||||||
|
import org.elasticsearch.common.Strings;
|
||||||
import org.elasticsearch.common.component.AbstractComponent;
|
import org.elasticsearch.common.component.AbstractComponent;
|
||||||
import org.elasticsearch.common.inject.internal.Nullable;
|
import org.elasticsearch.common.inject.internal.Nullable;
|
||||||
|
import org.elasticsearch.common.settings.Setting;
|
||||||
import org.elasticsearch.common.settings.Settings;
|
import org.elasticsearch.common.settings.Settings;
|
||||||
|
import org.elasticsearch.common.unit.TimeValue;
|
||||||
import org.elasticsearch.license.XPackLicenseState;
|
import org.elasticsearch.license.XPackLicenseState;
|
||||||
import org.elasticsearch.xpack.monitoring.MonitoringSettings;
|
import org.elasticsearch.xpack.XPackPlugin;
|
||||||
|
import org.elasticsearch.xpack.monitoring.Monitoring;
|
||||||
import org.elasticsearch.xpack.monitoring.exporter.MonitoringDoc;
|
import org.elasticsearch.xpack.monitoring.exporter.MonitoringDoc;
|
||||||
|
|
||||||
import java.util.Collection;
|
import java.util.Collection;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Objects;
|
||||||
|
import java.util.function.Function;
|
||||||
|
|
||||||
|
import static java.util.Collections.emptyList;
|
||||||
|
import static org.elasticsearch.common.settings.Setting.Property;
|
||||||
|
import static org.elasticsearch.common.settings.Setting.listSetting;
|
||||||
|
import static org.elasticsearch.common.settings.Setting.timeSetting;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* {@link Collector} are used to collect monitoring data about the cluster, nodes and indices.
|
* {@link Collector} are used to collect monitoring data about the cluster, nodes and indices.
|
||||||
*/
|
*/
|
||||||
public abstract class Collector extends AbstractComponent {
|
public abstract class Collector extends AbstractComponent {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* List of indices names whose stats will be exported (default to all indices)
|
||||||
|
*/
|
||||||
|
public static final Setting<List<String>> INDICES =
|
||||||
|
listSetting(collectionSetting("indices"), emptyList(), Function.identity(), Property.Dynamic, Property.NodeScope);
|
||||||
|
|
||||||
private final String name;
|
private final String name;
|
||||||
|
private final Setting<TimeValue> collectionTimeoutSetting;
|
||||||
|
|
||||||
protected final ClusterService clusterService;
|
protected final ClusterService clusterService;
|
||||||
protected final MonitoringSettings monitoringSettings;
|
|
||||||
protected final XPackLicenseState licenseState;
|
protected final XPackLicenseState licenseState;
|
||||||
|
|
||||||
public Collector(Settings settings, String name, ClusterService clusterService,
|
public Collector(final Settings settings, final String name, final ClusterService clusterService,
|
||||||
MonitoringSettings monitoringSettings, XPackLicenseState licenseState) {
|
final Setting<TimeValue> timeoutSetting, final XPackLicenseState licenseState) {
|
||||||
super(settings);
|
super(settings);
|
||||||
this.name = name;
|
this.name = name;
|
||||||
this.clusterService = clusterService;
|
this.clusterService = clusterService;
|
||||||
this.monitoringSettings = monitoringSettings;
|
this.collectionTimeoutSetting = timeoutSetting;
|
||||||
this.licenseState = licenseState;
|
this.licenseState = licenseState;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -92,6 +110,33 @@ public abstract class Collector extends AbstractComponent {
|
||||||
return System.currentTimeMillis();
|
return System.currentTimeMillis();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns the value of the collection timeout configured for the current {@link Collector}.
|
||||||
|
*
|
||||||
|
* @return the collection timeout, or {@code null} if the collector has not timeout defined.
|
||||||
|
*/
|
||||||
|
public TimeValue getCollectionTimeout() {
|
||||||
|
if (collectionTimeoutSetting == null) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
return clusterService.getClusterSettings().get(collectionTimeoutSetting);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns the names of indices Monitoring collects data from.
|
||||||
|
*
|
||||||
|
* @return a array of indices
|
||||||
|
*/
|
||||||
|
public String[] getCollectionIndices() {
|
||||||
|
final List<String> indices = clusterService.getClusterSettings().get(INDICES);
|
||||||
|
assert indices != null;
|
||||||
|
if (indices.isEmpty()) {
|
||||||
|
return Strings.EMPTY_ARRAY;
|
||||||
|
} else {
|
||||||
|
return indices.toArray(new String[indices.size()]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Creates a {@link MonitoringDoc.Node} from a {@link DiscoveryNode} and a timestamp, copying over the
|
* Creates a {@link MonitoringDoc.Node} from a {@link DiscoveryNode} and a timestamp, copying over the
|
||||||
* required information.
|
* required information.
|
||||||
|
@ -112,4 +157,14 @@ public abstract class Collector extends AbstractComponent {
|
||||||
node.getName(),
|
node.getName(),
|
||||||
timestamp);
|
timestamp);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
protected static String collectionSetting(final String settingName) {
|
||||||
|
Objects.requireNonNull(settingName, "setting name must not be null");
|
||||||
|
return XPackPlugin.featureSettingPrefix(Monitoring.NAME) + ".collection." + settingName;
|
||||||
|
}
|
||||||
|
|
||||||
|
protected static Setting<TimeValue> collectionTimeoutSetting(final String settingName) {
|
||||||
|
String name = collectionSetting(settingName);
|
||||||
|
return timeSetting(name, TimeValue.timeValueSeconds(10), Property.Dynamic, Property.NodeScope);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -14,17 +14,17 @@ import org.elasticsearch.client.Client;
|
||||||
import org.elasticsearch.cluster.ClusterState;
|
import org.elasticsearch.cluster.ClusterState;
|
||||||
import org.elasticsearch.cluster.service.ClusterService;
|
import org.elasticsearch.cluster.service.ClusterService;
|
||||||
import org.elasticsearch.common.Nullable;
|
import org.elasticsearch.common.Nullable;
|
||||||
|
import org.elasticsearch.common.settings.Setting;
|
||||||
import org.elasticsearch.common.settings.Settings;
|
import org.elasticsearch.common.settings.Settings;
|
||||||
|
import org.elasticsearch.common.unit.TimeValue;
|
||||||
import org.elasticsearch.license.License;
|
import org.elasticsearch.license.License;
|
||||||
import org.elasticsearch.license.LicenseService;
|
import org.elasticsearch.license.LicenseService;
|
||||||
import org.elasticsearch.license.LicenseUtils;
|
import org.elasticsearch.license.LicenseUtils;
|
||||||
import org.elasticsearch.license.XPackLicenseState;
|
import org.elasticsearch.license.XPackLicenseState;
|
||||||
import org.elasticsearch.xpack.XPackFeatureSet;
|
import org.elasticsearch.xpack.XPackFeatureSet;
|
||||||
import org.elasticsearch.xpack.action.XPackUsageRequestBuilder;
|
import org.elasticsearch.xpack.action.XPackUsageRequestBuilder;
|
||||||
import org.elasticsearch.xpack.monitoring.MonitoringSettings;
|
|
||||||
import org.elasticsearch.xpack.monitoring.collector.Collector;
|
import org.elasticsearch.xpack.monitoring.collector.Collector;
|
||||||
import org.elasticsearch.xpack.monitoring.exporter.MonitoringDoc;
|
import org.elasticsearch.xpack.monitoring.exporter.MonitoringDoc;
|
||||||
import org.elasticsearch.xpack.security.InternalClient;
|
|
||||||
|
|
||||||
import java.util.Collection;
|
import java.util.Collection;
|
||||||
import java.util.Collections;
|
import java.util.Collections;
|
||||||
|
@ -42,16 +42,20 @@ import java.util.List;
|
||||||
*/
|
*/
|
||||||
public class ClusterStatsCollector extends Collector {
|
public class ClusterStatsCollector extends Collector {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Timeout value when collecting the cluster stats information (default to 10s)
|
||||||
|
*/
|
||||||
|
public static final Setting<TimeValue> CLUSTER_STATS_TIMEOUT = collectionTimeoutSetting("cluster.stats.timeout");
|
||||||
|
|
||||||
private final LicenseService licenseService;
|
private final LicenseService licenseService;
|
||||||
private final Client client;
|
private final Client client;
|
||||||
|
|
||||||
public ClusterStatsCollector(final Settings settings,
|
public ClusterStatsCollector(final Settings settings,
|
||||||
final ClusterService clusterService,
|
final ClusterService clusterService,
|
||||||
final MonitoringSettings monitoringSettings,
|
|
||||||
final XPackLicenseState licenseState,
|
final XPackLicenseState licenseState,
|
||||||
final Client client,
|
final Client client,
|
||||||
final LicenseService licenseService) {
|
final LicenseService licenseService) {
|
||||||
super(settings, ClusterStatsMonitoringDoc.TYPE, clusterService, monitoringSettings, licenseState);
|
super(settings, ClusterStatsMonitoringDoc.TYPE, clusterService, CLUSTER_STATS_TIMEOUT, licenseState);
|
||||||
this.client = client;
|
this.client = client;
|
||||||
this.licenseService = licenseService;
|
this.licenseService = licenseService;
|
||||||
}
|
}
|
||||||
|
@ -65,8 +69,7 @@ public class ClusterStatsCollector extends Collector {
|
||||||
@Override
|
@Override
|
||||||
protected Collection<MonitoringDoc> doCollect(final MonitoringDoc.Node node) throws Exception {
|
protected Collection<MonitoringDoc> doCollect(final MonitoringDoc.Node node) throws Exception {
|
||||||
final Supplier<ClusterStatsResponse> clusterStatsSupplier =
|
final Supplier<ClusterStatsResponse> clusterStatsSupplier =
|
||||||
() -> client.admin().cluster().prepareClusterStats()
|
() -> client.admin().cluster().prepareClusterStats().get(getCollectionTimeout());
|
||||||
.get(monitoringSettings.clusterStatsTimeout());
|
|
||||||
final Supplier<List<XPackFeatureSet.Usage>> usageSupplier =
|
final Supplier<List<XPackFeatureSet.Usage>> usageSupplier =
|
||||||
() -> new XPackUsageRequestBuilder(client).get().getUsages();
|
() -> new XPackUsageRequestBuilder(client).get().getUsages();
|
||||||
|
|
||||||
|
|
|
@ -9,9 +9,10 @@ import org.elasticsearch.action.admin.indices.recovery.RecoveryResponse;
|
||||||
import org.elasticsearch.action.support.IndicesOptions;
|
import org.elasticsearch.action.support.IndicesOptions;
|
||||||
import org.elasticsearch.client.Client;
|
import org.elasticsearch.client.Client;
|
||||||
import org.elasticsearch.cluster.service.ClusterService;
|
import org.elasticsearch.cluster.service.ClusterService;
|
||||||
|
import org.elasticsearch.common.settings.Setting;
|
||||||
import org.elasticsearch.common.settings.Settings;
|
import org.elasticsearch.common.settings.Settings;
|
||||||
|
import org.elasticsearch.common.unit.TimeValue;
|
||||||
import org.elasticsearch.license.XPackLicenseState;
|
import org.elasticsearch.license.XPackLicenseState;
|
||||||
import org.elasticsearch.xpack.monitoring.MonitoringSettings;
|
|
||||||
import org.elasticsearch.xpack.monitoring.collector.Collector;
|
import org.elasticsearch.xpack.monitoring.collector.Collector;
|
||||||
import org.elasticsearch.xpack.monitoring.exporter.MonitoringDoc;
|
import org.elasticsearch.xpack.monitoring.exporter.MonitoringDoc;
|
||||||
|
|
||||||
|
@ -21,6 +22,8 @@ import java.util.Collections;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Objects;
|
import java.util.Objects;
|
||||||
|
|
||||||
|
import static org.elasticsearch.common.settings.Setting.boolSetting;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Collector for the Recovery API.
|
* Collector for the Recovery API.
|
||||||
* <p>
|
* <p>
|
||||||
|
@ -29,18 +32,32 @@ import java.util.Objects;
|
||||||
*/
|
*/
|
||||||
public class IndexRecoveryCollector extends Collector {
|
public class IndexRecoveryCollector extends Collector {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Timeout value when collecting the recovery information (default to 10s)
|
||||||
|
*/
|
||||||
|
public static final Setting<TimeValue> INDEX_RECOVERY_TIMEOUT = collectionTimeoutSetting("index.recovery.timeout");
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Flag to indicate if only active recoveries should be collected (default to false: all recoveries are collected)
|
||||||
|
*/
|
||||||
|
public static final Setting<Boolean> INDEX_RECOVERY_ACTIVE_ONLY =
|
||||||
|
boolSetting(collectionSetting("index.recovery.active_only"), false, Setting.Property.Dynamic, Setting.Property.NodeScope);
|
||||||
|
|
||||||
private final Client client;
|
private final Client client;
|
||||||
|
|
||||||
public IndexRecoveryCollector(final Settings settings,
|
public IndexRecoveryCollector(final Settings settings,
|
||||||
final ClusterService clusterService,
|
final ClusterService clusterService,
|
||||||
final MonitoringSettings monitoringSettings,
|
|
||||||
final XPackLicenseState licenseState,
|
final XPackLicenseState licenseState,
|
||||||
final Client client) {
|
final Client client) {
|
||||||
|
|
||||||
super(settings, IndexRecoveryMonitoringDoc.TYPE, clusterService, monitoringSettings, licenseState);
|
super(settings, IndexRecoveryMonitoringDoc.TYPE, clusterService, INDEX_RECOVERY_TIMEOUT, licenseState);
|
||||||
this.client = Objects.requireNonNull(client);
|
this.client = Objects.requireNonNull(client);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
boolean getActiveRecoveriesOnly() {
|
||||||
|
return clusterService.getClusterSettings().get(INDEX_RECOVERY_ACTIVE_ONLY);
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected boolean shouldCollect() {
|
protected boolean shouldCollect() {
|
||||||
return super.shouldCollect() && isLocalNodeMaster();
|
return super.shouldCollect() && isLocalNodeMaster();
|
||||||
|
@ -50,10 +67,10 @@ public class IndexRecoveryCollector extends Collector {
|
||||||
protected Collection<MonitoringDoc> doCollect(final MonitoringDoc.Node node) throws Exception {
|
protected Collection<MonitoringDoc> doCollect(final MonitoringDoc.Node node) throws Exception {
|
||||||
List<MonitoringDoc> results = new ArrayList<>(1);
|
List<MonitoringDoc> results = new ArrayList<>(1);
|
||||||
RecoveryResponse recoveryResponse = client.admin().indices().prepareRecoveries()
|
RecoveryResponse recoveryResponse = client.admin().indices().prepareRecoveries()
|
||||||
.setIndices(monitoringSettings.indices())
|
.setIndices(getCollectionIndices())
|
||||||
.setIndicesOptions(IndicesOptions.lenientExpandOpen())
|
.setIndicesOptions(IndicesOptions.lenientExpandOpen())
|
||||||
.setActiveOnly(monitoringSettings.recoveryActiveOnly())
|
.setActiveOnly(getActiveRecoveriesOnly())
|
||||||
.get(monitoringSettings.recoveryTimeout());
|
.get(getCollectionTimeout());
|
||||||
|
|
||||||
if (recoveryResponse.hasRecoveries()) {
|
if (recoveryResponse.hasRecoveries()) {
|
||||||
results.add(new IndexRecoveryMonitoringDoc(clusterUUID(), timestamp(), node, recoveryResponse));
|
results.add(new IndexRecoveryMonitoringDoc(clusterUUID(), timestamp(), node, recoveryResponse));
|
||||||
|
|
|
@ -10,9 +10,10 @@ import org.elasticsearch.action.admin.indices.stats.IndicesStatsResponse;
|
||||||
import org.elasticsearch.action.support.IndicesOptions;
|
import org.elasticsearch.action.support.IndicesOptions;
|
||||||
import org.elasticsearch.client.Client;
|
import org.elasticsearch.client.Client;
|
||||||
import org.elasticsearch.cluster.service.ClusterService;
|
import org.elasticsearch.cluster.service.ClusterService;
|
||||||
|
import org.elasticsearch.common.settings.Setting;
|
||||||
import org.elasticsearch.common.settings.Settings;
|
import org.elasticsearch.common.settings.Settings;
|
||||||
|
import org.elasticsearch.common.unit.TimeValue;
|
||||||
import org.elasticsearch.license.XPackLicenseState;
|
import org.elasticsearch.license.XPackLicenseState;
|
||||||
import org.elasticsearch.xpack.monitoring.MonitoringSettings;
|
|
||||||
import org.elasticsearch.xpack.monitoring.collector.Collector;
|
import org.elasticsearch.xpack.monitoring.collector.Collector;
|
||||||
import org.elasticsearch.xpack.monitoring.exporter.MonitoringDoc;
|
import org.elasticsearch.xpack.monitoring.exporter.MonitoringDoc;
|
||||||
|
|
||||||
|
@ -29,14 +30,18 @@ import java.util.List;
|
||||||
*/
|
*/
|
||||||
public class IndexStatsCollector extends Collector {
|
public class IndexStatsCollector extends Collector {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Timeout value when collecting index statistics (default to 10s)
|
||||||
|
*/
|
||||||
|
public static final Setting<TimeValue> INDEX_STATS_TIMEOUT = collectionTimeoutSetting("index.stats.timeout");
|
||||||
|
|
||||||
private final Client client;
|
private final Client client;
|
||||||
|
|
||||||
public IndexStatsCollector(final Settings settings,
|
public IndexStatsCollector(final Settings settings,
|
||||||
final ClusterService clusterService,
|
final ClusterService clusterService,
|
||||||
final MonitoringSettings monitoringSettings,
|
|
||||||
final XPackLicenseState licenseState,
|
final XPackLicenseState licenseState,
|
||||||
final Client client) {
|
final Client client) {
|
||||||
super(settings, "index-stats", clusterService, monitoringSettings, licenseState);
|
super(settings, "index-stats", clusterService, INDEX_STATS_TIMEOUT, licenseState);
|
||||||
this.client = client;
|
this.client = client;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -49,7 +54,7 @@ public class IndexStatsCollector extends Collector {
|
||||||
protected Collection<MonitoringDoc> doCollect(final MonitoringDoc.Node node) throws Exception {
|
protected Collection<MonitoringDoc> doCollect(final MonitoringDoc.Node node) throws Exception {
|
||||||
final List<MonitoringDoc> results = new ArrayList<>();
|
final List<MonitoringDoc> results = new ArrayList<>();
|
||||||
final IndicesStatsResponse indicesStats = client.admin().indices().prepareStats()
|
final IndicesStatsResponse indicesStats = client.admin().indices().prepareStats()
|
||||||
.setIndices(monitoringSettings.indices())
|
.setIndices(getCollectionIndices())
|
||||||
.setIndicesOptions(IndicesOptions.lenientExpandOpen())
|
.setIndicesOptions(IndicesOptions.lenientExpandOpen())
|
||||||
.clear()
|
.clear()
|
||||||
.setDocs(true)
|
.setDocs(true)
|
||||||
|
@ -62,7 +67,7 @@ public class IndexStatsCollector extends Collector {
|
||||||
.setRefresh(true)
|
.setRefresh(true)
|
||||||
.setQueryCache(true)
|
.setQueryCache(true)
|
||||||
.setRequestCache(true)
|
.setRequestCache(true)
|
||||||
.get(monitoringSettings.indexStatsTimeout());
|
.get(getCollectionTimeout());
|
||||||
|
|
||||||
final long timestamp = timestamp();
|
final long timestamp = timestamp();
|
||||||
final String clusterUuid = clusterUUID();
|
final String clusterUuid = clusterUUID();
|
||||||
|
|
|
@ -6,15 +6,15 @@
|
||||||
package org.elasticsearch.xpack.monitoring.collector.ml;
|
package org.elasticsearch.xpack.monitoring.collector.ml;
|
||||||
|
|
||||||
import org.elasticsearch.cluster.metadata.MetaData;
|
import org.elasticsearch.cluster.metadata.MetaData;
|
||||||
import org.elasticsearch.cluster.node.DiscoveryNode;
|
|
||||||
import org.elasticsearch.cluster.service.ClusterService;
|
import org.elasticsearch.cluster.service.ClusterService;
|
||||||
|
import org.elasticsearch.common.settings.Setting;
|
||||||
import org.elasticsearch.common.settings.Settings;
|
import org.elasticsearch.common.settings.Settings;
|
||||||
|
import org.elasticsearch.common.unit.TimeValue;
|
||||||
import org.elasticsearch.license.XPackLicenseState;
|
import org.elasticsearch.license.XPackLicenseState;
|
||||||
import org.elasticsearch.xpack.XPackClient;
|
import org.elasticsearch.xpack.XPackClient;
|
||||||
import org.elasticsearch.xpack.XPackSettings;
|
import org.elasticsearch.xpack.XPackSettings;
|
||||||
import org.elasticsearch.xpack.ml.action.GetJobsStatsAction;
|
import org.elasticsearch.xpack.ml.action.GetJobsStatsAction;
|
||||||
import org.elasticsearch.xpack.ml.client.MachineLearningClient;
|
import org.elasticsearch.xpack.ml.client.MachineLearningClient;
|
||||||
import org.elasticsearch.xpack.monitoring.MonitoringSettings;
|
|
||||||
import org.elasticsearch.xpack.monitoring.collector.Collector;
|
import org.elasticsearch.xpack.monitoring.collector.Collector;
|
||||||
import org.elasticsearch.xpack.monitoring.exporter.MonitoringDoc;
|
import org.elasticsearch.xpack.monitoring.exporter.MonitoringDoc;
|
||||||
import org.elasticsearch.xpack.security.InternalClient;
|
import org.elasticsearch.xpack.security.InternalClient;
|
||||||
|
@ -32,18 +32,21 @@ import java.util.stream.Collectors;
|
||||||
*/
|
*/
|
||||||
public class JobStatsCollector extends Collector {
|
public class JobStatsCollector extends Collector {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Timeout value when collecting ML job statistics (default to 10s)
|
||||||
|
*/
|
||||||
|
public static final Setting<TimeValue> JOB_STATS_TIMEOUT = collectionTimeoutSetting("ml.job.stats.timeout");
|
||||||
|
|
||||||
private final MachineLearningClient client;
|
private final MachineLearningClient client;
|
||||||
|
|
||||||
public JobStatsCollector(final Settings settings, final ClusterService clusterService,
|
public JobStatsCollector(final Settings settings, final ClusterService clusterService,
|
||||||
final MonitoringSettings monitoringSettings,
|
|
||||||
final XPackLicenseState licenseState, final InternalClient client) {
|
final XPackLicenseState licenseState, final InternalClient client) {
|
||||||
this(settings, clusterService, monitoringSettings, licenseState, new XPackClient(client).machineLearning());
|
this(settings, clusterService, licenseState, new XPackClient(client).machineLearning());
|
||||||
}
|
}
|
||||||
|
|
||||||
JobStatsCollector(final Settings settings, final ClusterService clusterService,
|
JobStatsCollector(final Settings settings, final ClusterService clusterService,
|
||||||
final MonitoringSettings monitoringSettings,
|
|
||||||
final XPackLicenseState licenseState, final MachineLearningClient client) {
|
final XPackLicenseState licenseState, final MachineLearningClient client) {
|
||||||
super(settings, JobStatsMonitoringDoc.TYPE, clusterService, monitoringSettings, licenseState);
|
super(settings, JobStatsMonitoringDoc.TYPE, clusterService, JOB_STATS_TIMEOUT, licenseState);
|
||||||
|
|
||||||
this.client = client;
|
this.client = client;
|
||||||
}
|
}
|
||||||
|
@ -61,7 +64,7 @@ public class JobStatsCollector extends Collector {
|
||||||
// fetch details about all jobs
|
// fetch details about all jobs
|
||||||
final GetJobsStatsAction.Response jobs =
|
final GetJobsStatsAction.Response jobs =
|
||||||
client.getJobsStats(new GetJobsStatsAction.Request(MetaData.ALL))
|
client.getJobsStats(new GetJobsStatsAction.Request(MetaData.ALL))
|
||||||
.actionGet(monitoringSettings.jobStatsTimeout());
|
.actionGet(getCollectionTimeout());
|
||||||
|
|
||||||
final long timestamp = timestamp();
|
final long timestamp = timestamp();
|
||||||
final String clusterUuid = clusterUUID();
|
final String clusterUuid = clusterUUID();
|
||||||
|
|
|
@ -12,9 +12,10 @@ import org.elasticsearch.action.admin.indices.stats.CommonStatsFlags;
|
||||||
import org.elasticsearch.bootstrap.BootstrapInfo;
|
import org.elasticsearch.bootstrap.BootstrapInfo;
|
||||||
import org.elasticsearch.client.Client;
|
import org.elasticsearch.client.Client;
|
||||||
import org.elasticsearch.cluster.service.ClusterService;
|
import org.elasticsearch.cluster.service.ClusterService;
|
||||||
|
import org.elasticsearch.common.settings.Setting;
|
||||||
import org.elasticsearch.common.settings.Settings;
|
import org.elasticsearch.common.settings.Settings;
|
||||||
|
import org.elasticsearch.common.unit.TimeValue;
|
||||||
import org.elasticsearch.license.XPackLicenseState;
|
import org.elasticsearch.license.XPackLicenseState;
|
||||||
import org.elasticsearch.xpack.monitoring.MonitoringSettings;
|
|
||||||
import org.elasticsearch.xpack.monitoring.collector.Collector;
|
import org.elasticsearch.xpack.monitoring.collector.Collector;
|
||||||
import org.elasticsearch.xpack.monitoring.exporter.MonitoringDoc;
|
import org.elasticsearch.xpack.monitoring.exporter.MonitoringDoc;
|
||||||
|
|
||||||
|
@ -30,6 +31,11 @@ import java.util.Objects;
|
||||||
*/
|
*/
|
||||||
public class NodeStatsCollector extends Collector {
|
public class NodeStatsCollector extends Collector {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Timeout value when collecting the nodes statistics (default to 10s)
|
||||||
|
*/
|
||||||
|
public static final Setting<TimeValue> NODE_STATS_TIMEOUT = collectionTimeoutSetting("node.stats.timeout");
|
||||||
|
|
||||||
private static final CommonStatsFlags FLAGS =
|
private static final CommonStatsFlags FLAGS =
|
||||||
new CommonStatsFlags(CommonStatsFlags.Flag.Docs,
|
new CommonStatsFlags(CommonStatsFlags.Flag.Docs,
|
||||||
CommonStatsFlags.Flag.FieldData,
|
CommonStatsFlags.Flag.FieldData,
|
||||||
|
@ -44,10 +50,10 @@ public class NodeStatsCollector extends Collector {
|
||||||
|
|
||||||
public NodeStatsCollector(final Settings settings,
|
public NodeStatsCollector(final Settings settings,
|
||||||
final ClusterService clusterService,
|
final ClusterService clusterService,
|
||||||
final MonitoringSettings monitoringSettings,
|
|
||||||
final XPackLicenseState licenseState,
|
final XPackLicenseState licenseState,
|
||||||
final Client client) {
|
final Client client) {
|
||||||
super(settings, NodeStatsMonitoringDoc.TYPE, clusterService, monitoringSettings, licenseState);
|
|
||||||
|
super(settings, NodeStatsMonitoringDoc.TYPE, clusterService, NODE_STATS_TIMEOUT, licenseState);
|
||||||
this.client = Objects.requireNonNull(client);
|
this.client = Objects.requireNonNull(client);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -67,7 +73,7 @@ public class NodeStatsCollector extends Collector {
|
||||||
request.threadPool(true);
|
request.threadPool(true);
|
||||||
request.fs(true);
|
request.fs(true);
|
||||||
|
|
||||||
final NodesStatsResponse response = client.admin().cluster().nodesStats(request).actionGet(monitoringSettings.nodeStatsTimeout());
|
final NodesStatsResponse response = client.admin().cluster().nodesStats(request).actionGet(getCollectionTimeout());
|
||||||
|
|
||||||
// if there's a failure, then we failed to work with the
|
// if there's a failure, then we failed to work with the
|
||||||
// _local node (guaranteed a single exception)
|
// _local node (guaranteed a single exception)
|
||||||
|
|
|
@ -13,7 +13,6 @@ import org.elasticsearch.cluster.service.ClusterService;
|
||||||
import org.elasticsearch.common.regex.Regex;
|
import org.elasticsearch.common.regex.Regex;
|
||||||
import org.elasticsearch.common.settings.Settings;
|
import org.elasticsearch.common.settings.Settings;
|
||||||
import org.elasticsearch.license.XPackLicenseState;
|
import org.elasticsearch.license.XPackLicenseState;
|
||||||
import org.elasticsearch.xpack.monitoring.MonitoringSettings;
|
|
||||||
import org.elasticsearch.xpack.monitoring.collector.Collector;
|
import org.elasticsearch.xpack.monitoring.collector.Collector;
|
||||||
import org.elasticsearch.xpack.monitoring.exporter.MonitoringDoc;
|
import org.elasticsearch.xpack.monitoring.exporter.MonitoringDoc;
|
||||||
|
|
||||||
|
@ -33,10 +32,9 @@ public class ShardsCollector extends Collector {
|
||||||
|
|
||||||
public ShardsCollector(final Settings settings,
|
public ShardsCollector(final Settings settings,
|
||||||
final ClusterService clusterService,
|
final ClusterService clusterService,
|
||||||
final MonitoringSettings monitoringSettings,
|
|
||||||
final XPackLicenseState licenseState) {
|
final XPackLicenseState licenseState) {
|
||||||
|
|
||||||
super(settings, ShardMonitoringDoc.TYPE, clusterService, monitoringSettings, licenseState);
|
super(settings, ShardMonitoringDoc.TYPE, clusterService, null, licenseState);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -48,7 +46,7 @@ public class ShardsCollector extends Collector {
|
||||||
protected Collection<MonitoringDoc> doCollect(final MonitoringDoc.Node node) throws Exception {
|
protected Collection<MonitoringDoc> doCollect(final MonitoringDoc.Node node) throws Exception {
|
||||||
final List<MonitoringDoc> results = new ArrayList<>(1);
|
final List<MonitoringDoc> results = new ArrayList<>(1);
|
||||||
|
|
||||||
ClusterState clusterState = clusterService.state();
|
final ClusterState clusterState = clusterService.state();
|
||||||
if (clusterState != null) {
|
if (clusterState != null) {
|
||||||
RoutingTable routingTable = clusterState.routingTable();
|
RoutingTable routingTable = clusterState.routingTable();
|
||||||
if (routingTable != null) {
|
if (routingTable != null) {
|
||||||
|
@ -58,8 +56,11 @@ public class ShardsCollector extends Collector {
|
||||||
final String stateUUID = clusterState.stateUUID();
|
final String stateUUID = clusterState.stateUUID();
|
||||||
final long timestamp = timestamp();
|
final long timestamp = timestamp();
|
||||||
|
|
||||||
|
final String[] indices = getCollectionIndices();
|
||||||
|
final boolean isAllIndices = IndexNameExpressionResolver.isAllIndices(Arrays.asList(indices));
|
||||||
|
|
||||||
for (ShardRouting shard : shards) {
|
for (ShardRouting shard : shards) {
|
||||||
if (match(shard.getIndexName())) {
|
if (isAllIndices || Regex.simpleMatch(indices, shard.getIndexName())) {
|
||||||
MonitoringDoc.Node shardNode = null;
|
MonitoringDoc.Node shardNode = null;
|
||||||
if (shard.assignedToNode()) {
|
if (shard.assignedToNode()) {
|
||||||
// If the shard is assigned to a node, the shard monitoring document refers to this node
|
// If the shard is assigned to a node, the shard monitoring document refers to this node
|
||||||
|
@ -73,9 +74,4 @@ public class ShardsCollector extends Collector {
|
||||||
}
|
}
|
||||||
return Collections.unmodifiableCollection(results);
|
return Collections.unmodifiableCollection(results);
|
||||||
}
|
}
|
||||||
|
|
||||||
private boolean match(final String indexName) {
|
|
||||||
final String[] indices = monitoringSettings.indices();
|
|
||||||
return IndexNameExpressionResolver.isAllIndices(Arrays.asList(indices)) || Regex.simpleMatch(indices, indexName);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -9,7 +9,6 @@ import org.elasticsearch.cluster.service.ClusterService;
|
||||||
import org.elasticsearch.common.settings.Settings;
|
import org.elasticsearch.common.settings.Settings;
|
||||||
import org.elasticsearch.common.settings.SettingsException;
|
import org.elasticsearch.common.settings.SettingsException;
|
||||||
import org.elasticsearch.license.XPackLicenseState;
|
import org.elasticsearch.license.XPackLicenseState;
|
||||||
import org.elasticsearch.xpack.monitoring.MonitoringSettings;
|
|
||||||
import org.joda.time.format.DateTimeFormat;
|
import org.joda.time.format.DateTimeFormat;
|
||||||
import org.joda.time.format.DateTimeFormatter;
|
import org.joda.time.format.DateTimeFormatter;
|
||||||
|
|
||||||
|
@ -73,11 +72,11 @@ public abstract class Exporter implements AutoCloseable {
|
||||||
protected abstract void doClose();
|
protected abstract void doClose();
|
||||||
|
|
||||||
protected static String settingFQN(final Config config) {
|
protected static String settingFQN(final Config config) {
|
||||||
return MonitoringSettings.EXPORTERS_SETTINGS.getKey() + config.name;
|
return Exporters.EXPORTERS_SETTINGS.getKey() + config.name;
|
||||||
}
|
}
|
||||||
|
|
||||||
protected static String settingFQN(final Config config, final String setting) {
|
protected static String settingFQN(final Config config, final String setting) {
|
||||||
return MonitoringSettings.EXPORTERS_SETTINGS.getKey() + config.name + "." + setting;
|
return Exporters.EXPORTERS_SETTINGS.getKey() + config.name + "." + setting;
|
||||||
}
|
}
|
||||||
|
|
||||||
protected static DateTimeFormatter dateTimeFormatter(final Config config) {
|
protected static DateTimeFormatter dateTimeFormatter(final Config config) {
|
||||||
|
|
|
@ -13,11 +13,11 @@ import org.elasticsearch.cluster.ClusterState;
|
||||||
import org.elasticsearch.cluster.service.ClusterService;
|
import org.elasticsearch.cluster.service.ClusterService;
|
||||||
import org.elasticsearch.common.component.AbstractLifecycleComponent;
|
import org.elasticsearch.common.component.AbstractLifecycleComponent;
|
||||||
import org.elasticsearch.common.component.Lifecycle;
|
import org.elasticsearch.common.component.Lifecycle;
|
||||||
|
import org.elasticsearch.common.settings.Setting;
|
||||||
import org.elasticsearch.common.settings.Settings;
|
import org.elasticsearch.common.settings.Settings;
|
||||||
import org.elasticsearch.common.settings.SettingsException;
|
import org.elasticsearch.common.settings.SettingsException;
|
||||||
import org.elasticsearch.common.util.concurrent.ThreadContext;
|
import org.elasticsearch.common.util.concurrent.ThreadContext;
|
||||||
import org.elasticsearch.license.XPackLicenseState;
|
import org.elasticsearch.license.XPackLicenseState;
|
||||||
import org.elasticsearch.xpack.monitoring.MonitoringSettings;
|
|
||||||
import org.elasticsearch.xpack.monitoring.exporter.local.LocalExporter;
|
import org.elasticsearch.xpack.monitoring.exporter.local.LocalExporter;
|
||||||
|
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
|
@ -32,9 +32,16 @@ import java.util.Set;
|
||||||
import java.util.concurrent.atomic.AtomicReference;
|
import java.util.concurrent.atomic.AtomicReference;
|
||||||
|
|
||||||
import static java.util.Collections.emptyMap;
|
import static java.util.Collections.emptyMap;
|
||||||
|
import static org.elasticsearch.common.settings.Setting.groupSetting;
|
||||||
|
|
||||||
public class Exporters extends AbstractLifecycleComponent implements Iterable<Exporter> {
|
public class Exporters extends AbstractLifecycleComponent implements Iterable<Exporter> {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Settings/Options per configured exporter
|
||||||
|
*/
|
||||||
|
public static final Setting<Settings> EXPORTERS_SETTINGS =
|
||||||
|
groupSetting("xpack.monitoring.exporters.", Setting.Property.Dynamic, Setting.Property.NodeScope);
|
||||||
|
|
||||||
private final Map<String, Exporter.Factory> factories;
|
private final Map<String, Exporter.Factory> factories;
|
||||||
private final AtomicReference<Map<String, Exporter>> exporters;
|
private final AtomicReference<Map<String, Exporter>> exporters;
|
||||||
private final ClusterService clusterService;
|
private final ClusterService clusterService;
|
||||||
|
@ -52,7 +59,7 @@ public class Exporters extends AbstractLifecycleComponent implements Iterable<Ex
|
||||||
this.clusterService = Objects.requireNonNull(clusterService);
|
this.clusterService = Objects.requireNonNull(clusterService);
|
||||||
this.licenseState = Objects.requireNonNull(licenseState);
|
this.licenseState = Objects.requireNonNull(licenseState);
|
||||||
|
|
||||||
clusterService.getClusterSettings().addSettingsUpdateConsumer(MonitoringSettings.EXPORTERS_SETTINGS, this::setExportersSetting);
|
clusterService.getClusterSettings().addSettingsUpdateConsumer(EXPORTERS_SETTINGS, this::setExportersSetting);
|
||||||
}
|
}
|
||||||
|
|
||||||
private void setExportersSetting(Settings exportersSetting) {
|
private void setExportersSetting(Settings exportersSetting) {
|
||||||
|
@ -67,7 +74,7 @@ public class Exporters extends AbstractLifecycleComponent implements Iterable<Ex
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected void doStart() {
|
protected void doStart() {
|
||||||
exporters.set(initExporters(MonitoringSettings.EXPORTERS_SETTINGS.get(settings)));
|
exporters.set(initExporters(EXPORTERS_SETTINGS.get(settings)));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|
|
@ -198,9 +198,7 @@ public class AutodetectCommunicatorTests extends ESTestCase {
|
||||||
((ActionListener<Boolean>) invocation.getArguments()[0]).onResponse(true);
|
((ActionListener<Boolean>) invocation.getArguments()[0]).onResponse(true);
|
||||||
return null;
|
return null;
|
||||||
}).when(dataCountsReporter).finishReporting(any());
|
}).when(dataCountsReporter).finishReporting(any());
|
||||||
JobTask jobTask = mock(JobTask.class);
|
return new AutodetectCommunicator(createJobDetails(), autodetectProcess, stateStreamer,
|
||||||
when(jobTask.getJobId()).thenReturn("foo");
|
|
||||||
return new AutodetectCommunicator(createJobDetails(), jobTask, autodetectProcess, stateStreamer,
|
|
||||||
dataCountsReporter, autoDetectResultProcessor, finishHandler,
|
dataCountsReporter, autoDetectResultProcessor, finishHandler,
|
||||||
new NamedXContentRegistry(Collections.emptyList()), executorService);
|
new NamedXContentRegistry(Collections.emptyList()), executorService);
|
||||||
}
|
}
|
||||||
|
|
|
@ -459,7 +459,6 @@ public class AutodetectProcessManagerTests extends ESTestCase {
|
||||||
JobTask jobTask = mock(JobTask.class);
|
JobTask jobTask = mock(JobTask.class);
|
||||||
when(jobTask.getJobId()).thenReturn("foo");
|
when(jobTask.getJobId()).thenReturn("foo");
|
||||||
assertFalse(manager.jobHasActiveAutodetectProcess(jobTask));
|
assertFalse(manager.jobHasActiveAutodetectProcess(jobTask));
|
||||||
when(communicator.getJobTask()).thenReturn(jobTask);
|
|
||||||
|
|
||||||
manager.openJob(jobTask, e -> {});
|
manager.openJob(jobTask, e -> {});
|
||||||
manager.processData(jobTask, createInputStream(""), randomFrom(XContentType.values()),
|
manager.processData(jobTask, createInputStream(""), randomFrom(XContentType.values()),
|
||||||
|
|
|
@ -8,38 +8,29 @@ package org.elasticsearch.xpack.monitoring;
|
||||||
import org.elasticsearch.common.settings.Settings;
|
import org.elasticsearch.common.settings.Settings;
|
||||||
import org.elasticsearch.common.unit.TimeValue;
|
import org.elasticsearch.common.unit.TimeValue;
|
||||||
import org.elasticsearch.test.ESTestCase;
|
import org.elasticsearch.test.ESTestCase;
|
||||||
import org.junit.Rule;
|
|
||||||
import org.junit.rules.ExpectedException;
|
|
||||||
|
|
||||||
/**
|
public class MonitoringHistoryDurationSettingsTests extends ESTestCase {
|
||||||
* Tests {@link MonitoringSettings}
|
|
||||||
*/
|
|
||||||
public class MonitoringSettingsTests extends ESTestCase {
|
|
||||||
@Rule
|
|
||||||
public ExpectedException expectedException = ExpectedException.none();
|
|
||||||
|
|
||||||
public void testHistoryDurationDefaults7Days() {
|
public void testHistoryDurationDefaults7Days() {
|
||||||
TimeValue sevenDays = TimeValue.timeValueHours(7 * 24);
|
TimeValue sevenDays = TimeValue.timeValueHours(7 * 24);
|
||||||
|
|
||||||
// 7 days
|
// 7 days
|
||||||
assertEquals(sevenDays, MonitoringSettings.HISTORY_DURATION.get(Settings.EMPTY));
|
assertEquals(sevenDays, Monitoring.HISTORY_DURATION.get(Settings.EMPTY));
|
||||||
// Note: this verifies the semantics because this is taken for granted that it never returns null!
|
// Note: this verifies the semantics because this is taken for granted that it never returns null!
|
||||||
assertEquals(sevenDays, MonitoringSettings.HISTORY_DURATION.get(buildSettings(MonitoringSettings.HISTORY_DURATION.getKey(), null)));
|
assertEquals(sevenDays, Monitoring.HISTORY_DURATION.get(buildSettings(Monitoring.HISTORY_DURATION.getKey(), null)));
|
||||||
}
|
}
|
||||||
|
|
||||||
public void testHistoryDurationMinimum24Hours() {
|
public void testHistoryDurationMinimum24Hours() {
|
||||||
// hit the minimum
|
// hit the minimum
|
||||||
assertEquals(MonitoringSettings.HISTORY_DURATION_MINIMUM,
|
assertEquals(Monitoring.HISTORY_DURATION_MINIMUM,
|
||||||
MonitoringSettings.HISTORY_DURATION.get(buildSettings(MonitoringSettings.HISTORY_DURATION.getKey(), "24h")));
|
Monitoring.HISTORY_DURATION.get(buildSettings(Monitoring.HISTORY_DURATION.getKey(), "24h")));
|
||||||
}
|
}
|
||||||
|
|
||||||
public void testHistoryDurationMinimum24HoursBlocksLower() {
|
public void testHistoryDurationMinimum24HoursBlocksLower() {
|
||||||
expectedException.expect(IllegalArgumentException.class);
|
|
||||||
|
|
||||||
// 1 ms early!
|
// 1 ms early!
|
||||||
String oneSecondEarly = (MonitoringSettings.HISTORY_DURATION_MINIMUM.millis() - 1) + "ms";
|
final String oneSecondEarly = (Monitoring.HISTORY_DURATION_MINIMUM.millis() - 1) + "ms";
|
||||||
|
expectThrows(IllegalArgumentException.class,
|
||||||
MonitoringSettings.HISTORY_DURATION.get(buildSettings(MonitoringSettings.HISTORY_DURATION.getKey(), oneSecondEarly));
|
() -> Monitoring.HISTORY_DURATION.get(buildSettings(Monitoring.HISTORY_DURATION.getKey(), oneSecondEarly)));
|
||||||
}
|
}
|
||||||
|
|
||||||
private Settings buildSettings(String key, String value) {
|
private Settings buildSettings(String key, String value) {
|
|
@ -86,7 +86,7 @@ public class MonitoringPluginTests extends MonitoringIntegTestCase {
|
||||||
protected Settings nodeSettings(int nodeOrdinal) {
|
protected Settings nodeSettings(int nodeOrdinal) {
|
||||||
return Settings.builder()
|
return Settings.builder()
|
||||||
.put(super.nodeSettings(nodeOrdinal))
|
.put(super.nodeSettings(nodeOrdinal))
|
||||||
.put(MonitoringSettings.INTERVAL.getKey(), "-1")
|
.put(MonitoringService.INTERVAL.getKey(), "-1")
|
||||||
.build();
|
.build();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -33,18 +33,20 @@ import static org.mockito.Mockito.when;
|
||||||
|
|
||||||
public class MonitoringServiceTests extends ESTestCase {
|
public class MonitoringServiceTests extends ESTestCase {
|
||||||
|
|
||||||
TestThreadPool threadPool;
|
private TestThreadPool threadPool;
|
||||||
MonitoringService monitoringService;
|
private MonitoringService monitoringService;
|
||||||
XPackLicenseState licenseState = mock(XPackLicenseState.class);
|
private XPackLicenseState licenseState = mock(XPackLicenseState.class);
|
||||||
ClusterService clusterService;
|
private ClusterService clusterService;
|
||||||
ClusterSettings clusterSettings;
|
private ClusterSettings clusterSettings;
|
||||||
|
|
||||||
@Before
|
@Before
|
||||||
public void setUp() throws Exception {
|
public void setUp() throws Exception {
|
||||||
super.setUp();
|
super.setUp();
|
||||||
threadPool = new TestThreadPool(getTestName());
|
threadPool = new TestThreadPool(getTestName());
|
||||||
clusterService = mock(ClusterService.class);
|
clusterService = mock(ClusterService.class);
|
||||||
clusterSettings = new ClusterSettings(Settings.EMPTY, new HashSet<>(MonitoringSettings.getSettings()));
|
|
||||||
|
final Monitoring monitoring = new Monitoring(Settings.EMPTY, licenseState);
|
||||||
|
clusterSettings = new ClusterSettings(Settings.EMPTY, new HashSet<>(monitoring.getSettings()));
|
||||||
when(clusterService.getClusterSettings()).thenReturn(clusterSettings);
|
when(clusterService.getClusterSettings()).thenReturn(clusterSettings);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -77,7 +79,7 @@ public class MonitoringServiceTests extends ESTestCase {
|
||||||
}
|
}
|
||||||
|
|
||||||
public void testInterval() throws Exception {
|
public void testInterval() throws Exception {
|
||||||
Settings settings = Settings.builder().put(MonitoringSettings.INTERVAL.getKey(), TimeValue.MINUS_ONE).build();
|
Settings settings = Settings.builder().put(MonitoringService.INTERVAL.getKey(), TimeValue.MINUS_ONE).build();
|
||||||
|
|
||||||
CountingExporter exporter = new CountingExporter();
|
CountingExporter exporter = new CountingExporter();
|
||||||
monitoringService = new MonitoringService(settings, clusterSettings, threadPool, emptySet(), exporter);
|
monitoringService = new MonitoringService(settings, clusterSettings, threadPool, emptySet(), exporter);
|
||||||
|
@ -102,7 +104,7 @@ public class MonitoringServiceTests extends ESTestCase {
|
||||||
final CountDownLatch latch = new CountDownLatch(1);
|
final CountDownLatch latch = new CountDownLatch(1);
|
||||||
final BlockingExporter exporter = new BlockingExporter(latch);
|
final BlockingExporter exporter = new BlockingExporter(latch);
|
||||||
|
|
||||||
Settings settings = Settings.builder().put(MonitoringSettings.INTERVAL.getKey(), MonitoringSettings.MIN_INTERVAL).build();
|
Settings settings = Settings.builder().put(MonitoringService.INTERVAL.getKey(), MonitoringService.MIN_INTERVAL).build();
|
||||||
monitoringService = new MonitoringService(settings, clusterSettings, threadPool, emptySet(), exporter);
|
monitoringService = new MonitoringService(settings, clusterSettings, threadPool, emptySet(), exporter);
|
||||||
|
|
||||||
monitoringService.start();
|
monitoringService.start();
|
||||||
|
|
|
@ -1,167 +0,0 @@
|
||||||
/*
|
|
||||||
* Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one
|
|
||||||
* or more contributor license agreements. Licensed under the Elastic License;
|
|
||||||
* you may not use this file except in compliance with the Elastic License.
|
|
||||||
*/
|
|
||||||
package org.elasticsearch.xpack.monitoring;
|
|
||||||
|
|
||||||
import org.elasticsearch.action.admin.cluster.settings.ClusterUpdateSettingsRequestBuilder;
|
|
||||||
import org.elasticsearch.common.network.NetworkModule;
|
|
||||||
import org.elasticsearch.common.settings.Setting;
|
|
||||||
import org.elasticsearch.common.settings.Settings;
|
|
||||||
import org.elasticsearch.common.unit.TimeValue;
|
|
||||||
import org.elasticsearch.plugins.Plugin;
|
|
||||||
import org.elasticsearch.test.ESIntegTestCase;
|
|
||||||
import org.elasticsearch.transport.Netty4Plugin;
|
|
||||||
import org.elasticsearch.xpack.monitoring.test.MonitoringIntegTestCase;
|
|
||||||
|
|
||||||
import java.util.ArrayList;
|
|
||||||
import java.util.Arrays;
|
|
||||||
import java.util.Collection;
|
|
||||||
import java.util.List;
|
|
||||||
|
|
||||||
import static org.elasticsearch.test.hamcrest.ElasticsearchAssertions.assertAcked;
|
|
||||||
import static org.hamcrest.Matchers.equalTo;
|
|
||||||
|
|
||||||
@ESIntegTestCase.ClusterScope(scope = ESIntegTestCase.Scope.TEST, supportsDedicatedMasters = false, numDataNodes = 1, numClientNodes = 0)
|
|
||||||
public class MonitoringSettingsIntegTests extends MonitoringIntegTestCase {
|
|
||||||
private final TimeValue interval = newRandomTimeValue();
|
|
||||||
private final TimeValue indexStatsTimeout = newRandomTimeValue();
|
|
||||||
private final String[] indices = randomStringArray();
|
|
||||||
private final TimeValue clusterStateTimeout = newRandomTimeValue();
|
|
||||||
private final TimeValue clusterStatsTimeout = newRandomTimeValue();
|
|
||||||
private final TimeValue jobStatsTimeout = newRandomTimeValue();
|
|
||||||
private final TimeValue recoveryTimeout = newRandomTimeValue();
|
|
||||||
private final Boolean recoveryActiveOnly = randomBoolean();
|
|
||||||
|
|
||||||
@Override
|
|
||||||
protected Settings nodeSettings(int nodeOrdinal) {
|
|
||||||
return Settings.builder()
|
|
||||||
.put(super.nodeSettings(nodeOrdinal))
|
|
||||||
.put(NetworkModule.HTTP_ENABLED.getKey(), false)
|
|
||||||
.put(monitoringSettings())
|
|
||||||
.build();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
protected Collection<Class<? extends Plugin>> nodePlugins() {
|
|
||||||
ArrayList<Class<? extends Plugin>> plugins = new ArrayList<>(super.nodePlugins());
|
|
||||||
plugins.add(Netty4Plugin.class); // for http
|
|
||||||
return plugins;
|
|
||||||
}
|
|
||||||
|
|
||||||
private Settings monitoringSettings() {
|
|
||||||
return Settings.builder()
|
|
||||||
.put(MonitoringSettings.INTERVAL.getKey(), interval)
|
|
||||||
.put(MonitoringSettings.INDEX_STATS_TIMEOUT.getKey(), indexStatsTimeout)
|
|
||||||
.putArray(MonitoringSettings.INDICES.getKey(), indices)
|
|
||||||
.put(MonitoringSettings.CLUSTER_STATE_TIMEOUT.getKey(), clusterStateTimeout)
|
|
||||||
.put(MonitoringSettings.CLUSTER_STATS_TIMEOUT.getKey(), clusterStatsTimeout)
|
|
||||||
.put(MonitoringSettings.JOB_STATS_TIMEOUT.getKey(), jobStatsTimeout)
|
|
||||||
.put(MonitoringSettings.INDEX_RECOVERY_TIMEOUT.getKey(), recoveryTimeout)
|
|
||||||
.put(MonitoringSettings.INDEX_RECOVERY_ACTIVE_ONLY.getKey(), recoveryActiveOnly)
|
|
||||||
.build();
|
|
||||||
}
|
|
||||||
|
|
||||||
public void testMonitoringSettings() throws Exception {
|
|
||||||
for (final MonitoringSettings monitoringSettings : internalCluster().getInstances(MonitoringSettings.class)) {
|
|
||||||
assertThat(monitoringSettings.indexStatsTimeout().millis(), equalTo(indexStatsTimeout.millis()));
|
|
||||||
assertArrayEquals(monitoringSettings.indices(), indices);
|
|
||||||
assertThat(monitoringSettings.clusterStateTimeout().millis(), equalTo(clusterStateTimeout.millis()));
|
|
||||||
assertThat(monitoringSettings.clusterStatsTimeout().millis(), equalTo(clusterStatsTimeout.millis()));
|
|
||||||
assertThat(monitoringSettings.jobStatsTimeout().millis(), equalTo(jobStatsTimeout.millis()));
|
|
||||||
assertThat(monitoringSettings.recoveryTimeout().millis(), equalTo(recoveryTimeout.millis()));
|
|
||||||
assertThat(monitoringSettings.recoveryActiveOnly(), equalTo(recoveryActiveOnly));
|
|
||||||
}
|
|
||||||
|
|
||||||
for (final MonitoringService service : internalCluster().getInstances(MonitoringService.class)) {
|
|
||||||
assertThat(service.getInterval().millis(), equalTo(interval.millis()));
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
logger.info("--> testing monitoring dynamic settings update");
|
|
||||||
Settings.Builder transientSettings = Settings.builder();
|
|
||||||
final Setting[] monitoringSettings = new Setting[]{
|
|
||||||
MonitoringSettings.INDICES,
|
|
||||||
MonitoringSettings.INTERVAL,
|
|
||||||
MonitoringSettings.INDEX_RECOVERY_TIMEOUT,
|
|
||||||
MonitoringSettings.INDEX_STATS_TIMEOUT,
|
|
||||||
MonitoringSettings.INDEX_RECOVERY_ACTIVE_ONLY,
|
|
||||||
MonitoringSettings.CLUSTER_STATE_TIMEOUT,
|
|
||||||
MonitoringSettings.CLUSTER_STATS_TIMEOUT,
|
|
||||||
MonitoringSettings.JOB_STATS_TIMEOUT};
|
|
||||||
for (Setting<?> setting : monitoringSettings) {
|
|
||||||
if (setting.isDynamic()) {
|
|
||||||
if (setting.get(Settings.EMPTY) instanceof TimeValue) {
|
|
||||||
transientSettings.put(setting.getKey(), newRandomTimeValue().toString());
|
|
||||||
} else if (setting.get(Settings.EMPTY) instanceof Boolean) {
|
|
||||||
transientSettings.put(setting.getKey(), randomBoolean());
|
|
||||||
} else if (setting.get(Settings.EMPTY) instanceof List) {
|
|
||||||
transientSettings.putArray(setting.getKey(), randomStringArray());
|
|
||||||
} else {
|
|
||||||
fail("unknown dynamic setting [" + setting + "]");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
logger.error("--> updating settings");
|
|
||||||
final Settings updatedSettings = transientSettings.build();
|
|
||||||
assertAcked(prepareRandomUpdateSettings(updatedSettings).get());
|
|
||||||
|
|
||||||
logger.error("--> checking that the value has been correctly updated on all monitoring settings services");
|
|
||||||
for (Setting<?> setting : monitoringSettings) {
|
|
||||||
if (setting.isDynamic() == false) {
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
if (setting == MonitoringSettings.INTERVAL) {
|
|
||||||
for (final MonitoringService service : internalCluster().getInstances(MonitoringService.class)) {
|
|
||||||
assertEquals(service.getInterval(), setting.get(updatedSettings));
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
for (final MonitoringSettings monitoringSettings1 : internalCluster().getInstances(MonitoringSettings.class)) {
|
|
||||||
if (setting == MonitoringSettings.INDEX_STATS_TIMEOUT) {
|
|
||||||
assertEquals(monitoringSettings1.indexStatsTimeout(), setting.get(updatedSettings));
|
|
||||||
} else if (setting == MonitoringSettings.CLUSTER_STATS_TIMEOUT) {
|
|
||||||
assertEquals(monitoringSettings1.clusterStatsTimeout(), setting.get(updatedSettings));
|
|
||||||
} else if (setting == MonitoringSettings.JOB_STATS_TIMEOUT) {
|
|
||||||
assertEquals(monitoringSettings1.jobStatsTimeout(), setting.get(updatedSettings));
|
|
||||||
} else if (setting == MonitoringSettings.CLUSTER_STATE_TIMEOUT) {
|
|
||||||
assertEquals(monitoringSettings1.clusterStateTimeout(), setting.get(updatedSettings));
|
|
||||||
} else if (setting == MonitoringSettings.INDEX_RECOVERY_TIMEOUT) {
|
|
||||||
assertEquals(monitoringSettings1.recoveryTimeout(), setting.get(updatedSettings));
|
|
||||||
} else if (setting == MonitoringSettings.INDEX_RECOVERY_ACTIVE_ONLY) {
|
|
||||||
assertEquals(Boolean.valueOf(monitoringSettings1.recoveryActiveOnly()), setting.get(updatedSettings));
|
|
||||||
} else if (setting == MonitoringSettings.INDICES) {
|
|
||||||
assertEquals(Arrays.asList(monitoringSettings1.indices()), setting.get(updatedSettings));
|
|
||||||
} else {
|
|
||||||
fail("unable to check value for unknown dynamic setting [" + setting + "]");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private ClusterUpdateSettingsRequestBuilder prepareRandomUpdateSettings(Settings updateSettings) {
|
|
||||||
ClusterUpdateSettingsRequestBuilder requestBuilder = client().admin().cluster().prepareUpdateSettings();
|
|
||||||
if (randomBoolean()) {
|
|
||||||
requestBuilder.setTransientSettings(updateSettings);
|
|
||||||
} else {
|
|
||||||
requestBuilder.setPersistentSettings(updateSettings);
|
|
||||||
}
|
|
||||||
return requestBuilder;
|
|
||||||
}
|
|
||||||
|
|
||||||
private TimeValue newRandomTimeValue() {
|
|
||||||
return TimeValue.parseTimeValue(randomFrom("30m", "1h", "3h", "5h", "7h", "10h", "1d"), null, getClass().getSimpleName());
|
|
||||||
}
|
|
||||||
|
|
||||||
private String[] randomStringArray() {
|
|
||||||
final int size = scaledRandomIntBetween(1, 10);
|
|
||||||
String[] items = new String[size];
|
|
||||||
|
|
||||||
for (int i = 0; i < size; i++) {
|
|
||||||
items[i] = randomAlphaOfLength(5);
|
|
||||||
}
|
|
||||||
return items;
|
|
||||||
}
|
|
||||||
}
|
|
|
@ -14,7 +14,6 @@ import org.elasticsearch.search.aggregations.AggregationBuilders;
|
||||||
import org.elasticsearch.search.aggregations.bucket.terms.StringTerms;
|
import org.elasticsearch.search.aggregations.bucket.terms.StringTerms;
|
||||||
import org.elasticsearch.test.ESIntegTestCase.ClusterScope;
|
import org.elasticsearch.test.ESIntegTestCase.ClusterScope;
|
||||||
import org.elasticsearch.test.ESIntegTestCase.Scope;
|
import org.elasticsearch.test.ESIntegTestCase.Scope;
|
||||||
import org.elasticsearch.xpack.monitoring.MonitoringSettings;
|
|
||||||
import org.elasticsearch.xpack.monitoring.collector.node.NodeStatsMonitoringDoc;
|
import org.elasticsearch.xpack.monitoring.collector.node.NodeStatsMonitoringDoc;
|
||||||
import org.elasticsearch.xpack.monitoring.test.MonitoringIntegTestCase;
|
import org.elasticsearch.xpack.monitoring.test.MonitoringIntegTestCase;
|
||||||
import org.junit.After;
|
import org.junit.After;
|
||||||
|
@ -33,7 +32,7 @@ public class MultiNodesStatsTests extends MonitoringIntegTestCase {
|
||||||
protected Settings nodeSettings(int nodeOrdinal) {
|
protected Settings nodeSettings(int nodeOrdinal) {
|
||||||
return Settings.builder()
|
return Settings.builder()
|
||||||
.put(super.nodeSettings(nodeOrdinal))
|
.put(super.nodeSettings(nodeOrdinal))
|
||||||
.put(MonitoringSettings.INTERVAL.getKey(), "-1")
|
.put(MonitoringService.INTERVAL.getKey(), "-1")
|
||||||
.put("xpack.monitoring.exporters.default_local.type", "local")
|
.put("xpack.monitoring.exporters.default_local.type", "local")
|
||||||
.build();
|
.build();
|
||||||
}
|
}
|
||||||
|
|
|
@ -27,6 +27,7 @@ import org.elasticsearch.xpack.monitoring.collector.indices.IndexStatsMonitoring
|
||||||
import org.elasticsearch.xpack.monitoring.collector.indices.IndicesStatsMonitoringDoc;
|
import org.elasticsearch.xpack.monitoring.collector.indices.IndicesStatsMonitoringDoc;
|
||||||
import org.elasticsearch.xpack.monitoring.collector.node.NodeStatsMonitoringDoc;
|
import org.elasticsearch.xpack.monitoring.collector.node.NodeStatsMonitoringDoc;
|
||||||
import org.elasticsearch.xpack.monitoring.collector.shards.ShardMonitoringDoc;
|
import org.elasticsearch.xpack.monitoring.collector.shards.ShardMonitoringDoc;
|
||||||
|
import org.elasticsearch.xpack.monitoring.exporter.Exporters;
|
||||||
import org.hamcrest.Matcher;
|
import org.hamcrest.Matcher;
|
||||||
import org.joda.time.format.DateTimeFormat;
|
import org.joda.time.format.DateTimeFormat;
|
||||||
|
|
||||||
|
@ -63,9 +64,9 @@ public class OldMonitoringIndicesBackwardsCompatibilityTests extends AbstractOld
|
||||||
Settings.Builder settings = Settings.builder().put(super.nodeSettings(ord))
|
Settings.Builder settings = Settings.builder().put(super.nodeSettings(ord))
|
||||||
.put(XPackSettings.MONITORING_ENABLED.getKey(), true)
|
.put(XPackSettings.MONITORING_ENABLED.getKey(), true)
|
||||||
// Don't clean old monitoring indexes - we want to make sure we can load them
|
// Don't clean old monitoring indexes - we want to make sure we can load them
|
||||||
.put(MonitoringSettings.HISTORY_DURATION.getKey(), TimeValue.timeValueHours(1000 * 365 * 24).getStringRep())
|
.put(Monitoring.HISTORY_DURATION.getKey(), TimeValue.timeValueHours(1000 * 365 * 24).getStringRep())
|
||||||
// Do not start monitoring exporters at startup
|
// Do not start monitoring exporters at startup
|
||||||
.put(MonitoringSettings.INTERVAL.getKey(), "-1");
|
.put(MonitoringService.INTERVAL.getKey(), "-1");
|
||||||
|
|
||||||
if (httpExporter) {
|
if (httpExporter) {
|
||||||
/* If we want to test the http exporter we have to create it but disable it. We need to create it so we don't use the default
|
/* If we want to test the http exporter we have to create it but disable it. We need to create it so we don't use the default
|
||||||
|
@ -85,7 +86,7 @@ public class OldMonitoringIndicesBackwardsCompatibilityTests extends AbstractOld
|
||||||
httpExporter.put("auth.username", SecuritySettingsSource.TEST_USER_NAME);
|
httpExporter.put("auth.username", SecuritySettingsSource.TEST_USER_NAME);
|
||||||
httpExporter.put("auth.password", SecuritySettingsSource.TEST_PASSWORD);
|
httpExporter.put("auth.password", SecuritySettingsSource.TEST_PASSWORD);
|
||||||
|
|
||||||
settings.putProperties(httpExporter, k -> MonitoringSettings.EXPORTERS_SETTINGS.getKey() + "my_exporter." + k);
|
settings.putProperties(httpExporter, k -> Exporters.EXPORTERS_SETTINGS.getKey() + "my_exporter." + k);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -105,7 +106,7 @@ public class OldMonitoringIndicesBackwardsCompatibilityTests extends AbstractOld
|
||||||
}
|
}
|
||||||
|
|
||||||
// Monitoring can now start to collect new data
|
// Monitoring can now start to collect new data
|
||||||
Settings.Builder settings = Settings.builder().put(MonitoringSettings.INTERVAL.getKey(), timeValueSeconds(3).getStringRep());
|
Settings.Builder settings = Settings.builder().put(MonitoringService.INTERVAL.getKey(), timeValueSeconds(3).getStringRep());
|
||||||
assertAcked(client().admin().cluster().prepareUpdateSettings().setTransientSettings(settings).get());
|
assertAcked(client().admin().cluster().prepareUpdateSettings().setTransientSettings(settings).get());
|
||||||
|
|
||||||
final String prefix = ".monitoring-" + MonitoredSystem.ES.getSystem() + "-" + TEMPLATE_VERSION + "-";
|
final String prefix = ".monitoring-" + MonitoredSystem.ES.getSystem() + "-" + TEMPLATE_VERSION + "-";
|
||||||
|
@ -167,7 +168,7 @@ public class OldMonitoringIndicesBackwardsCompatibilityTests extends AbstractOld
|
||||||
if they have not been re created by some in flight monitoring bulk request */
|
if they have not been re created by some in flight monitoring bulk request */
|
||||||
internalCluster().getInstances(MonitoringService.class).forEach(MonitoringService::stop);
|
internalCluster().getInstances(MonitoringService.class).forEach(MonitoringService::stop);
|
||||||
|
|
||||||
Settings.Builder settings = Settings.builder().put(MonitoringSettings.INTERVAL.getKey(), "-1");
|
Settings.Builder settings = Settings.builder().put(MonitoringService.INTERVAL.getKey(), "-1");
|
||||||
if (httpExporter) {
|
if (httpExporter) {
|
||||||
logger.info("--> Disabling http exporter after test");
|
logger.info("--> Disabling http exporter after test");
|
||||||
setupHttpExporter(settings, null);
|
setupHttpExporter(settings, null);
|
||||||
|
|
|
@ -8,7 +8,8 @@ package org.elasticsearch.xpack.monitoring.cleaner;
|
||||||
import org.elasticsearch.common.settings.Settings;
|
import org.elasticsearch.common.settings.Settings;
|
||||||
import org.elasticsearch.common.unit.TimeValue;
|
import org.elasticsearch.common.unit.TimeValue;
|
||||||
import org.elasticsearch.test.ESIntegTestCase.ClusterScope;
|
import org.elasticsearch.test.ESIntegTestCase.ClusterScope;
|
||||||
import org.elasticsearch.xpack.monitoring.MonitoringSettings;
|
import org.elasticsearch.xpack.monitoring.Monitoring;
|
||||||
|
import org.elasticsearch.xpack.monitoring.MonitoringService;
|
||||||
import org.elasticsearch.xpack.monitoring.exporter.Exporter;
|
import org.elasticsearch.xpack.monitoring.exporter.Exporter;
|
||||||
import org.elasticsearch.xpack.monitoring.exporter.Exporters;
|
import org.elasticsearch.xpack.monitoring.exporter.Exporters;
|
||||||
import org.elasticsearch.xpack.monitoring.exporter.MonitoringTemplateUtils;
|
import org.elasticsearch.xpack.monitoring.exporter.MonitoringTemplateUtils;
|
||||||
|
@ -29,7 +30,7 @@ public abstract class AbstractIndicesCleanerTestCase extends MonitoringIntegTest
|
||||||
protected Settings nodeSettings(int nodeOrdinal) {
|
protected Settings nodeSettings(int nodeOrdinal) {
|
||||||
Settings.Builder settings = Settings.builder()
|
Settings.Builder settings = Settings.builder()
|
||||||
.put(super.nodeSettings(nodeOrdinal))
|
.put(super.nodeSettings(nodeOrdinal))
|
||||||
.put(MonitoringSettings.INTERVAL.getKey(), "-1");
|
.put(MonitoringService.INTERVAL.getKey(), "-1");
|
||||||
return settings.build();
|
return settings.build();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -151,7 +152,7 @@ public abstract class AbstractIndicesCleanerTestCase extends MonitoringIntegTest
|
||||||
public void testRetentionAsGlobalSetting() throws Exception {
|
public void testRetentionAsGlobalSetting() throws Exception {
|
||||||
final int max = 10;
|
final int max = 10;
|
||||||
final int retention = randomIntBetween(1, max);
|
final int retention = randomIntBetween(1, max);
|
||||||
internalCluster().startNode(Settings.builder().put(MonitoringSettings.HISTORY_DURATION.getKey(),
|
internalCluster().startNode(Settings.builder().put(Monitoring.HISTORY_DURATION.getKey(),
|
||||||
String.format(Locale.ROOT, "%dd", retention)));
|
String.format(Locale.ROOT, "%dd", retention)));
|
||||||
|
|
||||||
final DateTime now = now();
|
final DateTime now = now();
|
||||||
|
|
|
@ -12,7 +12,7 @@ import org.elasticsearch.license.XPackLicenseState;
|
||||||
import org.elasticsearch.test.ESTestCase;
|
import org.elasticsearch.test.ESTestCase;
|
||||||
import org.elasticsearch.threadpool.TestThreadPool;
|
import org.elasticsearch.threadpool.TestThreadPool;
|
||||||
import org.elasticsearch.threadpool.ThreadPool;
|
import org.elasticsearch.threadpool.ThreadPool;
|
||||||
import org.elasticsearch.xpack.monitoring.MonitoringSettings;
|
import org.elasticsearch.xpack.monitoring.Monitoring;
|
||||||
import org.joda.time.DateTime;
|
import org.joda.time.DateTime;
|
||||||
import org.joda.time.DateTimeZone;
|
import org.joda.time.DateTimeZone;
|
||||||
import org.junit.After;
|
import org.junit.After;
|
||||||
|
@ -40,7 +40,7 @@ public class CleanerServiceTests extends ESTestCase {
|
||||||
|
|
||||||
@Before
|
@Before
|
||||||
public void start() {
|
public void start() {
|
||||||
clusterSettings = new ClusterSettings(Settings.EMPTY, Collections.singleton(MonitoringSettings.HISTORY_DURATION));
|
clusterSettings = new ClusterSettings(Settings.EMPTY, Collections.singleton(Monitoring.HISTORY_DURATION));
|
||||||
threadPool = new TestThreadPool("CleanerServiceTests");
|
threadPool = new TestThreadPool("CleanerServiceTests");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -54,14 +54,14 @@ public class CleanerServiceTests extends ESTestCase {
|
||||||
expectedException.expect(IllegalArgumentException.class);
|
expectedException.expect(IllegalArgumentException.class);
|
||||||
|
|
||||||
TimeValue expected = TimeValue.timeValueHours(1);
|
TimeValue expected = TimeValue.timeValueHours(1);
|
||||||
Settings settings = Settings.builder().put(MonitoringSettings.HISTORY_DURATION.getKey(), expected.getStringRep()).build();
|
Settings settings = Settings.builder().put(Monitoring.HISTORY_DURATION.getKey(), expected.getStringRep()).build();
|
||||||
|
|
||||||
new CleanerService(settings, clusterSettings, threadPool, licenseState);
|
new CleanerService(settings, clusterSettings, threadPool, licenseState);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void testGetRetentionWithSettingWithUpdatesAllowed() {
|
public void testGetRetentionWithSettingWithUpdatesAllowed() {
|
||||||
TimeValue expected = TimeValue.timeValueHours(25);
|
TimeValue expected = TimeValue.timeValueHours(25);
|
||||||
Settings settings = Settings.builder().put(MonitoringSettings.HISTORY_DURATION.getKey(), expected.getStringRep()).build();
|
Settings settings = Settings.builder().put(Monitoring.HISTORY_DURATION.getKey(), expected.getStringRep()).build();
|
||||||
|
|
||||||
when(licenseState.isUpdateRetentionAllowed()).thenReturn(true);
|
when(licenseState.isUpdateRetentionAllowed()).thenReturn(true);
|
||||||
|
|
||||||
|
@ -73,7 +73,7 @@ public class CleanerServiceTests extends ESTestCase {
|
||||||
public void testGetRetentionDefaultValueWithNoSettings() {
|
public void testGetRetentionDefaultValueWithNoSettings() {
|
||||||
when(licenseState.isUpdateRetentionAllowed()).thenReturn(true);
|
when(licenseState.isUpdateRetentionAllowed()).thenReturn(true);
|
||||||
|
|
||||||
assertEquals(MonitoringSettings.HISTORY_DURATION.get(Settings.EMPTY),
|
assertEquals(Monitoring.HISTORY_DURATION.get(Settings.EMPTY),
|
||||||
new CleanerService(Settings.EMPTY, clusterSettings, threadPool, licenseState).getRetention());
|
new CleanerService(Settings.EMPTY, clusterSettings, threadPool, licenseState).getRetention());
|
||||||
|
|
||||||
verify(licenseState).isUpdateRetentionAllowed();
|
verify(licenseState).isUpdateRetentionAllowed();
|
||||||
|
@ -81,11 +81,11 @@ public class CleanerServiceTests extends ESTestCase {
|
||||||
|
|
||||||
public void testGetRetentionDefaultValueWithSettingsButUpdatesNotAllowed() {
|
public void testGetRetentionDefaultValueWithSettingsButUpdatesNotAllowed() {
|
||||||
TimeValue notExpected = TimeValue.timeValueHours(25);
|
TimeValue notExpected = TimeValue.timeValueHours(25);
|
||||||
Settings settings = Settings.builder().put(MonitoringSettings.HISTORY_DURATION.getKey(), notExpected.getStringRep()).build();
|
Settings settings = Settings.builder().put(Monitoring.HISTORY_DURATION.getKey(), notExpected.getStringRep()).build();
|
||||||
|
|
||||||
when(licenseState.isUpdateRetentionAllowed()).thenReturn(false);
|
when(licenseState.isUpdateRetentionAllowed()).thenReturn(false);
|
||||||
|
|
||||||
assertEquals(MonitoringSettings.HISTORY_DURATION.get(Settings.EMPTY),
|
assertEquals(Monitoring.HISTORY_DURATION.get(Settings.EMPTY),
|
||||||
new CleanerService(settings, clusterSettings, threadPool, licenseState).getRetention());
|
new CleanerService(settings, clusterSettings, threadPool, licenseState).getRetention());
|
||||||
|
|
||||||
verify(licenseState).isUpdateRetentionAllowed();
|
verify(licenseState).isUpdateRetentionAllowed();
|
||||||
|
|
|
@ -12,12 +12,19 @@ import org.elasticsearch.cluster.metadata.MetaData;
|
||||||
import org.elasticsearch.cluster.node.DiscoveryNode;
|
import org.elasticsearch.cluster.node.DiscoveryNode;
|
||||||
import org.elasticsearch.cluster.node.DiscoveryNodes;
|
import org.elasticsearch.cluster.node.DiscoveryNodes;
|
||||||
import org.elasticsearch.cluster.service.ClusterService;
|
import org.elasticsearch.cluster.service.ClusterService;
|
||||||
|
import org.elasticsearch.common.settings.ClusterSettings;
|
||||||
|
import org.elasticsearch.common.settings.Setting;
|
||||||
|
import org.elasticsearch.common.settings.Settings;
|
||||||
import org.elasticsearch.common.transport.TransportAddress;
|
import org.elasticsearch.common.transport.TransportAddress;
|
||||||
|
import org.elasticsearch.common.unit.TimeValue;
|
||||||
|
import org.elasticsearch.common.util.set.Sets;
|
||||||
import org.elasticsearch.license.XPackLicenseState;
|
import org.elasticsearch.license.XPackLicenseState;
|
||||||
import org.elasticsearch.test.ESTestCase;
|
import org.elasticsearch.test.ESTestCase;
|
||||||
import org.elasticsearch.xpack.monitoring.MonitoringSettings;
|
import org.elasticsearch.xpack.monitoring.Monitoring;
|
||||||
import org.elasticsearch.xpack.security.InternalClient;
|
import org.elasticsearch.xpack.security.InternalClient;
|
||||||
|
|
||||||
|
import java.util.function.Function;
|
||||||
|
|
||||||
import static org.mockito.Mockito.mock;
|
import static org.mockito.Mockito.mock;
|
||||||
import static org.mockito.Mockito.when;
|
import static org.mockito.Mockito.when;
|
||||||
|
|
||||||
|
@ -28,9 +35,9 @@ public abstract class BaseCollectorTestCase extends ESTestCase {
|
||||||
protected ClusterState clusterState;
|
protected ClusterState clusterState;
|
||||||
protected DiscoveryNodes nodes;
|
protected DiscoveryNodes nodes;
|
||||||
protected MetaData metaData;
|
protected MetaData metaData;
|
||||||
protected MonitoringSettings monitoringSettings;
|
|
||||||
protected XPackLicenseState licenseState;
|
protected XPackLicenseState licenseState;
|
||||||
protected InternalClient client;
|
protected InternalClient client;
|
||||||
|
protected Settings settings;
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void setUp() throws Exception {
|
public void setUp() throws Exception {
|
||||||
|
@ -40,9 +47,9 @@ public abstract class BaseCollectorTestCase extends ESTestCase {
|
||||||
clusterState = mock(ClusterState.class);
|
clusterState = mock(ClusterState.class);
|
||||||
nodes = mock(DiscoveryNodes.class);
|
nodes = mock(DiscoveryNodes.class);
|
||||||
metaData = mock(MetaData.class);
|
metaData = mock(MetaData.class);
|
||||||
monitoringSettings = mock(MonitoringSettings.class);
|
|
||||||
licenseState = mock(XPackLicenseState.class);
|
licenseState = mock(XPackLicenseState.class);
|
||||||
client = mock(InternalClient.class);
|
client = mock(InternalClient.class);
|
||||||
|
settings = Settings.EMPTY;
|
||||||
}
|
}
|
||||||
|
|
||||||
protected void whenLocalNodeElectedMaster(final boolean electedMaster) {
|
protected void whenLocalNodeElectedMaster(final boolean electedMaster) {
|
||||||
|
@ -63,6 +70,28 @@ public abstract class BaseCollectorTestCase extends ESTestCase {
|
||||||
when(metaData.clusterUUID()).thenReturn(clusterUUID);
|
when(metaData.clusterUUID()).thenReturn(clusterUUID);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
protected void withCollectionTimeout(final Setting<TimeValue> collectionTimeout, final TimeValue timeout) {
|
||||||
|
withCollectionSetting(builder -> builder.put(collectionTimeout.getKey(), timeout.getStringRep()));
|
||||||
|
}
|
||||||
|
|
||||||
|
protected void withCollectionIndices(final String[] collectionIndices) {
|
||||||
|
final String key = Collector.INDICES.getKey();
|
||||||
|
if (collectionIndices != null) {
|
||||||
|
withCollectionSetting(builder -> builder.putArray(key, collectionIndices));
|
||||||
|
} else {
|
||||||
|
withCollectionSetting(builder -> builder.putNull(key));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
protected void withCollectionSetting(final Function<Settings.Builder, Settings.Builder> builder) {
|
||||||
|
settings = Settings.builder()
|
||||||
|
.put(settings)
|
||||||
|
.put(builder.apply(Settings.builder()).build())
|
||||||
|
.build();
|
||||||
|
when(clusterService.getClusterSettings())
|
||||||
|
.thenReturn(new ClusterSettings(settings, Sets.newHashSet(new Monitoring(settings, licenseState).getSettings())));
|
||||||
|
}
|
||||||
|
|
||||||
protected static DiscoveryNode localNode(final String uuid) {
|
protected static DiscoveryNode localNode(final String uuid) {
|
||||||
return new DiscoveryNode(uuid, new TransportAddress(TransportAddress.META_ADDRESS, 9300), Version.CURRENT);
|
return new DiscoveryNode(uuid, new TransportAddress(TransportAddress.META_ADDRESS, 9300), Version.CURRENT);
|
||||||
}
|
}
|
||||||
|
|
|
@ -25,7 +25,6 @@ import org.elasticsearch.xpack.action.XPackUsageResponse;
|
||||||
import org.elasticsearch.xpack.logstash.Logstash;
|
import org.elasticsearch.xpack.logstash.Logstash;
|
||||||
import org.elasticsearch.xpack.logstash.LogstashFeatureSet;
|
import org.elasticsearch.xpack.logstash.LogstashFeatureSet;
|
||||||
import org.elasticsearch.xpack.monitoring.MonitoredSystem;
|
import org.elasticsearch.xpack.monitoring.MonitoredSystem;
|
||||||
import org.elasticsearch.xpack.monitoring.MonitoringTestUtils;
|
|
||||||
import org.elasticsearch.xpack.monitoring.collector.BaseCollectorTestCase;
|
import org.elasticsearch.xpack.monitoring.collector.BaseCollectorTestCase;
|
||||||
import org.elasticsearch.xpack.monitoring.exporter.MonitoringDoc;
|
import org.elasticsearch.xpack.monitoring.exporter.MonitoringDoc;
|
||||||
|
|
||||||
|
@ -64,7 +63,7 @@ public class ClusterStatsCollectorTests extends BaseCollectorTestCase {
|
||||||
whenLocalNodeElectedMaster(false);
|
whenLocalNodeElectedMaster(false);
|
||||||
|
|
||||||
final ClusterStatsCollector collector =
|
final ClusterStatsCollector collector =
|
||||||
new ClusterStatsCollector(Settings.EMPTY, clusterService, monitoringSettings, licenseState, client, licenseService);
|
new ClusterStatsCollector(Settings.EMPTY, clusterService, licenseState, client, licenseService);
|
||||||
|
|
||||||
assertThat(collector.shouldCollect(), is(false));
|
assertThat(collector.shouldCollect(), is(false));
|
||||||
verify(nodes).isLocalNodeElectedMaster();
|
verify(nodes).isLocalNodeElectedMaster();
|
||||||
|
@ -74,13 +73,16 @@ public class ClusterStatsCollectorTests extends BaseCollectorTestCase {
|
||||||
whenLocalNodeElectedMaster(true);
|
whenLocalNodeElectedMaster(true);
|
||||||
|
|
||||||
final ClusterStatsCollector collector =
|
final ClusterStatsCollector collector =
|
||||||
new ClusterStatsCollector(Settings.EMPTY, clusterService, monitoringSettings, licenseState, client, licenseService);
|
new ClusterStatsCollector(Settings.EMPTY, clusterService, licenseState, client, licenseService);
|
||||||
|
|
||||||
assertThat(collector.shouldCollect(), is(true));
|
assertThat(collector.shouldCollect(), is(true));
|
||||||
verify(nodes).isLocalNodeElectedMaster();
|
verify(nodes).isLocalNodeElectedMaster();
|
||||||
}
|
}
|
||||||
|
|
||||||
public void testDoCollect() throws Exception {
|
public void testDoCollect() throws Exception {
|
||||||
|
final TimeValue timeout = TimeValue.timeValueSeconds(randomIntBetween(1, 120));
|
||||||
|
withCollectionTimeout(ClusterStatsCollector.CLUSTER_STATS_TIMEOUT, timeout);
|
||||||
|
|
||||||
whenLocalNodeElectedMaster(true);
|
whenLocalNodeElectedMaster(true);
|
||||||
|
|
||||||
final String clusterName = randomAlphaOfLength(10);
|
final String clusterName = randomAlphaOfLength(10);
|
||||||
|
@ -102,9 +104,6 @@ public class ClusterStatsCollectorTests extends BaseCollectorTestCase {
|
||||||
.build();
|
.build();
|
||||||
when(licenseService.getLicense()).thenReturn(license);
|
when(licenseService.getLicense()).thenReturn(license);
|
||||||
|
|
||||||
final TimeValue timeout = mock(TimeValue.class);
|
|
||||||
when(monitoringSettings.clusterStatsTimeout()).thenReturn(timeout);
|
|
||||||
|
|
||||||
final ClusterStatsResponse mockClusterStatsResponse = mock(ClusterStatsResponse.class);
|
final ClusterStatsResponse mockClusterStatsResponse = mock(ClusterStatsResponse.class);
|
||||||
|
|
||||||
final ClusterHealthStatus clusterStatus = randomFrom(ClusterHealthStatus.values());
|
final ClusterHealthStatus clusterStatus = randomFrom(ClusterHealthStatus.values());
|
||||||
|
@ -137,7 +136,8 @@ public class ClusterStatsCollectorTests extends BaseCollectorTestCase {
|
||||||
when(xPackUsageFuture.actionGet()).thenReturn(xPackUsageResponse);
|
when(xPackUsageFuture.actionGet()).thenReturn(xPackUsageResponse);
|
||||||
|
|
||||||
final ClusterStatsCollector collector =
|
final ClusterStatsCollector collector =
|
||||||
new ClusterStatsCollector(Settings.EMPTY, clusterService, monitoringSettings, licenseState, client, licenseService);
|
new ClusterStatsCollector(Settings.EMPTY, clusterService, licenseState, client, licenseService);
|
||||||
|
assertEquals(timeout, collector.getCollectionTimeout());
|
||||||
|
|
||||||
final Collection<MonitoringDoc> results = collector.doCollect(node);
|
final Collection<MonitoringDoc> results = collector.doCollect(node);
|
||||||
assertEquals(1, results.size());
|
assertEquals(1, results.size());
|
||||||
|
|
|
@ -16,6 +16,7 @@ import org.elasticsearch.cluster.node.DiscoveryNode;
|
||||||
import org.elasticsearch.cluster.routing.RecoverySource;
|
import org.elasticsearch.cluster.routing.RecoverySource;
|
||||||
import org.elasticsearch.cluster.routing.ShardRouting;
|
import org.elasticsearch.cluster.routing.ShardRouting;
|
||||||
import org.elasticsearch.cluster.routing.UnassignedInfo;
|
import org.elasticsearch.cluster.routing.UnassignedInfo;
|
||||||
|
import org.elasticsearch.common.Strings;
|
||||||
import org.elasticsearch.common.settings.Settings;
|
import org.elasticsearch.common.settings.Settings;
|
||||||
import org.elasticsearch.common.unit.TimeValue;
|
import org.elasticsearch.common.unit.TimeValue;
|
||||||
import org.elasticsearch.index.shard.ShardId;
|
import org.elasticsearch.index.shard.ShardId;
|
||||||
|
@ -53,8 +54,7 @@ public class IndexRecoveryCollectorTests extends BaseCollectorTestCase {
|
||||||
when(licenseState.isMonitoringAllowed()).thenReturn(false);
|
when(licenseState.isMonitoringAllowed()).thenReturn(false);
|
||||||
whenLocalNodeElectedMaster(randomBoolean());
|
whenLocalNodeElectedMaster(randomBoolean());
|
||||||
|
|
||||||
final IndexRecoveryCollector collector =
|
final IndexRecoveryCollector collector = new IndexRecoveryCollector(Settings.EMPTY, clusterService, licenseState, client);
|
||||||
new IndexRecoveryCollector(Settings.EMPTY, clusterService, monitoringSettings, licenseState, client);
|
|
||||||
|
|
||||||
assertThat(collector.shouldCollect(), is(false));
|
assertThat(collector.shouldCollect(), is(false));
|
||||||
verify(licenseState).isMonitoringAllowed();
|
verify(licenseState).isMonitoringAllowed();
|
||||||
|
@ -65,8 +65,7 @@ public class IndexRecoveryCollectorTests extends BaseCollectorTestCase {
|
||||||
// this controls the blockage
|
// this controls the blockage
|
||||||
whenLocalNodeElectedMaster(false);
|
whenLocalNodeElectedMaster(false);
|
||||||
|
|
||||||
final IndexRecoveryCollector collector =
|
final IndexRecoveryCollector collector = new IndexRecoveryCollector(Settings.EMPTY, clusterService, licenseState, client);
|
||||||
new IndexRecoveryCollector(Settings.EMPTY, clusterService, monitoringSettings, licenseState, client);
|
|
||||||
|
|
||||||
assertThat(collector.shouldCollect(), is(false));
|
assertThat(collector.shouldCollect(), is(false));
|
||||||
verify(licenseState).isMonitoringAllowed();
|
verify(licenseState).isMonitoringAllowed();
|
||||||
|
@ -77,8 +76,7 @@ public class IndexRecoveryCollectorTests extends BaseCollectorTestCase {
|
||||||
when(licenseState.isMonitoringAllowed()).thenReturn(true);
|
when(licenseState.isMonitoringAllowed()).thenReturn(true);
|
||||||
whenLocalNodeElectedMaster(true);
|
whenLocalNodeElectedMaster(true);
|
||||||
|
|
||||||
final IndexRecoveryCollector collector =
|
final IndexRecoveryCollector collector = new IndexRecoveryCollector(Settings.EMPTY, clusterService, licenseState, client);
|
||||||
new IndexRecoveryCollector(Settings.EMPTY, clusterService, monitoringSettings, licenseState, client);
|
|
||||||
|
|
||||||
assertThat(collector.shouldCollect(), is(true));
|
assertThat(collector.shouldCollect(), is(true));
|
||||||
verify(licenseState).isMonitoringAllowed();
|
verify(licenseState).isMonitoringAllowed();
|
||||||
|
@ -86,6 +84,9 @@ public class IndexRecoveryCollectorTests extends BaseCollectorTestCase {
|
||||||
}
|
}
|
||||||
|
|
||||||
public void testDoCollect() throws Exception {
|
public void testDoCollect() throws Exception {
|
||||||
|
final TimeValue timeout = TimeValue.timeValueSeconds(randomIntBetween(1, 120));
|
||||||
|
withCollectionTimeout(IndexRecoveryCollector.INDEX_RECOVERY_TIMEOUT, timeout);
|
||||||
|
|
||||||
whenLocalNodeElectedMaster(true);
|
whenLocalNodeElectedMaster(true);
|
||||||
|
|
||||||
final String clusterName = randomAlphaOfLength(10);
|
final String clusterName = randomAlphaOfLength(10);
|
||||||
|
@ -100,19 +101,18 @@ public class IndexRecoveryCollectorTests extends BaseCollectorTestCase {
|
||||||
final MonitoringDoc.Node node = randomMonitoringNode(random());
|
final MonitoringDoc.Node node = randomMonitoringNode(random());
|
||||||
|
|
||||||
final boolean recoveryOnly = randomBoolean();
|
final boolean recoveryOnly = randomBoolean();
|
||||||
when(monitoringSettings.recoveryActiveOnly()).thenReturn(recoveryOnly);
|
withCollectionSetting(builder -> builder.put(IndexRecoveryCollector.INDEX_RECOVERY_ACTIVE_ONLY.getKey(), recoveryOnly));
|
||||||
|
|
||||||
final String[] indices;
|
final String[] indices;
|
||||||
if (randomBoolean()) {
|
if (randomBoolean()) {
|
||||||
indices = null;
|
indices = randomBoolean() ? null : Strings.EMPTY_ARRAY;
|
||||||
} else {
|
} else {
|
||||||
indices = new String[randomIntBetween(1, 5)];
|
indices = new String[randomIntBetween(1, 5)];
|
||||||
for (int i = 0; i < indices.length; i++) {
|
for (int i = 0; i < indices.length; i++) {
|
||||||
indices[i] = randomAlphaOfLengthBetween(5, 10);
|
indices[i] = randomAlphaOfLengthBetween(5, 10);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
when(monitoringSettings.indices()).thenReturn(indices);
|
withCollectionIndices(indices);
|
||||||
when(monitoringSettings.recoveryTimeout()).thenReturn(TimeValue.timeValueSeconds(12));
|
|
||||||
|
|
||||||
final int nbRecoveries = randomBoolean() ? 0 : randomIntBetween(1, 3);
|
final int nbRecoveries = randomBoolean() ? 0 : randomIntBetween(1, 3);
|
||||||
final Map<String, List<RecoveryState>> recoveryStates = new HashMap<>();
|
final Map<String, List<RecoveryState>> recoveryStates = new HashMap<>();
|
||||||
|
@ -130,9 +130,6 @@ public class IndexRecoveryCollectorTests extends BaseCollectorTestCase {
|
||||||
final RecoveryResponse recoveryResponse =
|
final RecoveryResponse recoveryResponse =
|
||||||
new RecoveryResponse(randomInt(), randomInt(), randomInt(), randomBoolean(), recoveryStates, emptyList());
|
new RecoveryResponse(randomInt(), randomInt(), randomInt(), randomBoolean(), recoveryStates, emptyList());
|
||||||
|
|
||||||
final TimeValue timeout = mock(TimeValue.class);
|
|
||||||
when(monitoringSettings.recoveryTimeout()).thenReturn(timeout);
|
|
||||||
|
|
||||||
final RecoveryRequestBuilder recoveryRequestBuilder =
|
final RecoveryRequestBuilder recoveryRequestBuilder =
|
||||||
spy(new RecoveryRequestBuilder(mock(ElasticsearchClient.class), RecoveryAction.INSTANCE));
|
spy(new RecoveryRequestBuilder(mock(ElasticsearchClient.class), RecoveryAction.INSTANCE));
|
||||||
doReturn(recoveryResponse).when(recoveryRequestBuilder).get(eq(timeout));
|
doReturn(recoveryResponse).when(recoveryRequestBuilder).get(eq(timeout));
|
||||||
|
@ -146,8 +143,17 @@ public class IndexRecoveryCollectorTests extends BaseCollectorTestCase {
|
||||||
final Client client = mock(Client.class);
|
final Client client = mock(Client.class);
|
||||||
when(client.admin()).thenReturn(adminClient);
|
when(client.admin()).thenReturn(adminClient);
|
||||||
|
|
||||||
final IndexRecoveryCollector collector =
|
final IndexRecoveryCollector collector = new IndexRecoveryCollector(Settings.EMPTY, clusterService, licenseState, client);
|
||||||
new IndexRecoveryCollector(Settings.EMPTY, clusterService, monitoringSettings, licenseState, client);
|
assertEquals(timeout, collector.getCollectionTimeout());
|
||||||
|
assertEquals(recoveryOnly, collector.getActiveRecoveriesOnly());
|
||||||
|
|
||||||
|
if (indices != null) {
|
||||||
|
assertArrayEquals(indices, collector.getCollectionIndices());
|
||||||
|
} else {
|
||||||
|
// Collection indices has a default value equals to emptyList(),
|
||||||
|
// so it won't return a null indices array
|
||||||
|
assertArrayEquals(Strings.EMPTY_ARRAY, collector.getCollectionIndices());
|
||||||
|
}
|
||||||
|
|
||||||
final Collection<MonitoringDoc> results = collector.doCollect(node);
|
final Collection<MonitoringDoc> results = collector.doCollect(node);
|
||||||
verify(indicesAdminClient).prepareRecoveries();
|
verify(indicesAdminClient).prepareRecoveries();
|
||||||
|
|
|
@ -43,8 +43,7 @@ public class IndexStatsCollectorTests extends BaseCollectorTestCase {
|
||||||
when(licenseState.isMonitoringAllowed()).thenReturn(false);
|
when(licenseState.isMonitoringAllowed()).thenReturn(false);
|
||||||
whenLocalNodeElectedMaster(randomBoolean());
|
whenLocalNodeElectedMaster(randomBoolean());
|
||||||
|
|
||||||
final IndexStatsCollector collector =
|
final IndexStatsCollector collector = new IndexStatsCollector(Settings.EMPTY, clusterService, licenseState, client);
|
||||||
new IndexStatsCollector(Settings.EMPTY, clusterService, monitoringSettings, licenseState, client);
|
|
||||||
|
|
||||||
assertThat(collector.shouldCollect(), is(false));
|
assertThat(collector.shouldCollect(), is(false));
|
||||||
verify(licenseState).isMonitoringAllowed();
|
verify(licenseState).isMonitoringAllowed();
|
||||||
|
@ -55,8 +54,7 @@ public class IndexStatsCollectorTests extends BaseCollectorTestCase {
|
||||||
// this controls the blockage
|
// this controls the blockage
|
||||||
whenLocalNodeElectedMaster(false);
|
whenLocalNodeElectedMaster(false);
|
||||||
|
|
||||||
final IndexStatsCollector collector =
|
final IndexStatsCollector collector = new IndexStatsCollector(Settings.EMPTY, clusterService, licenseState, client);
|
||||||
new IndexStatsCollector(Settings.EMPTY, clusterService, monitoringSettings, licenseState, client);
|
|
||||||
|
|
||||||
assertThat(collector.shouldCollect(), is(false));
|
assertThat(collector.shouldCollect(), is(false));
|
||||||
verify(licenseState).isMonitoringAllowed();
|
verify(licenseState).isMonitoringAllowed();
|
||||||
|
@ -67,8 +65,7 @@ public class IndexStatsCollectorTests extends BaseCollectorTestCase {
|
||||||
when(licenseState.isMonitoringAllowed()).thenReturn(true);
|
when(licenseState.isMonitoringAllowed()).thenReturn(true);
|
||||||
whenLocalNodeElectedMaster(true);
|
whenLocalNodeElectedMaster(true);
|
||||||
|
|
||||||
final IndexStatsCollector collector =
|
final IndexStatsCollector collector = new IndexStatsCollector(Settings.EMPTY, clusterService, licenseState, client);
|
||||||
new IndexStatsCollector(Settings.EMPTY, clusterService, monitoringSettings, licenseState, client);
|
|
||||||
|
|
||||||
assertThat(collector.shouldCollect(), is(true));
|
assertThat(collector.shouldCollect(), is(true));
|
||||||
verify(licenseState).isMonitoringAllowed();
|
verify(licenseState).isMonitoringAllowed();
|
||||||
|
@ -76,6 +73,9 @@ public class IndexStatsCollectorTests extends BaseCollectorTestCase {
|
||||||
}
|
}
|
||||||
|
|
||||||
public void testDoCollect() throws Exception {
|
public void testDoCollect() throws Exception {
|
||||||
|
final TimeValue timeout = TimeValue.timeValueSeconds(randomIntBetween(1, 120));
|
||||||
|
withCollectionTimeout(IndexStatsCollector.INDEX_STATS_TIMEOUT, timeout);
|
||||||
|
|
||||||
whenLocalNodeElectedMaster(true);
|
whenLocalNodeElectedMaster(true);
|
||||||
|
|
||||||
final String clusterName = randomAlphaOfLength(10);
|
final String clusterName = randomAlphaOfLength(10);
|
||||||
|
@ -86,9 +86,6 @@ public class IndexStatsCollectorTests extends BaseCollectorTestCase {
|
||||||
|
|
||||||
final MonitoringDoc.Node node = randomMonitoringNode(random());
|
final MonitoringDoc.Node node = randomMonitoringNode(random());
|
||||||
|
|
||||||
final TimeValue timeout = mock(TimeValue.class);
|
|
||||||
when(monitoringSettings.indexStatsTimeout()).thenReturn(timeout);
|
|
||||||
|
|
||||||
final Map<String, IndexStats> indicesStats = new HashMap<>();
|
final Map<String, IndexStats> indicesStats = new HashMap<>();
|
||||||
final int indices = randomIntBetween(0, 10);
|
final int indices = randomIntBetween(0, 10);
|
||||||
for (int i = 0; i < indices; i++) {
|
for (int i = 0; i < indices; i++) {
|
||||||
|
@ -114,8 +111,8 @@ public class IndexStatsCollectorTests extends BaseCollectorTestCase {
|
||||||
final Client client = mock(Client.class);
|
final Client client = mock(Client.class);
|
||||||
when(client.admin()).thenReturn(adminClient);
|
when(client.admin()).thenReturn(adminClient);
|
||||||
|
|
||||||
final IndexStatsCollector collector =
|
final IndexStatsCollector collector = new IndexStatsCollector(Settings.EMPTY, clusterService, licenseState, client);
|
||||||
new IndexStatsCollector(Settings.EMPTY, clusterService, monitoringSettings, licenseState, client);
|
assertEquals(timeout, collector.getCollectionTimeout());
|
||||||
|
|
||||||
final Collection<MonitoringDoc> results = collector.doCollect(node);
|
final Collection<MonitoringDoc> results = collector.doCollect(node);
|
||||||
verify(indicesAdminClient).prepareStats();
|
verify(indicesAdminClient).prepareStats();
|
||||||
|
|
|
@ -47,7 +47,7 @@ public class JobStatsCollectorTests extends BaseCollectorTestCase {
|
||||||
when(licenseState.isMonitoringAllowed()).thenReturn(false);
|
when(licenseState.isMonitoringAllowed()).thenReturn(false);
|
||||||
when(licenseState.isMachineLearningAllowed()).thenReturn(mlAllowed);
|
when(licenseState.isMachineLearningAllowed()).thenReturn(mlAllowed);
|
||||||
|
|
||||||
final JobStatsCollector collector = new JobStatsCollector(settings, clusterService, monitoringSettings, licenseState, client);
|
final JobStatsCollector collector = new JobStatsCollector(settings, clusterService, licenseState, client);
|
||||||
|
|
||||||
assertThat(collector.shouldCollect(), is(false));
|
assertThat(collector.shouldCollect(), is(false));
|
||||||
|
|
||||||
|
@ -63,7 +63,7 @@ public class JobStatsCollectorTests extends BaseCollectorTestCase {
|
||||||
// this controls the blockage
|
// this controls the blockage
|
||||||
whenLocalNodeElectedMaster(false);
|
whenLocalNodeElectedMaster(false);
|
||||||
|
|
||||||
final JobStatsCollector collector = new JobStatsCollector(settings, clusterService, monitoringSettings, licenseState, client);
|
final JobStatsCollector collector = new JobStatsCollector(settings, clusterService, licenseState, client);
|
||||||
|
|
||||||
assertThat(collector.shouldCollect(), is(false));
|
assertThat(collector.shouldCollect(), is(false));
|
||||||
|
|
||||||
|
@ -78,7 +78,7 @@ public class JobStatsCollectorTests extends BaseCollectorTestCase {
|
||||||
when(licenseState.isMachineLearningAllowed()).thenReturn(randomBoolean());
|
when(licenseState.isMachineLearningAllowed()).thenReturn(randomBoolean());
|
||||||
whenLocalNodeElectedMaster(randomBoolean());
|
whenLocalNodeElectedMaster(randomBoolean());
|
||||||
|
|
||||||
final JobStatsCollector collector = new JobStatsCollector(settings, clusterService, monitoringSettings, licenseState, client);
|
final JobStatsCollector collector = new JobStatsCollector(settings, clusterService, licenseState, client);
|
||||||
|
|
||||||
assertThat(collector.shouldCollect(), is(false));
|
assertThat(collector.shouldCollect(), is(false));
|
||||||
|
|
||||||
|
@ -93,7 +93,7 @@ public class JobStatsCollectorTests extends BaseCollectorTestCase {
|
||||||
when(licenseState.isMachineLearningAllowed()).thenReturn(false);
|
when(licenseState.isMachineLearningAllowed()).thenReturn(false);
|
||||||
whenLocalNodeElectedMaster(randomBoolean());
|
whenLocalNodeElectedMaster(randomBoolean());
|
||||||
|
|
||||||
final JobStatsCollector collector = new JobStatsCollector(settings, clusterService, monitoringSettings, licenseState, client);
|
final JobStatsCollector collector = new JobStatsCollector(settings, clusterService, licenseState, client);
|
||||||
|
|
||||||
assertThat(collector.shouldCollect(), is(false));
|
assertThat(collector.shouldCollect(), is(false));
|
||||||
|
|
||||||
|
@ -107,7 +107,7 @@ public class JobStatsCollectorTests extends BaseCollectorTestCase {
|
||||||
when(licenseState.isMachineLearningAllowed()).thenReturn(true);
|
when(licenseState.isMachineLearningAllowed()).thenReturn(true);
|
||||||
whenLocalNodeElectedMaster(true);
|
whenLocalNodeElectedMaster(true);
|
||||||
|
|
||||||
final JobStatsCollector collector = new JobStatsCollector(settings, clusterService, monitoringSettings, licenseState, client);
|
final JobStatsCollector collector = new JobStatsCollector(settings, clusterService, licenseState, client);
|
||||||
|
|
||||||
assertThat(collector.shouldCollect(), is(true));
|
assertThat(collector.shouldCollect(), is(true));
|
||||||
|
|
||||||
|
@ -115,20 +115,20 @@ public class JobStatsCollectorTests extends BaseCollectorTestCase {
|
||||||
}
|
}
|
||||||
|
|
||||||
public void testDoCollect() throws Exception {
|
public void testDoCollect() throws Exception {
|
||||||
final TimeValue timeout = mock(TimeValue.class);
|
|
||||||
final MetaData metaData = mock(MetaData.class);
|
final MetaData metaData = mock(MetaData.class);
|
||||||
final String clusterUuid = randomAlphaOfLength(5);
|
final String clusterUuid = randomAlphaOfLength(5);
|
||||||
final MonitoringDoc.Node node = randomMonitoringNode(random());
|
final MonitoringDoc.Node node = randomMonitoringNode(random());
|
||||||
final MachineLearningClient client = mock(MachineLearningClient.class);
|
final MachineLearningClient client = mock(MachineLearningClient.class);
|
||||||
|
|
||||||
when(monitoringSettings.jobStatsTimeout()).thenReturn(timeout);
|
final TimeValue timeout = TimeValue.timeValueSeconds(randomIntBetween(1, 120));
|
||||||
|
withCollectionTimeout(JobStatsCollector.JOB_STATS_TIMEOUT, timeout);
|
||||||
|
|
||||||
when(clusterService.state()).thenReturn(clusterState);
|
when(clusterService.state()).thenReturn(clusterState);
|
||||||
when(clusterState.metaData()).thenReturn(metaData);
|
when(clusterState.metaData()).thenReturn(metaData);
|
||||||
when(metaData.clusterUUID()).thenReturn(clusterUuid);
|
when(metaData.clusterUUID()).thenReturn(clusterUuid);
|
||||||
|
|
||||||
final JobStatsCollector collector =
|
final JobStatsCollector collector = new JobStatsCollector(Settings.EMPTY, clusterService, licenseState, client);
|
||||||
new JobStatsCollector(Settings.EMPTY, clusterService, monitoringSettings, licenseState, client);
|
assertEquals(timeout, collector.getCollectionTimeout());
|
||||||
|
|
||||||
final List<JobStats> jobStats = mockJobStats();
|
final List<JobStats> jobStats = mockJobStats();
|
||||||
|
|
||||||
|
|
|
@ -15,6 +15,7 @@ import org.elasticsearch.client.AdminClient;
|
||||||
import org.elasticsearch.client.Client;
|
import org.elasticsearch.client.Client;
|
||||||
import org.elasticsearch.client.ClusterAdminClient;
|
import org.elasticsearch.client.ClusterAdminClient;
|
||||||
import org.elasticsearch.common.settings.Settings;
|
import org.elasticsearch.common.settings.Settings;
|
||||||
|
import org.elasticsearch.common.unit.TimeValue;
|
||||||
import org.elasticsearch.xpack.monitoring.MonitoredSystem;
|
import org.elasticsearch.xpack.monitoring.MonitoredSystem;
|
||||||
import org.elasticsearch.xpack.monitoring.collector.BaseCollectorTestCase;
|
import org.elasticsearch.xpack.monitoring.collector.BaseCollectorTestCase;
|
||||||
import org.elasticsearch.xpack.monitoring.exporter.MonitoringDoc;
|
import org.elasticsearch.xpack.monitoring.exporter.MonitoringDoc;
|
||||||
|
@ -41,8 +42,7 @@ public class NodeStatsCollectorTests extends BaseCollectorTestCase {
|
||||||
when(licenseState.isMonitoringAllowed()).thenReturn(false);
|
when(licenseState.isMonitoringAllowed()).thenReturn(false);
|
||||||
whenLocalNodeElectedMaster(randomBoolean());
|
whenLocalNodeElectedMaster(randomBoolean());
|
||||||
|
|
||||||
final NodeStatsCollector collector =
|
final NodeStatsCollector collector = new NodeStatsCollector(Settings.EMPTY, clusterService, licenseState, client);
|
||||||
new NodeStatsCollector(Settings.EMPTY, clusterService, monitoringSettings, licenseState, client);
|
|
||||||
|
|
||||||
assertThat(collector.shouldCollect(), is(false));
|
assertThat(collector.shouldCollect(), is(false));
|
||||||
verify(licenseState).isMonitoringAllowed();
|
verify(licenseState).isMonitoringAllowed();
|
||||||
|
@ -52,8 +52,7 @@ public class NodeStatsCollectorTests extends BaseCollectorTestCase {
|
||||||
when(licenseState.isMonitoringAllowed()).thenReturn(true);
|
when(licenseState.isMonitoringAllowed()).thenReturn(true);
|
||||||
whenLocalNodeElectedMaster(true);
|
whenLocalNodeElectedMaster(true);
|
||||||
|
|
||||||
final NodeStatsCollector collector =
|
final NodeStatsCollector collector = new NodeStatsCollector(Settings.EMPTY, clusterService, licenseState, client);
|
||||||
new NodeStatsCollector(Settings.EMPTY, clusterService, monitoringSettings, licenseState, client);
|
|
||||||
|
|
||||||
assertThat(collector.shouldCollect(), is(true));
|
assertThat(collector.shouldCollect(), is(true));
|
||||||
verify(licenseState).isMonitoringAllowed();
|
verify(licenseState).isMonitoringAllowed();
|
||||||
|
@ -62,6 +61,9 @@ public class NodeStatsCollectorTests extends BaseCollectorTestCase {
|
||||||
public void testDoCollectWithFailures() throws Exception {
|
public void testDoCollectWithFailures() throws Exception {
|
||||||
when(licenseState.isMonitoringAllowed()).thenReturn(true);
|
when(licenseState.isMonitoringAllowed()).thenReturn(true);
|
||||||
|
|
||||||
|
final TimeValue timeout = TimeValue.parseTimeValue(randomPositiveTimeValue(), NodeStatsCollectorTests.class.getName());
|
||||||
|
withCollectionTimeout(NodeStatsCollector.NODE_STATS_TIMEOUT, timeout);
|
||||||
|
|
||||||
final NodesStatsResponse nodesStatsResponse = mock(NodesStatsResponse.class);
|
final NodesStatsResponse nodesStatsResponse = mock(NodesStatsResponse.class);
|
||||||
when(nodesStatsResponse.hasFailures()).thenReturn(true);
|
when(nodesStatsResponse.hasFailures()).thenReturn(true);
|
||||||
|
|
||||||
|
@ -69,10 +71,10 @@ public class NodeStatsCollectorTests extends BaseCollectorTestCase {
|
||||||
when(nodesStatsResponse.failures()).thenReturn(Collections.singletonList(exception));
|
when(nodesStatsResponse.failures()).thenReturn(Collections.singletonList(exception));
|
||||||
|
|
||||||
final Client client = mock(Client.class);
|
final Client client = mock(Client.class);
|
||||||
thenReturnNodeStats(client, nodesStatsResponse);
|
thenReturnNodeStats(client, timeout, nodesStatsResponse);
|
||||||
|
|
||||||
final NodeStatsCollector collector =
|
final NodeStatsCollector collector = new NodeStatsCollector(Settings.EMPTY, clusterService, licenseState, client);
|
||||||
new NodeStatsCollector(Settings.EMPTY, clusterService, monitoringSettings, licenseState, client);
|
assertEquals(timeout, collector.getCollectionTimeout());
|
||||||
|
|
||||||
final FailedNodeException e = expectThrows(FailedNodeException.class, () -> collector.doCollect(randomMonitoringNode(random())));
|
final FailedNodeException e = expectThrows(FailedNodeException.class, () -> collector.doCollect(randomMonitoringNode(random())));
|
||||||
assertEquals(exception, e);
|
assertEquals(exception, e);
|
||||||
|
@ -81,6 +83,9 @@ public class NodeStatsCollectorTests extends BaseCollectorTestCase {
|
||||||
public void testDoCollect() throws Exception {
|
public void testDoCollect() throws Exception {
|
||||||
when(licenseState.isMonitoringAllowed()).thenReturn(true);
|
when(licenseState.isMonitoringAllowed()).thenReturn(true);
|
||||||
|
|
||||||
|
final TimeValue timeout = TimeValue.timeValueSeconds(randomIntBetween(1, 120));
|
||||||
|
withCollectionTimeout(NodeStatsCollector.NODE_STATS_TIMEOUT, timeout);
|
||||||
|
|
||||||
final boolean isMaster = randomBoolean();
|
final boolean isMaster = randomBoolean();
|
||||||
whenLocalNodeElectedMaster(isMaster);
|
whenLocalNodeElectedMaster(isMaster);
|
||||||
|
|
||||||
|
@ -99,10 +104,10 @@ public class NodeStatsCollectorTests extends BaseCollectorTestCase {
|
||||||
when(nodeStats.getTimestamp()).thenReturn(timestamp);
|
when(nodeStats.getTimestamp()).thenReturn(timestamp);
|
||||||
|
|
||||||
final Client client = mock(Client.class);
|
final Client client = mock(Client.class);
|
||||||
thenReturnNodeStats(client, nodesStatsResponse);
|
thenReturnNodeStats(client, timeout, nodesStatsResponse);
|
||||||
|
|
||||||
final NodeStatsCollector collector =
|
final NodeStatsCollector collector = new NodeStatsCollector(Settings.EMPTY, clusterService, licenseState, client);
|
||||||
new NodeStatsCollector(Settings.EMPTY, clusterService, monitoringSettings, licenseState, client);
|
assertEquals(timeout, collector.getCollectionTimeout());
|
||||||
|
|
||||||
final Collection<MonitoringDoc> results = collector.doCollect(node);
|
final Collection<MonitoringDoc> results = collector.doCollect(node);
|
||||||
assertEquals(1, results.size());
|
assertEquals(1, results.size());
|
||||||
|
@ -124,10 +129,10 @@ public class NodeStatsCollectorTests extends BaseCollectorTestCase {
|
||||||
assertThat(document.isMlockall(), equalTo(BootstrapInfo.isMemoryLocked()));
|
assertThat(document.isMlockall(), equalTo(BootstrapInfo.isMemoryLocked()));
|
||||||
}
|
}
|
||||||
|
|
||||||
private void thenReturnNodeStats(final Client client, final NodesStatsResponse nodesStatsResponse) {
|
private void thenReturnNodeStats(final Client client, final TimeValue timeout, final NodesStatsResponse nodesStatsResponse) {
|
||||||
@SuppressWarnings("unchecked")
|
@SuppressWarnings("unchecked")
|
||||||
final ActionFuture<NodesStatsResponse> future = (ActionFuture<NodesStatsResponse>) mock(ActionFuture.class);
|
final ActionFuture<NodesStatsResponse> future = (ActionFuture<NodesStatsResponse>) mock(ActionFuture.class);
|
||||||
when(future.actionGet(eq(monitoringSettings.nodeStatsTimeout()))).thenReturn(nodesStatsResponse);
|
when(future.actionGet(eq(timeout))).thenReturn(nodesStatsResponse);
|
||||||
|
|
||||||
final ClusterAdminClient clusterAdminClient = mock(ClusterAdminClient.class);
|
final ClusterAdminClient clusterAdminClient = mock(ClusterAdminClient.class);
|
||||||
when(clusterAdminClient.nodesStats(any(NodesStatsRequest.class))).thenReturn(future);
|
when(clusterAdminClient.nodesStats(any(NodesStatsRequest.class))).thenReturn(future);
|
||||||
|
|
|
@ -47,7 +47,7 @@ public class ShardsCollectorTests extends BaseCollectorTestCase {
|
||||||
when(licenseState.isMonitoringAllowed()).thenReturn(false);
|
when(licenseState.isMonitoringAllowed()).thenReturn(false);
|
||||||
whenLocalNodeElectedMaster(randomBoolean());
|
whenLocalNodeElectedMaster(randomBoolean());
|
||||||
|
|
||||||
final ShardsCollector collector = new ShardsCollector(Settings.EMPTY, clusterService, monitoringSettings, licenseState);
|
final ShardsCollector collector = new ShardsCollector(Settings.EMPTY, clusterService, licenseState);
|
||||||
|
|
||||||
assertThat(collector.shouldCollect(), is(false));
|
assertThat(collector.shouldCollect(), is(false));
|
||||||
verify(licenseState).isMonitoringAllowed();
|
verify(licenseState).isMonitoringAllowed();
|
||||||
|
@ -58,7 +58,7 @@ public class ShardsCollectorTests extends BaseCollectorTestCase {
|
||||||
// this controls the blockage
|
// this controls the blockage
|
||||||
whenLocalNodeElectedMaster(false);
|
whenLocalNodeElectedMaster(false);
|
||||||
|
|
||||||
final ShardsCollector collector = new ShardsCollector(Settings.EMPTY, clusterService, monitoringSettings, licenseState);
|
final ShardsCollector collector = new ShardsCollector(Settings.EMPTY, clusterService, licenseState);
|
||||||
|
|
||||||
assertThat(collector.shouldCollect(), is(false));
|
assertThat(collector.shouldCollect(), is(false));
|
||||||
verify(licenseState).isMonitoringAllowed();
|
verify(licenseState).isMonitoringAllowed();
|
||||||
|
@ -69,7 +69,7 @@ public class ShardsCollectorTests extends BaseCollectorTestCase {
|
||||||
when(licenseState.isMonitoringAllowed()).thenReturn(true);
|
when(licenseState.isMonitoringAllowed()).thenReturn(true);
|
||||||
whenLocalNodeElectedMaster(true);
|
whenLocalNodeElectedMaster(true);
|
||||||
|
|
||||||
final ShardsCollector collector = new ShardsCollector(Settings.EMPTY, clusterService, monitoringSettings, licenseState);
|
final ShardsCollector collector = new ShardsCollector(Settings.EMPTY, clusterService, licenseState);
|
||||||
|
|
||||||
assertThat(collector.shouldCollect(), is(true));
|
assertThat(collector.shouldCollect(), is(true));
|
||||||
verify(licenseState).isMonitoringAllowed();
|
verify(licenseState).isMonitoringAllowed();
|
||||||
|
@ -79,7 +79,7 @@ public class ShardsCollectorTests extends BaseCollectorTestCase {
|
||||||
public void testDoCollectWhenNoClusterState() throws Exception {
|
public void testDoCollectWhenNoClusterState() throws Exception {
|
||||||
when(clusterService.state()).thenReturn(null);
|
when(clusterService.state()).thenReturn(null);
|
||||||
|
|
||||||
final ShardsCollector collector = new ShardsCollector(Settings.EMPTY, clusterService, monitoringSettings, licenseState);
|
final ShardsCollector collector = new ShardsCollector(Settings.EMPTY, clusterService, licenseState);
|
||||||
|
|
||||||
final Collection<MonitoringDoc> results = collector.doCollect(randomMonitoringNode(random()));
|
final Collection<MonitoringDoc> results = collector.doCollect(randomMonitoringNode(random()));
|
||||||
assertThat(results, notNullValue());
|
assertThat(results, notNullValue());
|
||||||
|
@ -98,7 +98,7 @@ public class ShardsCollectorTests extends BaseCollectorTestCase {
|
||||||
when(clusterState.stateUUID()).thenReturn(stateUUID);
|
when(clusterState.stateUUID()).thenReturn(stateUUID);
|
||||||
|
|
||||||
final String[] indices = randomFrom(NONE, Strings.EMPTY_ARRAY, new String[]{"_all"}, new String[]{"_index*"});
|
final String[] indices = randomFrom(NONE, Strings.EMPTY_ARRAY, new String[]{"_all"}, new String[]{"_index*"});
|
||||||
when(monitoringSettings.indices()).thenReturn(indices);
|
withCollectionIndices(indices);
|
||||||
|
|
||||||
final RoutingTable routingTable = mockRoutingTable();
|
final RoutingTable routingTable = mockRoutingTable();
|
||||||
when(clusterState.routingTable()).thenReturn(routingTable);
|
when(clusterState.routingTable()).thenReturn(routingTable);
|
||||||
|
@ -108,7 +108,9 @@ public class ShardsCollectorTests extends BaseCollectorTestCase {
|
||||||
when(nodes.get(eq("_current"))).thenReturn(localNode);
|
when(nodes.get(eq("_current"))).thenReturn(localNode);
|
||||||
when(clusterState.getNodes()).thenReturn(nodes);
|
when(clusterState.getNodes()).thenReturn(nodes);
|
||||||
|
|
||||||
final ShardsCollector collector = new ShardsCollector(Settings.EMPTY, clusterService, monitoringSettings, licenseState);
|
final ShardsCollector collector = new ShardsCollector(Settings.EMPTY, clusterService, licenseState);
|
||||||
|
assertNull(collector.getCollectionTimeout());
|
||||||
|
assertArrayEquals(indices, collector.getCollectionIndices());
|
||||||
|
|
||||||
final Collection<MonitoringDoc> results = collector.doCollect(node);
|
final Collection<MonitoringDoc> results = collector.doCollect(node);
|
||||||
assertThat(results, notNullValue());
|
assertThat(results, notNullValue());
|
||||||
|
|
|
@ -19,8 +19,7 @@ import org.elasticsearch.license.XPackLicenseState;
|
||||||
import org.elasticsearch.test.ESTestCase;
|
import org.elasticsearch.test.ESTestCase;
|
||||||
import org.elasticsearch.threadpool.ThreadPool;
|
import org.elasticsearch.threadpool.ThreadPool;
|
||||||
import org.elasticsearch.xpack.monitoring.MonitoredSystem;
|
import org.elasticsearch.xpack.monitoring.MonitoredSystem;
|
||||||
import org.elasticsearch.xpack.monitoring.MonitoringSettings;
|
import org.elasticsearch.xpack.monitoring.MonitoringService;
|
||||||
import org.elasticsearch.xpack.monitoring.action.MonitoringBulkDoc;
|
|
||||||
import org.elasticsearch.xpack.monitoring.cleaner.CleanerService;
|
import org.elasticsearch.xpack.monitoring.cleaner.CleanerService;
|
||||||
import org.elasticsearch.xpack.monitoring.exporter.local.LocalExporter;
|
import org.elasticsearch.xpack.monitoring.exporter.local.LocalExporter;
|
||||||
import org.elasticsearch.xpack.security.InternalClient;
|
import org.elasticsearch.xpack.security.InternalClient;
|
||||||
|
@ -40,6 +39,7 @@ import java.util.concurrent.TimeUnit;
|
||||||
import java.util.concurrent.atomic.AtomicInteger;
|
import java.util.concurrent.atomic.AtomicInteger;
|
||||||
import java.util.concurrent.atomic.AtomicReference;
|
import java.util.concurrent.atomic.AtomicReference;
|
||||||
|
|
||||||
|
import static java.util.Collections.singleton;
|
||||||
import static org.hamcrest.Matchers.containsString;
|
import static org.hamcrest.Matchers.containsString;
|
||||||
import static org.hamcrest.Matchers.empty;
|
import static org.hamcrest.Matchers.empty;
|
||||||
import static org.hamcrest.Matchers.equalTo;
|
import static org.hamcrest.Matchers.equalTo;
|
||||||
|
@ -75,7 +75,7 @@ public class ExportersTests extends ESTestCase {
|
||||||
// default state.version() will be 0, which is "valid"
|
// default state.version() will be 0, which is "valid"
|
||||||
state = mock(ClusterState.class);
|
state = mock(ClusterState.class);
|
||||||
clusterSettings = new ClusterSettings(Settings.EMPTY,
|
clusterSettings = new ClusterSettings(Settings.EMPTY,
|
||||||
new HashSet<>(Arrays.asList(MonitoringSettings.INTERVAL, MonitoringSettings.EXPORTERS_SETTINGS)));
|
new HashSet<>(Arrays.asList(MonitoringService.INTERVAL, Exporters.EXPORTERS_SETTINGS)));
|
||||||
when(clusterService.getClusterSettings()).thenReturn(clusterSettings);
|
when(clusterService.getClusterSettings()).thenReturn(clusterSettings);
|
||||||
when(clusterService.state()).thenReturn(state);
|
when(clusterService.state()).thenReturn(state);
|
||||||
|
|
||||||
|
@ -180,7 +180,7 @@ public class ExportersTests extends ESTestCase {
|
||||||
.put("xpack.monitoring.exporters._name0.type", "_type")
|
.put("xpack.monitoring.exporters._name0.type", "_type")
|
||||||
.put("xpack.monitoring.exporters._name1.type", "_type")
|
.put("xpack.monitoring.exporters._name1.type", "_type")
|
||||||
.build();
|
.build();
|
||||||
clusterSettings = new ClusterSettings(nodeSettings, new HashSet<>(Arrays.asList(MonitoringSettings.EXPORTERS_SETTINGS)));
|
clusterSettings = new ClusterSettings(nodeSettings, singleton(Exporters.EXPORTERS_SETTINGS));
|
||||||
when(clusterService.getClusterSettings()).thenReturn(clusterSettings);
|
when(clusterService.getClusterSettings()).thenReturn(clusterSettings);
|
||||||
|
|
||||||
exporters = new Exporters(nodeSettings, factories, clusterService, licenseState, threadContext) {
|
exporters = new Exporters(nodeSettings, factories, clusterService, licenseState, threadContext) {
|
||||||
|
|
|
@ -29,7 +29,7 @@ import org.elasticsearch.test.ESIntegTestCase.Scope;
|
||||||
import org.elasticsearch.test.http.MockRequest;
|
import org.elasticsearch.test.http.MockRequest;
|
||||||
import org.elasticsearch.test.http.MockResponse;
|
import org.elasticsearch.test.http.MockResponse;
|
||||||
import org.elasticsearch.test.http.MockWebServer;
|
import org.elasticsearch.test.http.MockWebServer;
|
||||||
import org.elasticsearch.xpack.monitoring.MonitoringSettings;
|
import org.elasticsearch.xpack.monitoring.MonitoringService;
|
||||||
import org.elasticsearch.xpack.monitoring.MonitoringTestUtils;
|
import org.elasticsearch.xpack.monitoring.MonitoringTestUtils;
|
||||||
import org.elasticsearch.xpack.monitoring.collector.indices.IndexRecoveryMonitoringDoc;
|
import org.elasticsearch.xpack.monitoring.collector.indices.IndexRecoveryMonitoringDoc;
|
||||||
import org.elasticsearch.xpack.monitoring.exporter.ClusterAlertsUtil;
|
import org.elasticsearch.xpack.monitoring.exporter.ClusterAlertsUtil;
|
||||||
|
@ -107,7 +107,7 @@ public class HttpExporterIT extends MonitoringIntegTestCase {
|
||||||
// we make an exporter on demand per test
|
// we make an exporter on demand per test
|
||||||
return Settings.builder()
|
return Settings.builder()
|
||||||
.put(super.nodeSettings(nodeOrdinal))
|
.put(super.nodeSettings(nodeOrdinal))
|
||||||
.put(MonitoringSettings.INTERVAL.getKey(), "-1")
|
.put(MonitoringService.INTERVAL.getKey(), "-1")
|
||||||
.put("xpack.monitoring.exporters._http.type", "http")
|
.put("xpack.monitoring.exporters._http.type", "http")
|
||||||
.put("xpack.monitoring.exporters._http.enabled", false)
|
.put("xpack.monitoring.exporters._http.enabled", false)
|
||||||
.build();
|
.build();
|
||||||
|
|
|
@ -11,7 +11,7 @@ import org.elasticsearch.license.XPackLicenseState;
|
||||||
import org.elasticsearch.threadpool.TestThreadPool;
|
import org.elasticsearch.threadpool.TestThreadPool;
|
||||||
import org.elasticsearch.threadpool.ThreadPool;
|
import org.elasticsearch.threadpool.ThreadPool;
|
||||||
import org.elasticsearch.xpack.XPackSettings;
|
import org.elasticsearch.xpack.XPackSettings;
|
||||||
import org.elasticsearch.xpack.monitoring.MonitoringSettings;
|
import org.elasticsearch.xpack.monitoring.MonitoringService;
|
||||||
import org.elasticsearch.xpack.monitoring.cleaner.CleanerService;
|
import org.elasticsearch.xpack.monitoring.cleaner.CleanerService;
|
||||||
import org.elasticsearch.xpack.monitoring.exporter.Exporter;
|
import org.elasticsearch.xpack.monitoring.exporter.Exporter;
|
||||||
import org.elasticsearch.xpack.monitoring.test.MonitoringIntegTestCase;
|
import org.elasticsearch.xpack.monitoring.test.MonitoringIntegTestCase;
|
||||||
|
@ -65,7 +65,7 @@ public abstract class LocalExporterIntegTestCase extends MonitoringIntegTestCase
|
||||||
|
|
||||||
protected Settings localExporterSettings() {
|
protected Settings localExporterSettings() {
|
||||||
return Settings.builder()
|
return Settings.builder()
|
||||||
.put(MonitoringSettings.INTERVAL.getKey(), "-1")
|
.put(MonitoringService.INTERVAL.getKey(), "-1")
|
||||||
.put("xpack.monitoring.exporters." + exporterName + ".type", LocalExporter.TYPE)
|
.put("xpack.monitoring.exporters." + exporterName + ".type", LocalExporter.TYPE)
|
||||||
.put("xpack.monitoring.exporters." + exporterName + ".enabled", false)
|
.put("xpack.monitoring.exporters." + exporterName + ".enabled", false)
|
||||||
.put("xpack.monitoring.exporters." + exporterName + "." + CLUSTER_ALERTS_MANAGEMENT_SETTING, useClusterAlerts())
|
.put("xpack.monitoring.exporters." + exporterName + "." + CLUSTER_ALERTS_MANAGEMENT_SETTING, useClusterAlerts())
|
||||||
|
|
|
@ -26,7 +26,7 @@ import org.elasticsearch.search.aggregations.metrics.max.Max;
|
||||||
import org.elasticsearch.test.ESIntegTestCase;
|
import org.elasticsearch.test.ESIntegTestCase;
|
||||||
import org.elasticsearch.xpack.XPackClient;
|
import org.elasticsearch.xpack.XPackClient;
|
||||||
import org.elasticsearch.xpack.monitoring.MonitoredSystem;
|
import org.elasticsearch.xpack.monitoring.MonitoredSystem;
|
||||||
import org.elasticsearch.xpack.monitoring.MonitoringSettings;
|
import org.elasticsearch.xpack.monitoring.MonitoringService;
|
||||||
import org.elasticsearch.xpack.monitoring.MonitoringTestUtils;
|
import org.elasticsearch.xpack.monitoring.MonitoringTestUtils;
|
||||||
import org.elasticsearch.xpack.monitoring.action.MonitoringBulkDoc;
|
import org.elasticsearch.xpack.monitoring.action.MonitoringBulkDoc;
|
||||||
import org.elasticsearch.xpack.monitoring.action.MonitoringBulkRequestBuilder;
|
import org.elasticsearch.xpack.monitoring.action.MonitoringBulkRequestBuilder;
|
||||||
|
@ -71,7 +71,7 @@ public class LocalExporterIntegTests extends LocalExporterIntegTestCase {
|
||||||
private void stopMonitoring() throws Exception {
|
private void stopMonitoring() throws Exception {
|
||||||
// Now disabling the monitoring service, so that no more collection are started
|
// Now disabling the monitoring service, so that no more collection are started
|
||||||
assertAcked(client().admin().cluster().prepareUpdateSettings().setTransientSettings(
|
assertAcked(client().admin().cluster().prepareUpdateSettings().setTransientSettings(
|
||||||
Settings.builder().putNull(MonitoringSettings.INTERVAL.getKey())
|
Settings.builder().putNull(MonitoringService.INTERVAL.getKey())
|
||||||
.putNull("xpack.monitoring.exporters._local.enabled")
|
.putNull("xpack.monitoring.exporters._local.enabled")
|
||||||
.putNull("xpack.monitoring.exporters._local.index.name.time_format")));
|
.putNull("xpack.monitoring.exporters._local.index.name.time_format")));
|
||||||
}
|
}
|
||||||
|
@ -126,7 +126,7 @@ public class LocalExporterIntegTests extends LocalExporterIntegTestCase {
|
||||||
|
|
||||||
// monitoring service is started
|
// monitoring service is started
|
||||||
exporterSettings = Settings.builder()
|
exporterSettings = Settings.builder()
|
||||||
.put(MonitoringSettings.INTERVAL.getKey(), 3L, TimeUnit.SECONDS);
|
.put(MonitoringService.INTERVAL.getKey(), 3L, TimeUnit.SECONDS);
|
||||||
assertAcked(client().admin().cluster().prepareUpdateSettings().setTransientSettings(exporterSettings));
|
assertAcked(client().admin().cluster().prepareUpdateSettings().setTransientSettings(exporterSettings));
|
||||||
|
|
||||||
final int numNodes = internalCluster().getNodeNames().length;
|
final int numNodes = internalCluster().getNodeNames().length;
|
||||||
|
|
|
@ -11,7 +11,6 @@ import org.apache.http.entity.ContentType;
|
||||||
import org.apache.http.entity.StringEntity;
|
import org.apache.http.entity.StringEntity;
|
||||||
import org.apache.http.nio.entity.NStringEntity;
|
import org.apache.http.nio.entity.NStringEntity;
|
||||||
import org.apache.lucene.util.Constants;
|
import org.apache.lucene.util.Constants;
|
||||||
import org.apache.lucene.util.LuceneTestCase;
|
|
||||||
import org.elasticsearch.ElasticsearchException;
|
import org.elasticsearch.ElasticsearchException;
|
||||||
import org.elasticsearch.Version;
|
import org.elasticsearch.Version;
|
||||||
import org.elasticsearch.client.Response;
|
import org.elasticsearch.client.Response;
|
||||||
|
@ -64,7 +63,6 @@ import static org.hamcrest.Matchers.not;
|
||||||
import static org.hamcrest.Matchers.notNullValue;
|
import static org.hamcrest.Matchers.notNullValue;
|
||||||
import static org.hamcrest.Matchers.nullValue;
|
import static org.hamcrest.Matchers.nullValue;
|
||||||
|
|
||||||
@LuceneTestCase.AwaitsFix(bugUrl = "https://github.com/elastic/x-pack-elasticsearch/issues/2609")
|
|
||||||
public class MonitoringIT extends ESRestTestCase {
|
public class MonitoringIT extends ESRestTestCase {
|
||||||
|
|
||||||
private static final String BASIC_AUTH_VALUE = basicAuthHeaderValue("x_pack_rest_user", TEST_PASSWORD_SECURE_STRING);
|
private static final String BASIC_AUTH_VALUE = basicAuthHeaderValue("x_pack_rest_user", TEST_PASSWORD_SECURE_STRING);
|
||||||
|
@ -411,9 +409,6 @@ public class MonitoringIT extends ESRestTestCase {
|
||||||
final Map<String, Object> source = (Map<String, Object>) document.get("_source");
|
final Map<String, Object> source = (Map<String, Object>) document.get("_source");
|
||||||
assertEquals(5, source.size());
|
assertEquals(5, source.size());
|
||||||
|
|
||||||
final Map<String, Object> nodeStats = (Map<String, Object>) source.get(NodeStatsMonitoringDoc.TYPE);
|
|
||||||
assertEquals(Constants.WINDOWS ? 8 : 9, nodeStats.size());
|
|
||||||
|
|
||||||
NodeStatsMonitoringDoc.XCONTENT_FILTERS.forEach(filter -> {
|
NodeStatsMonitoringDoc.XCONTENT_FILTERS.forEach(filter -> {
|
||||||
if (Constants.WINDOWS && filter.startsWith("node_stats.os.cpu.load_average")) {
|
if (Constants.WINDOWS && filter.startsWith("node_stats.os.cpu.load_average")) {
|
||||||
// load average is unavailable on Windows
|
// load average is unavailable on Windows
|
||||||
|
|
|
@ -10,7 +10,7 @@ import org.elasticsearch.common.bytes.BytesArray;
|
||||||
import org.elasticsearch.common.collect.Tuple;
|
import org.elasticsearch.common.collect.Tuple;
|
||||||
import org.elasticsearch.common.settings.Settings;
|
import org.elasticsearch.common.settings.Settings;
|
||||||
import org.elasticsearch.common.xcontent.XContentType;
|
import org.elasticsearch.common.xcontent.XContentType;
|
||||||
import org.elasticsearch.xpack.monitoring.MonitoringSettings;
|
import org.elasticsearch.xpack.monitoring.MonitoringService;
|
||||||
import org.elasticsearch.xpack.monitoring.test.MonitoringIntegTestCase;
|
import org.elasticsearch.xpack.monitoring.test.MonitoringIntegTestCase;
|
||||||
import org.elasticsearch.xpack.security.InternalClient;
|
import org.elasticsearch.xpack.security.InternalClient;
|
||||||
|
|
||||||
|
@ -24,7 +24,7 @@ public class MonitoringInternalClientTests extends MonitoringIntegTestCase {
|
||||||
protected Settings nodeSettings(int nodeOrdinal) {
|
protected Settings nodeSettings(int nodeOrdinal) {
|
||||||
return Settings.builder()
|
return Settings.builder()
|
||||||
.put(super.nodeSettings(nodeOrdinal))
|
.put(super.nodeSettings(nodeOrdinal))
|
||||||
.put(MonitoringSettings.INTERVAL.getKey(), "-1")
|
.put(MonitoringService.INTERVAL.getKey(), "-1")
|
||||||
.build();
|
.build();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -14,7 +14,7 @@ import org.elasticsearch.common.settings.Settings;
|
||||||
import org.elasticsearch.common.xcontent.json.JsonXContent;
|
import org.elasticsearch.common.xcontent.json.JsonXContent;
|
||||||
import org.elasticsearch.plugins.Plugin;
|
import org.elasticsearch.plugins.Plugin;
|
||||||
import org.elasticsearch.transport.Netty4Plugin;
|
import org.elasticsearch.transport.Netty4Plugin;
|
||||||
import org.elasticsearch.xpack.monitoring.MonitoringSettings;
|
import org.elasticsearch.xpack.monitoring.MonitoringService;
|
||||||
import org.elasticsearch.xpack.monitoring.test.MonitoringIntegTestCase;
|
import org.elasticsearch.xpack.monitoring.test.MonitoringIntegTestCase;
|
||||||
|
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
|
@ -35,7 +35,7 @@ public class MonitoringSettingsFilterTests extends MonitoringIntegTestCase {
|
||||||
return Settings.builder()
|
return Settings.builder()
|
||||||
.put(super.nodeSettings(nodeOrdinal))
|
.put(super.nodeSettings(nodeOrdinal))
|
||||||
.put(NetworkModule.HTTP_ENABLED.getKey(), true)
|
.put(NetworkModule.HTTP_ENABLED.getKey(), true)
|
||||||
.put(MonitoringSettings.INTERVAL.getKey(), "-1")
|
.put(MonitoringService.INTERVAL.getKey(), "-1")
|
||||||
.put("xpack.monitoring.exporters._http.type", "http")
|
.put("xpack.monitoring.exporters._http.type", "http")
|
||||||
.put("xpack.monitoring.exporters._http.enabled", false)
|
.put("xpack.monitoring.exporters._http.enabled", false)
|
||||||
.put("xpack.monitoring.exporters._http.auth.username", "_user")
|
.put("xpack.monitoring.exporters._http.auth.username", "_user")
|
||||||
|
|
|
@ -34,7 +34,6 @@ import org.elasticsearch.xpack.XPackPlugin;
|
||||||
import org.elasticsearch.xpack.XPackSettings;
|
import org.elasticsearch.xpack.XPackSettings;
|
||||||
import org.elasticsearch.xpack.ml.MachineLearning;
|
import org.elasticsearch.xpack.ml.MachineLearning;
|
||||||
import org.elasticsearch.xpack.monitoring.MonitoringService;
|
import org.elasticsearch.xpack.monitoring.MonitoringService;
|
||||||
import org.elasticsearch.xpack.monitoring.MonitoringSettings;
|
|
||||||
import org.elasticsearch.xpack.monitoring.client.MonitoringClient;
|
import org.elasticsearch.xpack.monitoring.client.MonitoringClient;
|
||||||
import org.elasticsearch.xpack.monitoring.exporter.ClusterAlertsUtil;
|
import org.elasticsearch.xpack.monitoring.exporter.ClusterAlertsUtil;
|
||||||
import org.elasticsearch.xpack.monitoring.exporter.MonitoringTemplateUtils;
|
import org.elasticsearch.xpack.monitoring.exporter.MonitoringTemplateUtils;
|
||||||
|
@ -404,7 +403,7 @@ public abstract class MonitoringIntegTestCase extends ESIntegTestCase {
|
||||||
|
|
||||||
protected void updateMonitoringInterval(long value, TimeUnit timeUnit) {
|
protected void updateMonitoringInterval(long value, TimeUnit timeUnit) {
|
||||||
assertAcked(client().admin().cluster().prepareUpdateSettings().setTransientSettings(
|
assertAcked(client().admin().cluster().prepareUpdateSettings().setTransientSettings(
|
||||||
Settings.builder().put(MonitoringSettings.INTERVAL.getKey(), value, timeUnit)));
|
Settings.builder().put(MonitoringService.INTERVAL.getKey(), value, timeUnit)));
|
||||||
}
|
}
|
||||||
|
|
||||||
/** security related settings */
|
/** security related settings */
|
||||||
|
|
|
@ -830,6 +830,7 @@ public class AuthenticationServiceTests extends ESTestCase {
|
||||||
random().nextBytes(randomBytes);
|
random().nextBytes(randomBytes);
|
||||||
final CountDownLatch latch = new CountDownLatch(1);
|
final CountDownLatch latch = new CountDownLatch(1);
|
||||||
final Authentication expected = new Authentication(user, new RealmRef(firstRealm.name(), firstRealm.type(), "authc_test"), null);
|
final Authentication expected = new Authentication(user, new RealmRef(firstRealm.name(), firstRealm.type(), "authc_test"), null);
|
||||||
|
AtomicBoolean success = new AtomicBoolean(false);
|
||||||
try (ThreadContext.StoredContext ignore = threadContext.stashContext()) {
|
try (ThreadContext.StoredContext ignore = threadContext.stashContext()) {
|
||||||
threadContext.putHeader("Authorization", "Bearer " + Base64.getEncoder().encodeToString(randomBytes));
|
threadContext.putHeader("Authorization", "Bearer " + Base64.getEncoder().encodeToString(randomBytes));
|
||||||
service.authenticate("_action", message, null, ActionListener.wrap(result -> {
|
service.authenticate("_action", message, null, ActionListener.wrap(result -> {
|
||||||
|
@ -839,18 +840,22 @@ public class AuthenticationServiceTests extends ESTestCase {
|
||||||
assertThat(result.getAuthenticatedBy(), is(notNullValue()));
|
assertThat(result.getAuthenticatedBy(), is(notNullValue()));
|
||||||
assertThreadContextContainsAuthentication(result);
|
assertThreadContextContainsAuthentication(result);
|
||||||
assertEquals(expected, result);
|
assertEquals(expected, result);
|
||||||
|
success.set(true);
|
||||||
latch.countDown();
|
latch.countDown();
|
||||||
}, this::logAndFail));
|
}, this::logAndFail));
|
||||||
} catch (IllegalArgumentException ex) {
|
} catch (IllegalArgumentException ex) {
|
||||||
assertThat(ex.getMessage(), containsString("array length must be <= to " + ArrayUtil.MAX_ARRAY_LENGTH + " but was: "));
|
assertThat(ex.getMessage(), containsString("array length must be <= to " + ArrayUtil.MAX_ARRAY_LENGTH + " but was: "));
|
||||||
|
latch.countDown();
|
||||||
} catch (NegativeArraySizeException ex) {
|
} catch (NegativeArraySizeException ex) {
|
||||||
assertThat(ex.getMessage(), containsString("array size must be positive but was: "));
|
assertThat(ex.getMessage(), containsString("array size must be positive but was: "));
|
||||||
|
latch.countDown();
|
||||||
}
|
}
|
||||||
|
|
||||||
// we need to use a latch here because the key computation goes async on another thread!
|
// we need to use a latch here because the key computation goes async on another thread!
|
||||||
latch.await();
|
latch.await();
|
||||||
|
if (success.get()) {
|
||||||
verify(auditTrail).authenticationSuccess(firstRealm.name(), user, "_action", message);
|
verify(auditTrail).authenticationSuccess(firstRealm.name(), user, "_action", message);
|
||||||
|
}
|
||||||
verifyNoMoreInteractions(auditTrail);
|
verifyNoMoreInteractions(auditTrail);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -46,7 +46,9 @@ public class ESNativeRealmMigrateToolTests extends CommandTestCase {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected Environment createEnv(Terminal terminal, Map<String, String> settings) throws UserException {
|
protected Environment createEnv(Terminal terminal, Map<String, String> settings) throws UserException {
|
||||||
return new Environment(Settings.builder().put(settings).build());
|
Settings.Builder builder = Settings.builder();
|
||||||
|
settings.forEach((k,v) -> builder.put(k, v));
|
||||||
|
return new Environment(builder.build());
|
||||||
}
|
}
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
|
@ -100,7 +100,9 @@ public class SetupPasswordToolTests extends CommandTestCase {
|
||||||
return new AutoSetup() {
|
return new AutoSetup() {
|
||||||
@Override
|
@Override
|
||||||
protected Environment createEnv(Terminal terminal, Map<String, String> settings) throws UserException {
|
protected Environment createEnv(Terminal terminal, Map<String, String> settings) throws UserException {
|
||||||
return new Environment(Settings.builder().put(settings).build());
|
Settings.Builder builder = Settings.builder();
|
||||||
|
settings.forEach((k,v) -> builder.put(k, v));
|
||||||
|
return new Environment(builder.build());
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
@ -110,7 +112,9 @@ public class SetupPasswordToolTests extends CommandTestCase {
|
||||||
return new InteractiveSetup() {
|
return new InteractiveSetup() {
|
||||||
@Override
|
@Override
|
||||||
protected Environment createEnv(Terminal terminal, Map<String, String> settings) throws UserException {
|
protected Environment createEnv(Terminal terminal, Map<String, String> settings) throws UserException {
|
||||||
return new Environment(Settings.builder().put(settings).build());
|
Settings.Builder builder = Settings.builder();
|
||||||
|
settings.forEach((k,v) -> builder.put(k, v));
|
||||||
|
return new Environment(builder.build());
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
|
@ -50,7 +50,9 @@ public class SystemKeyToolTests extends CommandTestCase {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected Environment createEnv(Terminal terminal, Map<String, String> settings) throws UserException {
|
protected Environment createEnv(Terminal terminal, Map<String, String> settings) throws UserException {
|
||||||
return new Environment(Settings.builder().put(settings).build());
|
Settings.Builder builder = Settings.builder();
|
||||||
|
settings.forEach((k,v) -> builder.put(k, v));
|
||||||
|
return new Environment(builder.build());
|
||||||
}
|
}
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
|
@ -145,6 +145,11 @@ public class LicensingTribeIT extends ESIntegTestCase {
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void testDummy() throws Exception {
|
||||||
|
// this test is here so that testLicensePropagateToTribeNode's assumption
|
||||||
|
// doesn't result in this test suite to have no tests run and trigger a build failure
|
||||||
|
}
|
||||||
|
|
||||||
private static final String PLATINUM_LICENSE = "{\"license\":{\"uid\":\"1\",\"type\":\"platinum\"," +
|
private static final String PLATINUM_LICENSE = "{\"license\":{\"uid\":\"1\",\"type\":\"platinum\"," +
|
||||||
"\"issue_date_in_millis\":1411948800000,\"expiry_date_in_millis\":1914278399999,\"max_nodes\":1," +
|
"\"issue_date_in_millis\":1411948800000,\"expiry_date_in_millis\":1914278399999,\"max_nodes\":1," +
|
||||||
"\"issued_to\":\"issuedTo\",\"issuer\":\"issuer\"," +
|
"\"issued_to\":\"issuedTo\",\"issuer\":\"issuer\"," +
|
||||||
|
|
Loading…
Reference in New Issue