GS2-Log GS2-Deploy/CDK リファレンス

GS2-Deployのスタックの作成に使用するテンプレートのフォーマットと、CDKによる各種言語のテンプレート出力の実装例

エンティティ

Namespace

ネームスペース

ネームスペースは一つのプロジェクトで同じサービスを異なる用途で複数利用できるようにするための仕組みです。
GS2 のサービスは基本的にネームスペースというレイヤーがあり、ネームスペースが異なれば同じサービスでもまったく別のデータ空間として取り扱われます。

そのため、各サービスの利用を開始するにあたってネームスペースを作成する必要があります。

必須デフォルト値の制限説明
namestring~ 128文字ネームスペース名
descriptionstring~ 1024文字説明文
typestring“gs2”~ 128文字ログの書き出し方法
gcpCredentialJsonstring{type} == “bigquery”~ 5120文字GCPのクレデンシャル
bigQueryDatasetNamestring{type} == “bigquery”~ 1024文字BigQueryのデータセット名
logExpireDaysint{type} in [“gs2”, “bigquery”]~ 3650ログの保存期間(日)
awsRegionstring{type} == “firehose”~ 256文字AWSのリージョン
awsAccessKeyIdstring{type} == “firehose”~ 256文字AWSのアクセスキーID
awsSecretAccessKeystring{type} == “firehose”~ 256文字AWSのシークレットアクセスキー
firehoseStreamNamestring{type} == “firehose”~ 256文字Kinesis Firehose のストリーム名

type に指定する列挙型の定義

定義説明
gs2GS2による管理
bigqueryBigQuery への書き出し
firehoseKinesis Firehose への書き出し

GetAttr

説明
ItemNamespace作成したネームスペース

実装例

Type: GS2::Log::Namespace
Properties:
  Name: namespace-0001
  Description: null
  Type: gs2
  GcpCredentialJson: {"project_id": "gs2-dev"}
  BigQueryDatasetName: dataset_0001
  LogExpireDays: 3
  AwsRegion: awsRegion
  AwsAccessKeyId: awsAccessKeyId
  AwsSecretAccessKey: awsSecretAccessKey
  FirehoseStreamName: firehoseStreamName
import "github.com/gs2io/gs2-golang-cdk/core"
import "github.com/gs2io/gs2-golang-cdk/log"
import "github.com/openlyinc/pointy"

SampleStack := core.NewStack()
log.NewNamespace(
    &SampleStack,
    "namespace-0001",
    log.NamespaceOptions{
        Type: "gs2",
        GcpCredentialJson: "{\"project_id\": \"gs2-dev\"}",
        BigQueryDatasetName: "dataset_0001",
        LogExpireDays: 3,
        AwsRegion: "awsRegion",
        AwsAccessKeyId: "awsAccessKeyId",
        AwsSecretAccessKey: "awsSecretAccessKey",
        FirehoseStreamName: "firehoseStreamName",
    },
)

println(SampleStack.Yaml())  // Generate Template
class SampleStack extends \Gs2Cdk\Core\Model\Stack
{
    function __construct() {
        parent::__construct();
        new \Gs2Cdk\Log\Model\Namespace_(
            stack: $this,
            name: "namespace-0001",
            options: new \Gs2Cdk\Log\Model\Options\NamespaceOptions(
                type: "gs2",
                gcpCredentialJson: "{\"project_id\": \"gs2-dev\"}",
                bigQueryDatasetName: "dataset_0001",
                logExpireDays: 3,
                awsRegion: "awsRegion",
                awsAccessKeyId: "awsAccessKeyId",
                awsSecretAccessKey: "awsSecretAccessKey",
                firehoseStreamName: "firehoseStreamName"
            )
        );
    }
}

print((new SampleStack())->yaml());  // Generate Template
class SampleStack extends io.gs2.cdk.core.model.Stack
{
    public SampleStack() {
        super();
        new io.gs2.cdk.log.model.Namespace(
                this,
                "namespace-0001",
                new io.gs2.cdk.log.model.options.NamespaceOptions()
                        .withtype = "gs2"
                        .withgcpCredentialJson = "{\"project_id\": \"gs2-dev\"}"
                        .withbigQueryDatasetName = "dataset_0001"
                        .withlogExpireDays = 3
                        .withawsRegion = "awsRegion"
                        .withawsAccessKeyId = "awsAccessKeyId"
                        .withawsSecretAccessKey = "awsSecretAccessKey"
                        .withfirehoseStreamName = "firehoseStreamName"
                }
        );
    }
}

