- Elastic Common Schema (ECS) Reference: other versions:
- Overview
- Using ECS
- ECS Field Reference
- Base Fields
- Agent Fields
- Autonomous System Fields
- Client Fields
- Cloud Fields
- Code Signature Fields
- Container Fields
- Data Stream Fields
- Destination Fields
- Device Fields
- DLL Fields
- DNS Fields
- ECS Fields
- ELF Header Fields
- Email Fields
- Error Fields
- Event Fields
- FaaS Fields
- File Fields
- Geo Fields
- Group Fields
- Hash Fields
- Host Fields
- HTTP Fields
- Interface Fields
- Log Fields
- Mach-O Header Fields
- Network Fields
- Observer Fields
- Orchestrator Fields
- Organization Fields
- Operating System Fields
- Package Fields
- PE Header Fields
- Process Fields
- Registry Fields
- Related Fields
- Risk information Fields
- Rule Fields
- Server Fields
- Service Fields
- Source Fields
- Threat Fields
- TLS Fields
- Tracing Fields
- URL Fields
- User Fields
- User agent Fields
- VLAN Fields
- Volume Fields
- Vulnerability Fields
- x509 Certificate Fields
- ECS Categorization Fields
- Migrating to ECS
- Additional Information
- Release Notes
Cloud Fields Usage and Examples
editCloud Fields Usage and Examples
editHere are the subjects covered in this page.
Field reuse
editThe cloud fields can be used to * describe the cloud resource an event comes from * or to describe the context of an external cloud resource that has a direct invocation relationship to the observed service or resource
Cloud fields at the Root of an Event
editUse the cloud fields at the root of an event to describe the cloud resource the event primarily relates to. An example for this use case is a log entry being recorded for a service that is deployed in a cloud environment:
{ "cloud": { "provider": "aws", "region": "us-east-1", "service": { "name": "ec2" } } }
Describing external cloud resources in an invocation relationship
editManaged cloud services can be in an invocation relationship to the observed service (i.e. service for which the corresponding event is captured).
For instance, an observed service running on AWS Lambda can be invoked through an AWS API Gateway.
Another example is an observed service that invokes an external cloud service (e.g. AWS Simple Email Service).
In the context of an invocation relationship, cloud fields can be nested under cloud.origin.*
and cloud.target.*
, respectively,
to capture the cloud context on origin or target cloud services from the perspective of an observed service.
This concept is similar to nesting of service fields under service.origin.*
and service.target.*
.
Let’s consider an exemplary event that represents an inbound AWS Lambda invocation coming from an AWS API Gateway. Use the following cloud.origin.*
nesting to describe the API Gateway service from the perspective of the AWS Lambda service:
{ "service": { "name": "MyLambdaFunction", "version": "1.0.0", "origin": { "name": "MyGateway", "version" "2.0", } }, "cloud": { "provider": "aws", "region": "us-east-1", "service": { "name": "lambda" }, "origin": { "provider": "aws", "region": "eu-west-1", "service": { "name": "apigateway" } } } }
Describes the observed AWS Lambda function |
|
Describes the API Gateway service where the inbound request comes from |
|
Describes the cloud context of the observed AWS Lambda function |
|
Describes the cloud context of the API Gateway service where the inbound request comes from |
Note that cloud.origin.*
and cloud.target.*
fields should only be used on events that represent an invocation relationship.
On this page