2020-04-30 15:07:27 +08:00
|
|
|
package server
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
2020-03-26 15:02:29 +08:00
|
|
|
|
2020-04-29 21:38:49 +08:00
|
|
|
"github.com/pingcap-incubator/tinykv/kv/coprocessor"
|
2020-04-30 15:07:27 +08:00
|
|
|
"github.com/pingcap-incubator/tinykv/kv/storage"
|
|
|
|
"github.com/pingcap-incubator/tinykv/kv/storage/raft_storage"
|
|
|
|
"github.com/pingcap-incubator/tinykv/kv/transaction/latches"
|
2020-04-29 21:38:49 +08:00
|
|
|
coppb "github.com/pingcap-incubator/tinykv/proto/pkg/coprocessor"
|
2020-04-30 15:07:27 +08:00
|
|
|
"github.com/pingcap-incubator/tinykv/proto/pkg/kvrpcpb"
|
|
|
|
"github.com/pingcap-incubator/tinykv/proto/pkg/tinykvpb"
|
2020-04-29 21:38:49 +08:00
|
|
|
"github.com/pingcap/tidb/kv"
|
2020-04-30 15:07:27 +08:00
|
|
|
)
|
|
|
|
|
|
|
|
var _ tinykvpb.TinyKvServer = new(Server)
|
|
|
|
|
|
|
|
// Server is a TinyKV server, it 'faces outwards', sending and receiving messages from clients such as TinySQL.
|
|
|
|
type Server struct {
|
|
|
|
storage storage.Storage
|
2020-03-26 15:02:29 +08:00
|
|
|
|
2022-10-09 15:35:17 +08:00
|
|
|
// (Used in 4B)
|
2020-04-30 15:07:27 +08:00
|
|
|
Latches *latches.Latches
|
2020-04-29 21:38:49 +08:00
|
|
|
|
|
|
|
// coprocessor API handler, out of course scope
|
|
|
|
copHandler *coprocessor.CopHandler
|
2020-04-30 15:07:27 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
func NewServer(storage storage.Storage) *Server {
|
|
|
|
return &Server{
|
|
|
|
storage: storage,
|
|
|
|
Latches: latches.NewLatches(),
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// The below functions are Server's gRPC API (implements TinyKvServer).
|
|
|
|
|
|
|
|
// Raft commands (tinykv <-> tinykv)
|
|
|
|
// Only used for RaftStorage, so trivially forward it.
|
|
|
|
func (server *Server) Raft(stream tinykvpb.TinyKv_RaftServer) error {
|
|
|
|
return server.storage.(*raft_storage.RaftStorage).Raft(stream)
|
|
|
|
}
|
|
|
|
|
|
|
|
// Snapshot stream (tinykv <-> tinykv)
|
|
|
|
// Only used for RaftStorage, so trivially forward it.
|
|
|
|
func (server *Server) Snapshot(stream tinykvpb.TinyKv_SnapshotServer) error {
|
|
|
|
return server.storage.(*raft_storage.RaftStorage).Snapshot(stream)
|
|
|
|
}
|
|
|
|
|
|
|
|
// Transactional API.
|
|
|
|
func (server *Server) KvGet(_ context.Context, req *kvrpcpb.GetRequest) (*kvrpcpb.GetResponse, error) {
|
2020-03-26 15:02:29 +08:00
|
|
|
// Your Code Here (4B).
|
2020-04-30 15:07:27 +08:00
|
|
|
return nil, nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (server *Server) KvPrewrite(_ context.Context, req *kvrpcpb.PrewriteRequest) (*kvrpcpb.PrewriteResponse, error) {
|
2020-03-26 15:02:29 +08:00
|
|
|
// Your Code Here (4B).
|
2020-04-30 15:07:27 +08:00
|
|
|
return nil, nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (server *Server) KvCommit(_ context.Context, req *kvrpcpb.CommitRequest) (*kvrpcpb.CommitResponse, error) {
|
2020-03-26 15:02:29 +08:00
|
|
|
// Your Code Here (4B).
|
2020-04-30 15:07:27 +08:00
|
|
|
return nil, nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (server *Server) KvScan(_ context.Context, req *kvrpcpb.ScanRequest) (*kvrpcpb.ScanResponse, error) {
|
2020-03-26 15:02:29 +08:00
|
|
|
// Your Code Here (4C).
|
2020-04-30 15:07:27 +08:00
|
|
|
return nil, nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (server *Server) KvCheckTxnStatus(_ context.Context, req *kvrpcpb.CheckTxnStatusRequest) (*kvrpcpb.CheckTxnStatusResponse, error) {
|
2020-03-26 15:02:29 +08:00
|
|
|
// Your Code Here (4C).
|
2020-04-30 15:07:27 +08:00
|
|
|
return nil, nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (server *Server) KvBatchRollback(_ context.Context, req *kvrpcpb.BatchRollbackRequest) (*kvrpcpb.BatchRollbackResponse, error) {
|
2020-03-26 15:02:29 +08:00
|
|
|
// Your Code Here (4C).
|
2020-04-30 15:07:27 +08:00
|
|
|
return nil, nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (server *Server) KvResolveLock(_ context.Context, req *kvrpcpb.ResolveLockRequest) (*kvrpcpb.ResolveLockResponse, error) {
|
2020-03-26 15:02:29 +08:00
|
|
|
// Your Code Here (4C).
|
2020-04-30 15:07:27 +08:00
|
|
|
return nil, nil
|
|
|
|
}
|
|
|
|
|
|
|
|
// SQL push down commands.
|
2020-04-29 21:38:49 +08:00
|
|
|
func (server *Server) Coprocessor(_ context.Context, req *coppb.Request) (*coppb.Response, error) {
|
|
|
|
resp := new(coppb.Response)
|
|
|
|
reader, err := server.storage.Reader(req.Context)
|
|
|
|
if err != nil {
|
|
|
|
if regionErr, ok := err.(*raft_storage.RegionError); ok {
|
|
|
|
resp.RegionError = regionErr.RequestErr
|
|
|
|
return resp, nil
|
|
|
|
}
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
switch req.Tp {
|
|
|
|
case kv.ReqTypeDAG:
|
|
|
|
return server.copHandler.HandleCopDAGRequest(reader, req), nil
|
|
|
|
case kv.ReqTypeAnalyze:
|
|
|
|
return server.copHandler.HandleCopAnalyzeRequest(reader, req), nil
|
|
|
|
}
|
|
|
|
return nil, nil
|
2020-04-30 15:07:27 +08:00
|
|
|
}
|