Browse Source

skip fixing read only volumes

fix https://github.com/chrislusf/seaweedfs/issues/2562
pull/2564/head
chrislu 3 years ago
parent
commit
60dc450091
  1. 7
      weed/shell/command_volume_fsck.go

7
weed/shell/command_volume_fsck.go

@ -215,6 +215,10 @@ func (c *commandVolumeFsck) findExtraChunksInVolumeServers(volumeIdToVInfo map[u
fmt.Fprintf(writer, "Skip purging for Erasure Coded volume %d.\n", volumeId) fmt.Fprintf(writer, "Skip purging for Erasure Coded volume %d.\n", volumeId)
continue continue
} }
if vinfo.isReadOnly {
fmt.Fprintf(writer, "Skip purging for read only volume %d.\n", volumeId)
continue
}
if inUseCount == 0 { if inUseCount == 0 {
if err := deleteVolume(c.env.option.GrpcDialOption, needle.VolumeId(volumeId), vinfo.server); err != nil { if err := deleteVolume(c.env.option.GrpcDialOption, needle.VolumeId(volumeId), vinfo.server); err != nil {
return fmt.Errorf("delete volume %d: %v", volumeId, err) return fmt.Errorf("delete volume %d: %v", volumeId, err)
@ -440,6 +444,7 @@ type VInfo struct {
server pb.ServerAddress server pb.ServerAddress
collection string collection string
isEcVolume bool isEcVolume bool
isReadOnly bool
} }
func (c *commandVolumeFsck) collectVolumeIds(commandEnv *CommandEnv, verbose bool, writer io.Writer) (volumeIdToServer map[uint32]VInfo, err error) { func (c *commandVolumeFsck) collectVolumeIds(commandEnv *CommandEnv, verbose bool, writer io.Writer) (volumeIdToServer map[uint32]VInfo, err error) {
@ -462,6 +467,7 @@ func (c *commandVolumeFsck) collectVolumeIds(commandEnv *CommandEnv, verbose boo
server: pb.NewServerAddressFromDataNode(t), server: pb.NewServerAddressFromDataNode(t),
collection: vi.Collection, collection: vi.Collection,
isEcVolume: false, isEcVolume: false,
isReadOnly: vi.ReadOnly,
} }
} }
for _, ecShardInfo := range diskInfo.EcShardInfos { for _, ecShardInfo := range diskInfo.EcShardInfos {
@ -469,6 +475,7 @@ func (c *commandVolumeFsck) collectVolumeIds(commandEnv *CommandEnv, verbose boo
server: pb.NewServerAddressFromDataNode(t), server: pb.NewServerAddressFromDataNode(t),
collection: ecShardInfo.Collection, collection: ecShardInfo.Collection,
isEcVolume: true, isEcVolume: true,
isReadOnly: true,
} }
} }
} }

Loading…
Cancel
Save