{"id":31922033,"url":"https://github.com/dev-shimada/phantom-ecs","last_synced_at":"2025-10-13T22:56:31.000Z","repository":{"id":299728266,"uuid":"1003708518","full_name":"dev-shimada/phantom-ecs","owner":"dev-shimada","description":null,"archived":false,"fork":false,"pushed_at":"2025-06-18T01:29:54.000Z","size":78,"stargazers_count":0,"open_issues_count":0,"forks_count":0,"subscribers_count":0,"default_branch":"main","last_synced_at":"2025-06-18T02:30:48.880Z","etag":null,"topics":[],"latest_commit_sha":null,"homepage":null,"language":"Go","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":"mit","status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/dev-shimada.png","metadata":{"files":{"readme":"README.md","changelog":null,"contributing":null,"funding":null,"license":"LICENSE","code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null,"governance":null,"roadmap":null,"authors":null,"dei":null,"publiccode":null,"codemeta":null,"zenodo":null}},"created_at":"2025-06-17T14:46:45.000Z","updated_at":"2025-06-18T01:29:57.000Z","dependencies_parsed_at":"2025-06-18T02:31:02.877Z","dependency_job_id":"5a7a9b8f-f34d-41bd-b133-b94804ba4b2e","html_url":"https://github.com/dev-shimada/phantom-ecs","commit_stats":null,"previous_names":["dev-shimada/phantom-ecs"],"tags_count":0,"template":false,"template_full_name":null,"purl":"pkg:github/dev-shimada/phantom-ecs","repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/dev-shimada%2Fphantom-ecs","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/dev-shimada%2Fphantom-ecs/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/dev-shimada%2Fphantom-ecs/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/dev-shimada%2Fphantom-ecs/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/dev-shimada","download_url":"https://codeload.github.com/dev-shimada/phantom-ecs/tar.gz/refs/heads/main","sbom_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/dev-shimada%2Fphantom-ecs/sbom","scorecard":null,"host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":279017081,"owners_count":26085984,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2022-07-04T15:15:14.044Z","status":"online","status_checked_at":"2025-10-13T02:00:06.723Z","response_time":61,"last_error":null,"robots_txt_status":"success","robots_txt_updated_at":"2025-07-24T06:49:26.215Z","robots_txt_url":"https://github.com/robots.txt","online":true,"can_crawl_api":true,"host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":[],"created_at":"2025-10-13T22:56:10.712Z","updated_at":"2025-10-13T22:56:30.992Z","avatar_url":"https://github.com/dev-shimada.png","language":"Go","funding_links":[],"categories":[],"sub_categories":[],"readme":"100% AI に書いてもらいました\n\n# phantom-ecs\n\nAWS ECS サービス調査CLIツール\n\n[![Go Version](https://img.shields.io/badge/Go-1.24.3-blue.svg)](https://golang.org)\n[![License](https://img.shields.io/badge/License-MIT-green.svg)](LICENSE)\n\n## 📖 概要\n\nphantom-ecs は AWS ECS サービスの調査、分析、デプロイを効率的に行うためのCLIツールです。テスト駆動開発（TDD）によって開発され、本番環境での使用を想定した堅牢性を持っています。\n\n### 主な機能\n\n- **🔍 スキャン**: AWS上のECSサービス一覧表示\n- **🔎 調査**: 特定ECSサービスの詳細情報取得\n- **🚀 デプロイ**: 既存サービスを基にした新しいサービスの作成\n- **⚡ バッチ処理**: 複数サービスの同時処理\n- **📊 ログ**: 構造化ログとファイルローテーション\n- **⚙️ 設定管理**: YAML設定ファイルと環境変数サポート\n- **🔄 リトライ**: 自動リトライとレート制限対応\n\n## 🚀 インストール\n\n### バイナリのダウンロード\n\n最新のリリースから実行可能ファイルをダウンロード:\n\n```bash\n# Linux/macOS\ncurl -L https://github.com/dev-shimada/phantom-ecs/releases/latest/download/phantom-ecs-$(uname -s)-$(uname -m) -o phantom-ecs\nchmod +x phantom-ecs\nsudo mv phantom-ecs /usr/local/bin/\n```\n\n### ソースからビルド\n\n```bash\ngit clone https://github.com/dev-shimada/phantom-ecs.git\ncd phantom-ecs\nmake build\n```\n\n### Go installでインストール\n\n```bash\ngo install github.com/dev-shimada/phantom-ecs@latest\n```\n\n## 📋 使用方法\n\n### 基本的なコマンド\n\n#### サービス一覧の表示\n\n```bash\n# 基本的なスキャン\nphantom-ecs scan\n\n# 特定リージョンでのスキャン\nphantom-ecs scan --region ap-northeast-1\n\n# JSON形式での出力\nphantom-ecs scan --output json\n\n# 特定プロファイルの使用\nphantom-ecs scan --profile production\n```\n\n#### サービスの詳細調査\n\n```bash\n# サービスの詳細情報を表示\nphantom-ecs inspect my-service\n\n# YAML形式での出力\nphantom-ecs inspect my-service --output yaml\n\n# 特定クラスターのサービス調査\nphantom-ecs inspect my-service --cluster my-cluster\n```\n\n#### サービスのデプロイ\n\n```bash\n# 既存サービスのコピーを作成\nphantom-ecs deploy my-service --target-cluster new-cluster\n\n# Dry runモード（実行せず確認のみ）\nphantom-ecs deploy my-service --target-cluster new-cluster --dry-run\n```\n\n#### バッチ処理\n\n```bash\n# 複数サービスの同時処理\nphantom-ecs batch --services service1,service2,service3\n\n# 設定ファイルを使用したバッチ処理\nphantom-ecs batch --config-file batch-config.yaml\n\n# 同時実行数とリトライ設定\nphantom-ecs batch --services service1,service2 --concurrency 5 --retry-count 3\n```\n\n### 設定ファイル\n\n#### YAML設定ファイルの例\n\n```yaml\n# ~/.phantom-ecs.yaml\nprofiles:\n  default:\n    region: us-east-1\n    output_format: table\n    \n  production:\n    region: ap-northeast-1\n    output_format: json\n    aws_profile: prod-profile\n    \n  development:\n    region: us-west-2\n    output_format: yaml\n\nlogging:\n  level: info\n  format: json\n  filename: /var/log/phantom-ecs.log\n  max_size: 100    # MB\n  max_age: 30      # 日\n  max_backups: 10  # ファイル数\n\nbatch:\n  max_concurrency: 5\n  retry_attempts: 3\n  retry_delay: 2s\n  show_progress: true\n```\n\n#### 環境変数\n\n```bash\n# AWS設定\nexport AWS_REGION=ap-northeast-1\nexport AWS_PROFILE=production\n\n# phantom-ecs設定\nexport PHANTOM_ECS_REGION=ap-northeast-1\nexport PHANTOM_ECS_OUTPUT_FORMAT=json\nexport PHANTOM_ECS_LOG_LEVEL=debug\nexport PHANTOM_ECS_BATCH_MAX_CONCURRENCY=10\n```\n\n### コマンドオプション\n\n#### グローバルオプション\n\n- `--region, -r`: AWSリージョン（デフォルト: us-east-1）\n- `--profile, -p`: AWSプロファイル\n- `--output, -o`: 出力形式（json|yaml|table）\n- `--config`: 設定ファイルパス\n\n#### scanコマンド\n\n```bash\nphantom-ecs scan [flags]\n\nFlags:\n  --region string     AWSリージョン (default \"us-east-1\")\n  --profile string    AWSプロファイル\n  --output string     出力形式 (json|yaml|table) (default \"table\")\n```\n\n#### inspectコマンド\n\n```bash\nphantom-ecs inspect \u003cservice-name\u003e [flags]\n\nFlags:\n  --cluster string    クラスター名\n  --region string     AWSリージョン (default \"us-east-1\")\n  --profile string    AWSプロファイル\n  --output string     出力形式 (json|yaml|table) (default \"table\")\n```\n\n#### deployコマンド\n\n```bash\nphantom-ecs deploy \u003cservice-name\u003e [flags]\n\nFlags:\n  --target-cluster string  作成先クラスター名\n  --region string          AWSリージョン (default \"us-east-1\")\n  --profile string         AWSプロファイル\n  --dry-run               実行せずに処理内容を表示\n```\n\n#### batchコマンド\n\n```bash\nphantom-ecs batch [flags]\n\nFlags:\n  --services strings       処理対象のサービス名（カンマ区切り）\n  --config-file string     バッチ設定ファイルのパス\n  --batch-profile string   使用するバッチプロファイル (default \"default\")\n  --concurrency int        同時実行数 (default 3)\n  --retry-count int        リトライ回数 (default 3)\n  --retry-delay duration   リトライ間隔 (default 2s)\n  --progress               プログレスバーを表示 (default true)\n  --dry-run               実際には実行せず、処理内容のみ表示\n```\n\n## 🔧 開発\n\n### 前提条件\n\n- Go 1.24.3以上\n- AWS CLI設定済み\n- Docker（テスト用のLocalStack実行時）\n\n### ビルド\n\n```bash\n# 開発用ビルド\nmake build\n\n# リリース用ビルド\nmake build-release\n\n# 全プラットフォーム向けビルド\nmake build-all\n```\n\n### テスト\n\n```bash\n# 単体テスト\nmake test\n\n# 統合テスト\nmake test-integration\n\n# カバレッジ付きテスト\nmake test-coverage\n\n# 全てのテスト\nmake test-all\n```\n\n### ローカル開発\n\n```bash\n# 依存関係のインストール\ngo mod download\n\n# 開発用実行\ngo run main.go scan --region us-east-1\n\n# テスト実行\ngo test ./...\n\n# ベンチマーク\ngo test -bench=. ./...\n```\n\n## 🧪 テスト\n\nこのプロジェクトはテスト駆動開発（TDD）で開発されています。\n\n### テスト種別\n\n- **単体テスト**: 各パッケージの個別機能テスト\n- **統合テスト**: AWS APIとの実際の連携テスト\n- **エンドツーエンドテスト**: CLIコマンド実行テスト\n\n### テスト実行\n\n```bash\n# 全テスト実行\nmake test-all\n\n# 特定パッケージのテスト\ngo test ./internal/scanner/\n\n# 詳細出力でテスト\ngo test -v ./...\n\n# カバレッジレポート生成\nmake coverage-html\n```\n\n## 📊 パフォーマンス\n\n### ベンチマーク結果\n\n- **バッチ処理**: 100サービスを10並列で約1秒で処理\n- **同時実行**: 最大20の同時接続をサポート\n- **メモリ使用量**: 通常動作時50MB以下\n\n### 最適化のポイント\n\n- ゴルーチンによる並列処理\n- 適切なレート制限\n- 効率的なメモリ管理\n- コネクションプーリング\n\n## 🛠️ アーキテクチャ\n\n### プロジェクト構造\n\n```\nphantom-ecs/\n├── cmd/                    # CLIコマンド定義\n├── internal/               # 内部パッケージ\n│   ├── aws/               # AWS操作\n│   ├── batch/             # バッチ処理\n│   ├── config/            # 設定管理\n│   ├── errors/            # エラーハンドリング\n│   ├── logger/            # ロギング\n│   ├── models/            # データモデル\n│   ├── scanner/           # サービススキャン\n│   ├── inspector/         # サービス調査\n│   ├── deployer/          # サービスデプロイ\n│   └── utils/             # ユーティリティ\n├── pkg/                   # 公開パッケージ\n├── tests/                 # テスト\n├── testdata/              # テストデータ\n└── docs/                  # ドキュメント\n```\n\n### 設計原則\n\n- **Single Responsibility**: 各パッケージは単一の責務を持つ\n- **Dependency Injection**: インターフェースベースの設計\n- **Error Handling**: 適切なエラー分類と処理\n- **Testability**: テスト可能な設計\n\n## 📝 ライセンス\n\nMIT License - 詳細は [LICENSE](LICENSE) ファイルを参照してください。\n\n## 🤝 コントリビューション\n\n1. このリポジトリをフォーク\n2. フィーチャーブランチを作成 (`git checkout -b feature/amazing-feature`)\n3. 変更をコミット (`git commit -m 'Add some amazing feature'`)\n4. ブランチにプッシュ (`git push origin feature/amazing-feature`)\n5. プルリクエストを作成\n\n### 開発ガイドライン\n\n- テストファーストでの開発\n- ゴランの標準コーディング規約に従う\n- 適切なドキュメンテーション\n- パフォーマンスを考慮した実装\n\n## 📞 サポート\n\n- **Issues**: [GitHub Issues](https://github.com/dev-shimada/phantom-ecs/issues)\n- **Discussions**: [GitHub Discussions](https://github.com/dev-shimada/phantom-ecs/discussions)\n- **Documentation**: [Wiki](https://github.com/dev-shimada/phantom-ecs/wiki)\n\n## 🗓️ ロードマップ\n\n- [ ] v1.1.0: Fargate Spot対応\n- [ ] v1.2.0: ECS Execサポート\n- [ ] v1.3.0: CloudFormation統合\n- [ ] v2.0.0: EKS対応\n\n---\n\n**作成者**: dev-shimada  \n**最終更新**: 2025年6月17日\n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fdev-shimada%2Fphantom-ecs","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fdev-shimada%2Fphantom-ecs","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fdev-shimada%2Fphantom-ecs/lists"}