forked from istio/operator
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Add a bunch of Istio stuff to the operator. (istio#24)
- Parse command-line options with Cobra - Use pkg/log for logging, including adding requisite command-line options. - Use pkg/ctrlz for introspection, including requisite command-line options. - Use pkg/version for standard versioning, including requisite command-line options
- Loading branch information
Showing
87 changed files
with
17,160 additions
and
167 deletions.
There are no files selected for viewing
Large diffs are not rendered by default.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,123 +1,13 @@ | ||
package main | ||
|
||
import ( | ||
"context" | ||
"flag" | ||
"fmt" | ||
"os" | ||
"runtime" | ||
|
||
// Import all Kubernetes client auth plugins (e.g. Azure, GCP, OIDC, etc.) | ||
_ "k8s.io/client-go/plugin/pkg/client/auth" | ||
|
||
"istio.io/operator/pkg/apis" | ||
"istio.io/operator/pkg/controller" | ||
|
||
"github.com/operator-framework/operator-sdk/pkg/k8sutil" | ||
"github.com/operator-framework/operator-sdk/pkg/leader" | ||
"github.com/operator-framework/operator-sdk/pkg/log/zap" | ||
"github.com/operator-framework/operator-sdk/pkg/metrics" | ||
sdkVersion "github.com/operator-framework/operator-sdk/version" | ||
"github.com/spf13/pflag" | ||
"sigs.k8s.io/controller-runtime/pkg/client/config" | ||
"sigs.k8s.io/controller-runtime/pkg/manager" | ||
logf "sigs.k8s.io/controller-runtime/pkg/runtime/log" | ||
"sigs.k8s.io/controller-runtime/pkg/runtime/signals" | ||
) | ||
|
||
// Change below variables to serve metrics on different host or port. | ||
var ( | ||
metricsHost = "0.0.0.0" | ||
metricsPort int32 = 8383 | ||
) | ||
var log = logf.Log.WithName("cmd") | ||
|
||
func printVersion() { | ||
log.Info(fmt.Sprintf("Go Version: %s", runtime.Version())) | ||
log.Info(fmt.Sprintf("Go OS/Arch: %s/%s", runtime.GOOS, runtime.GOARCH)) | ||
log.Info(fmt.Sprintf("Version of operator-sdk: %v", sdkVersion.Version)) | ||
} | ||
|
||
func main() { | ||
// Add the zap logger flag set to the CLI. The flag set must | ||
// be added before calling pflag.Parse(). | ||
pflag.CommandLine.AddFlagSet(zap.FlagSet()) | ||
|
||
// Add flags registered by imported packages (e.g. glog and | ||
// controller-runtime) | ||
pflag.CommandLine.AddGoFlagSet(flag.CommandLine) | ||
|
||
pflag.Parse() | ||
|
||
// Use a zap logr.Logger implementation. If none of the zap | ||
// flags are configured (or if the zap flag set is not being | ||
// used), this defaults to a production zap logger. | ||
// | ||
// The logger instantiated here can be changed to any logger | ||
// implementing the logr.Logger interface. This logger will | ||
// be propagated through the whole operator, generating | ||
// uniform and structured logs. | ||
logf.SetLogger(zap.Logger()) | ||
|
||
printVersion() | ||
|
||
namespace, err := k8sutil.GetWatchNamespace() | ||
if err != nil { | ||
log.Error(err, "Failed to get watch namespace") | ||
os.Exit(1) | ||
} | ||
|
||
// Get a config to talk to the apiserver | ||
cfg, err := config.GetConfig() | ||
if err != nil { | ||
log.Error(err, "") | ||
os.Exit(1) | ||
} | ||
|
||
ctx := context.TODO() | ||
|
||
// Become the leader before proceeding | ||
err = leader.Become(ctx, "istio-operator-lock") | ||
if err != nil { | ||
log.Error(err, "") | ||
os.Exit(1) | ||
} | ||
|
||
// Create a new Cmd to provide shared dependencies and start components | ||
mgr, err := manager.New(cfg, manager.Options{ | ||
Namespace: namespace, | ||
MetricsBindAddress: fmt.Sprintf("%s:%d", metricsHost, metricsPort), | ||
}) | ||
if err != nil { | ||
log.Error(err, "") | ||
os.Exit(1) | ||
} | ||
|
||
log.Info("Registering Components.") | ||
|
||
// Setup Scheme for all resources | ||
if err := apis.AddToScheme(mgr.GetScheme()); err != nil { | ||
log.Error(err, "") | ||
os.Exit(1) | ||
} | ||
|
||
// Setup all Controllers | ||
if err := controller.AddToManager(mgr); err != nil { | ||
log.Error(err, "") | ||
os.Exit(1) | ||
} | ||
|
||
// Create Service object to expose the metrics port. | ||
_, err = metrics.ExposeMetricsPort(ctx, metricsPort) | ||
if err != nil { | ||
log.Info(err.Error()) | ||
} | ||
|
||
log.Info("Starting the Cmd.") | ||
rootCmd := getRootCmd(os.Args[1:]) | ||
|
||
// Start the Cmd | ||
if err := mgr.Start(signals.SetupSignalHandler()); err != nil { | ||
log.Error(err, "Manager exited non-zero") | ||
os.Exit(1) | ||
if err := rootCmd.Execute(); err != nil { | ||
os.Exit(-1) | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,42 @@ | ||
// Copyright 2019 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 main | ||
|
||
import ( | ||
"flag" | ||
|
||
"github.com/spf13/cobra" | ||
|
||
"istio.io/pkg/version" | ||
) | ||
|
||
// getRootCmd returns the root of the cobra command-tree. | ||
func getRootCmd(args []string) *cobra.Command { | ||
rootCmd := &cobra.Command{ | ||
Use: "operator", | ||
Short: "The Istio operator.", | ||
Args: cobra.ExactArgs(0), | ||
PersistentPreRunE: func(cmd *cobra.Command, args []string) error { | ||
return nil | ||
}, | ||
} | ||
rootCmd.SetArgs(args) | ||
rootCmd.PersistentFlags().AddGoFlagSet(flag.CommandLine) | ||
|
||
rootCmd.AddCommand(serverCmd()) | ||
rootCmd.AddCommand(version.CobraCommand()) | ||
|
||
return rootCmd | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,135 @@ | ||
// Copyright 2019 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 main | ||
|
||
import ( | ||
"context" | ||
"fmt" | ||
"os" | ||
|
||
// Import all Kubernetes client auth plugins (e.g. Azure, GCP, OIDC, etc.) | ||
_ "k8s.io/client-go/plugin/pkg/client/auth" | ||
|
||
"github.com/operator-framework/operator-sdk/pkg/k8sutil" | ||
"github.com/operator-framework/operator-sdk/pkg/leader" | ||
"github.com/operator-framework/operator-sdk/pkg/metrics" | ||
"github.com/spf13/cobra" | ||
"sigs.k8s.io/controller-runtime/pkg/client/config" | ||
"sigs.k8s.io/controller-runtime/pkg/manager" | ||
"sigs.k8s.io/controller-runtime/pkg/runtime/signals" | ||
|
||
"istio.io/operator/pkg/apis" | ||
"istio.io/operator/pkg/controller" | ||
"istio.io/pkg/ctrlz" | ||
"istio.io/pkg/log" | ||
) | ||
|
||
// Change below variables to serve metrics on different host or port. | ||
var ( | ||
metricsHost = "0.0.0.0" | ||
metricsPort int32 = 8383 | ||
) | ||
|
||
func serverCmd() *cobra.Command { | ||
loggingOptions := log.DefaultOptions() | ||
introspectionOptions := ctrlz.DefaultOptions() | ||
|
||
serverCmd := &cobra.Command{ | ||
Use: "server", | ||
Short: "Starts the Istio operation server", | ||
Args: cobra.ExactArgs(0), | ||
RunE: func(cmd *cobra.Command, args []string) error { | ||
if err := log.Configure(loggingOptions); err != nil { | ||
log.Errorf("Unable to configure logging: %v", err) | ||
} | ||
|
||
if cs, err := ctrlz.Run(introspectionOptions, nil); err == nil { | ||
defer cs.Close() | ||
} else { | ||
log.Errorf("Unable to initialize ControlZ: %v", err) | ||
} | ||
|
||
run() | ||
return nil | ||
}, | ||
} | ||
|
||
loggingOptions.AttachCobraFlags(serverCmd) | ||
introspectionOptions.AttachCobraFlags(serverCmd) | ||
|
||
return serverCmd | ||
} | ||
|
||
func run() { | ||
namespace, err := k8sutil.GetWatchNamespace() | ||
if err != nil { | ||
log.Errora(err, "Failed to get watch namespace") | ||
os.Exit(1) | ||
} | ||
|
||
// Get a config to talk to the apiserver | ||
cfg, err := config.GetConfig() | ||
if err != nil { | ||
log.Errora(err, "") | ||
os.Exit(1) | ||
} | ||
|
||
ctx := context.TODO() | ||
|
||
// Become the leader before proceeding | ||
err = leader.Become(ctx, "istio-operator-lock") | ||
if err != nil { | ||
log.Errora(err, "") | ||
os.Exit(1) | ||
} | ||
|
||
// Create a new Cmd to provide shared dependencies and start components | ||
mgr, err := manager.New(cfg, manager.Options{ | ||
Namespace: namespace, | ||
MetricsBindAddress: fmt.Sprintf("%s:%d", metricsHost, metricsPort), | ||
}) | ||
if err != nil { | ||
log.Errora(err, "") | ||
os.Exit(1) | ||
} | ||
|
||
log.Info("Registering Components.") | ||
|
||
// Setup Scheme for all resources | ||
if err := apis.AddToScheme(mgr.GetScheme()); err != nil { | ||
log.Errora(err, "") | ||
os.Exit(1) | ||
} | ||
|
||
// Setup all Controllers | ||
if err := controller.AddToManager(mgr); err != nil { | ||
log.Errora(err, "") | ||
os.Exit(1) | ||
} | ||
|
||
// Create Service object to expose the metrics port. | ||
_, err = metrics.ExposeMetricsPort(ctx, metricsPort) | ||
if err != nil { | ||
log.Info(err.Error()) | ||
} | ||
|
||
log.Info("Starting the Cmd.") | ||
|
||
// Start the Cmd | ||
if err := mgr.Start(signals.SetupSignalHandler()); err != nil { | ||
log.Errora(err, "Manager exited non-zero") | ||
os.Exit(1) | ||
} | ||
} |
Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.
Oops, something went wrong.
Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.
Oops, something went wrong.
Oops, something went wrong.