You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
|
|
package shell
import ( "github.com/seaweedfs/seaweedfs/weed/util" "io" )
func init() { Commands = append(Commands, &commandUnlock{}) Commands = append(Commands, &commandLock{}) }
// =========== Lock ==============
type commandLock struct { }
func (c *commandLock) Name() string { return "lock" }
func (c *commandLock) Help() string { return `lock in order to exclusively manage the cluster
This is a blocking operation if there is already another lock. ` }
func (c *commandLock) IsResourceHeavy() bool { return false }
func (c *commandLock) Do(args []string, commandEnv *CommandEnv, writer io.Writer) (err error) {
commandEnv.locker.RequestLock(util.DetectedHostAddress())
return nil }
// =========== Unlock ==============
type commandUnlock struct { }
func (c *commandUnlock) Name() string { return "unlock" }
func (c *commandUnlock) Help() string { return `unlock the cluster-wide lock
` }
func (c *commandUnlock) IsResourceHeavy() bool { return false }
func (c *commandUnlock) Do(args []string, commandEnv *CommandEnv, writer io.Writer) (err error) {
commandEnv.locker.ReleaseLock()
return nil }
|