Documentation ¶
Index ¶
- Constants
- Variables
- func NewErrInvalidArgument(message string, kv map[string]interface{}, err error) error
- func NewErrNotFound(key string, err error) error
- func ValidateDatabaseIDFormat(projectID string) bool
- func ValidateInstanceIDFormat(projectID string) bool
- type Database
- type Error
- type QueryStat
- type QueryStatsCopyService
- func (s *QueryStatsCopyService) Close() error
- func (s *QueryStatsCopyService) Copy(ctx context.Context, dataset *bigquery.Dataset, bigQueryTable string, ...) (int, error)
- func (s *QueryStatsCopyService) CopyWithSpannerClient(ctx context.Context, dataset *bigquery.Dataset, bigQueryTable string, ...) (int, error)
- func (s *QueryStatsCopyService) CreateTable(ctx context.Context, dataset *bigquery.Dataset, table string) error
- func (s *QueryStatsCopyService) GetQueryStats(ctx context.Context, table QueryStatsTopTable, intervalEnd time.Time) ([]*QueryStat, error)
- func (s *QueryStatsCopyService) GetQueryStatsWithSpannerClient(ctx context.Context, table QueryStatsTopTable, spannerClient *spanner.Client, ...) ([]*QueryStat, error)
- type QueryStatsParam
- type QueryStatsTopTable
- type QueryWithStats
Constants ¶
const ( QueryWithStatsElapsedTimeKey = "elapsed_time" QueryWithStatsCPUTimeKey = "cpu_time" QueryWithStatsQueryPlanCreationTimeKey = "query_plan_creation_time" QueryWithStatsRuntimeCreationTimeKey = "runtime_creation_time" QueryWithStatsStatisticsLoadTimeKey = "statistics_load_time" QueryWithStatsFilesystemDelaySecondsKey = "filesystem_delay_seconds" QueryWithStatsDeletedRowsScannedKey = "deleted_rows_scanned" QueryWithStatsRemoteServerCallsKey = "remote_server_calls" QueryWithStatsRowsReturnedKey = "rows_returned" QueryWithStatsRowsScannedKey = "rows_scanned" QueryWithStatsDataBytesReadKey = "data_bytes_read" QueryWithStatsBytesReturnedKey = "bytes_returned" QueryWithStatsOptimizerStatisticsPackageKey = "optimizer_statistics_package" QueryWithStatsQueryTextKey = "query_text" QueryWithStatsOptimizerVersionKey = "optimizer_version" )
Variables ¶
var ErrInvalidArgument = &Error{ Code: "InvalidArgument", Message: "invalid argument", KV: map[string]interface{}{}, }
ErrInvalidArgument is 引数に問題がある時に返す
var ErrNotFound = &Error{ Code: "NotFound", Message: "not found", KV: map[string]interface{}{}, }
ErrNotFound is 見つからなかった時に返す
var (
ErrRequiredSpannerClient = xerrors.New("required spanner client.")
)
var QueryStatsBigQueryTableSchema = bigquery.Schema{ {Name: "interval_end", Required: true, Type: bigquery.TimestampFieldType}, {Name: "text", Required: true, Type: bigquery.StringFieldType}, {Name: "text_truncated", Required: true, Type: bigquery.BooleanFieldType}, {Name: "text_fingerprint", Required: true, Type: bigquery.IntegerFieldType}, {Name: "execution_count", Required: true, Type: bigquery.IntegerFieldType}, {Name: "avg_latency_seconds", Required: true, Type: bigquery.FloatFieldType}, {Name: "avg_rows", Required: true, Type: bigquery.FloatFieldType}, {Name: "avg_bytes", Required: true, Type: bigquery.FloatFieldType}, {Name: "avg_rows_scanned", Required: true, Type: bigquery.FloatFieldType}, {Name: "avg_cpu_seconds", Required: true, Type: bigquery.FloatFieldType}, }
QueryStatsBigQueryTableSchema is BigQuery Table Schema
Functions ¶
func NewErrInvalidArgument ¶
NewErrInvalidArgument is return InvalidArgument
func NewErrNotFound ¶
NewErrNotFound is return ErrNotFound
func ValidateDatabaseIDFormat ¶
ValidateDatabaseIDFormat is InstanceIDのFormatを検証する
The database ID must conform to the regular expression [a-z][a-z0-9_\-]*[a-z0-9] and be between 2 and 30 characters in length. https://cloud.google.com/spanner/docs/reference/rest/v1/projects.instances.databases/create
func ValidateInstanceIDFormat ¶
ValidateInstanceIDFormat is InstanceIDのFormatを検証する
Valid identifiers are of the form [a-z][-a-z0-9]*[a-z0-9] and must be between 2 and 64 characters in length. https://cloud.google.com/spanner/docs/reference/rest/v1/projects.instances/create
Types ¶
type Database ¶
func SplitDatabaseName ¶
SplitDatabaseName is projects/{PROJECT_ID}/instances/{INSTANCE}/databases/{DB} 形式の文字列をstructにして返す
func (*Database) ToSpannerDatabaseName ¶
ToSpannerDatabaseName is Spanner Database Name として指定できる形式の文字列を返す
type Error ¶
type Error struct { Code string Message string KV map[string]interface{} // contains filtered or unexported fields }
Error is Error情報を保持する struct
type QueryStat ¶
type QueryStat struct { IntervalEnd time.Time `spanner:"interval_end"` // End of the time interval that the included query executions occurred in. Text string // SQL query text, truncated to approximately 64KB. TextTruncated bool `spanner:"text_truncated"` // Whether or not the query text was truncated. TextFingerprint int64 `spanner:"text_fingerprint"` // Hash of the query text. ExecuteCount int64 `spanner:"execution_count"` // Number of times Cloud Spanner saw the query during the interval. AvgLatencySeconds float64 `spanner:"avg_latency_seconds"` // Average length of time, in seconds, for each query execution within the database. This average excludes the encoding and transmission time for the result set as well as overhead. AvgRows float64 `spanner:"avg_rows"` // Average number of rows that the query returned. AvgBytes float64 `spanner:"avg_bytes"` // Average number of data bytes that the query returned, excluding transmission encoding overhead. AvgRowsScanned float64 `spanner:"avg_rows_scanned"` // Average number of rows that the query scanned, excluding deleted values. AvgCPUSeconds float64 `spanner:"avg_cpu_seconds"` // Average number of seconds of CPU time Cloud Spanner spent on all operations to execute the query. }
type QueryStatsCopyService ¶
type QueryStatsCopyService struct { Spanner *spanner.Client BQ *bigquery.Client // contains filtered or unexported fields }
func NewQueryStatsCopyService ¶
func NewQueryStatsCopyService(ctx context.Context, bq *bigquery.Client) (*QueryStatsCopyService, error)
NewQueryStatsCopyService is QueryStatsCopyServiceを生成する
func NewQueryStatsCopyServiceWithSpannerClient ¶
func NewQueryStatsCopyServiceWithSpannerClient(ctx context.Context, bq *bigquery.Client, spannerClient *spanner.Client) (*QueryStatsCopyService, error)
NewQueryStatsCopyServiceWithSpannerClient is Statsを取得したいSpanner DBが1つしかないのであれば、Spanner Clientを設定して、QueryStatsCopyServiceを作成する
func (*QueryStatsCopyService) Close ¶
func (s *QueryStatsCopyService) Close() error
func (*QueryStatsCopyService) Copy ¶
func (s *QueryStatsCopyService) Copy(ctx context.Context, dataset *bigquery.Dataset, bigQueryTable string, queryStatsTable QueryStatsTopTable, intervalEnd time.Time) (int, error)
Copy is SpannerからQuery Statsを引っ張ってきて、BigQueryにCopyしていく
func (*QueryStatsCopyService) CopyWithSpannerClient ¶
func (s *QueryStatsCopyService) CopyWithSpannerClient(ctx context.Context, dataset *bigquery.Dataset, bigQueryTable string, queryStatsTable QueryStatsTopTable, spannerClient *spanner.Client, intervalEnd time.Time) (int, error)
CopyWithSpannerClient is SpannerからQuery Statsを引っ張ってきて、BigQueryにCopyしていく
func (*QueryStatsCopyService) CreateTable ¶
func (s *QueryStatsCopyService) CreateTable(ctx context.Context, dataset *bigquery.Dataset, table string) error
ToBigQuery is QueryStatsをBigQueryにStreamingInsertでInsertする
func (*QueryStatsCopyService) GetQueryStats ¶
func (s *QueryStatsCopyService) GetQueryStats(ctx context.Context, table QueryStatsTopTable, intervalEnd time.Time) ([]*QueryStat, error)
GetQueryStats is SpannerからQueryStatsを取得する
func (*QueryStatsCopyService) GetQueryStatsWithSpannerClient ¶
func (s *QueryStatsCopyService) GetQueryStatsWithSpannerClient(ctx context.Context, table QueryStatsTopTable, spannerClient *spanner.Client, intervalEnd time.Time) ([]*QueryStat, error)
GetQueryStatsWithSpannerClient is 指定したSpannerClientを利用して、SpannerからQueryStatsを取得する
type QueryStatsParam ¶
type QueryStatsParam struct {
Table string
}
type QueryStatsTopTable ¶
type QueryStatsTopTable string
const ( QueryStatsTopMinuteTable QueryStatsTopTable = "spanner_sys.query_stats_top_minute" QueryStatsTop10MinuteTable QueryStatsTopTable = "spanner_sys.query_stats_top_10minute" QueryStatsTopHourTable QueryStatsTopTable = "spanner_sys.query_stats_top_hour" )
type QueryWithStats ¶
type QueryWithStats struct { ElapsedTime string `json:"elapsedTime"` CPUTime string `json:"cpuTime"` QueryPlanCreationTime string `json:"queryPlanCreationTime"` RuntimeCreationTime string `json:"runtimeCreationTime"` StatisticsLoadTime string `json:"statisticsLoadTime"` FilesystemDelaySeconds string `json:"filesystemDelaySeconds"` DeletedRowsScanned int64 `json:"deletedRowsScanned"` RemoteServerCalls string `json:"remoteServerCalls"` RowsReturned int64 `json:"rowsReturned"` RowsScanned int64 `json:"rowsScanned"` DataBytesRead int64 `json:"dataBytesRead"` BytesReturned int64 `json:"bytesReturned"` OptimizerStatisticsPackage string `json:"optimizerStatisticsPackage"` QueryText string `json:"queryText"` OptimizerVersion string `json:"optimizerVersion"` }
QueryWithStats is Query 実行時に返ってくるStatsの情報を持つstruct
func ConvertQueryWithStats ¶
func ConvertQueryWithStats(stats map[string]interface{}) (*QueryWithStats, error)
ConvertQueryWithStats is Query 実行時に返ってくる stats の map を struct に割り当てる