mirror of
https://github.com/containers/podman.git
synced 2025-10-25 18:25:59 +08:00
add macvlan as a supported network driver
instead of using the --macvlan to indicate that you want to make a macvlan network, podman network create now honors the driver name of *macvlan*. Any options to macvlan, like the parent device, should be specified as a -o option. For example, -o parent=eth0. the --macvlan option was marked as deprecated in the man page but is still supported for the duration of 3.0. Signed-off-by: baude <bbaude@redhat.com>
This commit is contained in:
@ -29,7 +29,7 @@ func Create(name string, options entities.NetworkCreateOptions, runtimeConfig *c
|
||||
return nil, err
|
||||
}
|
||||
defer l.releaseCNILock()
|
||||
if len(options.MacVLAN) > 0 {
|
||||
if len(options.MacVLAN) > 0 || options.Driver == MacVLANNetworkDriver {
|
||||
fileName, err = createMacVLAN(name, options, runtimeConfig)
|
||||
} else {
|
||||
fileName, err = createBridge(name, options, runtimeConfig)
|
||||
@ -256,9 +256,17 @@ func createMacVLAN(name string, options entities.NetworkCreateOptions, runtimeCo
|
||||
return "", err
|
||||
}
|
||||
|
||||
// Make sure the host-device exists
|
||||
if !util.StringInSlice(options.MacVLAN, liveNetNames) {
|
||||
return "", errors.Errorf("failed to find network interface %q", options.MacVLAN)
|
||||
// The parent can be defined with --macvlan or as an option (-o parent:device)
|
||||
parentNetworkDevice := options.MacVLAN
|
||||
if len(parentNetworkDevice) < 1 {
|
||||
if parent, ok := options.Options["parent"]; ok {
|
||||
parentNetworkDevice = parent
|
||||
}
|
||||
}
|
||||
|
||||
// Make sure the host-device exists if provided
|
||||
if len(parentNetworkDevice) > 0 && !util.StringInSlice(parentNetworkDevice, liveNetNames) {
|
||||
return "", errors.Errorf("failed to find network interface %q", parentNetworkDevice)
|
||||
}
|
||||
if len(name) > 0 {
|
||||
netNames, err := GetNetworkNamesFromFileSystem(runtimeConfig)
|
||||
@ -275,7 +283,7 @@ func createMacVLAN(name string, options entities.NetworkCreateOptions, runtimeCo
|
||||
}
|
||||
}
|
||||
ncList := NewNcList(name, version.Current(), options.Labels)
|
||||
macvlan := NewMacVLANPlugin(options.MacVLAN)
|
||||
macvlan := NewMacVLANPlugin(parentNetworkDevice)
|
||||
plugins = append(plugins, macvlan)
|
||||
ncList["plugins"] = plugins
|
||||
b, err := json.MarshalIndent(ncList, "", " ")
|
||||
|
||||
@ -177,9 +177,13 @@ func NewMacVLANPlugin(device string) MacVLANConfig {
|
||||
|
||||
m := MacVLANConfig{
|
||||
PluginType: "macvlan",
|
||||
Master: device,
|
||||
IPAM: i,
|
||||
}
|
||||
// CNI is supposed to use the default route if a
|
||||
// parent device is not provided
|
||||
if len(device) > 0 {
|
||||
m.Master = device
|
||||
}
|
||||
return m
|
||||
}
|
||||
|
||||
|
||||
@ -17,11 +17,17 @@ import (
|
||||
"github.com/sirupsen/logrus"
|
||||
)
|
||||
|
||||
// DefaultNetworkDriver is the default network type used
|
||||
var DefaultNetworkDriver = "bridge"
|
||||
var (
|
||||
// BridgeNetworkDriver defines the bridge cni driver
|
||||
BridgeNetworkDriver = "bridge"
|
||||
// DefaultNetworkDriver is the default network type used
|
||||
DefaultNetworkDriver = BridgeNetworkDriver
|
||||
// MacVLANNetworkDriver defines the macvlan cni driver
|
||||
MacVLANNetworkDriver = "macvlan"
|
||||
)
|
||||
|
||||
// SupportedNetworkDrivers describes the list of supported drivers
|
||||
var SupportedNetworkDrivers = []string{DefaultNetworkDriver}
|
||||
var SupportedNetworkDrivers = []string{BridgeNetworkDriver, MacVLANNetworkDriver}
|
||||
|
||||
// isSupportedDriver checks if the user provided driver is supported
|
||||
func isSupportedDriver(driver string) error {
|
||||
|
||||
Reference in New Issue
Block a user