System.out.println(new SampleStack().yaml());  // Generate Template
public class SampleStack : Gs2Cdk.Core.Model.Stack
{
    public SampleStack() {
        new Gs2Cdk.Gs2Log.Model.Namespace(
            stack: this,
            name: "namespace-0001",
            options: new Gs2Cdk.Gs2Log.Model.Options.NamespaceOptions
            {
                type = "gs2",
                gcpCredentialJson = "{\"project_id\": \"gs2-dev\"}",
                bigQueryDatasetName = "dataset_0001",
                logExpireDays = 3,
                awsRegion = "awsRegion",
                awsAccessKeyId = "awsAccessKeyId",
                awsSecretAccessKey = "awsSecretAccessKey",
                firehoseStreamName = "firehoseStreamName"
            }
        );
    }
}

Debug.Log(new SampleStack().Yaml());  // Generate Template
import core from "@/gs2cdk/core";
import log from "@/gs2cdk/log";

class SampleStack extends core.Stack
{
    public constructor() {
        super();
        new log.model.Namespace(
            this,
            "namespace-0001",
            {
                type: "gs2",
                gcpCredentialJson: "{\"project_id\": \"gs2-dev\"}",
                bigQueryDatasetName: "dataset_0001",
                logExpireDays: 3,
                awsRegion: "awsRegion",
                awsAccessKeyId: "awsAccessKeyId",
                awsSecretAccessKey: "awsSecretAccessKey",
                firehoseStreamName: "firehoseStreamName"
            }
        );
    }
}

console.log(new SampleStack().yaml());  // Generate Template
from gs2_cdk import Stack, core, log

class SampleStack(Stack):

    def __init__(self):
        super().__init__()
        log.Namespace(
            stack=self,
            name='namespace-0001',
            options=log.NamespaceOptions(
                type='gs2',
                gcp_credential_json='{"project_id": "gs2-dev"}',
                big_query_dataset_name='dataset_0001',
                log_expire_days=3,
                aws_region='awsRegion',
                aws_access_key_id='awsAccessKeyId',
                aws_secret_access_key='awsSecretAccessKey',
                firehose_stream_name='firehoseStreamName',
            ),
        )

print(SampleStack().yaml())  # Generate Template

Insight

GS2-Insight は GS2-Log に蓄積されたアクセスログを可視化・分析するツールです。
GS2-Insight 自体はオープンソースで github にて公開されています。
https://github.com/gs2io/gs2-insight

ここでは、公開されているオープンソースのコードをご自身でホスティングすることなく、オンデマンドで起動してご利用いただけます。
オンデマンド起動された GS2-Insight は最大2時間利用することができます。
2時間を超えて利用したい場合は、ご自身でホスティングしてご利用ください。

必須デフォルト値の制限説明
namespaceNamestring~ 128文字ネームスペース名

status に指定する列挙型の定義

定義説明
ALLOCATINGサーバーの割り当て中
LAUNCHING起動処理中
ACTIVE有効
DELETED削除済み

GetAttr

説明
ItemInsightGS2-Insight

実装例

Type: GS2::Log::Insight
Properties:
  NamespaceName: namespace-0001
import "github.com/gs2io/gs2-golang-cdk/core"
import "github.com/gs2io/gs2-golang-cdk/log"
import "github.com/openlyinc/pointy"

SampleStack := core.NewStack()
log.NewInsight(
    &SampleStack,
    "namespace-0001",
)

println(SampleStack.Yaml())  // Generate Template
class SampleStack extends \Gs2Cdk\Core\Model\Stack
{
    function __construct() {
        parent::__construct();
        new \Gs2Cdk\Log\Model\Insight(
            stack: $this,
            namespaceName: "namespace-0001"
        );
    }
}

print((new SampleStack())->yaml());  // Generate Template
class SampleStack extends io.gs2.cdk.core.model.Stack
{
    public SampleStack() {
        super();
        new io.gs2.cdk.log.model.Insight(
                this,
                "namespace-0001"
        );
    }
}

System.out.println(new SampleStack().yaml());  // Generate Template
public class SampleStack : Gs2Cdk.Core.Model.Stack
{
    public SampleStack() {
        new Gs2Cdk.Gs2Log.Model.Insight(
            stack: this,
            namespaceName: "namespace-0001"
        );
    }
}

Debug.Log(new SampleStack().Yaml());  // Generate Template
import core from "@/gs2cdk/core";
import log from "@/gs2cdk/log";

class SampleStack extends core.Stack
{
    public constructor() {
        super();
        new log.model.Insight(
            this,
            "namespace-0001"
        );
    }
}

console.log(new SampleStack().yaml());  // Generate Template
from gs2_cdk import Stack, core, log

