Linux VM にファイルを転送する


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

転送元 転送先が Linux VM
Linux または macOS
Windows

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

Cloud Storage バケットは、ユーザーと VM 間の転送ポイントとして使用できます。ウェブブラウザ、Google Cloud CLI、プログラミング言語を使用して、Cloud Storage と Compute Engine VM の間でファイルを転送できます。

アップロードとダウンロードのステップでは、必要に応じてさまざまなタイプの認証情報を使用できます。

Cloud Storage を使用してコンピュータと VM の間でファイルを転送するには、次の操作を行います。

  1. ファイル転送に使用する既存のバケットがない場合は、Cloud Storage バケットを作成します。
  2. IAM 権限を使用して、バケットへのアクセスを変更します。
    • ファイルをバケットにアップロードするアカウントには Storage オブジェクト管理者を付与する必要があります。
    • ファイルをダウンロードするアカウントに、Storage オブジェクト閲覧者のロールを付与する必要があります。
  3. ソースデバイスにログインし、バケットにファイルをアップロードします。
  4. 宛先デバイスにログインし、ファイル転送を完了したバケットからファイルをダウンロードします。
  5. (省略可)不要なストレージ料金が発生しないように、ファイルを削除します。

逆方向にファイルを転送する必要がある場合は、このプロセスを逆に行うことでできます。ファイルをアップロードするアカウントに、バケットへの書き込みアクセス権があることを確認してください。

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

ブラウザの SSH を使用して VM への SSH 接続を確立できる場合は、その接続を使用して VM との間でファイルを転送できます。

VM へのアップロード

  1. Google Cloud コンソールで [VM インスタンス] ページに移動します。

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

  2. In the list of virtual machine instances, click SSH in the row of the instance that you want to connect to.

    SSH button next to instance name.

  3. 接続が確立されたら、アップロード アイコン をクリックします。

    アップロード ボタン。

    [アップロード] ダイアログが開きます。

  4. アップロードするファイルを選択します。
  5. [ファイルをアップロード] をクリックしてファイルをアップロードします。ファイルは /home/USER ディレクトリにアップロードされます。

VM からのダウンロード

  1. Google Cloud コンソールで [VM インスタンス] ページに移動します。

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

  2. In the list of virtual machine instances, click SSH in the row of the instance that you want to connect to.

    SSH button next to instance name.

  3. 接続が確立されたら、ダウンロード アイコン をクリックします。

    ダウンロード ボタン。

    [ダウンロード] ダイアログが開きます。

  4. [パス] テキスト ボックスに、ダウンロードするファイルの相対ファイルパスを入力します。
  5. [ダウンロード] をクリックしてファイルをダウンロードします。ファイルは、ワークステーションのデフォルトのダウンロード フォルダにダウンロードされます。

Google Cloud CLI を使用してファイルを転送する

Google Cloud CLI では確立済みの SSH 接続を介したセキュアコピー プロトコル(SCP)ファイル転送ユーティリティが使用できます。

SCP を使用してファイルを転送するには、次の手順に沿って操作します。

  1. ファイアウォール ルールを確認し、ポート 22 での SSH 接続が許可されていることを確認します。ない場合は、SSH ファイアウォール ルールを作成します。
  2. 転送するファイルが含まれているソースデバイスに gcloud CLI がインストールされていることを確認します。
  3. gcloud compute scp コマンドを使用して、宛先のマシンにファイルを転送します。

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

gcloud compute scp LOCAL_FILE_PATH VM_NAME:REMOTE_DIR

次のように置き換えます。

  • LOCAL_FILE_PATH: ワークステーション上のファイルのパス
  • VM_NAME: VM の名前
  • REMOTE_DIR: リモートマシン上のディレクトリ

リモートマシンからファイルとディレクトリを逆方向にコピーすることもできます。次の例では、ディレクトリをソースからコピー先に再帰的にコピーします。

gcloud compute scp --recurse VM_NAME:REMOTE_DIR LOCAL_FILE_PATH

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

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

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

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

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

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

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

  1. Google Cloud Console プロジェクトまたは VM インスタンスに公開鍵を適用していない場合は、SSH 認証鍵ペアを作成し、公開鍵をプロジェクトまたはインスタンス メタデータに追加します。

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

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

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

    scp -i ~/.ssh/my-ssh-key LOCAL_FILE_PATH USERNAME@IP_ADDRESS:~
    

    次のように置き換えます。

    • LOCAL_FILE_PATH: アップロードするローカル ファイルの名前
    • USERNAME: ユーザー名
    • IP-ADDRESS: VM の外部 IP アドレス

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

scp -i ~/.ssh/my-ssh-key USERNAME@IP_ADDRESS:REMOTE_FILE_PATH LOCAL_FILE_PATH

次のように置き換えます。

  • USERNAME: ユーザー名
  • IP_ADDRESS: VM の外部 IP アドレス
  • REMOTE_FILE_PATH: ダウンロードするリモート ファイルの名前
  • LOCAL_FILE_PATH: ファイルをダウンロードする、ワークステーション上の場所

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

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

WinSCP では、PuTTY を使用して VM に接続するときと同じ鍵ファイルが使用されます。

  1. インスタンス用に鍵ベースの SSH 認証を構成していない場合は、次の手順で操作します。

    1. PuTTYgen を使用して SSH 認証鍵ペアを作成します。SSH 認証秘密鍵は、.ppk 形式(PuTTYgen が作成する鍵のデフォルト)を使用する必要があります。

    2. 公開 SSH 認証鍵をプロジェクトのメタデータまたは VM のメタデータに追加します。詳細については、SSH 認証鍵をプロジェクト メタデータに追加するまたは SSH 認証鍵をインスタンス メタデータに追加するをご覧ください。

  2. ファイルの送信先となる VM の外部 IP を確認します。

    1. Google Cloud コンソールで [VM インスタンス] ページに移動します。

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

    2. VM のリストで、VM の [外部 IP] 列で外部 IP アドレスを探します。
  3. WinSCP をダウンロードしてインストールします。多くの場合、デフォルトのインストール設定で問題なくインストールできます。

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

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

    1. [File protocol] フィールドでは、ファイル転送プロトコルとして SCP を選択します。

    2. [Host name] フィールドには、接続する VM の外部 IP アドレスを指定します。

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

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

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

  7. [Private key file] ボックスに、VM 用に作成した SSH 認証鍵ペアの秘密鍵ファイルのパスを指定します。

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

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

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

  10. 通常、VM のホーム ディレクトリ外のファイルは、操作する権限がありません。VM のホーム ディレクトリに移動します。

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

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

次のステップ