mirror of
https://github.com/minio/minio.git
synced 2024-12-24 06:05:55 -05:00
fix: crash in globalTierJournal when TierConfig is not initialized (#17791)
This commit is contained in:
parent
b762fbaf21
commit
239ccc9c40
@ -346,7 +346,7 @@ var (
|
||||
|
||||
globalTierConfigMgr *TierConfigMgr
|
||||
|
||||
globalTierJournal *tierJournal
|
||||
globalTierJournal *TierJournal
|
||||
|
||||
globalConsoleSrv *restapi.Server
|
||||
|
||||
|
@ -362,6 +362,7 @@ func initAllSubsystems(ctx context.Context) {
|
||||
|
||||
// Create new ILM tier configuration subsystem
|
||||
globalTierConfigMgr = NewTierConfigMgr()
|
||||
globalTierJournal = NewTierJournal()
|
||||
|
||||
globalTransitionState = newTransitionState(GlobalContext)
|
||||
globalSiteResyncMetrics = newSiteResyncMetrics(GlobalContext)
|
||||
@ -798,14 +799,10 @@ func serverMain(ctx *cli.Context) {
|
||||
go func() {
|
||||
// Initialize transition tier configuration manager
|
||||
bootstrapTrace("globalTierConfigMgr.Init")
|
||||
err := globalTierConfigMgr.Init(GlobalContext, newObject)
|
||||
if err != nil {
|
||||
if err := globalTierConfigMgr.Init(GlobalContext, newObject); err != nil {
|
||||
logger.LogIf(GlobalContext, err)
|
||||
} else {
|
||||
globalTierJournal, err = initTierDeletionJournal(GlobalContext)
|
||||
if err != nil {
|
||||
logger.FatalIf(err, "Unable to initialize remote tier pending deletes journal")
|
||||
}
|
||||
logger.FatalIf(globalTierJournal.Init(GlobalContext), "Unable to initialize remote tier pending deletes journal")
|
||||
}
|
||||
}()
|
||||
|
||||
|
@ -32,7 +32,7 @@ import (
|
||||
)
|
||||
|
||||
//go:generate msgp -file $GOFILE -unexported
|
||||
//msgp:ignore tierJournal tierDiskJournal walkfn
|
||||
//msgp:ignore TierJournal tierDiskJournal walkfn
|
||||
|
||||
type tierDiskJournal struct {
|
||||
sync.RWMutex
|
||||
@ -40,7 +40,8 @@ type tierDiskJournal struct {
|
||||
file *os.File // active journal file
|
||||
}
|
||||
|
||||
type tierJournal struct {
|
||||
// TierJournal holds an in-memory and an on-disk delete journal of tiered content.
|
||||
type TierJournal struct {
|
||||
*tierDiskJournal // for processing legacy journal entries
|
||||
*tierMemJournal // for processing new journal entries
|
||||
}
|
||||
@ -62,24 +63,28 @@ func newTierDiskJournal() *tierDiskJournal {
|
||||
return &tierDiskJournal{}
|
||||
}
|
||||
|
||||
// initTierDeletionJournal intializes an in-memory journal built using a
|
||||
// buffered channel for new journal entries. It also initializes the on-disk
|
||||
// journal only to process existing journal entries made from previous versions.
|
||||
func initTierDeletionJournal(ctx context.Context) (*tierJournal, error) {
|
||||
j := &tierJournal{
|
||||
tierMemJournal: newTierMemJoural(1000),
|
||||
// NewTierJournal initializes tier deletion journal
|
||||
func NewTierJournal() *TierJournal {
|
||||
j := &TierJournal{
|
||||
tierMemJournal: newTierMemJournal(1000),
|
||||
tierDiskJournal: newTierDiskJournal(),
|
||||
}
|
||||
return j
|
||||
}
|
||||
|
||||
// Init intializes an in-memory journal built using a
|
||||
// buffered channel for new journal entries. It also initializes the on-disk
|
||||
// journal only to process existing journal entries made from previous versions.
|
||||
func (t *TierJournal) Init(ctx context.Context) error {
|
||||
for _, diskPath := range globalEndpoints.LocalDisksPaths() {
|
||||
j.diskPath = diskPath
|
||||
t.diskPath = diskPath
|
||||
|
||||
go j.deletePending(ctx) // for existing journal entries from previous MinIO versions
|
||||
go j.processEntries(ctx) // for newer journal entries circa free-versions
|
||||
return j, nil
|
||||
go t.deletePending(ctx) // for existing journal entries from previous MinIO versions
|
||||
go t.processEntries(ctx) // for newer journal entries circa free-versions
|
||||
return nil
|
||||
}
|
||||
|
||||
return nil, errors.New("no local drive found")
|
||||
return errors.New("no local drive found")
|
||||
}
|
||||
|
||||
// rotate rotates the journal. If a read-only journal already exists it does
|
||||
|
@ -28,7 +28,7 @@ type tierMemJournal struct {
|
||||
entries chan jentry
|
||||
}
|
||||
|
||||
func newTierMemJoural(nevents int) *tierMemJournal {
|
||||
func newTierMemJournal(nevents int) *tierMemJournal {
|
||||
return &tierMemJournal{
|
||||
entries: make(chan jentry, nevents),
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user