検索
ホームページバックエンド開発Golangファイル転送用の Golang を使用した AWS Transfer Family

現代のテクノロジーの世界では、多くの組織にとって安全かつ効率的なファイル転送が不可欠です。アマゾン ウェブ サービスが提供するマネージド型の安全なファイル転送ソリューションである AWS Transfer Family では、SFTP、FTPS、FTP、AS2 などの標準プロトコルを使用したファイル転送が可能です。効率性と使いやすさで知られるプログラミング言語 Golang と組み合わせると、ファイル転送を効果的に管理および自動化するための強力な組み合わせが作成されます。

この記事では、AWS Transfer Family を Golang と統合してファイル転送プロセスを最適化する方法について説明します。 AWS Transfer Family の設定から Golang を使用した SFTP クライアントの実装まで、これらのテクノロジーを最大限に活用できるようにステップバイステップでガイドします。

AWS Transfer Family とは何ですか?

AWS Transfer Family は、SFTP、AS2、FTPS、FTP などのプロトコルを使用して、Amazon S3 や Amazon EFS などの AWS ストレージ サービスとの間でファイルを転送できる、安全なフルマネージド サービスです。

主な特長

  • サポートされているプロトコル: SFTP、FTPS、FTP、AS2
  • AWS ストレージの統合: Amazon S3、Amazon EFS
  • ユースケース: データレイク、内部転送、データ分散、コンプライアンスワークフロー、サプライチェーンロジスティクス、B2B トランザクション。

利点

  • リアルタイムのスケーラビリティ。
  • インフラストラクチャ管理は必要ありません。
  • データ処理と分析にネイティブ AWS サービスを活用します。
  • フルマネージドのサーバーレス ワークフロー サービス。
  • 従量課金制の料金設定。

前提条件

  • AWS アカウント: アクティブなアマゾン ウェブ サービス アカウント。まだお持ちでない場合は、AWS ウェブサイトでサインアップできます。
  • Golang: Go (Golang) プログラミング言語に関する知識。
  • AWS の管理者権限。
  • AWS Transfer Family: AWS Transfer Family を設定および管理するための管理読み取りおよび書き込み権限。これには、転送サーバーを作成および管理する機能が含まれます。このサービスには関連費用がかかることに注意してください。
  • Amazon S3: Amazon S3 バケットの読み取りおよび書き込みを行う管理権限。
  • AWS IAM: 転送の統合とセキュリティに必要な IAM ロールとポリシーを管理する権限。

建築設計

AWS Transfer Family を Golang と統合するために提案されたアーキテクチャ設計は、以下の図に示すように、次のコンポーネントで構成されます。

AWS Transfer Family with Golang for File Transfers

この記事で提案されている API は、その基本的な機能を示す基本的な例として機能します。実際のシナリオでは、API はより複雑になり、追加機能が含まれる場合があります。その主な機能は、バックアップ目的であっても、他のシステムとの統合であっても、ファイルを AWS Transfer Family SFTP サーバーにアップロードし、S3 バケットに保存することです。ユースケースはさまざまで、各組織のニーズによって異なります。追加の使用例は次のとおりです: AWS Transfer Family の顧客

さらに、この記事で提案されている API は、AWS Elastic Beanstalk や AWS Fargate などのサービスを使用して AWS クラウドにデプロイされ、各組織の特定の要件に応じて、より優れたスケーラビリティと可用性を実現できます。

始めましょう!

実装

公開鍵と秘密鍵を生成する

AWS Transfer Family SFTP サーバーに接続するための公開キーと秘密キーのペアを生成します。これは、次のコマンドを使用してマシン上でローカルに実行できます。

$ ssh-keygen -t rsa -b 4096 -f /aws_example_ssh_key

  • aws_example_ssh_key: キー名
  • PATH: キーが保存されるディレクトリ
  • rsa: 暗号化アルゴリズム
  • 4096: キーサイズ
  • f: 出力ファイル名
