mirror of
https://github.com/argoproj/argo-cd
synced 2026-04-21 17:07:16 +00:00
* chore: Upgrade Go module to v2 Signed-off-by: jannfis <jann@mistrust.net> * Restore import order Signed-off-by: jannfis <jann@mistrust.net> * fix knowntypes_normalizer codegen error Signed-off-by: Alexander Matyushentsev <AMatyushentsev@gmail.com> * fix codegen Signed-off-by: Alexander Matyushentsev <AMatyushentsev@gmail.com> * fix Procfile Signed-off-by: Alexander Matyushentsev <AMatyushentsev@gmail.com> Co-authored-by: Alexander Matyushentsev <AMatyushentsev@gmail.com>
53 lines
1.3 KiB
Go
53 lines
1.3 KiB
Go
package sharding
|
|
|
|
import (
|
|
"fmt"
|
|
"hash/fnv"
|
|
"os"
|
|
"strconv"
|
|
"strings"
|
|
|
|
"github.com/argoproj/argo-cd/v2/pkg/apis/application/v1alpha1"
|
|
)
|
|
|
|
func InferShard() (int, error) {
|
|
hostname, err := os.Hostname()
|
|
if err != nil {
|
|
return 0, err
|
|
}
|
|
parts := strings.Split(hostname, "-")
|
|
if len(parts) == 0 {
|
|
return 0, fmt.Errorf("hostname should ends with shard number separated by '-' but got: %s", hostname)
|
|
}
|
|
shard, err := strconv.Atoi(parts[len(parts)-1])
|
|
if err != nil {
|
|
return 0, fmt.Errorf("hostname should ends with shard number separated by '-' but got: %s", hostname)
|
|
}
|
|
return shard, nil
|
|
}
|
|
|
|
// GetShardByID calculates cluster shard as `clusterSecret.UID % replicas count`
|
|
func GetShardByID(id string, replicas int) int {
|
|
if id == "" {
|
|
return 0
|
|
} else {
|
|
h := fnv.New32a()
|
|
_, _ = h.Write([]byte(id))
|
|
return int(h.Sum32() % uint32(replicas))
|
|
}
|
|
}
|
|
|
|
func GetClusterFilter(replicas int, shard int) func(c *v1alpha1.Cluster) bool {
|
|
return func(c *v1alpha1.Cluster) bool {
|
|
clusterShard := 0
|
|
// cluster might be nil if app is using invalid cluster URL, assume shard 0 in this case.
|
|
if c != nil {
|
|
if c.Shard != nil {
|
|
clusterShard = int(*c.Shard)
|
|
} else {
|
|
clusterShard = GetShardByID(c.ID, replicas)
|
|
}
|
|
}
|
|
return clusterShard == shard
|
|
}
|
|
}
|