Linux VM へのファイルの転送


Compute Engine インスタンスにファイルを転送する場合、ワークステーションの OS とターゲット インスタンスの OS に基づいて各種オプションを使用できます。

転送元 転送先が Linux インスタンス
Linux または macOS
Windows

Cloud Storage を経由したファイルの転送

Cloud Storage バケットは、ユーザーと VM の間の簡易に使用できる中間転送ポイントとして機能します。

このファイル転送方式は、サービス アカウントまたは個人のユーザー認証情報を使用して VM から Cloud Storage バケットにアクセスできる限り、ほぼすべての種類のオペレーティング システムと VM で使用できます。

まず、自身のワークステーションから Cloud Storage バケットにファイルをアップロードします。次に、それらのファイルをバケットからインスタンスへダウンロードします。

  1. Cloud Storage バケットを作成するか、ファイル転送に使用する既存のバケットを指定します。
  2. ワークステーションからバケットにファイルをアップロードします。
  3. SSH を使用して VM に接続します。
  4. VM 上で、バケットからファイルをダウンロードします。

逆方向にファイルを転送する必要がある場合は、上記のプロセスを逆方向に実行します。まず、VM からファイルをアップロードし、次にそれらのファイルをワークステーションへダウンロードします。

ブラウザの SSH を使用したファイルの転送

ブラウザからの SSH ウィンドウを使用してインスタンスへの SSH 接続を確立できる場合は、その接続を使用してファイルをインスタンスに転送できます。

  1. Cloud Console で、[VM インスタンス] ページに移動します。

    [VM インスタンス] に移動

  2. 仮想マシン インスタンスのリストで、接続するインスタンスの行にある [SSH] をクリックします。

    インスタンス名の横にある SSH ボタン。

  3. 接続が確立したら、ブラウザからの SSH ウィンドウの右上にある歯車アイコンをクリックして、[ファイルをアップロード] を選択します。また、[ファイルをダウンロード] を選択すれば、インスタンスからファイルをダウンロードできます。
    歯車アイコンのメニュー。
  4. 転送ダイアログが開きます。転送するファイルを指定します。

アップロードされたファイルはユーザーの /home/$USER ディレクトリにあります。

ダウンロードされたファイルは、ローカル ワークステーションのデフォルトのダウンロード フォルダにあります。

gcloud コマンドライン ツールを使用したファイルの転送

gcloud コマンドライン ツールには SCP ファイル転送ユーティリティが備わっています。このユーティリティは初回接続時に SSH 認証鍵ペアを作成します。秘密鍵はローカル デバイスに保存され、対応する公開鍵はプロジェクト メタデータまたはインスタンス メタデータにコピーされます。

SCP を使用してファイルを転送するには、インスタンスが使用するネットワーク上に、ポート 22 での SSH 接続を許可するファイアウォール ルールが必要です。このファイアウォール ルールが存在することを確認するには、Google Cloud Console で tcp:22 接続を許可するファイアウォール ルールを探します。

[ファイアウォール ルール] に移動

ポート 22 で SSH 接続を許可するファイアウォール ルールがない場合は、ファイアウォール ルールを作成します。

gcloud ツールをインストールすると、scp コマンドを使用してインスタンスにファイルやディレクトリをコピーできます。

次の例では、ワークステーションからインスタンスのホーム ディレクトリにファイルをコピーします。

gcloud compute scp local-file-path instance-name:~

以下を置き換えます。

  • local-file-path: ワークステーション上のファイルのパス。
  • instance-name: インスタンスの名前。

ファイルやディレクトリをインスタンスからローカル ワークステーションにコピーすることもできます。次の例では、インスタンス(コピー元)からワークステーション(コピー先)にディレクトリを再帰的にコピーしています。

gcloud compute scp --recurse instance-name:remote-dir local-dir

以下を置き換えます。

  • instance-name: インスタンスの名前。
  • remote-dir: インスタンス上のディレクトリのパス。
  • local-dir: ワークステーション上のディレクトリを配置するパス。

詳細については、gcloud compute scp リファレンス ドキュメントをご覧ください。

Linux ワークステーションまたは macOS ワークステーションの SCP を使用したファイルの転送

scp コマンドライン ツールは、gcloud compute scp と同様に動作しますが、SSH 認証鍵を手動で管理する必要があります。

SCP を使用してファイルを転送するには、インスタンスが使用するネットワーク上に、ポート 22 での SSH 接続を許可するファイアウォール ルールが必要です。このファイアウォール ルールが存在することを確認するには、Google Cloud Console で tcp:22 接続を許可するファイアウォール ルールを探します。