ssh-keygen -t rsa -b 4096 -f <path>/aws_example_ssh_key
Generating public/private rsa key pair.
Enter passphrase (empty for no passphrase):
Enter same passphrase again:
Your identification has been saved in <path>/aws_example_ssh_key
Your public key has been saved in <path>/aws_example_ssh_key.pub
The key fingerprint is:
SHA256:P80TXbp10tjdzJLc3KAhtWP9YWQe+A181WvqUQyaTFc rodrigoquispe@0WJMD6M
The key's randomart image is:
+---[RSA 4096]----+
|            ..oE+|
|           o ** +|
|          + O **+|
|           * *.^*|
|        S   o % #|
|         . o + =.|
|          o = o  |
|           . o   |
|                 |
+----[SHA256]-----+
</path></path></path>
  • パスフレーズを入力してください (パスフレーズがない場合は空白): キーのパスワード。
  • 同じパスフレーズを再度入力します: キーのパスワードを確認します。
  • あなたの ID は /aws_example_ssh_key に保存されました: 秘密キーは、指定されたパスの aws_example_ssh_key ファイルに保存されます。
  • 公開キーは /aws_example_ssh_key.pub に保存されました: 公開キーは、指定されたパスの aws_example_ssh_key.pub ファイルに保存されます。

AWS Transfer Family with Golang for File Transfers

Transfer Family サービスの作成

AWS マネジメントコンソールにログインし、AWS Transfer Family サービスを選択してサーバーを作成します。

AWS Transfer Family with Golang for File Transfers

安全なファイル転送のために SFTP (SSH ファイル転送プロトコル) を選択し、[次へ] をクリックします。

AWS Transfer Family with Golang for File Transfers

ID プロバイダーを選択し、[管理対象サービス] を選択します。

AWS Transfer Family with Golang for File Transfers

エンドポイント構成で、「パブリックにアクセス可能」を選択し、「次へ」をクリックします。

AWS Transfer Family with Golang for File Transfers

ストレージ オプションとして「Amazon S3」を選択し、[次へ] をクリックします。

AWS Transfer Family with Golang for File Transfers

「追加の詳細の構成」セクションでは、設定をデフォルト値のままにします。

AWS Transfer Family with Golang for File Transfers
AWS Transfer Family with Golang for File Transfers

AWS Transfer Family with Golang for File Transfers

AWS Transfer Family with Golang for File Transfers

内容を確認し、「次へ」をクリックして作成します。
作成が完了すると、次のようなものが得られます。まだユーザーがいないことがわかり、パブリック エンドポイントを介して S3 をストレージとして使用して間もなく開始されることがわかります。

AWS Transfer Family with Golang for File Transfers

ロールを作成する

AWS 転送ファミリーから s3 サービス用の新しいロールを作成します。これを行うには、IAM サービスに移動し、AWS サービス タイプの新しいロールを作成し、ユースケースで [転送して次へ] を選択します。

AWS Transfer Family with Golang for File Transfers

S3 バケットへのフルアクセスを許可するアクセス許可ポリシー、AmazonS3FullAccess。ただし、このポリシーは非常に許容されるものであり、運用環境での使用はお勧めできません。そして次です。

AWS Transfer Family with Golang for File Transfers

ロールの名前「role-example-transfer-to-s3」の割り当てに進み、確認して「ロールの作成」をクリックします。

AWS Transfer Family with Golang for File Transfers

S3バケットの作成

s3 バケットの作成に進みます。これを行うには、s3 サービスに移動して新しいバケットを作成します。

AWS Transfer Family with Golang for File Transfers

デフォルト設定のままでバケットの名前を設定し、バケットを作成します。

バケット名: "bucket-example-transfer"。

AWS Transfer Family with Golang for File Transfers

AWS Transfer Family with Golang for File Transfers

作成の最後には次のようなものになります:

AWS Transfer Family with Golang for File Transfers

S3 を使用した Transfer Family の SFTP ユーザーの構成

AWS Transfer Family サービスに移動し、前に作成したサーバーを選択します。

  • 「ユーザー」タブを選択し、「ユーザーを追加」をクリックします。
  • ユーザー名を入力してください。
  • 前に作成した IAM ロールを割り当てます。
  • 「ポリシー」をなしに設定します
  • 「ホーム ディレクトリ」フィールドに、bucket-example-transfer と入力します。これは、前に作成した S3 バケットの名前です。
  • 「ユーザーを追加」をクリックします。

AWS Transfer Family with Golang for File Transfers

この記事に従うには、aws_example_ssh_key.pub の開始時に生成された公開キーを提供する必要があります。

公開キーの内容を表示するには、次のコマンドを使用します:

$ cat aws_example_ssh_key.pub

公開鍵は次のようになります:

