0
2

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 3 years have passed since last update.

GCPで実現するBeyondCorp RemoteAccess

Posted at

本記事

:ok: GCPのリソース
:ng: ゼロトラストネットワークの概念および説明

BeyondCorp Remote Access

BeyondCorp - 企業セキュリティに対する新しいアプローチ
Googleが提唱している ゼロトラストネットワーク の実現方法の一つです。

検証環境

検証のゴール

  • Fireboxのログイン画面をインターネット経由でアクセスする
    • アクセス元がAny-Trustedのみ許可のためインターネットからは本来アクセスできない設定

システム構成

設定

CloudVPN

別途掲載しているので省略します。
GCPとWatchGuard製FireBoxのVPN接続

GCP側の設定

以下。

On-prem側の設定

不要。GCPとのVPN接続しているため。

GAE

  • 利用したコマンド各種
    • npm init で入力した内容は追加で一部あり
    • 参考にある runtime:nodejs8 は2020年10月18日でサポート対象外のため、 runtime:nodejs10へ変更
mkdir gae-proxy
cd gae-proxy/
npm init
npm install http --save
npm install http-proxy --save
vi app.yaml
vi index.js
vi package.json
cat package.json
ls -l
gcloud app deploy

参考: GAE Standard環境のNode.jsでリバースプロキシ構築

ReverseProxy

  • app.yaml
runtime: nodejs10
  • index.js
const http = require('http');
const httpProxy = require('http-proxy');
const port = process.env.PORT || 8080;
httpProxy.createProxyServer({target: 'http://192.168.***.***:8080/'}).listen(port);
  • package.json
{
  "name": "gae-proxy",
  "version": "1.0.0",
  "description": "proxy",
  "main": "index.js",
  "scripts": {
    "start": "node index.js"
  },
  "author": "Unknown",
  "license": "MIT",
  "dependencies": {
    "http": "0.0.1-security",
    "http-proxy": "^1.18.1"
  }
}

IAP

IAPの作成

OAuth同意画面

  • ユーザの種類
    • 内部 ... Google Workspace(G Suite)のユーザのみ
    • 外部 ... Googleアカウント全員

008_IAP_1.png

  • 画面に表示する項目
    • アプリ名 ... 画面に表示する
    • ユーザサポートメール ... 外部公開してもよい問い合わせ先メールアドレス(Google グループでサポート用グループメールアドレス発行を推奨)
    • デベロッパーの連絡先情報 ... なにか問題があったときの連絡先

009_IAP_2.png

認証ユーザの設定

  • IAPで認証するユーザの設定

012_IAP_6.png

  • IAPの有効化前確認

013_IAP_7.png

画面中央の IAP を有効化するとIAPの保護対象となる

Access Context Manager

設定ユーザへの権限設定

  • プロジェクト内部の権限ではなく組織全体の権限適用
    • ●が3つなのは、プロジェクト(リソース管理グループ)を表す
      • 不要になったらプロジェクト毎、削除(シャットダウン)することで課金制御が可能
    • 🏢が組織を表す
      • 組織全体の権限を制御するときはこちらで制御しなければならない

ハマるポイント
プロジェクト内で権限を付与したからといって、
組織全体に関わるリソース(Access Context Manager)に対して、
アクセス権限を与えたことにならない。

014_IAP_8.png

画面上部が必ず組織全体のアイコンになっていることを確認しアクセス権限を付与すること

015_IAP_9.png

そこで初めてAccess Context Managerへのアクセスが可能となる

016_IAP_10.png

認証可能なデバイスの設定

全体

  • 条件を作成
    • 基本モード ... GUIで設定
    • 詳細モード ... JSONといったコードベースで設定

017_ACL_1.png

リージョン(アクセス元の国)

JP で日本を絞り込み検索するとよい

018_ACL_2.png

OSのポリシー

バージョン指定は数値設定となるため、
制御で細かい設定が可能な一方メンテナンスコストが高くなるため、
バージョン指定は可能な限り設定しないことを推奨。

019_ACL_3.png

サンプルポリシー

020_ACL_4.png

ここまで設定したものの...

GAEでカスタムドメインの利用が可能

  • サンプルで作成した環境の場合、Google Domainでドメインを取得しているため親和性が高い
  • 外部のドメイン事業者で取得している場合は、DNSレコードの変更が必要

021_GAE_1.png

Google マネージド証明書

Googleが提供するSSL証明書が 無料 で利用可能な模様。

使用されるSSL証明書の発行元が「Let’s Encrypt」

とあるので、利用するユーザが嫌わなければこちらの採用も無料で検討してよいのではないかと考えるようになりました。
ただ、発行のリクエストから最大で48時間掛かるともあるので、導入までのリードタイムは考えないといけないです。

参考:
Google マネージド SSL 証明書の使用
GCPで無料HTTPS化{Compute Engine編}

まとめ

IAPはHTTPS前提であり初期検証を行っていた構成は
そもそもHTTPのバックエンドに投げる構成ではなダメ。
また、Google公式ドキュメントを読み込んでいく中で、
自然と頭の中でオンプレミスにあるリソースへのアクセスを前提としていたので、
IAP Connector(GKE)を利用する前提かと思っていたが、
リバースプロキシをGCP内に置くとなると、ライトな構成になっていく印象を受けた。

IAP による App Engine アプリの保護
IAP でオンプレミス アプリとリソースを保護する

1.NGパターン

Client (person) -[HTTPS]→ Internet -[HTTPS]→ IAP Connector -[HTTP]→ (CloudVPN) → On-Prem Server

2.On-Premに置くことを前提

Client (person) -[HTTPS]→ Internet -[HTTPS]→ IAP Connector -[HTTPS]→ (CloudVPN) -[HTTPS]→ Reverse Proxy -[HTTP]-> On-Prem Server

3.On-Premに置くことを前提

Client (person) -[HTTPS]→ Internet -[HTTPS]→ IAP Connector -[HTTPS]→ (CloudVPN) -[HTTPS]→ Reverse Proxy -[HTTP]-> On-Prem Server

1,2,3 で共通していたことは、IAP ConnectorがGKEで動くPodであることが運用課題だった。
ここに来て検証をすすめる中でGAE自体をReverse Proxyとする場合に、GKEを使う必要がなくなったように見える。

4.GAEをカスタムドメイン + Google マネージド証明書 でReverseProxyとする前提

Client (person) -[HTTPS]→ Internet -[HTTPS]→ GAE -[HTTP]→  (CloudVPN) -[HTTP]-> On-Prem Server
0
2
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
0
2

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?