[ファイアウォール ルール] に移動

ポート 22 で SSH 接続を許可するファイアウォール ルールがない場合は、ファイアウォール ルールを作成します。

scp ツールは、標準 SSH を使用してインスタンスに接続するときと同じ鍵ファイルを使用します。

  1. Google Cloud Console プロジェクトまたはインスタンスに公開鍵を適用していない場合は、SSH 認証鍵ペアを取得して公開鍵 SSH 認証鍵ファイルをプロジェクトまたはインスタンスに適用します。

  2. ファイルの転送先となるインスタンスの外部 IP を確認します。Google Cloud Console で、[VM インスタンス] ページに移動します。

    インスタンス ページに移動

  3. scp ツールを使用して、ワークステーションからターゲット インスタンスのホーム ディレクトリにファイルをコピーします。この例では、秘密鍵は ~/.ssh/my-ssh-key にあります。

    scp -i ~/.ssh/my-ssh-key local-file-path username@ip-address:~
    

    以下を置き換えます。

    • local-file-path: アップロードするローカル ファイルの名前。
    • username: ユーザー名。
    • ip-address: インスタンスの IP アドレス。

また、コピー元の変数とコピー先の変数を入れ替えることで、インスタンスからローカル ワークステーションにファイルをコピーすることもできます。この例では、インスタンスからワークステーションのパスにファイルをコピーします。

scp -i ~/.ssh/my-ssh-key username@ip-address:remote-file-path local-file-path

以下を置き換えます。

  • username: ユーザー名。
  • ip-address: インスタンスの IP アドレス。
  • remote-file-path: ダウンロードするリモート ファイルの名前。
  • local-file-path: ファイルをダウンロードする、ワークステーション上の場所。

Windows ワークステーションの WinSCP を使用したファイルの転送

Windows ワークステーションでは、WinSCP クライアントにより、ファイル ブラウザのグラフィカル インターフェースを介してインスタンス上のファイルを管理できます。

WinSCP は、PuTTY を使用してインスタンスに接続するときと同じ鍵ファイルを使用します。

  1. Cloud Console プロジェクトまたはインスタンスに公開鍵を適用していない場合は、SSH 認証鍵ペアを取得して公開鍵 SSH 認証鍵ファイルをプロジェクトまたはインスタンスに適用します。

  2. WinSCP をダウンロードしてインストールします。多くの場合、デフォルトのインストール設定で問題なくインストールできます。

  3. WinSCP プログラムを起動します。ログイン ウィンドウが開き、接続設定を構成できます。

  4. ファイルの転送先となるインスタンスの外部 IP を確認します。Google Cloud Console で、[VM インスタンス] ページに移動します。

    インスタンス ページに移動

  5. WinSCP で、接続設定を構成します。

    1. [File protocol] フィールドを SCP に設定します。

    2. [Host Name] フィールドに、接続するインスタンスの外部 IP アドレスを入力します。

    3. [User name] フィールドに、プロジェクトへのアクセスに使用する Google ユーザー名を入力します。この例では、ユーザーは example-user です。

      ファイル プロトコルを SCP に、ホスト名を 104.196.31.103 に、ユーザー名を example-user に設定。

  6. [Advanced] プルダウン メニューから詳細設定を開き、[SSH] > [Authentication] に移動します。

  7. [Private key file] ボックスに、秘密鍵ファイルのパスを指定します。この例では、鍵ファイルは my-ssh-key.ppk です。

    詳細サイト設定ダイアログで、秘密鍵ファイルを my-ssh-key.ppk に設定。

  8. [OK] をクリックして、詳細設定を保存します。

  9. [Login] をクリックして、インスタンスに接続します。接続に成功するとウィンドウが開き、左側にローカルのファイル システムが、右側にインスタンスのファイル システムが表示されます。これらのファイル システムで他のディレクトリに移動でき、またファイルをドラッグしてインスタンスからファイルを転送できます。

  10. ほとんどの場合、ユーザーにはインスタンスのホーム ディレクトリ外のファイルを管理する権限はありません。インスタンス上のホーム ディレクトリに移動するには、WinSCP の path フィールドにホーム ディレクトリと username を入力します。

    /home/username
    
  11. WinSCP インターフェースを使用して、ワークステーションとインスタンスの間でファイルを移動します。

  12. インスタンスにファイルをコピーしたら、インスタンスに接続します。これで、完全な sudo 権限でファイルの実行や移動ができます。

次のステップ