ssh-keygen -t rsa -b 4096 -f <path>/aws_example_ssh_key
Generating public/private rsa key pair.
Enter passphrase (empty for no passphrase):
Enter same passphrase again:
Your identification has been saved in <path>/aws_example_ssh_key
Your public key has been saved in <path>/aws_example_ssh_key.pub
The key fingerprint is:
SHA256:P80TXbp10tjdzJLc3KAhtWP9YWQe+A181WvqUQyaTFc rodrigoquispe@0WJMD6M
The key's randomart image is:
+---[RSA 4096]----+
|            ..oE+|
|           o ** +|
|          + O **+|
|           * *.^*|
|        S   o % #|
|         . o + =.|
|          o = o  |
|           . o   |
|                 |
+----[SHA256]-----+
</path></path></path>

これは、「SSH 公開キー」フィールドに含める必要があるキーです。サーバーへの安全なアクセスを可能にするために、キー全体をコピーしてこのフィールドに正確に貼り付けてください。

AWS Transfer Family with Golang for File Transfers

ユーザーを作成すると、以下のような確認画面が表示されます。これは、ユーザーが正常にセットアップされ、SFTP サービスを使用する準備ができていることを示します。

AWS Transfer Family with Golang for File Transfers

プロジェクトの構造

以下では、Golang プロジェクト構造の詳細な概要を示し、参照用に GitHub リポジトリへのリンクを示します。この概要は、プロジェクトの構成と、さまざまなコンポーネントがどのように構造化され相互接続されているかを理解するのに役立ちます。

ssh-rsa AAAAB3NzaC1yc2EBBAADAQABAAACAQC/qNMJaCz8+I3G71bTFf8Cpe+AAAA0BBBBBBBA6C+/a8fyl9Dw4wjj0huc4ItlX2auKG3skxTYP1ZgO5/7M7xmp2Hf+AAAA0BBBBBBBA6CynWwfwkS5XEIfNtoNWCSeB6ra4anljFdLJH4ZReOM18xxBZCyz2gGA7ePprM0nfpgoQKjp8eDoz6HFcvH4Qynea06W72D+tUWjCRH6bgPBsw/cCfj+VrcqsQXif/X8nViS679+V+AAAA0BBBBBBBA6C+t/5dD3uFPyc8yJn2fNEHB4kfIB9JR5fPIo4dVqPebloPg9vKT2M+AAAA0BBBBBBBA6C/AAAA0BBBBBBBA6C+XLTJSAljgq9JQ4l3vnT4RSsKuK+DX2um5DsN/Zwk9Qwf8JRJey/AAAA0BBBBBBBA6C+/AAAA0BBBBBBBA6CNkVaeDOYSIeGkMBUmmMaeVNeaR967SBLoHNzBfodKKaIpsmW2yHvIitg/YKu2YXKe/DnYU3G8om13uL8qIOB85CugVQ== rodrigoquispe@AAAA0BBBBBBBA6C

使用する依存関係は、Gin と SFTP です。

├── cmd
│   └── main.go
├── go.mod
├── go.sum
└── internal
    ├── app
    │   └── service.go
    ├── domain
    │   └── models.go
    ├── handler
    │   └── sftp_handler.go
    └── infra
        ├── config.go
        └── sftp_client.go

SFTP サーバーに接続するには、秘密キーと Transfer Family ユーザーの資格情報が配置されている config.go ファイルに次の資格情報を設定します。

$ go get -u github.com/gin-gonic/gin
$ go get -u github.com/pkg/sftp
  • ホスト: 前に取得した接続エンドポイント。
  • ポート: 22
  • ユーザー: 前に作成したユーザー名。
  • PrivateKeyPath: 前に作成した秘密キーへのパス。

SFTP サーバーにアップロードされたファイルが保存されるパスの設定も検討してください。私の場合、/bucket-example-transfer/rodrigo です。

// config.go

func LoadConfig() *Config {
    return &Config{
        Host:           "<host>.server.transfer.us-east-1.amazonaws.com",
    Port:           "<port>",
    User:           "<user>",
    PrivateKeyPath: "<path>/aws_example_ssh_key",
    }
}
</path></user></port></host>

指定された構成で新しい SFTP クライアントを作成する関数:

// service.go

func (u *Service) Upload(file *domain.File) error {
    return u.sftpClient.UploadFile(file, "/bucket-example-transfer/rodrigo/")
}

SFTP サーバーにファイルをアップロードするメソッド。

