Amazon Simple Storage Service (Amazon S3) discovery
Summarize
Summary of Amazon Simple Storage Service (Amazon S3) discovery
The ServiceNow Discovery application uses the Amazon AWS S3 pattern to identify both public and non-public Amazon S3 storage buckets through REST API calls. This pattern can be triggered by discovery schedules or AWS Config events, which notify ServiceNow of configuration changes in AWS resources. It supports discovery of S3 buckets in AWS GovCloud (US), though outgoing connection discovery for these buckets will be available in future releases. The feature is compatible with ServiceNow Jakarta Patch 10, Kingston Patch 8, or London Patch 1.
Show less
Prerequisites
- Create an appropriate IAM user policy for AWS users managing access.
- Configure AWS credentials using secret and access keys with AmazonS3ReadOnlyAccess permissions.
- Discover logical datacenters hosting S3 buckets by running discovery on an AWS cloud service account.
- Set up a discovery schedule for the AWS service account.
- Enable alert-based discovery by configuring AWS event processing for discovery and service mapping.
- Download the latest Discovery and Service Mapping Patterns from the ServiceNow Store.
- Ensure the MID Server host machine meets system requirements.
- Verify REST API permissions using the Cloud Discovery patterns spreadsheet to grant necessary user rights for discovery.
Data Collected
The discovery process populates the Cloud Object Storage [cmdbcicloudobjectstorage] table with key details about each bucket, including:
- Bucket name and creation date
- Cloud provider and Amazon Resource Name (ARN)
- Service name (defaulted to S3)
- Owner of the bucket
- Encryption type (None, AES-256, AWS-KMS)
- Access control types (Public or Not Public for ACL and policy)
- Replication destination bucket ARN
These details enable visibility into bucket configurations and replication relationships within the Dependency Views map, showing replication chains between buckets.
CI Relationships
- Replicates to::Replicated By relationships between S3 bucket CIs
- Hosted on::Hosts relationships linking S3 buckets to logical datacenters
Service Mapping can additionally discover outgoing connections from S3 buckets to other AWS cloud resources such as Lambda functions, enhancing service maps.
Troubleshooting
Discovery failures due to REST timeouts: Occur when many configuration items respond simultaneously, exceeding the default 30-second timeout (mid.sa.cloud.requesttimeout). Increase this timeout parameter on the MID Server to resolve.
Pattern Designer debug session timeouts: Caused by the default 240-second debugger timeout (sa.debugger.maxtimeout). Adjust this parameter to allow longer debugging periods.
Adjusting these parameters helps ensure smooth discovery and pattern debugging operations.
The ServiceNow Discovery application uses the Amazon AWS S3 pattern to find public and non-public storage buckets of Amazon Simple Storage Service. The pattern uses a set of REST API calls to find these resources. Discovering some of these resources may require updating to the latest version of the Discovery and Service Mapping Patterns application from the ServiceNow Store.
In addition to the discovery schedule, the ServiceNow instance triggers the Amazon AWS S3 pattern when AWS Config sends an event to the ServiceNow instance. Config is a service that continuously monitors AWS resources and sends events to the ServiceNow every time it senses that a resource configuration has changed.
Amazon AWS S3 pattern can also discover AWS S3 buckets located in the AWS GovCloud (US) region. For AWS S3 located in the AWS GovCloud (SU), the pattern cannot discover AWS S3 outgoing connections to other cloud resources like Lambda function. Discovery of outgoing connections for AWS S3 will be supported in future releases.
You can use this pattern on the ServiceNow platform using Jakarta Patch 10, Kingston Patch 8, or London Patch 1.
Request apps on the Store
Visit the ServiceNow Store website to view all the available apps and for information about submitting requests to the store. For cumulative release notes information for all released apps, see the ServiceNow Store version history release notes.
Prerequisites
- If you use Identity and Access Management (IAM) to manage users in Amazon Web Services (AWS) platform, ensure that you created a user policy for the AWS user. For more information, refer to Create an IAM user policy for Cloud Provisioning and Governance in the ServiceNow Cloud Provisioning and Governance documentation.
- Configure the AWS service account.
- Configure AWS credentials, using a secret key and an access key.
- AmazonS3ReadOnlyAccess policy user permissions.
- Discover Logical Datacenters hosting S3 buckets as described in Run Discovery on an AWS cloud service account in the ServiceNow Cloud Provisioning and Governance documentation.
- Create a schedule for the relevant AWS service account as described in Schedule Discovery on a service account in the ServiceNow Cloud Provisioning and Governance documentation.
- To enable alert-based discovery, configure the AWS event service as described in Set up AWS event processing for Discovery and Service Mapping in the ServiceNow Cloud Provisioning and Governance documentation.
- For Cloud Discovery, download the Discovery and Service Mapping Patterns from the ServiceNow Store.
- When installing the MID Server, ensure that the host machine meets or exceeds the MID Server system requirements published on the ServiceNow documentation site.
Verify the REST API Permissions
Download the Cloud Discovery patterns spreadsheet so you can grant user permissions required for running the Discovery patterns. In addition to permissions, the spreadsheet also includes useful information such as pattern names, types, CI Classes, and links to vendor documentation. New patterns are available quarterly, so check periodically to be sure you have the latest version of the spreadsheet.
Data collected by Discovery during horizontal discovery
| Table and field | Description |
|---|---|
| Cloud Object Storage [cmdb_ci_cloud_object_storage] | |
| Bucket name [bucket_name] | The name of the AWS S3 bucket. You can discover all buckets hosted on a Logical Datacenter during one discovery process. |
| Creation date [creation date] | Creation date of the AWS S3 bucket. |
| Cloud provider [cloud_provider] | Amazon AWS |
| Object ID [object_id] | The Amazon Resource Name (ARN), expressed in this format: arn:aws:s3:::<bucket name> |
| Service name [service_name] | Set to S3 by default. |
| Owner [owner] | Name of the AWS S3 bucket owner. |
| Encryption type [encryption_type] | Type of encryption for this bucket. The choices are:
|
| ACL access type [acl_access_type] | The choices for access control types are:
|
| Policy access type [policy_access_type] | The choices for policy access types are:
|
| Replication destination [replication_destination] | Bucket ARN of the Replication Destination bucket. |
CI relationships
| CI | Relationship | CI |
|---|---|---|
| cmdb_ci_cloud_object_storage | Replicates to::Replicated By | cmdb_ci_cloud_object_storage |
| cmdb_ci_cloud_object_storage | Hosted on::Hosts | cmdb_ci_logical_datacenter |
Data discovered by Service Mapping during top-down discovery
Service Mapping can discover AWS S3 outgoing connections to cloud resources, for example Lambda function.
Troubleshooting
| Symptom | Cause | Solution |
|---|---|---|
| Discovery fails. The discovery message contains the information about an error caused by the REST timeout. | There are many CIs sending the REST call response in the deployment. The MID Server cannot process the REST call response without exceeding the time limit controlled by the mid.sa.cloud.request_timeout parameter. | By default, the mid.sa.cloud.request_timeout parameter is set to 30000 milliseconds. Increase the value of this parameter on the relevant MID Server and run discovery again. Note: If the Configuration Parameters related list for the relevant MID Server does not show this parameter, you may need to add it. |
| Pattern Designer fails during a debug session. The Pattern Designer message contains information about an error caused by a timeout. | The Pattern Designer fails because of a timeout during pattern debugging (and not during discovery). | By default, the sa.debugger.max_timeoutparameter is set to 240 seconds. Increase the value of this parameter on the relevant MID Server. |