-
Notifications
You must be signed in to change notification settings - Fork 599
[GCP] Add GCP Compute Metricset #2301
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Merged
Merged
Changes from 4 commits
Commits
Show all changes
7 commits
Select commit
Hold shift + click to select a range
2f57518
Add GCP Compute metricset
legoguy1000 529a49c
minor fix
legoguy1000 3948e06
remove old readme's
legoguy1000 043e43c
fix fields
legoguy1000 60d37b1
update fields and resolve comments
legoguy1000 b95671c
Fix dashboards
legoguy1000 32e57ee
update sample data
legoguy1000 File filter
Filter by extension
Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
There are no files selected for viewing
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
| Original file line number | Diff line number | Diff line change |
|---|---|---|
| @@ -0,0 +1,12 @@ | ||
| # Audit | ||
|
|
||
| Google Cloud services write audit logs that record administrative activities and accesses within your Google Cloud resources. | ||
| More information on the type of data included in the audit logs can be found in the [documentation](https://cloud.google.com/logging/docs/audit) | ||
|
|
||
| ## Logs | ||
|
|
||
| This is the `audit` dataset. | ||
|
|
||
| {{event "audit"}} | ||
|
|
||
| {{fields "audit"}} |
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
| Original file line number | Diff line number | Diff line change |
|---|---|---|
| @@ -0,0 +1,9 @@ | ||
| # Billing | ||
|
|
||
| ## Metrics | ||
|
|
||
| This is the `billing` dataset. | ||
|
|
||
| {{event "billing"}} | ||
|
|
||
| {{fields "billing"}} |
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
| Original file line number | Diff line number | Diff line change |
|---|---|---|
| @@ -0,0 +1,9 @@ | ||
| # Compute | ||
|
|
||
| ## Metrics | ||
|
|
||
| This is the `compute` dataset. | ||
|
|
||
| {{event "compute"}} | ||
|
|
||
| {{fields "compute"}} |
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
| Original file line number | Diff line number | Diff line change |
|---|---|---|
| @@ -0,0 +1,12 @@ | ||
| # Firewall | ||
|
|
||
| Firewall Rules Logging lets you audit, verify, and analyze the effects of your firewall rules. | ||
| More information on the type of data included in the firewall logs can be found in the [documentation](https://cloud.google.com/vpc/docs/firewall-rules-logging) | ||
|
|
||
| ## Logs | ||
|
|
||
| This is the `firewall` dataset. | ||
|
|
||
| {{event "firewall"}} | ||
|
|
||
| {{fields "firewall"}} |
This file was deleted.
Oops, something went wrong.
This file was deleted.
Oops, something went wrong.
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
| Original file line number | Diff line number | Diff line change |
|---|---|---|
| @@ -0,0 +1,13 @@ | ||
| # VPC Flow | ||
|
|
||
| VPC Flow Logs records a sample of network flows sent from and received by VM instances, including instances used as GKE nodes. | ||
| These logs can be used for network monitoring, forensics, real-time security analysis, and expense optimization. | ||
| More information on the type of data included in the firewall logs can be found in the [documentation](https://cloud.google.com/vpc/docs/using-flow-logs) | ||
|
|
||
| ## Logs | ||
|
|
||
| This is the `vpcflow` dataset. | ||
|
|
||
| {{event "vpcflow"}} | ||
|
|
||
| {{fields "vpcflow"}} |
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
16 changes: 16 additions & 0 deletions
16
packages/gcp/data_stream/compute/agent/stream/stream.yml.hbs
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
| Original file line number | Diff line number | Diff line change |
|---|---|---|
| @@ -0,0 +1,16 @@ | ||
| metricsets: ["compute"] | ||
| period: {{period}} | ||
| project_id: {{project_id}} | ||
| {{#if credentials_file}} | ||
| credentials_file: {{credentials_file}} | ||
| {{/if}} | ||
| {{#if credentials_json}} | ||
| credentials_json: {{credentials_json}} | ||
| {{/if}} | ||
| {{#if region}} | ||
| region: {{region}} | ||
| {{/if}} | ||
| {{#if zone}} | ||
| zone: {{zone}} | ||
| {{/if}} | ||
| exclude_labels: {{exclude_labels}} | ||
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
| Original file line number | Diff line number | Diff line change |
|---|---|---|
| @@ -0,0 +1,198 @@ | ||
| - name: cloud | ||
| title: Cloud | ||
| group: 2 | ||
| description: Fields related to the cloud or infrastructure the events are coming from. | ||
| footnote: 'Examples: If Metricbeat is running on an EC2 host and fetches data from its host, the cloud info contains the data about this machine. If Metricbeat runs on a remote machine outside the cloud and fetches data from a service running in the cloud, the field contains cloud data from the machine the service is running on.' | ||
|
legoguy1000 marked this conversation as resolved.
Outdated
|
||
| type: group | ||
| fields: | ||
| - name: account.id | ||
| level: extended | ||
| type: keyword | ||
| ignore_above: 1024 | ||
| description: 'The cloud account or organization id used to identify different entities in a multi-tenant environment. | ||
|
|
||
| Examples: AWS account id, Google Cloud ORG Id, or other unique identifier.' | ||
| example: 666777888999 | ||
| - name: availability_zone | ||
| level: extended | ||
| type: keyword | ||
| ignore_above: 1024 | ||
| description: Availability zone in which this host is running. | ||
| example: us-east-1c | ||
| - name: instance.id | ||
| level: extended | ||
| type: keyword | ||
| ignore_above: 1024 | ||
| description: Instance ID of the host machine. | ||
| example: i-1234567890abcdef0 | ||
| - name: instance.name | ||
| level: extended | ||
| type: keyword | ||
| ignore_above: 1024 | ||
| description: Instance name of the host machine. | ||
| - name: machine.type | ||
| level: extended | ||
| type: keyword | ||
| ignore_above: 1024 | ||
| description: Machine type of the host machine. | ||
| example: t2.medium | ||
| - name: provider | ||
| level: extended | ||
| type: keyword | ||
| ignore_above: 1024 | ||
| description: Name of the cloud provider. Example values are aws, azure, gcp, or digitalocean. | ||
| example: aws | ||
| - name: region | ||
| level: extended | ||
| type: keyword | ||
| ignore_above: 1024 | ||
| description: Region in which this host is running. | ||
| example: us-east-1 | ||
| - name: project.id | ||
| type: keyword | ||
| description: Name of the project in Google Cloud. | ||
| - name: image.id | ||
| type: keyword | ||
| description: Image ID for the cloud instance. | ||
| - name: container | ||
| title: Container | ||
| group: 2 | ||
| description: 'Container fields are used for meta information about the specific container that is the source of information. | ||
|
|
||
| These fields help correlate data based containers from any runtime.' | ||
| type: group | ||
| fields: | ||
| - name: id | ||
| level: core | ||
| type: keyword | ||
| ignore_above: 1024 | ||
| description: Unique container id. | ||
| - name: image.name | ||
| level: extended | ||
| type: keyword | ||
| ignore_above: 1024 | ||
| description: Name of the image the container was built on. | ||
| - name: labels | ||
| level: extended | ||
| type: object | ||
| object_type: keyword | ||
| description: Image labels. | ||
| - name: name | ||
| level: extended | ||
| type: keyword | ||
| ignore_above: 1024 | ||
| description: Container name. | ||
| - name: host | ||
| title: Host | ||
| group: 2 | ||
| description: 'A host is defined as a general computing instance. | ||
|
|
||
| ECS host.* fields should be populated with details about the host on which the event happened, or from which the measurement was taken. Host types include hardware, virtual machines, Docker containers, and Kubernetes nodes.' | ||
| type: group | ||
| fields: | ||
| - name: architecture | ||
| level: core | ||
| type: keyword | ||
| ignore_above: 1024 | ||
| description: Operating system architecture. | ||
| example: x86_64 | ||
| - name: domain | ||
| level: extended | ||
| type: keyword | ||
| ignore_above: 1024 | ||
| description: 'Name of the domain of which the host is a member. | ||
|
|
||
| For example, on Windows this could be the host''s Active Directory domain or NetBIOS domain name. For Linux this could be the domain of the host''s LDAP provider.' | ||
| example: CONTOSO | ||
| default_field: false | ||
| - name: hostname | ||
| level: core | ||
| type: keyword | ||
| ignore_above: 1024 | ||
| description: 'Hostname of the host. | ||
|
|
||
| It normally contains what the `hostname` command returns on the host machine.' | ||
| - name: id | ||
| level: core | ||
| type: keyword | ||
| ignore_above: 1024 | ||
| description: 'Unique host id. | ||
|
|
||
| As hostname is not always unique, use values that are meaningful in your environment. | ||
|
|
||
| Example: The current usage of `beat.name`.' | ||
| - name: ip | ||
| level: core | ||
| type: ip | ||
| description: Host ip addresses. | ||
| - name: mac | ||
| level: core | ||
| type: keyword | ||
| ignore_above: 1024 | ||
| description: Host mac addresses. | ||
| - name: name | ||
| level: core | ||
| type: keyword | ||
| ignore_above: 1024 | ||
| description: 'Name of the host. | ||
|
|
||
| It can contain what `hostname` returns on Unix systems, the fully qualified domain name, or a name specified by the user. The sender decides which value to use.' | ||
| - name: os.family | ||
| level: extended | ||
| type: keyword | ||
| ignore_above: 1024 | ||
| description: OS family (such as redhat, debian, freebsd, windows). | ||
| example: debian | ||
| - name: os.kernel | ||
| level: extended | ||
| type: keyword | ||
| ignore_above: 1024 | ||
| description: Operating system kernel version as a raw string. | ||
| example: 4.4.0-112-generic | ||
| - name: os.name | ||
| level: extended | ||
| type: keyword | ||
| ignore_above: 1024 | ||
| multi_fields: | ||
| - name: text | ||
| type: text | ||
| norms: false | ||
| default_field: false | ||
| description: Operating system name, without the version. | ||
| example: Mac OS X | ||
| - name: os.platform | ||
| level: extended | ||
| type: keyword | ||
| ignore_above: 1024 | ||
| description: Operating system platform (such centos, ubuntu, windows). | ||
| example: darwin | ||
| - name: os.version | ||
| level: extended | ||
| type: keyword | ||
| ignore_above: 1024 | ||
| description: Operating system version as a raw string. | ||
| example: 10.14.1 | ||
| - name: type | ||
| level: core | ||
| type: keyword | ||
| ignore_above: 1024 | ||
| description: 'Type of host. | ||
|
|
||
| For Cloud providers this can be the machine type like `t2.medium`. If vm, this could be the container, for example, or other information meaningful in your environment.' | ||
| - name: containerized | ||
| type: boolean | ||
| description: > | ||
| If the host is a container. | ||
|
|
||
| - name: os.build | ||
| type: keyword | ||
| example: "18D109" | ||
| description: > | ||
| OS build information. | ||
|
|
||
| - name: os.codename | ||
| type: keyword | ||
| example: "stretch" | ||
| description: > | ||
| OS codename, if any. | ||
|
|
||
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
| Original file line number | Diff line number | Diff line change |
|---|---|---|
| @@ -0,0 +1,20 @@ | ||
| - name: data_stream.type | ||
| type: constant_keyword | ||
| description: Data stream type. | ||
| - name: data_stream.dataset | ||
| type: constant_keyword | ||
| description: Data stream dataset. | ||
| - name: data_stream.namespace | ||
| type: constant_keyword | ||
| description: Data stream namespace. | ||
| - name: '@timestamp' | ||
| type: date | ||
| description: Event timestamp. | ||
| - name: event.module | ||
| type: constant_keyword | ||
| description: Event module | ||
| value: gcp | ||
| - name: event.dataset | ||
| type: constant_keyword | ||
| description: Event dataset | ||
| value: gcp.compute |
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
| Original file line number | Diff line number | Diff line change |
|---|---|---|
| @@ -0,0 +1,24 @@ | ||
| - external: ecs | ||
| name: cloud | ||
| - external: ecs | ||
| name: cloud.account.id | ||
| - external: ecs | ||
| name: cloud.account.name | ||
| - external: ecs | ||
| name: cloud.availability_zone | ||
| - external: ecs | ||
| name: cloud.instance.id | ||
| - external: ecs | ||
| name: cloud.machine.type | ||
| - external: ecs | ||
| name: cloud.provider | ||
| - external: ecs | ||
| name: cloud.region | ||
| - external: ecs | ||
| name: ecs.version | ||
| - external: ecs | ||
| name: error | ||
| - external: ecs | ||
| name: error.message | ||
| - external: ecs | ||
| name: service.type |
Oops, something went wrong.
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
Uh oh!
There was an error while loading. Please reload this page.