class SampleStack(Stack):

    def __init__(self):
        super().__init__()
        log.Insight(
            stack=self,
            namespace_name='namespace-0001',
        )

print(SampleStack().yaml())  # Generate Template

AccessLog

アクセスログ

マイクロサービスへのリクエスト及びその応答内容を記録したログです。

必須デフォルト値の制限説明
timestamplong日時 (UNIX時間 単位:ミリ秒)
requestIdstring~ 1024文字リクエストID
servicestring~ 1024文字マイクロサービスの種類
methodstring~ 1024文字マイクロサービスのメソッド
userIdstring~ 128文字ユーザーID
requeststring~ 10485760文字リクエストパラメータ
resultstring~ 10485760文字応答内容

AccessLogCount

アクセスログ集計

必須デフォルト値の制限説明
servicestring~ 1024文字マイクロサービスの種類
methodstring~ 1024文字マイクロサービスのメソッド
userIdstring~ 128文字ユーザーID
countlong~ 9223372036854775805回数

IssueStampSheetLog

トランザクション発行ログ

必須デフォルト値の制限説明
timestamplong日時 (UNIX時間 単位:ミリ秒)
transactionIdstring~ 1024文字トランザクションID
servicestring~ 1024文字マイクロサービスの種類
methodstring~ 1024文字マイクロサービスのメソッド
userIdstring~ 128文字ユーザーID
actionstring~ 1024文字入手アクション
argsstring~ 5242880文字引数
tasksList<string>~ 10 itemsスタンプタスクリスト

IssueStampSheetLogCount

トランザクション発行ログ集計

必須デフォルト値の制限説明
servicestring~ 1024文字マイクロサービスの種類
methodstring~ 1024文字マイクロサービスのメソッド
userIdstring~ 128文字ユーザーID
actionstring~ 1024文字入手アクション
countlong~ 9223372036854775805回数

ExecuteStampSheetLog

入手アクション実行ログ

マイクロサービスごとのトランザクションの実行内容ログです。

必須デフォルト値の制限説明
timestamplong日時 (UNIX時間 単位:ミリ秒)
transactionIdstring~ 1024文字トランザクションID
servicestring~ 1024文字マイクロサービスの種類
methodstring~ 1024文字マイクロサービスのメソッド
userIdstring~ 128文字ユーザーID
actionstring~ 1024文字入手アクション
argsstring~ 5242880文字引数

ExecuteStampSheetLogCount

入手アクション実行ログ集計

必須デフォルト値の制限説明
servicestring~ 1024文字マイクロサービスの種類
methodstring~ 1024文字マイクロサービスのメソッド
userIdstring~ 128文字ユーザーID
actionstring~ 1024文字入手アクション
countlong~ 9223372036854775805回数

ExecuteStampTaskLog

スタンプタスク実行ログ

マイクロサービスごとのスタンプタスクの実行内容ログです。

必須デフォルト値の制限説明
timestamplong日時 (UNIX時間 単位:ミリ秒)
taskIdstring~ 1024文字タスクID
servicestring~ 1024文字マイクロサービスの種類
methodstring~ 1024文字マイクロサービスのメソッド
userIdstring~ 128文字ユーザーID
actionstring~ 1024文字入手アクション
argsstring~ 5242880文字引数

ExecuteStampTaskLogCount

入手アクション実行ログ集計

必須デフォルト値の制限説明
servicestring~ 1024文字マイクロサービスの種類
methodstring~ 1024文字マイクロサービスのメソッド
userIdstring~ 128文字ユーザーID
actionstring~ 1024文字入手アクション
countlong~ 9223372036854775805回数

AccessLogWithTelemetry

テレメトリー情報付きアクセスログ

マイクロサービスへのリクエスト及びその応答内容を記録したログにレスポンスタイムや呼び出し元のコンテキスト情報を付加したログ

必須デフォルト値の制限説明
timestamplong日時 (UNIX時間 単位:ミリ秒)
sourceRequestIdstring~ 1024文字呼び出し元リクエストID
requestIdstring~ 1024文字リクエストID
durationlong~ 9223372036854775805実行時間(ms)
servicestring~ 1024文字マイクロサービスの種類
methodstring~ 1024文字マイクロサービスのメソッド
userIdstring~ 128文字ユーザーID
requeststring~ 10485760文字リクエストパラメータ
resultstring~ 10485760文字応答内容
statusenum {
    “ok”,
    “error”
}
~ 128文字実行時間(ms)

status に指定する列挙型の定義

定義説明
ok正常
error異常

InGameLogTag

ゲーム内ログのタグ

必須デフォルト値の制限説明
keystring~ 64文字タグ名
valuestring~ 128文字タグ値