elasticsearch-migrate

elasticsearch-migrate

[7.2.0] Deprecated in 7.2.0. This tool is deprecated. Use the native realm directly.

The elasticsearch-migrate command migrates existing file-based users and roles to the native realm. From 5.0 onward, you should use the native realm to manage roles and local users.

Synopsis

  1. bin/elasticsearch-migrate
  2. (native (-U, --url <url>)
  3. [-h, --help] [-E <KeyValuePair>]
  4. [-n, --users <uids>] [-r, --roles <roles>]
  5. [-u, --username <uid>] [-p, --password <password>]
  6. [-s, --silent] [-v, --verbose])

Description

When migrating from Shield 2.x, the elasticsearch-migrate tool should be run prior to upgrading to ensure all roles can be migrated as some may be in a deprecated format that X-Pack cannot read. The migrate tool is available in Shield 2.4.0 and higher.

The elasticsearch-migrate tool loads the existing file-based users and roles and calls the user and roles APIs to add them to the native realm. You can migrate all users and roles, or specify the ones you want to migrate. Users and roles that already exist in the native realm are not replaced or overridden. If the names you specify with the --users and --roles options don’t exist in the file realm, they are skipped.

Parameters

The native subcommand supports the following options:

-E <KeyValuePair>

Configures a setting.

-h, --help

Returns all of the command parameters.

-n, --users

Comma-separated list of the users that you want to migrate. If this parameter is not specified, all users are migrated.

-p, --password

Password to use for authentication with Elasticsearch.

-r, --roles

Comma-separated list of the roles that you want to migrate. If this parameter is not specified, all roles are migrated.

-s, --silent

Shows minimal output.

-U, --url

Endpoint URL of the Elasticsearch cluster to which you want to migrate the file-based users and roles. This parameter is required.

-u, --username

Username to use for authentication with Elasticsearch.

-v, --verbose

Shows verbose output.

Examples

Run the elasticsearch-migrate tool when X-Pack is installed. For example:

  1. $ bin/elasticsearch-migrate native -U http://localhost:9200 -u elastic
  2. -p x-pack-test-password -n lee,foo -r role1,role2,role3,role4,foo
  3. starting migration of users and roles...
  4. importing users from [/home/es/config/shield/users]...
  5. found existing users: [test_user, joe3, joe2]
  6. migrating user [lee]
  7. {"user":{"created":true}}
  8. no user [foo] found, skipping
  9. importing roles from [/home/es/config/shield/roles.yml]...
  10. found existing roles: [marvel_user, role_query_fields, admin_role, role3, admin,
  11. remote_marvel_agent, power_user, role_new_format_name_array, role_run_as,
  12. logstash, role_fields, role_run_as1, role_new_format, kibana4_server, user,
  13. transport_client, role1.ab, role_query]
  14. migrating role [role1]
  15. {"role":{"created":true}}
  16. migrating role [role2]
  17. {"role":{"created":true}}
  18. role [role3] already exists, skipping
  19. no role [foo] found, skipping
  20. users and roles imported.

Additionally, the -E flag can be used to specify additional settings. For example to specify a different configuration directory, the command would look like:

  1. $ bin/elasticsearch-migrate native -U http://localhost:9200 -u elastic
  2. -p x-pack-test-password -E path.conf=/etc/elasticsearch