Integrate E1s to Improve AWS ECS Daily Operations with Security

Posted on Dec 31, 2024

Introduction

In my organization, we maintained a feature that allows developers to access databases via ORM methods. This required duplicating the environment to provide a separate environment for developer access, ensuring security while maintaining an up-to-date deployment with the latest schema for production.

Previously, we had fully migrated the system production traffic from EC2 to ECS, but the database access workflow continued to rely on dedicated EC2 instances due to the incomplete legacy migration. However, this approach introduced several challenges:

  • Managing SSH keys for server access.
  • Limited scalability and significant operational overhead.
  • Complex CI/CD pipelines tied to EC2 instances.
  • High AWS costs due to persistent EC2 usage.
  • Security risks from less granular access control and limited audit capabilities.

To address these issues, I integrated e1s(a CLI tool to manage ECS resources in the terminal) with the ECS Exec, replacing the EC2-based workflow for database access. This transition simplified operations, reduced costs, and enhanced security.

This blog outlines the transformation, comparing the old and new workflows, and highlights the benefits of the integration.

Old vs. New Workflow

Old Workflow: EC2-Based Operations

Old Workflow: Access via Dedicated EC2 Instances

  • Team members used SSH keys to log into specific EC2 servers.
  • Operational tasks were performed manually on these instances.

old-workflow.png

New Workflow: ECS-Based Operations with e1s

  • Team members use onelogin aws assume role cli(OneLogin is our company-wide identity provider) to get temporary AWS credentials.
  • ECS Exec access enabled on operation container while keeps production containers exec disabled for security reasons.
  • Team members use e1s with their specific AWS credentials to easily run ECS Exec to operate containers with full audit logs.

new-workflow.png

Benefits Overview

Reduced Complexity

  • Eliminates the need for SSH keys and dedicated EC2 servers, reducing manual operations related to key management.
  • Simplifies CI workflows by removing EC2 deployment requirements.

Enhanced Security

  • No longer requires managing SSH keys, eliminating risks from forgotten or misplaced keys.
  • Isolates production secrets to specific ECS containers.
  • Enforces Role-Based Access Control (RBAC) through OneLogin-granted IAM roles.
  • Logs ECS Exec output to S3 for improved auditing and traceability.

Cost Efficiency

  • Significantly reduces AWS expenses by removing persistent EC2 instances.
  • Lowers CI costs by eliminating EC2-specific deployment pipelines.

Conclusion

Managing infrastructure security and operational efficiency is crucial for modern tech teams. Migrating to e1s has transformed our operations, offering a leaner, more secure, and cost-efficient workflow. I hope e1s becomes a part of your toolkit, simplifying your operations just as it has for us!