blob: 6850faf8a41b2001bc12b6aff99584eb1021a417 [file] [log] [blame]
// Copyright Istio Authors
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
package bootstrap
import (
"encoding/json"
"os"
)
import (
"istio.io/pkg/filewatcher"
"istio.io/pkg/log"
"istio.io/pkg/version"
)
import (
"github.com/apache/dubbo-go-pixiu/pilot/pkg/features"
"github.com/apache/dubbo-go-pixiu/pkg/config/mesh"
"github.com/apache/dubbo-go-pixiu/pkg/config/mesh/kubemesh"
)
const (
// defaultMeshConfigMapName is the default name of the ConfigMap with the mesh config
// The actual name can be different - use getMeshConfigMapName
defaultMeshConfigMapName = "istio"
// configMapKey should match the expected MeshConfig file name
configMapKey = "mesh"
)
// initMeshConfiguration creates the mesh in the pilotConfig from the input arguments.
// Original/default behavior:
// - use the mounted file, if it exists.
// - use istio-REVISION if k8s is enabled
// - fallback to default
//
// If the 'SHARED_MESH_CONFIG' env is set (experimental feature in 1.10):
// - if a file exist, load it - will be merged
// - if istio-REVISION exists, will be used, even if the file is present.
// - the SHARED_MESH_CONFIG config map will also be loaded and merged.
func (s *Server) initMeshConfiguration(args *PilotArgs, fileWatcher filewatcher.FileWatcher) {
log.Info("initializing mesh configuration ", args.MeshConfigFile)
defer func() {
if s.environment.Watcher != nil {
log.Infof("mesh configuration: %s", mesh.PrettyFormatOfMeshConfig(s.environment.Mesh()))
log.Infof("version: %s", version.Info.String())
argsdump, _ := json.MarshalIndent(args, "", " ")
log.Infof("flags: %s", argsdump)
}
}()
// Watcher will be merging more than one mesh config source?
multiWatch := features.SharedMeshConfig != ""
var err error
if _, err = os.Stat(args.MeshConfigFile); !os.IsNotExist(err) {
s.environment.Watcher, err = mesh.NewFileWatcher(fileWatcher, args.MeshConfigFile, multiWatch)
if err == nil {
if multiWatch && s.kubeClient != nil {
kubemesh.AddUserMeshConfig(
s.kubeClient, s.environment.Watcher, args.Namespace, configMapKey, features.SharedMeshConfig, s.internalStop)
} else {
// Normal install no longer uses this mode - testing and special installs still use this.
log.Warnf("Using local mesh config file %s, in cluster configs ignored", args.MeshConfigFile)
}
return
}
}
// Config file either didn't exist or failed to load.
if s.kubeClient == nil {
// Use a default mesh.
meshConfig := mesh.DefaultMeshConfig()
s.environment.Watcher = mesh.NewFixedWatcher(meshConfig)
log.Warnf("Using default mesh - missing file %s and no k8s client", args.MeshConfigFile)
return
}
// Watch the istio ConfigMap for mesh config changes.
// This may be necessary for external Istiod.
configMapName := getMeshConfigMapName(args.Revision)
multiWatcher := kubemesh.NewConfigMapWatcher(
s.kubeClient, args.Namespace, configMapName, configMapKey, multiWatch, s.internalStop)
s.environment.Watcher = multiWatcher
s.environment.NetworksWatcher = multiWatcher
log.Infof("initializing mesh networks from mesh config watcher")
if multiWatch {
kubemesh.AddUserMeshConfig(s.kubeClient, s.environment.Watcher, args.Namespace, configMapKey, features.SharedMeshConfig, s.internalStop)
}
}
// initMeshNetworks loads the mesh networks configuration from the file provided
// in the args and add a watcher for changes in this file.
func (s *Server) initMeshNetworks(args *PilotArgs, fileWatcher filewatcher.FileWatcher) {
if s.environment.NetworksWatcher != nil {
return
}
log.Info("initializing mesh networks")
if args.NetworksConfigFile != "" {
var err error
s.environment.NetworksWatcher, err = mesh.NewNetworksWatcher(fileWatcher, args.NetworksConfigFile)
if err != nil {
log.Info(err)
}
}
if s.environment.NetworksWatcher == nil {
log.Info("mesh networks configuration not provided")
s.environment.NetworksWatcher = mesh.NewFixedNetworksWatcher(nil)
}
}
func getMeshConfigMapName(revision string) string {
name := defaultMeshConfigMapName
if revision == "" || revision == "default" {
return name
}
return name + "-" + revision
}