* Adding deprecation notes to host and user risk score documentation * Adding deprecation notes to experimental ML packages
11 KiB
The setup instructions in this document have been deprecated. Please follow the steps outlined here, to enable Host Risk Score in your environment.
Host Risk Score
Host Risk Score is an experimental feature that assigns risk scores to hosts in a given Kibana space. Risk scores are calculated for each host by utilizing transforms on the alerting indices. The transform runs hourly to update the score as new alerts are generated. The Host Risk Score package contains all of the required artifacts for setup. The Host Risk Score feature provides drilldown Lens dashboards and additional Kibana features such as the Host Risk Score Card on the Overview page of the Elastic Security app, and the Host Risk Keyword on the Alert details flyout for an enhanced experience.
Notes
- Host name collision: Hosts are identified by the
host.namefield in alerts. There may be some edge cases where different hosts use the same name. details
Setup Instructions
- Obtain artifacts
- Upload scripts
- Upload ingest pipeline
- Upload and start the
pivottransform - Create the Host Risk Score index
- Upload and start the
latesttransform - Import dashboards
- Enable Kibana features
1. Obtain artifacts
The Host Risk Score functionality is space aware for privacy. Downloaded artifacts must be modified with the desired space before they can be used.
- Download the release bundle from here. The Host Risk Score releases can be identified by the tag
ML-HostRiskScore-YYYYMMDD-N. Check the release description to make sure it is compatible with the Elastic Stack version you are running. - Unzip the contents of
ML-HostRiskScore-YYYYMMDD-N.zip. - Run
ml_hostriskscore_generate_scripts.pyscript in the unzipped directory with your Kibana space as the argument.
python ml_hostriskscore_generate_scripts.py --space default
- Find a new folder named after your space in the unzipped directory. You will be using the scripts within this directory for the next steps.
Note: Host Risk Score artifacts should be updated if/when you update to a newer Elastic Stack version. To do this, simply download a release bundle that is compatible with your new Stack version and repeat all the steps. Backwards compatibility of release bundles is not guaranteed.
2. Upload scripts
- Navigate to
Management / Dev Toolsin Kibana. - Upload the contents of
ml_hostriskscore_levels_script.json,ml_hostriskscore_map_script.json,ml_hostriskscore_reduce_script.jsonandml_hostriskscore_init_script.json(for Elastic Stack version 8.1+ only) using the Script API with the following syntax. - Ensure that your space name (such as
default) replaces<your-space-name>in the script names below.
PUT _scripts/ml_hostriskscore_levels_script_<your-space-name>
{contents of ml_hostriskscore_levels_script.json file}
PUT _scripts/ml_hostriskscore_map_script_<your-space-name>
{contents of ml_hostriskscore_map_script.json file}
PUT _scripts/ml_hostriskscore_reduce_script_<your-space-name>
{contents of ml_hostriskscore_reduce_script.json file}
For Elastic Stack version 8.1+ only
PUT _scripts/ml_hostriskscore_init_script_<your-space-name>
{contents of ml_hostriskscore_init_script.json file}
3. Upload ingest pipeline
- Upload the contents of
ml_hostriskscore_ingest_pipeline.jsonusing the Ingest API with the following syntax. - Ensure that your space name (such as
default) replaces<your-space-name>below.
PUT _ingest/pipeline/ml_hostriskscore_ingest_pipeline_<your-space-name>
{contents of ml_hostriskscore_ingest_pipeline.json file}
4. Upload and start the pivot transform
This transform calculates the risk level every hour for each host in the Kibana space specified.
- Upload the contents of
ml_hostriskscore_pivot_transform.jsonusing the Transform API with the following syntax. - Ensure that your space name (such as
default) replaces<your-space-name>below.
PUT _transform/ml_hostriskscore_pivot_transform_<your-space-name>
{contents of ml_hostriskscore_pivot_transform.json file}
- Navigate to
TransformsunderManagement / Stack Managementin Kibana. Find the transform with the IDml_hostriskscore_pivot_transform_<your-space-name>. Open theActionsmenu on the right side of the row, then clickStart. - Confirm the transform is working as expected by navigating to
Management / Dev Toolsand ensuring the target index exists.
GET ml_host_risk_score_<your-space-name>/_search
5. Create the Host Risk Score index
- Navigate to
Management / Dev Toolsin Kibana. - Create the Host Risk Score index (
ml_host_risk_score_latest_<your-space-name>) with the following mappings. - Ensure that your space name (such as
default) replaces<your-space-name>below.
PUT ml_host_risk_score_latest_<your-space-name>
{
"mappings":{
"properties":{
"host.name":{
"type":"keyword"
}
}
}
}
6. Upload and start the latest transform
This transform recurringly calculates risk levels for all hosts in the Kibana space specified.
- Upload the contents of
ml_hostriskscore_latest_transform.jsonusing the Transform API with the following syntax. - Ensure that your space name (such as
default) replaces<your-space-name>below.
PUT _transform/ml_hostriskscore_latest_transform_<your-space-name>
{contents of ml_hostriskscore_latest_transform.json file}
- Navigate to
TransformsunderManagement / Stack Managementin Kibana. Find the transform with the IDml_hostriskscore_latest_transform_<your-space-name>. Open theActionsmenu on the right side of the row, and clickStart. - Confirm the transform is working as expected by navigating to
Management / Dev Toolsand ensuring the target index exists. You should see documents starting to appear in the index if there is ongoing alerting activity associated with hosts.
GET ml_host_risk_score_latest_<your-space-name>/_search
7. Import dashboards
- Navigate to
Management / Stack Management / Kibana / Saved Objectsin Kibana. - Click on
Importand import theml_hostriskscore_dashboards.ndjsonfile. - Navigate to
Analytics / Dashboard. - Confirm you can see a dashboard named
Current Risk Scores for Hosts, which displays the current list (Top 20) of suspicious hosts in your environment. - Confirm you can see a dashboard named
Drilldown of Host Risk Score, which allows you to further drill down into details of the risk associated with a particular host of interest.
8. Enable Kibana features
To enable the Kibana features for Host Risk Score, you will first need to add the following configuration to kibana.yml.
xpack.securitySolution.enableExperimental: ['riskyHostsEnabled']
Instructions to modify kibana.yml on Elastic Cloud
-
Click on Kibana on the sidebar and click on Edit configuration on your Kibana instance

-
Modify Kibana configuration by adding
xpack.securitySolution.enableExperimental: ['riskyHostsEnabled']
Once you have modified the kibana.yml file, you will find Host Risk Scoring features in the following Kibana locations:
Host Risk Score card on the Overview page

Host Risk Keyword on Alert Details Flyout

For Elastic Stack version 8.1+ only:
Host risk classification column in the All hosts table on the Hosts page

Hosts by risk tab on the Hosts page

The host risk table in the above tab is not affected by the KQL time range. The table shows the latest recorded risk score for each host.
Host risk overview on the Host details page

Hosts by risk tab on the Host details page

Host name collision details
Physical Windows clients - desktops and laptops - in an Active Directory forest are unlikely to have name collisions, as their computer accounts and distinguished names should be unique. Non-domain member servers, desktops and laptops, in a Windows workgroup, may occasionally have name collisions. Macs are often not managed by a directory service and may have name collisions. Virtual servers, that are created from templates or cloning processes may have hostname collisions.



