Merge pull request #10820 from jvanz/indfra-container-name-issue-10794
--infra-name command line argument
This commit is contained in:
		
						commit
						ce28dc3c4c
					
				|  | @ -86,6 +86,10 @@ func init() { | |||
| 	flags.String(infraCommandFlagName, containerConfig.Engine.InfraCommand, "The command to run on the infra container when the pod is started") | ||||
| 	_ = createCommand.RegisterFlagCompletionFunc(infraCommandFlagName, completion.AutocompleteNone) | ||||
| 
 | ||||
| 	infraNameFlagName := "infra-name" | ||||
| 	flags.StringVarP(&createOptions.InfraName, infraNameFlagName, "", "", "The name used as infra container name") | ||||
| 	_ = createCommand.RegisterFlagCompletionFunc(infraNameFlagName, completion.AutocompleteNone) | ||||
| 
 | ||||
| 	labelFileFlagName := "label-file" | ||||
| 	flags.StringSliceVar(&labelFile, labelFileFlagName, []string{}, "Read in a line delimited file of labels") | ||||
| 	_ = createCommand.RegisterFlagCompletionFunc(labelFileFlagName, completion.AutocompleteDefault) | ||||
|  | @ -148,6 +152,9 @@ func create(cmd *cobra.Command, args []string) error { | |||
| 			return errors.New("cannot set infra-image without an infra container") | ||||
| 		} | ||||
| 		createOptions.InfraImage = "" | ||||
| 		if createOptions.InfraName != "" { | ||||
| 			return errors.New("cannot set infra-name without an infra container") | ||||
| 		} | ||||
| 
 | ||||
| 		if cmd.Flag("share").Changed && share != "none" && share != "" { | ||||
| 			return fmt.Errorf("cannot set share(%s) namespaces without an infra container", cmd.Flag("share").Value) | ||||
|  |  | |||
|  | @ -75,6 +75,10 @@ The command that will be run to start the infra container. Default: "/pause". | |||
| 
 | ||||
| The image that will be created for the infra container. Default: "k8s.gcr.io/pause:3.1". | ||||
| 
 | ||||
| #### **--infra-name**=*name* | ||||
| 
 | ||||
| The name that will be used for the pod's infra container. | ||||
| 
 | ||||
| #### **--ip**=*ipaddr* | ||||
| 
 | ||||
| Set a static IP for the pod's shared network. | ||||
|  |  | |||
|  | @ -459,6 +459,19 @@ func WithDefaultInfraCommand(cmd string) RuntimeOption { | |||
| 	} | ||||
| } | ||||
| 
 | ||||
| // WithDefaultInfraName sets the infra container name for a single pod.
 | ||||
| func WithDefaultInfraName(name string) RuntimeOption { | ||||
| 	return func(rt *Runtime) error { | ||||
| 		if rt.valid { | ||||
| 			return define.ErrRuntimeFinalized | ||||
| 		} | ||||
| 
 | ||||
| 		rt.config.Engine.InfraImage = name | ||||
| 
 | ||||
| 		return nil | ||||
| 	} | ||||
| } | ||||
| 
 | ||||
| // WithRenumber instructs libpod to perform a lock renumbering while
 | ||||
| // initializing. This will handle migrations from early versions of libpod with
 | ||||
| // file locks to newer versions with SHM locking, as well as changes in the
 | ||||
|  | @ -1787,6 +1800,19 @@ func WithInfraCommand(cmd []string) PodCreateOption { | |||
| 	} | ||||
| } | ||||
| 
 | ||||
| // WithInfraName sets the infra container name for a single pod.
 | ||||
| func WithInfraName(name string) PodCreateOption { | ||||
| 	return func(pod *Pod) error { | ||||
| 		if pod.valid { | ||||
| 			return define.ErrPodFinalized | ||||
| 		} | ||||
| 
 | ||||
| 		pod.config.InfraContainer.InfraName = name | ||||
| 
 | ||||
| 		return nil | ||||
| 	} | ||||
| } | ||||
| 
 | ||||
