mirror of
https://github.com/minio/minio.git
synced 2025-01-24 13:13:16 -05:00
allow changing server command line from http->https (#14832)
this is allowed as long as order is preserved as is on an existing setup, the new command line is updated in `pool.bin` to facilitate future decommission's on these pools.
This commit is contained in:
parent
01a71c366d
commit
424b44c247
@ -25,6 +25,7 @@ import (
|
||||
"net/http"
|
||||
"sort"
|
||||
"strconv"
|
||||
"strings"
|
||||
"sync"
|
||||
"time"
|
||||
|
||||
@ -309,9 +310,31 @@ func (p *poolMeta) validate(pools []*erasureSets) (bool, error) {
|
||||
specifiedPools[pool.endpoints.CmdLine] = idx
|
||||
}
|
||||
|
||||
replaceScheme := func(k string) string {
|
||||
// This is needed as fallback when users are changeing
|
||||
// from http->https or https->http, we need to verify
|
||||
// both because MinIO remembers the command-line in
|
||||
// "exact" order - as long as this order is not disturbed
|
||||
// we allow changing the "scheme" i.e internode communication
|
||||
// from plain-text to TLS or from TLS to plain-text.
|
||||
if strings.HasPrefix(k, "http://") {
|
||||
k = strings.ReplaceAll(k, "http://", "https://")
|
||||
} else if strings.HasPrefix(k, "https://") {
|
||||
k = strings.ReplaceAll(k, "https://", "http://")
|
||||
}
|
||||
return k
|
||||
}
|
||||
|
||||
var update bool
|
||||
// Check if specified pools need to remove decommissioned pool.
|
||||
for k := range specifiedPools {
|
||||
pi, ok := rememberedPools[k]
|
||||
if !ok {
|
||||
pi, ok = rememberedPools[replaceScheme(k)]
|
||||
if ok {
|
||||
update = true // Looks like user is changing from http->https or https->http
|
||||
}
|
||||
}
|
||||
if ok && pi.completed {
|
||||
return false, fmt.Errorf("pool(%s) = %s is decommissioned, please remove from server command line", humanize.Ordinal(pi.position+1), k)
|
||||
}
|
||||
@ -323,6 +346,12 @@ func (p *poolMeta) validate(pools []*erasureSets) (bool, error) {
|
||||
continue
|
||||
}
|
||||
_, ok := specifiedPools[k]
|
||||
if !ok {
|
||||
_, ok = specifiedPools[replaceScheme(k)]
|
||||
if ok {
|
||||
update = true // Looks like user is changing from http->https or https->http
|
||||
}
|
||||
}
|
||||
if !ok {
|
||||
return false, fmt.Errorf("pool(%s) = %s is not specified, please specify on server command line", humanize.Ordinal(pi.position+1), k)
|
||||
}
|
||||
@ -332,6 +361,12 @@ func (p *poolMeta) validate(pools []*erasureSets) (bool, error) {
|
||||
if len(rememberedPools) == len(specifiedPools) {
|
||||
for k, pi := range rememberedPools {
|
||||
pos, ok := specifiedPools[k]
|
||||
if !ok {
|
||||
pos, ok = specifiedPools[replaceScheme(k)]
|
||||
if ok {
|
||||
update = true // Looks like user is changing from http->https or https->http
|
||||
}
|
||||
}
|
||||
if !ok {
|
||||
return false, fmt.Errorf("pool(%s) = %s is not specified, please specify on server command line", humanize.Ordinal(pi.position+1), k)
|
||||
}
|
||||
@ -341,7 +376,9 @@ func (p *poolMeta) validate(pools []*erasureSets) (bool, error) {
|
||||
}
|
||||
}
|
||||
|
||||
update := len(rememberedPools) != len(specifiedPools)
|
||||
if !update {
|
||||
update = len(rememberedPools) != len(specifiedPools)
|
||||
}
|
||||
if update {
|
||||
for k, pi := range rememberedPools {
|
||||
if pi.decomStarted && !pi.completed {
|
||||
|
Loading…
x
Reference in New Issue
Block a user