proxy

package
v0.0.0-...-4867541 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Aug 19, 2020 License: Apache-2.0 Imports: 16 Imported by: 0

Documentation

Index

Constants

View Source
const (
	Find          = "mprpc.MongoProxy.Find"
	FindIter      = "mprpc.MongoProxy.FindIter"
	Count         = "mprpc.MongoProxy.Count"
	Explain       = "mprpc.MongoProxy.Explain"
	Aggregate     = "mprpc.MongoProxy.Aggregate"
	Bulk          = "mprpc.MongoProxy.Bulk"
	Update        = "mprpc.MongoProxy.Update"
	Remove        = "mprpc.MongoProxy.Remove"
	Insert        = "mprpc.MongoProxy.Insert"
	FindAndModify = "mprpc.MongoProxy.FindAndModify"
	Distinct      = "mprpc.MongoProxy.Distinct"
	Healthcheck   = "mprpc.MongoProxy.Healthcheck"
)

Function List in Proxy

View Source
const (
	Database   = "ebenchmark"
	Collection = "default"
)

Database used for ebenchmark

Variables

This section is empty.

Functions

This section is empty.

Types

type AggregateParam

type AggregateParam struct {
	Pipeline bson.M
}

Aggregate param for upper services

type Client

type Client struct {
	Host       string
	Collection *mprpc.Collection
	Turbo      bool

	Healthy   int32
	ProtoFile string
	// contains filtered or unexported fields
}

Client represents a middleware with the actual database driver

Currently client will use ebenchmark database as defined in const to avoid interfere with production workload. client support multi api. See the documentation on const for more details.

func NewClient

func NewClient(config *cfg.ProxyConfig, namespace string, cancel context.CancelFunc) (client *Client, err error)

NewClient Creates a new proxy client based on provided cfg This method is generally called just once for con establish, does health check in the background task, and check for env: PROTOSET_FILE, this env represent grpc interface with driver

Once Client is not useful anymore, Close must be called to release the resources appropriately

func (*Client) Aggregate

func (client *Client) Aggregate(ctx context.Context, query *AggregateParam) (documents []interface{}, err error)

Aggregate processes data records and return computed results. Aggregation operations group values from multiple documents together, and can perform a variety of operations on the grouped data to return a single result.

See proxy.AggregateParam for customizing aggregate param

Relevant documentation:

http://docs.mongodb.org/manual/reference/aggregation
http://docs.mongodb.org/manual/applications/aggregation
http://docs.mongodb.org/manual/tutorial/aggregation-examples

func (*Client) Close

func (client *Client) Close() (err error)

Close will release the resources in a proxy client, and call cancelFunc if specified

Call Close after NewClient, See NewClient for more details

func (*Client) Count

func (client *Client) Count(ctx context.Context, query *QueryParam) (count uint64, err error)

Count returns the total number of documents in the collection.

See proxy.QueryParam for customizing query param

func (*Client) Distinct

func (client *Client) Distinct(ctx context.Context, query *QueryParam) (distinctKeys []interface{}, err error)

Distinct unmarshals into result the list of distinct values for the given key.

See proxy.QueryParam for customizing distinct param

Relevant documentation:

http://www.mongodb.org/display/DOCS/Aggregation

func (*Client) Explain

func (client *Client) Explain(ctx context.Context, query *QueryParam) (explainFields bson.M, err error)

Explain returns a number of details about how the MongoDB cfg would execute the requested query, such as the number of objects examined, the number of times the read lock was yielded to allow writes to go in, and so on.

See proxy.QueryParam for customizing query param

Relevant documentation:

http://www.mongodb.org/display/DOCS/Optimization
http://www.mongodb.org/display/DOCS/Query+Optimizer

func (*Client) Find

func (client *Client) Find(ctx context.Context, query *QueryParam) (docs []bson.M, err error)

Find prepares a query using the provided document

See proxy.QueryParam for customizing query param

Relevant documentation:

http://www.mongodb.org/display/DOCS/Querying
http://www.mongodb.org/display/DOCS/Advanced+Queries