ssh-keygen -t rsa -b 4096 -f <path>/aws_example_ssh_key
Generating public/private rsa key pair.
Enter passphrase (empty for no passphrase):
Enter same passphrase again:
Your identification has been saved in <path>/aws_example_ssh_key
Your public key has been saved in <path>/aws_example_ssh_key.pub
The key fingerprint is:
SHA256:P80TXbp10tjdzJLc3KAhtWP9YWQe+A181WvqUQyaTFc rodrigoquispe@0WJMD6M
The key's randomart image is:
+---[RSA 4096]----+
|            ..oE+|
|           o ** +|
|          + O **+|
|           * *.^*|
|        S   o % #|
|         . o + =.|
|          o = o  |
|           . o   |
|                 |
+----[SHA256]-----+
</path></path></path>

次のコマンドを使用してプロジェクトを実行します:

$ go run cmd/main.go

AWS Transfer Family with Golang for File Transfers

次に、Postman を使用してファイルを SFTP サーバーにアップロードします。次に、S3 に移動して、ファイルが正しくアップロードされたことを確認します。

AWS Transfer Family with Golang for File Transfers

AWS Transfer Family with Golang for File Transfers

ファイルは問題なくアップロードされました。

お読みいただきありがとうございます。

以上がファイル転送用の Golang を使用した AWS Transfer Familyの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
DebianでLibofficeのセキュリティ設定を行う方法DebianでLibofficeのセキュリティ設定を行う方法May 16, 2025 pm 01:24 PM

Debianシステムの全体的なセキュリティを確保することは、Libofficeなどのアプリケーションの実行環境を保護するために重要です。システムセキュリティを改善するための一般的な推奨事項を次に示します。システムの更新は、システムを定期的に更新して、既知のセキュリティの脆弱性をパッチします。 Debian12.10は、いくつかの重要なソフトウェアパッケージを含む多数のセキュリティの脆弱性を修正するセキュリティアップデートをリリースしました。ユーザー許可管理は、潜在的なセキュリティリスクを減らすために、日常業務にルートユーザーを使用することを回避します。通常のユーザーを作成し、SUDOグループに参加して、システムへの直接アクセスを制限することをお勧めします。 SSHサービスセキュリティ構成は、SSHキーペアを使用して、ルートリモートログインを認証、無効にし、空のパスワードでログインを制限します。これらの措置は、SSHサービスのセキュリティを強化し、

DebianでRustコンピレーションオプションを構成する方法DebianでRustコンピレーションオプションを構成する方法May 16, 2025 pm 01:21 PM

Debianシステムでの錆コンピレーションオプションの調整は、さまざまな方法で実現できます。以下は、いくつかの方法の詳細な説明です:Rustupツールを使用してRustupを構成およびインストールします。Rustupをまだインストールしていない場合は、次のコマンドを使用してインストールできます。設定コンピレーションオプション:Rustupを使用して、さまざまなツールチェーンとターゲットのコンパイルオプションを構成できます。 RustupoverRideコマンドを使用して、特定のプロジェクトのコンピレーションオプションを設定できます。たとえば、プロジェクトに特定の錆バージョンを設定する場合

DebianでKubernetesノードを管理する方法DebianでKubernetesノードを管理する方法May 16, 2025 pm 01:18 PM

Kubernetes(k8s)ノードの管理Debianシステムのノードの管理には、通常、次の重要な手順が含まれます。1。Kubernetesコンポーネントコンポーネントの設定準備:すべてのノード(マスターノードとワーカーノードを含む)がインストールされ、Kubernetes Clusterをインストールするための基本的な要件を満たしていることを確認してください。スワップパーティションの無効化:Kubeletがスムーズに実行できるようにするには、Swap Partitionを無効にすることをお勧めします。ファイアウォールルールの設定:Kubelet、Kube-Apiserver、Kube-Schedulerなどが使用するポートなど、必要なポートを許可します。

DebianのGolangのセキュリティ設定DebianのGolangのセキュリティ設定May 16, 2025 pm 01:15 PM

DebianにGolang環境を設定する場合、システムセキュリティを確保することが重要です。安全なGolang開発環境を構築するのに役立つ重要なセキュリティセットアップの手順と提案を次に示します。セキュリティセットアップステップシステムの更新:Golangをインストールする前にシステムが最新であることを確認してください。次のコマンドを使用して、システムパッケージリストとインストールパッケージを更新します。sudoaptupdatesudoaptupgrade-yファイアウォール構成:システムへのアクセスを制限するためにファイアウォール(iptablesなど)をインストールして構成します。必要なポート(HTTP、HTTPS、SSHなど)のみが許可されます。 sudoaptininstalliptablessud

