Amazon Simple Storage Service (Amazon S3) discovery with Patterns
Summarize
Summary of Amazon Simple Storage Service (Amazon S3) discovery with Patterns
The ServiceNow Discovery application uses the Amazon AWS S3 pattern to identify both public and private Amazon S3 storage buckets through REST API calls. This pattern supports discovery on ServiceNow platform versions Jakarta Patch 10, Kingston Patch 8, and London Patch 1. It can also discover buckets in the AWS GovCloud (US) region, although discovery of outgoing connections from these buckets to other AWS resources is planned for future releases.
Show less
The discovery can be triggered by a scheduled discovery process or by AWS Config events that notify ServiceNow of resource configuration changes.
Prerequisites and Configuration
- Set up an AWS IAM user with appropriate policy permissions, specifically AmazonS3ReadOnlyAccess.
- Configure AWS service account credentials (access key and secret key) in ServiceNow.
- Discover logical datacenters hosting S3 buckets using Cloud Provisioning and Governance documentation guidance.
- Create discovery schedules for AWS service accounts.
- Enable alert-based discovery by configuring AWS event processing.
- Download and install the latest Discovery and Service Mapping Patterns from the ServiceNow Store.
- Ensure the MID Server meets system requirements for discovery operations.
- Verify REST API permissions using the Cloud Discovery patterns spreadsheet to grant necessary user permissions for pattern execution.
Data Collected During Discovery
Discovery collects key information for each S3 bucket, including:
- Bucket name and creation date
- Cloud provider and Amazon Resource Name (ARN)
- Service name (defaulted to S3)
- Bucket owner account ID
- Encryption type (None, AES-256, AWS-KMS)
- Access control types for ACL and policy (Public or Not Public)
- Replication destination bucket ARN if applicable
This data is stored in the Cloud Object Storage [cmdbcicloudobjectstorage] table within your CMDB.
CI Relationships and Service Mapping
Discovery establishes relationships such as:
- Replicates to::Replicated By between S3 bucket CIs
- Hosted on::Hosts between S3 buckets and logical datacenters
Service Mapping enhances discovery by identifying outgoing connections from S3 buckets to other AWS services like Lambda functions, visualized in application service maps.
Troubleshooting
- Discovery REST timeout errors: Increase the
mid.sa.cloud.requesttimeoutparameter on the MID Server if REST calls exceed the default 30,000 ms timeout. - Pattern Designer debug timeout errors: Increase the
sa.debugger.maxtimeoutparameter if pattern debugging times out (default is 240 seconds).
Adjusting these parameters helps ensure discovery and pattern debugging complete successfully in environments with many CIs or slower response times.
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 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] | Account ID in which the bucket exists. |
| 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. |