mirror of
				https://github.com/optim-enterprises-bv/kubernetes.git
				synced 2025-10-31 10:18:13 +00:00 
			
		
		
		
	 bbd447f555
			
		
	
	bbd447f555
	
	
	
		
			
			Automatic merge from submit-queue create service add create ExternalName service implementation @kubernetes/kubectl create service add ExternalName support, refer #34731 for more detail. ```release-note kubectl create service externalname ```
		
			
				
	
	
		
			283 lines
		
	
	
		
			10 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			283 lines
		
	
	
		
			10 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| /*
 | |
| Copyright 2016 The Kubernetes 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 cmd
 | |
| 
 | |
| import (
 | |
| 	"fmt"
 | |
| 	"io"
 | |
| 
 | |
| 	"github.com/spf13/cobra"
 | |
| 
 | |
| 	"k8s.io/kubernetes/pkg/api"
 | |
| 	"k8s.io/kubernetes/pkg/kubectl"
 | |
| 	"k8s.io/kubernetes/pkg/kubectl/cmd/templates"
 | |
| 	cmdutil "k8s.io/kubernetes/pkg/kubectl/cmd/util"
 | |
| )
 | |
| 
 | |
| // NewCmdCreateService is a macro command to create a new service
 | |
| func NewCmdCreateService(f cmdutil.Factory, cmdOut, errOut io.Writer) *cobra.Command {
 | |
| 	cmd := &cobra.Command{
 | |
| 		Use:     "service",
 | |
| 		Aliases: []string{"svc"},
 | |
| 		Short:   "Create a service using specified subcommand.",
 | |
| 		Long:    "Create a service using specified subcommand.",
 | |
| 		Run:     cmdutil.DefaultSubCommandRun(errOut),
 | |
| 	}
 | |
| 	cmd.AddCommand(NewCmdCreateServiceClusterIP(f, cmdOut))
 | |
| 	cmd.AddCommand(NewCmdCreateServiceNodePort(f, cmdOut))
 | |
| 	cmd.AddCommand(NewCmdCreateServiceLoadBalancer(f, cmdOut))
 | |
| 	cmd.AddCommand(NewCmdCreateServiceExternalName(f, cmdOut))
 | |
| 
 | |
| 	return cmd
 | |
| }
 | |
| 
 | |
| var (
 | |
| 	serviceClusterIPLong = templates.LongDesc(`
 | |
|     Create a clusterIP service with the specified name.`)
 | |
| 
 | |
| 	serviceClusterIPExample = templates.Examples(`
 | |
|     # Create a new clusterIP service named my-cs
 | |
|     kubectl create service clusterip my-cs --tcp=5678:8080
 | |
| 
 | |
|     # Create a new clusterIP service named my-cs (in headless mode)
 | |
|     kubectl create service clusterip my-cs --clusterip="None"`)
 | |
| )
 | |
| 
 | |
| func addPortFlags(cmd *cobra.Command) {
 | |
| 	cmd.Flags().StringSlice("tcp", []string{}, "Port pairs can be specified as '<port>:<targetPort>'.")
 | |
| }
 | |
| 
 | |
| // NewCmdCreateServiceClusterIP is a command to create a clusterIP service
 | |
| func NewCmdCreateServiceClusterIP(f cmdutil.Factory, cmdOut io.Writer) *cobra.Command {
 | |
| 	cmd := &cobra.Command{
 | |
| 		Use:     "clusterip NAME [--tcp=<port>:<targetPort>] [--dry-run]",
 | |
| 		Short:   "Create a clusterIP service.",
 | |
| 		Long:    serviceClusterIPLong,
 | |
| 		Example: serviceClusterIPExample,
 | |
| 		Run: func(cmd *cobra.Command, args []string) {
 | |
| 			err := CreateServiceClusterIP(f, cmdOut, cmd, args)
 | |
| 			cmdutil.CheckErr(err)
 | |
| 		},
 | |
| 	}
 | |
| 	cmdutil.AddApplyAnnotationFlags(cmd)
 | |
| 	cmdutil.AddValidateFlags(cmd)
 | |
| 	cmdutil.AddPrinterFlags(cmd)
 | |
| 	cmdutil.AddGeneratorFlags(cmd, cmdutil.ServiceClusterIPGeneratorV1Name)
 | |
| 	addPortFlags(cmd)
 | |
| 	cmd.Flags().String("clusterip", "", "Assign your own ClusterIP or set to 'None' for a 'headless' service (no loadbalancing).")
 | |
| 	return cmd
 | |
| }
 | |
| 
 | |
| // CreateServiceClusterIP implements the behavior to run the create service clusterIP command
 | |
| func CreateServiceClusterIP(f cmdutil.Factory, cmdOut io.Writer, cmd *cobra.Command, args []string) error {
 | |
| 	name, err := NameFromCommandArgs(cmd, args)
 | |
| 	if err != nil {
 | |
| 		return err
 | |
| 	}
 | |
| 	var generator kubectl.StructuredGenerator
 | |
| 	switch generatorName := cmdutil.GetFlagString(cmd, "generator"); generatorName {
 | |
| 	case cmdutil.ServiceClusterIPGeneratorV1Name:
 | |
| 		generator = &kubectl.ServiceCommonGeneratorV1{
 | |
| 			Name:      name,
 | |
| 			TCP:       cmdutil.GetFlagStringSlice(cmd, "tcp"),
 | |
| 			Type:      api.ServiceTypeClusterIP,
 | |
| 			ClusterIP: cmdutil.GetFlagString(cmd, "clusterip"),
 | |
| 		}
 | |
| 	default:
 | |
| 		return cmdutil.UsageError(cmd, fmt.Sprintf("Generator: %s not supported.", generatorName))
 | |
| 	}
 | |
| 	return RunCreateSubcommand(f, cmd, cmdOut, &CreateSubcommandOptions{
 | |
| 		Name:                name,
 | |
| 		StructuredGenerator: generator,
 | |
| 		DryRun:              cmdutil.GetDryRunFlag(cmd),
 | |
| 		OutputFormat:        cmdutil.GetFlagString(cmd, "output"),
 | |
| 	})
 | |
| }
 | |
| 
 | |
| var (
 | |
| 	serviceNodePortLong = templates.LongDesc(`
 | |
|     Create a nodeport service with the specified name.`)
 | |
| 
 | |
| 	serviceNodePortExample = templates.Examples(`
 | |
|     # Create a new nodeport service named my-ns
 | |
|     kubectl create service nodeport my-ns --tcp=5678:8080`)
 | |
| )
 | |
| 
 | |
| // NewCmdCreateServiceNodePort is a macro command for creating a NodePort service
 | |
| func NewCmdCreateServiceNodePort(f cmdutil.Factory, cmdOut io.Writer) *cobra.Command {
 | |
| 	cmd := &cobra.Command{
 | |
| 		Use:     "nodeport NAME [--tcp=port:targetPort] [--dry-run]",
 | |
| 		Short:   "Create a NodePort service.",
 | |
| 		Long:    serviceNodePortLong,
 | |
| 		Example: serviceNodePortExample,
 | |
| 		Run: func(cmd *cobra.Command, args []string) {
 | |
| 			err := CreateServiceNodePort(f, cmdOut, cmd, args)
 | |
| 			cmdutil.CheckErr(err)
 | |
| 		},
 | |
| 	}
 | |
| 	cmdutil.AddApplyAnnotationFlags(cmd)
 | |
| 	cmdutil.AddValidateFlags(cmd)
 | |
| 	cmdutil.AddPrinterFlags(cmd)
 | |
| 	cmdutil.AddGeneratorFlags(cmd, cmdutil.ServiceNodePortGeneratorV1Name)
 | |
| 	cmd.Flags().Int("node-port", 0, "Port used to expose the service on each node in a cluster.")
 | |
| 	addPortFlags(cmd)
 | |
| 	return cmd
 | |
| }
 | |
| 
 | |
| // CreateServiceNodePort is the implementation of the create service nodeport command
 | |
| func CreateServiceNodePort(f cmdutil.Factory, cmdOut io.Writer, cmd *cobra.Command, args []string) error {
 | |
| 	name, err := NameFromCommandArgs(cmd, args)
 | |
| 	if err != nil {
 | |
| 		return err
 | |
| 	}
 | |
| 	var generator kubectl.StructuredGenerator
 | |
| 	switch generatorName := cmdutil.GetFlagString(cmd, "generator"); generatorName {
 | |
| 	case cmdutil.ServiceNodePortGeneratorV1Name:
 | |
| 		generator = &kubectl.ServiceCommonGeneratorV1{
 | |
| 			Name:      name,
 | |
| 			TCP:       cmdutil.GetFlagStringSlice(cmd, "tcp"),
 | |
| 			Type:      api.ServiceTypeNodePort,
 | |
| 			ClusterIP: "",
 | |
| 			NodePort:  cmdutil.GetFlagInt(cmd, "node-port"),
 | |
| 		}
 | |
| 	default:
 | |
| 		return cmdutil.UsageError(cmd, fmt.Sprintf("Generator: %s not supported.", generatorName))
 | |
| 	}
 | |
| 	return RunCreateSubcommand(f, cmd, cmdOut, &CreateSubcommandOptions{
 | |
| 		Name:                name,
 | |
| 		StructuredGenerator: generator,
 | |
| 		DryRun:              cmdutil.GetDryRunFlag(cmd),
 | |
| 		OutputFormat:        cmdutil.GetFlagString(cmd, "output"),
 | |
| 	})
 | |
| }
 | |
| 
 | |
| var (
 | |
| 	serviceLoadBalancerLong = templates.LongDesc(`
 | |
|     Create a LoadBalancer service with the specified name.`)
 | |
| 
 | |
| 	serviceLoadBalancerExample = templates.Examples(`
 | |
|     # Create a new LoadBalancer service named my-lbs
 | |
|     kubectl create service loadbalancer my-lbs --tcp=5678:8080`)
 | |
| )
 | |
| 
 | |
| // NewCmdCreateServiceLoadBalancer is a macro command for creating a LoadBalancer service
 | |
| func NewCmdCreateServiceLoadBalancer(f cmdutil.Factory, cmdOut io.Writer) *cobra.Command {
 | |
| 	cmd := &cobra.Command{
 | |
| 		Use:     "loadbalancer NAME [--tcp=port:targetPort] [--dry-run]",
 | |
| 		Short:   "Create a LoadBalancer service.",
 | |
| 		Long:    serviceLoadBalancerLong,
 | |
| 		Example: serviceLoadBalancerExample,
 | |
| 		Run: func(cmd *cobra.Command, args []string) {
 | |
| 			err := CreateServiceLoadBalancer(f, cmdOut, cmd, args)
 | |
| 			cmdutil.CheckErr(err)
 | |
| 		},
 | |
| 	}
 | |
| 	cmdutil.AddApplyAnnotationFlags(cmd)
 | |
| 	cmdutil.AddValidateFlags(cmd)
 | |
| 	cmdutil.AddPrinterFlags(cmd)
 | |
| 	cmdutil.AddGeneratorFlags(cmd, cmdutil.ServiceLoadBalancerGeneratorV1Name)
 | |
| 	addPortFlags(cmd)
 | |
| 	return cmd
 | |
| }
 | |
| 
 | |
| // CreateServiceLoadBalancer is the implementation of the service loadbalancer command
 | |
| func CreateServiceLoadBalancer(f cmdutil.Factory, cmdOut io.Writer, cmd *cobra.Command, args []string) error {
 | |
| 	name, err := NameFromCommandArgs(cmd, args)
 | |
| 	if err != nil {
 | |
| 		return err
 | |
| 	}
 | |
| 	var generator kubectl.StructuredGenerator
 | |
| 	switch generatorName := cmdutil.GetFlagString(cmd, "generator"); generatorName {
 | |
| 	case cmdutil.ServiceLoadBalancerGeneratorV1Name:
 | |
| 		generator = &kubectl.ServiceCommonGeneratorV1{
 | |
| 			Name:      name,
 | |
| 			TCP:       cmdutil.GetFlagStringSlice(cmd, "tcp"),
 | |
| 			Type:      api.ServiceTypeLoadBalancer,
 | |
| 			ClusterIP: "",
 | |
| 		}
 | |
| 	default:
 | |
| 		return cmdutil.UsageError(cmd, fmt.Sprintf("Generator: %s not supported.", generatorName))
 | |
| 	}
 | |
| 	return RunCreateSubcommand(f, cmd, cmdOut, &CreateSubcommandOptions{
 | |
| 		Name:                name,
 | |
| 		StructuredGenerator: generator,
 | |
| 		DryRun:              cmdutil.GetFlagBool(cmd, "dry-run"),
 | |
| 		OutputFormat:        cmdutil.GetFlagString(cmd, "output"),
 | |
| 	})
 | |
| }
 | |
| 
 | |
| var (
 | |
| 	serviceExternalNameLong = templates.LongDesc(`
 | |
| 	Create an ExternalName service with the specified name.
 | |
| 
 | |
| 	ExternalName service references to an external DNS address instead of
 | |
| 	only pods, which will allow application authors to reference services
 | |
| 	that exist off platform, on other clusters, or locally.`)
 | |
| 
 | |
| 	serviceExternalNameExample = templates.Examples(`
 | |
| 	# Create a new ExternalName service named my-ns 
 | |
| 	kubectl create service externalname my-ns --external-name bar.com`)
 | |
| )
 | |
| 
 | |
| // NewCmdCreateServiceExternalName is a macro command for creating a ExternalName service
 | |
| func NewCmdCreateServiceExternalName(f cmdutil.Factory, cmdOut io.Writer) *cobra.Command {
 | |
| 	cmd := &cobra.Command{
 | |
| 		Use:     "externalname NAME --external-name external.name [--dry-run]",
 | |
| 		Short:   "Create an ExternalName service.",
 | |
| 		Long:    serviceExternalNameLong,
 | |
| 		Example: serviceExternalNameExample,
 | |
| 		Run: func(cmd *cobra.Command, args []string) {
 | |
| 			err := CreateExternalNameService(f, cmdOut, cmd, args)
 | |
| 			cmdutil.CheckErr(err)
 | |
| 		},
 | |
| 	}
 | |
| 	cmdutil.AddApplyAnnotationFlags(cmd)
 | |
| 	cmdutil.AddValidateFlags(cmd)
 | |
| 	cmdutil.AddPrinterFlags(cmd)
 | |
| 	cmdutil.AddGeneratorFlags(cmd, cmdutil.ServiceExternalNameGeneratorV1Name)
 | |
| 	addPortFlags(cmd)
 | |
| 	cmd.Flags().String("external-name", "", "external name of service")
 | |
| 	cmd.MarkFlagRequired("external-name")
 | |
| 	return cmd
 | |
| }
 | |
| 
 | |
| // CreateExternalNameService is the implementation of the service externalname command
 | |
| func CreateExternalNameService(f cmdutil.Factory, cmdOut io.Writer, cmd *cobra.Command, args []string) error {
 | |
| 	name, err := NameFromCommandArgs(cmd, args)
 | |
| 	if err != nil {
 | |
| 		return err
 | |
| 	}
 | |
| 	var generator kubectl.StructuredGenerator
 | |
| 	switch generatorName := cmdutil.GetFlagString(cmd, "generator"); generatorName {
 | |
| 	case cmdutil.ServiceExternalNameGeneratorV1Name:
 | |
| 		generator = &kubectl.ServiceCommonGeneratorV1{
 | |
| 			Name:         name,
 | |
| 			Type:         api.ServiceTypeExternalName,
 | |
| 			ExternalName: cmdutil.GetFlagString(cmd, "external-name"),
 | |
| 			ClusterIP:    "",
 | |
| 		}
 | |
| 	default:
 | |
| 		return cmdutil.UsageError(cmd, fmt.Sprintf("Generator: %s not supported.", generatorName))
 | |
| 	}
 | |
| 	return RunCreateSubcommand(f, cmd, cmdOut, &CreateSubcommandOptions{
 | |
| 		Name:                name,
 | |
| 		StructuredGenerator: generator,
 | |
| 		DryRun:              cmdutil.GetDryRunFlag(cmd),
 | |
| 		OutputFormat:        cmdutil.GetFlagString(cmd, "output"),
 | |
| 	})
 | |
| }
 |