func (*Client) FindAndModify

func (client *Client) FindAndModify(ctx context.Context, param *FindModifyParam) (singleDoc interface{}, err error)

FindAndModify allows updating, upserting or removing a document matching a query and atomically returning either the old version (the default) or the new version of the document (when ReturnNew is true). If no objects are found Apply returns ErrNotFound.

See proxy.FindModifyParam for customizing findAndModify param

Relevant documentation:

http://www.mongodb.org/display/DOCS/findAndModify+Command
http://www.mongodb.org/display/DOCS/Updating
http://www.mongodb.org/display/DOCS/Atomic+Operations

func (*Client) FindIter

func (client *Client) FindIter(ctx context.Context, query *QueryParam) (stream mprpc.MongoProxy_FindIterClient, err error)

FindIter works like Find, but uses iterClient as stream function

See proxy.QueryParam for customizing query param

Relevant documentation:

http://www.mongodb.org/display/DOCS/Querying
http://www.mongodb.org/display/DOCS/Advanced+Queries

func (*Client) HealthCheck

func (client *Client) HealthCheck() (err error)

HealthCheck checks database driver, and atomically update client

func (*Client) Insert

func (client *Client) Insert(ctx context.Context, param *InsertParam) (err error)

Insert inserts one or more documents in the respective collection.

See proxy.InsertParam for customizing insert param

Relevant documentation:

http://www.mongodb.org/display/DOCS/Inserting

func (*Client) Remove

func (client *Client) Remove(ctx context.Context, param *RemoveParam) (changeInfo *mprpc.ChangeInfo, err error)

Remove finds documents matching the provided selector document and removes it from the database.

See proxy.RemoveParam for customizing remove param

Relevant documentation:

http://www.mongodb.org/display/DOCS/Removing

func (*Client) Update

func (client *Client) Update(ctx context.Context, param *UpdateParam) (changeInfo *mprpc.ChangeInfo, err error)

Update finds a single document matching the provided selector document and modifies it according to the update document.

See proxy.QueryParam for customizing query param

Relevant documentation:

http://www.mongodb.org/display/DOCS/Updating
http://www.mongodb.org/display/DOCS/Atomic+Operations

type Empty

type Empty struct{}

type FindAndModifyMode

type FindAndModifyMode int
const (
	FindAndDelete FindAndModifyMode = 0
	FindAndUpdate FindAndModifyMode = 1
	FindAndUpsert FindAndModifyMode = 2
)

Mode for FindAndModify

type FindModifyParam

type FindModifyParam struct {
	Filter   bson.M
	Desired  bson.M
	Mode     FindAndModifyMode
	SortRule []string
	Fields   bson.M
	Amp      cfg.Amplifier
}

FindAndModify param for upper services

type InsertParam

type InsertParam struct {
	Docs []interface{}
	Amp  cfg.Amplifier
}

Insert param for upper services

type QueryParam

type QueryParam struct {
	Filter      bson.M
	Fields      bson.M
	Limit       int64
	Skip        int64
	Sort        []string
	Distinctkey string
	FindOne     bool
	UsingIndex  []string
	Amp         cfg.Amplifier
}

Query param for upper services

type RemoveParam

type RemoveParam struct {
	Filter bson.M
	Amp    cfg.Amplifier
}

Remove param for upper services

func UndoInsert

func UndoInsert(param *InsertParam) (params []*RemoveParam)

UndoInsert generate removeParam based on given insert param Currently nested struct is not supported

Please refer proxy.InsertParam, proxy.RemoveParam for more details

type Storage

type Storage interface {
	Find(ctx context.Context, query *QueryParam) (docs []bson.M, err error)
	FindIter(ctx context.Context, query *QueryParam) (stream mprpc.MongoProxy_FindIterClient, err error)
}

type UpdateParam

type UpdateParam struct {
	Filter bson.M
	Update bson.M
	Upsert bool
	Multi  bool
	Amp    cfg.Amplifier
}

Update param for upper services

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL