1
// Copyright 2018 The CubeFS Authors.
3
// Licensed under the Apache License, Version 2.0 (the "License");
4
// you may not use this file except in compliance with the License.
5
// You may obtain a copy of the License at
7
// http://www.apache.org/licenses/LICENSE-2.0
9
// Unless required by applicable law or agreed to in writing, software
10
// distributed under the License is distributed on an "AS IS" BASIS,
11
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
12
// implied. See the License for the specific language governing
13
// permissions and limitations under the License.
20
"github.com/cubefs/cubefs/proto"
21
"github.com/cubefs/cubefs/util/errors"
22
"github.com/cubefs/cubefs/util/log"
26
ForceClosedConnect = true
27
NoClosedConnect = false
30
var ErrForbiddenMetaPartition = errors.New("meta partition is forbidden")
32
func (m *metadataManager) IsForbiddenOp(mp MetaPartition, reqOp uint8) bool {
33
if !mp.IsForbidden() {
39
proto.OpMetaCreateDentry,
40
proto.OpMetaTxCreateDentry,
41
proto.OpQuotaCreateDentry,
42
proto.OpMetaDeleteDentry,
43
proto.OpMetaTxDeleteDentry,
44
proto.OpMetaBatchDeleteDentry,
45
proto.OpMetaUpdateDentry,
46
proto.OpMetaTxUpdateDentry,
48
proto.OpMetaUpdateXAttr,
50
proto.OpMetaBatchSetXAttr,
51
proto.OpMetaRemoveXAttr,
54
proto.OpMetaExtentsAdd,
55
proto.OpMetaExtentAddWithCheck,
56
proto.OpMetaObjExtentAdd,
57
proto.OpMetaBatchObjExtentsAdd,
58
proto.OpMetaBatchExtentsAdd,
59
proto.OpMetaExtentsDel,
61
proto.OpMetaCreateInode,
62
proto.OpQuotaCreateInode,
63
proto.OpMetaTxUnlinkInode,
64
proto.OpMetaUnlinkInode,
65
proto.OpMetaBatchUnlinkInode,
66
proto.OpMetaTxLinkInode,
67
proto.OpMetaLinkInode,
68
proto.OpMetaEvictInode,
69
proto.OpMetaBatchEvictInode,
71
proto.OpMetaBatchDeleteInode,
72
proto.OpMetaClearInodeCache,
73
proto.OpMetaTxCreateInode,
75
proto.OpAddMultipartPart,
76
proto.OpRemoveMultipart,
77
proto.OpCreateMultipart,
79
proto.OpMetaBatchSetInodeQuota,
80
proto.OpMetaBatchDeleteInodeQuota:
88
// The proxy is used during the leader change. When a leader of a partition changes, the proxy forwards the request to
90
func (m *metadataManager) serveProxy(conn net.Conn, mp MetaPartition,
91
p *Packet) (ok bool) {
101
if m.IsForbiddenOp(mp, reqOp) {
102
err = ErrForbiddenMetaPartition
103
p.PacketErrorWithBody(proto.OpErr, []byte(err.Error()))
104
m.respondToClient(conn, p)
108
if leaderAddr, ok = mp.IsLeader(); ok {
111
if leaderAddr == "" {
113
p.PacketErrorWithBody(proto.OpAgain, []byte(err.Error()))
117
mConn, err = m.connPool.GetConnect(leaderAddr)
119
p.PacketErrorWithBody(proto.OpErr, []byte(err.Error()))
120
m.connPool.PutConnect(mConn, ForceClosedConnect)
124
// send to master connection
125
if err = p.WriteToConn(mConn); err != nil {
126
p.PacketErrorWithBody(proto.OpErr, []byte(err.Error()))
127
m.connPool.PutConnect(mConn, ForceClosedConnect)
131
// read connection from the master
132
if err = p.ReadFromConnWithVer(mConn, proto.NoReadDeadlineTime); err != nil {
133
p.PacketErrorWithBody(proto.OpErr, []byte(err.Error()))
134
m.connPool.PutConnect(mConn, ForceClosedConnect)
137
if reqID != p.ReqID || reqOp != p.Opcode {
138
log.LogErrorf("serveProxy: send and received packet mismatch: req(%v_%v) resp(%v_%v)",
139
reqID, reqOp, p.ReqID, p.Opcode)
141
m.connPool.PutConnect(mConn, NoClosedConnect)
143
m.respondToClient(conn, p)
145
log.LogErrorf("[serveProxy]: req: %d - %v, %v, packet(%v)", p.GetReqID(),
146
p.GetOpMsg(), err, p)
148
log.LogDebugf("[serveProxy] req: %d - %v, resp: %v, packet(%v)", p.GetReqID(), p.GetOpMsg(),