| // WithPodName sets the name of the pod.
 | ||||
| func WithPodName(name string) PodCreateOption { | ||||
| 	return func(pod *Pod) error { | ||||
|  |  | |||
|  | @ -112,6 +112,7 @@ type InfraContainerConfig struct { | |||
| 	ExitCommand        []string              `json:"exitCommand,omitempty"` | ||||
| 	InfraImage         string                `json:"infraImage,omitempty"` | ||||
| 	InfraCommand       []string              `json:"infraCommand,omitempty"` | ||||
| 	InfraName          string                `json:"infraName,omitempty"` | ||||
| 	Slirp4netns        bool                  `json:"slirp4netns,omitempty"` | ||||
| 	NetworkOptions     map[string][]string   `json:"network_options,omitempty"` | ||||
| 	ResourceLimits     *specs.LinuxResources `json:"resource_limits,omitempty"` | ||||
|  |  | |||
|  | @ -201,7 +201,11 @@ func (r *Runtime) makeInfraContainer(ctx context.Context, p *Pod, imgName, rawIm | |||
| 		g.AddLinuxSysctl(sysctlKey, sysctlVal) | ||||
| 	} | ||||
| 
 | ||||
| 	containerName := p.ID()[:IDTruncLength] + "-infra" | ||||
| 	containerName := p.config.InfraContainer.InfraName | ||||
| 	if containerName == "" { | ||||
| 		containerName = p.ID()[:IDTruncLength] + "-infra" | ||||
| 	} | ||||
| 	logrus.Infof("Infra container name %s", containerName) | ||||
| 	options = append(options, r.WithPod(p)) | ||||
| 	options = append(options, WithRootFSFromImage(imgID, imgName, rawImageName)) | ||||
| 	options = append(options, WithName(containerName)) | ||||
|  |  | |||
|  | @ -133,6 +133,7 @@ type PodCreateConfig struct { | |||
| 	Infra        bool     `json:"infra"` | ||||
| 	InfraCommand string   `json:"infra-command"` | ||||
| 	InfraImage   string   `json:"infra-image"` | ||||
| 	InfraName    string   `json:"infra-name"` | ||||
| 	Labels       []string `json:"labels"` | ||||
| 	Publish      []string `json:"publish"` | ||||
| 	Share        string   `json:"share"` | ||||
|  |  | |||
|  | @ -112,6 +112,7 @@ type PodCreateOptions struct { | |||
| 	Hostname           string | ||||
| 	Infra              bool | ||||
| 	InfraImage         string | ||||
| 	InfraName          string | ||||
| 	InfraCommand       string | ||||
| 	InfraConmonPidFile string | ||||
| 	Labels             map[string]string | ||||
|  | @ -172,6 +173,7 @@ func (p *PodCreateOptions) ToPodSpecGen(s *specgen.PodSpecGenerator) error { | |||
| 		s.InfraConmonPidFile = p.InfraConmonPidFile | ||||
| 	} | ||||
| 	s.InfraImage = p.InfraImage | ||||
| 	s.InfraName = p.InfraName | ||||
| 	s.SharedNamespaces = p.Share | ||||
| 	s.PodCreateCommand = p.CreateCommand | ||||
| 
 | ||||
|  |  | |||
|  | @ -98,6 +98,10 @@ func createPodOptions(p *specgen.PodSpecGenerator, rt *libpod.Runtime) ([]libpod | |||
| 		options = append(options, libpod.WithInfraImage(p.InfraImage)) | ||||
| 	} | ||||
| 
 | ||||
| 	if len(p.InfraName) > 0 { | ||||
| 		options = append(options, libpod.WithInfraName(p.InfraName)) | ||||
| 	} | ||||
| 
 | ||||
| 	if len(p.InfraCommand) > 0 { | ||||
| 		options = append(options, libpod.WithInfraCommand(p.InfraCommand)) | ||||
| 	} | ||||
|  |  | |||
|  | @ -36,6 +36,9 @@ func (p *PodSpecGenerator) Validate() error { | |||
| 		if len(p.InfraImage) > 0 { | ||||
| 			return exclusivePodOptions("NoInfra", "InfraImage") | ||||
| 		} | ||||
| 		if len(p.InfraName) > 0 { | ||||
| 			return exclusivePodOptions("NoInfra", "InfraName") | ||||
| 		} | ||||
| 		if len(p.SharedNamespaces) > 0 { | ||||
| 			return exclusivePodOptions("NoInfra", "SharedNamespaces") | ||||
| 		} | ||||
|  |  | |||
|  | @ -43,6 +43,12 @@ type PodBasicConfig struct { | |||
| 	// Conflicts with NoInfra=true.
 | ||||
| 	// Optional.
 | ||||
| 	InfraImage string `json:"infra_image,omitempty"` | ||||
| 	// InfraName is the name that will be used for the infra container.
 | ||||
| 	// If not set, the default set in the Libpod configuration file will be
 | ||||
| 	// used.
 | ||||
| 	// Conflicts with NoInfra=true.
 | ||||
| 	// Optional.
 | ||||
| 	InfraName string `json:"infra_name,omitempty"` | ||||
| 	// SharedNamespaces instructs the pod to share a set of namespaces.
 | ||||
| 	// Shared namespaces will be joined (by default) by every container
 | ||||
| 	// which joins the pod.
 | ||||
|  |  | |||
|  | @ -205,6 +205,7 @@ function random_ip() { | |||
|     # entrypoint to confirm that --infra-command will override. | ||||
|     local infra_image="infra_$(random_string 10 | tr A-Z a-z)" | ||||
|     local infra_command="/pause_$(random_string 10)" | ||||
|     local infra_name="infra_container_$(random_string 10 | tr A-Z a-z)" | ||||
|     run_podman build -t $infra_image - << EOF | ||||
| FROM $IMAGE | ||||
| RUN ln /home/podman/pause $infra_command | ||||
|  | @ -225,7 +226,8 @@ EOF | |||
|                --publish    "$port_out:$port_in"         \ | ||||
|                --label      "${labelname}=${labelvalue}" \ | ||||
|                --infra-image   "$infra_image"            \ | ||||
|                --infra-command "$infra_command" | ||||
|                --infra-command "$infra_command"          \ | ||||
|                --infra-name "$infra_name" | ||||
|     pod_id="$output" | ||||
| 
 | ||||
|     # Check --pod-id-file | ||||
|  | @ -237,6 +239,9 @@ EOF | |||
|     # confirm that entrypoint is what we set | ||||
|     run_podman container inspect --format '{{.Config.Entrypoint}}' $infra_cid | ||||
|     is "$output" "$infra_command" "infra-command took effect" | ||||
|     # confirm that infra container name is set | ||||
|     run_podman container inspect --format '{{.Name}}' $infra_cid | ||||
|     is "$output" "$infra_name" "infra-name took effect" | ||||
| 
 | ||||
|     # Check each of the options | ||||
|     if [ -n "$mac_option" ]; then | ||||
|  | @ -310,6 +315,16 @@ EOF | |||
|     run_podman rm $cid | ||||
|     run_podman pod rm -f mypod | ||||
|     run_podman rmi $infra_image | ||||
| 
 | ||||
| } | ||||
| 
 | ||||
| @test "podman pod create should fail when infra-name is already in use" { | ||||
|     local infra_name="infra_container_$(random_string 10 | tr A-Z a-z)" | ||||
|     run_podman pod create --infra-name "$infra_name" | ||||
|     run_podman '?' pod create --infra-name "$infra_name" | ||||
|     if [ $status -eq 0 ]; then | ||||
|         die "Podman should fail when user try to create two pods with the same infra-name value" | ||||
|     fi | ||||
| } | ||||
| 
 | ||||
| # vim: filetype=sh | ||||
|  |  | |||
		Loading…
	
		Reference in New Issue