Kubernetesの展開のパフォーマンスをDebianで最適化する方法Kubernetesの展開のパフォーマンスをDebianで最適化する方法May 16, 2025 pm 01:12 PM

DebianでKubernetesクラスターのパフォーマンスを最適化および展開することは、複数の側面を含む複雑なタスクです。主要な最適化戦略と提案を次に示します。ハードウェアリソース最適化CPU:十分なCPUリソースがKubernetesノードとポッドに割り当てられていることを確認してください。メモリ:特にメモリ集約型アプリケーションのノードのメモリ容量を増加させます。ストレージ:高性能SSDストレージを使用し、レイテンシを導入する可能性のあるネットワークファイルシステム(NFSなど)の使用を避けます。カーネルパラメーター最適化編集 /etc/sysctl.confファイル、次のパラメーターを追加または変更します:net.core.somaxconn:65535net.ipv4.tcp_max_syn

PythonスクリプトによるDebianでタスクをスケジュールする方法PythonスクリプトによるDebianでタスクをスケジュールする方法May 16, 2025 pm 01:09 PM

Debianシステムでは、Cronを使用して時限タスクを手配し、Pythonスクリプトの自動実行を実現できます。まず、端子を開始します。次のコマンドを入力して、現在のユーザーのCrontabファイルを編集します。Crontab-Eルートアクセス許可を持つ他のユーザーのCrontabファイルを編集する必要がある場合は、編集するユーザー名にユーザー名を置き換えるために、sudocrontab-uusername-eを使用してください。 crontabファイルでは、次のように形式のタイミングされたタスクを追加できます:*****/path/to/your/python-script.pyこれら5つのアスタリスクは議事録(0-59)以降を表します

DebianでGolangネットワークパラメーターを構成する方法DebianでGolangネットワークパラメーターを構成する方法May 16, 2025 pm 01:06 PM

DebianシステムでGolangのネットワークパラメーターを調整することは、さまざまな方法で実現できます。以下はいくつかの実行可能な方法です。方法1:環境変数を設定することにより、環境変数を一時的に設定します。端末に次のコマンドを入力して、環境変数を一時的に設定します。この設定は、現在のセッションでのみ有効です。 ExportGodeBug = "GCTRACE = 1NETDNS = GO" GCTRACE = 1はガベージコレクション追跡をアクティブにし、NetDNS = GOはシステムのデフォルトではなく独自のDNSリゾルバーを使用します。環境変数を永続的に設定します:〜/.bashrcや〜/.profileなどのシェル構成ファイルに上記のコマンドを追加します

DebianのLibofficeのショートカットキーは何ですかDebianのLibofficeのショートカットキーは何ですかMay 16, 2025 pm 01:03 PM

DebianシステムでLibofficeをカスタマイズするためのショートカットキーは、システム設定を通じて調整できます。 Libofficeショートカットキーを設定するための一般的に使用される手順と方法を次に示します。Libofficeショートカットキーを設定するための基本的な手順オープンシステム設定:Debianシステムで、左上隅のメニュー(通常ギアアイコン)をクリックし、「システム設定」を選択します。 [デバイス]を選択します。[システム設定]ウィンドウで、[デバイス]を選択します。キーボードを選択します。デバイス設定ページで、キーボードを選択します。対応するツールへのコマンドを見つけます。キーボード設定ページで、下にスクロールして「ショートカットキー」オプションを表示します。クリックすると、ポップアップにウィンドウが表示されます。ポップアップウィンドウで対応するLibofficeワーカーを見つけます

See all articles

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

SublimeText3 Linux 新バージョン

SublimeText3 Linux 新バージョン

SublimeText3 Linux 最新バージョン

SublimeText3 英語版

SublimeText3 英語版

推奨: Win バージョン、コードプロンプトをサポート!

VSCode Windows 64 ビットのダウンロード

VSCode Windows 64 ビットのダウンロード

Microsoft によって発売された無料で強力な IDE エディター

MantisBT

MantisBT

Mantis は、製品の欠陥追跡を支援するために設計された、導入が簡単な Web ベースの欠陥追跡ツールです。 PHP、MySQL、Web サーバーが必要です。デモおよびホスティング サービスをチェックしてください。

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

強力な PHP 統合開発環境