Redis インスタンスへの接続

このページでは、Compute Engine と Google Kubernetes Engine を使用して Redis インスタンスに接続する方法について説明します。また、Telnet を使用して基本的な Redis コマンドをテストする手順についても説明します。

Memorystore for Redis でサポートされる Google Cloud 環境の一覧については、サポートされる環境をご覧ください。Memorystore でサポートされる一部のサーバーレス環境には、Serverless VPC Access コネクタが必要です。詳細については、サーバーレス VPC アクセス コネクタの要件をご覧ください。

Compute Engine VM から Redis インスタンスへの接続

Redis インスタンスには、その Redis インスタンスと同じプロジェクト、リージョン、ネットワーク内に配置されている任意の Compute Engine VM インスタンスから接続できます。

  1. Linux VM の使用に関するクイックスタートの手順に沿って、Compute Engine VM インスタンスを作成して接続します。Compute Engine VM インスタンスは、必ず Redis インスタンスと同じリージョンに作成してください。 クイックスタートの説明に従い、Debian 8 イメージを使用して VM インスタンスを作成した場合は、apt-get を使用して telnet をインストールします。

    sudo apt-get install telnet
    
  2. ターミナルで次のように入力して、Redis インスタンスの IP アドレスに telnet で接続します。variables は、適切な値に置き換えてください。

          telnet instance-ip-address 6379
    

    コマンドが正常終了した場合は、次の結果が返されます。

          Trying instance-ip-address…
          Connected to instance-ip-address
    
  3. telnet セッションで、次のようにいくつかの Redis コマンドを入力します。

    次のように入力します:

    PING
    

    結果:

    PONG
    

    入力

    SET HELLO WORLD
    

    結果:

    +OK
    

    次のように入力します:

    GET HELLO
    

    結果:

    $5
    WORLD
    

Redis クライアントを使用して Redis インスタンスにコマンドを発行することもできます。Redis クライアントの使用方法については、Redis クイック スタートガイドをご覧ください。

Google Kubernetes Engine クラスタから Redis インスタンスへの接続

Redis インスタンスには、そのインスタンスと同じリージョンに配置され、同じネットワークを使用する Google Kubernetes Engine クラスタから接続できます。

bash シェルを実行しているポッドから接続する

  1. Cloud Console の [GKE] ページに移動します。
    GKE
  2. 接続元とする GKE クラスタをクリックします。クラスタをまだ作成していない場合は、Redis インスタンスと同じゾーンおよびリージョンに IP エイリアスを有効にしてクラスタを作成します。IP エイリアスを有効にしてクラスタを作成する方法については、IP エイリアスのドキュメントをご覧ください。
  3. クラスタ名の右側にある [接続] ボタンをクリックし、表示されるウィンドウで [Cloud Shell で実行] ボタンをクリックします。
  4. 次のコマンドを実行して、kubectl コマンドライン アクセスを構成します。
    gcloud container clusters get-credentials CLUSTER_NAME --zone=CLUSTER_ZONE --project=PROJECT_ID
    • CLUSTER_NAME はクラスタの名前です。
    • CLUSTER_ZONE は、クラスタが配置されているゾーンです。Redis インスタンスが配置されているゾーンでもある必要があります。
    • PROJECT_ID は、クラスタと Redis インスタンスが存在するプロジェクトです。
    kubeconfig generated for CLUSTER_NAME」という成功メッセージが表示されます。
  5. クラスタのバージョンが 1.8 以上かつ IP エイリアスが有効になっている場合は、この手順をスキップします。クラスタのバージョンが 1.7 以下の場合、またはバージョン 1.8 以上で IP エイリアスが有効になっていない場合は、次の回避策の手順を行ってからインスタンスに接続してください。 IP エイリアスの設定を有効にしてクラスタを作成する方法など、IP エイリアスの詳細については IP エイリアスのドキュメントを参照してください。
  6. 次のコマンドを使用して、bash シェルに接続します。
    kubectl run -i --tty busybox --image=busybox -- sh
  7. ホストアドレスとポート番号を使用して、Redis インスタンスに telnet で接続します。
    telnet HOST-IP PORT
  8. 基本的な Redis コマンドを入力して、接続を確認します。
    PING
    +PONG
  9. telnet 接続を閉じるには、Ctrl+C キー(Mac では Command+C キー)を押します。ポッド内で bash シェルを終了するには、「return」と入力します。操作が完了して Redis に接続する必要がなくなった場合は、/k8s-custom-iptables/ ディレクトリから次のコマンドを実行します。
    ./uninstall.sh

Google Kubernetes Engine ポッドから Redis インスタンスに接続する

事前に GKE クラスタを準備しておく必要があります。クラスタをまだ作成していない場合は、Redis インスタンスと同じゾーンおよびリージョンに IP エイリアスを有効にしてクラスタを作成します。IP エイリアスを有効にしてクラスタを作成する方法については、IP エイリアスのドキュメントをご覧ください。

  1. コンソールの右上隅にある [Cloud Shell をアクティブにする] ボタン Cloud Shell をアクティブにする をクリックします。
  2. 次のコマンドを実行して、kubectl コマンドライン アクセスを構成します。
    gcloud container clusters get-credentials CLUSTER_NAME --zone CLUSTER_ZONE --project PROJECT_ID
    • CLUSTER_NAME はクラスタの名前です。
    • CLUSTER_ZONE は、クラスタが配置されているゾーンです。Redis インスタンスが配置されているゾーンでもある必要があります。
    • PROJECT_ID は、クラスタと Redis インスタンスが存在するプロジェクトです。
    kubeconfig generated for CLUSTER_NAME」という成功メッセージが表示されます。
  3. クラスタのバージョンが 1.8 以上かつ IP エイリアスが有効になっている場合は、この手順をスキップします。クラスタのバージョンが 1.7 以下の場合、またはバージョン 1.8 以上で IP エイリアスが有効になっていない場合は、次の回避策の手順を行ってからインスタンスに接続してください。 IP エイリアスの設定を有効にしてクラスタを作成する方法など、IP エイリアスの詳細については IP エイリアスのドキュメントを参照してください。
  4. 次のコマンドを使用して、redis-cli を実行する Redis ポッドを起動します。
    kubectl run -i --tty redisbox --image=gcr.io/google_containers/redis:v1 -- sh
  5. HOST-IP を Redis インスタンスのホスト IP アドレスに置き換えて、redis-cli コマンドを実行します。
    redis-cli -h HOST-IP info
  6. オプションで Redis ベンチマーク コマンドを実行します。ここでも HOST-IP の部分は、実際の Redis インスタンスのホスト IP アドレスに置き換えてください。
    redis-benchmark -c 100 -n 100000 -d 1024 -r 100000 -t PING,SET,GET,INCR,LPUSH,RPUSH,LPOP,RPOP,SADD,SPOP,MSET -h HOST-IP -q
  7. Redis ポッドを終了するには、「return」と入力します。操作が完了して Redis に接続する必要がなくなった場合は、/k8s-custom-iptables/ ディレクトリから次のコマンドを実行します。
    ./uninstall.sh

次のステップ

次の環境で動作するサンプル アプリケーションを使用して、Redis インスタンスに接続します。