mirror of
				https://github.com/containers/podman.git
				synced 2025-10-25 18:25:59 +08:00 
			
		
		
		
	Merge pull request #11751 from Luap99/net-alias
always add short container id as net alias
This commit is contained in:
		| @ -1310,7 +1310,7 @@ func (c *Container) restore(ctx context.Context, options ContainerCheckpointOpti | ||||
| 	if err == nil && options.Name == "" && (!options.IgnoreStaticIP || !options.IgnoreStaticMAC) { | ||||
| 		// The file with the network.status does exist. Let's restore the | ||||
| 		// container with the same networks settings as during checkpointing. | ||||
| 		aliases, err := c.runtime.state.GetAllNetworkAliases(c) | ||||
| 		aliases, err := c.GetAllNetworkAliases() | ||||
| 		if err != nil { | ||||
| 			return err | ||||
| 		} | ||||
|  | ||||
| @ -186,9 +186,6 @@ outer: | ||||
| 		} | ||||
| 		return errors.Errorf("requested static ip %s not in any subnet on network %s", ip.String(), network.libpodNet.Name) | ||||
| 	} | ||||
| 	if len(netOpts.Aliases) > 0 && !network.libpodNet.DNSEnabled { | ||||
| 		return errors.New("cannot set aliases on a network without dns enabled") | ||||
| 	} | ||||
| 	return nil | ||||
| } | ||||
|  | ||||
|  | ||||
| @ -966,6 +966,26 @@ var _ = Describe("run CNI", func() { | ||||
| 			}) | ||||
| 		}) | ||||
|  | ||||
| 		It("setup with aliases but dns disabled should work", func() { | ||||
| 			runTest(func() { | ||||
| 				defNet := types.DefaultNetworkName | ||||
| 				intName := "eth0" | ||||
| 				setupOpts := types.SetupOptions{ | ||||
| 					NetworkOptions: types.NetworkOptions{ | ||||
| 						ContainerID: stringid.GenerateNonCryptoID(), | ||||
| 						Networks: map[string]types.PerNetworkOptions{ | ||||
| 							defNet: { | ||||
| 								InterfaceName: intName, | ||||
| 								Aliases:       []string{"somealias"}, | ||||
| 							}, | ||||
| 						}, | ||||
| 					}, | ||||
| 				} | ||||
| 				_, err := libpodNet.Setup(netNSContainer.Path(), setupOpts) | ||||
| 				Expect(err).ToNot(HaveOccurred()) | ||||
| 			}) | ||||
| 		}) | ||||
|  | ||||
| 	}) | ||||
|  | ||||
| 	Context("invalid network setup test", func() { | ||||
| @ -1052,27 +1072,6 @@ var _ = Describe("run CNI", func() { | ||||
| 			}) | ||||
| 		}) | ||||
|  | ||||
| 		It("setup with aliases but dns disabled", func() { | ||||
| 			runTest(func() { | ||||
| 				defNet := types.DefaultNetworkName | ||||
| 				intName := "eth0" | ||||
| 				setupOpts := types.SetupOptions{ | ||||
| 					NetworkOptions: types.NetworkOptions{ | ||||
| 						ContainerID: stringid.GenerateNonCryptoID(), | ||||
| 						Networks: map[string]types.PerNetworkOptions{ | ||||
| 							defNet: { | ||||
| 								InterfaceName: intName, | ||||
| 								Aliases:       []string{"somealias"}, | ||||
| 							}, | ||||
| 						}, | ||||
| 					}, | ||||
| 				} | ||||
| 				_, err := libpodNet.Setup(netNSContainer.Path(), setupOpts) | ||||
| 				Expect(err).To(HaveOccurred()) | ||||
| 				Expect(err.Error()).To(ContainSubstring("cannot set aliases on a network without dns enabled")) | ||||
| 			}) | ||||
| 		}) | ||||
|  | ||||
| 		It("setup without networks", func() { | ||||
| 			runTest(func() { | ||||
| 				setupOpts := types.SetupOptions{ | ||||
|  | ||||
| @ -151,7 +151,9 @@ type PerNetworkOptions struct { | ||||
| 	// StaticIPv4 for this container. Optional. | ||||
| 	StaticIPs []net.IP `json:"static_ips,omitempty"` | ||||
| 	// Aliases contains a list of names which the dns server should resolve | ||||
| 	// to this container. Can only be set when DNSEnabled is true on the Network. | ||||
| 	// to this container. Should only be set when DNSEnabled is true on the Network. | ||||
| 	// If aliases are set but there is no dns support for this network the | ||||
| 	// network interface implementation should ignore this and NOT error. | ||||
| 	// Optional. | ||||
| 	Aliases []string `json:"aliases,omitempty"` | ||||
| 	// StaticMac for this container. Optional. | ||||
|  | ||||
| @ -48,6 +48,41 @@ const ( | ||||
| 	persistentCNIDir = "/var/lib/cni" | ||||
| ) | ||||
|  | ||||
| // GetAllNetworkAliases returns all configured aliases for this container. | ||||
| // It also adds the container short ID as alias to match docker. | ||||
| func (c *Container) GetAllNetworkAliases() (map[string][]string, error) { | ||||
| 	allAliases, err := c.runtime.state.GetAllNetworkAliases(c) | ||||
| 	if err != nil { | ||||
| 		return nil, err | ||||
| 	} | ||||
|  | ||||
| 	// get the all attached networks, we cannot use GetAllNetworkAliases() | ||||
| 	// since it returns nil if there are no aliases | ||||
| 	nets, _, err := c.networks() | ||||
| 	if err != nil { | ||||
| 		return nil, err | ||||
| 	} | ||||
|  | ||||
| 	// add container short ID as alias to match docker | ||||
| 	for _, net := range nets { | ||||
| 		allAliases[net] = append(allAliases[net], c.config.ID[:12]) | ||||
| 	} | ||||
| 	return allAliases, nil | ||||
| } | ||||
|  | ||||
| // GetNetworkAliases returns configured aliases for this network. | ||||
| // It also adds the container short ID as alias to match docker. | ||||
| func (c *Container) GetNetworkAliases(netName string) ([]string, error) { | ||||
| 	aliases, err := c.runtime.state.GetNetworkAliases(c, netName) | ||||
| 	if err != nil { | ||||
| 		return nil, err | ||||
| 	} | ||||
|  | ||||
| 	// add container short ID as alias to match docker | ||||
| 	aliases = append(aliases, c.config.ID[:12]) | ||||
| 	return aliases, nil | ||||
| } | ||||
|  | ||||
| func (c *Container) getNetworkOptions() (types.NetworkOptions, error) { | ||||
| 	opts := types.NetworkOptions{ | ||||
| 		ContainerID:   c.config.ID, | ||||
| @ -61,7 +96,7 @@ func (c *Container) getNetworkOptions() (types.NetworkOptions, error) { | ||||
| 	if err != nil { | ||||
| 		return opts, err | ||||
| 	} | ||||
| 	aliases, err := c.runtime.state.GetAllNetworkAliases(c) | ||||
| 	aliases, err := c.GetAllNetworkAliases() | ||||
| 	if err != nil { | ||||
| 		return opts, err | ||||
| 	} | ||||
| @ -872,7 +907,7 @@ func (r *Runtime) reloadContainerNetwork(ctr *Container) (map[string]types.Statu | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	aliases, err := ctr.runtime.state.GetAllNetworkAliases(ctr) | ||||
| 	aliases, err := ctr.GetAllNetworkAliases() | ||||
| 	if err != nil { | ||||
| 		return nil, err | ||||
| 	} | ||||
| @ -975,6 +1010,11 @@ func (c *Container) getContainerNetworkInfo() (*define.InspectNetworkSettings, e | ||||
| 			for _, net := range networks { | ||||
| 				cniNet := new(define.InspectAdditionalNetwork) | ||||
| 				cniNet.NetworkID = net | ||||
| 				aliases, err := c.GetNetworkAliases(net) | ||||
| 				if err != nil { | ||||
| 					return nil, err | ||||
| 				} | ||||
| 				cniNet.Aliases = aliases | ||||
| 				settings.Networks[net] = cniNet | ||||
| 			} | ||||
| 		} | ||||
| @ -1009,7 +1049,7 @@ func (c *Container) getContainerNetworkInfo() (*define.InspectNetworkSettings, e | ||||
| 				return nil, err | ||||
| 			} | ||||
|  | ||||
| 			aliases, err := c.runtime.state.GetNetworkAliases(c, name) | ||||
| 			aliases, err := c.GetNetworkAliases(name) | ||||
| 			if err != nil { | ||||
| 				return nil, err | ||||
| 			} | ||||
| @ -1222,6 +1262,14 @@ func (c *Container) NetworkConnect(nameOrID, netName string, aliases []string) e | ||||
| 	// get network status before we connect | ||||
| 	networkStatus := c.getNetworkStatus() | ||||
|  | ||||
| 	network, err := c.runtime.network.NetworkInspect(netName) | ||||
| 	if err != nil { | ||||
| 		return err | ||||
| 	} | ||||
| 	if !network.DNSEnabled && len(aliases) > 0 { | ||||
| 		return errors.Wrapf(define.ErrInvalidArg, "cannot set network aliases for network %q because dns is disabled", netName) | ||||
| 	} | ||||
|  | ||||
| 	if err := c.runtime.state.NetworkConnect(c, netName, aliases); err != nil { | ||||
| 		return err | ||||
| 	} | ||||
| @ -1253,6 +1301,7 @@ func (c *Container) NetworkConnect(nameOrID, netName string, aliases []string) e | ||||
| 	if !exists { | ||||
| 		return errors.Errorf("no network interface name for container %s on network %s", c.config.ID, netName) | ||||
| 	} | ||||
| 	aliases = append(aliases, c.config.ID[:12]) | ||||
| 	opts.Networks = map[string]types.PerNetworkOptions{ | ||||
| 		netName: { | ||||
| 			Aliases:       aliases, | ||||
|  | ||||
| @ -234,13 +234,6 @@ func (r *Runtime) newContainer(ctx context.Context, rSpec *spec.Spec, options .. | ||||
| } | ||||
|  | ||||
| func (r *Runtime) setupContainer(ctx context.Context, ctr *Container) (_ *Container, retErr error) { | ||||
| 	// Validate the container | ||||
| 	if err := ctr.validate(); err != nil { | ||||
| 		return nil, err | ||||
| 	} | ||||
| 	if ctr.config.IsInfra { | ||||
| 		ctr.config.StopTimeout = 10 | ||||
| 	} | ||||
| 	// normalize the networks to names | ||||
| 	// ocicni only knows about cni names so we have to make | ||||
| 	// sure we do not use ids internally | ||||
| @ -265,11 +258,26 @@ func (r *Runtime) setupContainer(ctx context.Context, ctr *Container) (_ *Contai | ||||
| 			if err != nil { | ||||
| 				return nil, err | ||||
| 			} | ||||
| 			network, err := r.network.NetworkInspect(netName) | ||||
| 			if err != nil { | ||||
| 				return nil, err | ||||
| 			} | ||||
| 			if !network.DNSEnabled { | ||||
| 				return nil, errors.Wrapf(define.ErrInvalidArg, "cannot set network aliases for network %q because dns is disabled", netName) | ||||
| 			} | ||||
| 			netAliases[netName] = aliases | ||||
| 		} | ||||
| 		ctr.config.NetworkAliases = netAliases | ||||
| 	} | ||||
|  | ||||
| 	// Validate the container | ||||
| 	if err := ctr.validate(); err != nil { | ||||
| 		return nil, err | ||||
| 	} | ||||
| 	if ctr.config.IsInfra { | ||||
| 		ctr.config.StopTimeout = 10 | ||||
| 	} | ||||
|  | ||||
| 	// Inhibit shutdown until creation succeeds | ||||
| 	shutdown.Inhibit() | ||||
| 	defer shutdown.Uninhibit() | ||||
|  | ||||
		Reference in New Issue
	
	Block a user
	 OpenShift Merge Robot
					OpenShift Merge Robot