1
0
Fork 0
mirror of https://github.com/moby/moby.git synced 2022-11-09 12:21:53 -05:00
moby--moby/libnetwork
fanjiyun a24e5f5fd4 reduce parameters for func JoinOptionPriority
Signed-off-by: fanjiyun <fan.jiyun@zte.com.cn>
2020-05-15 18:29:54 +08:00
..
.circleci
api
bitseq Fix gofmt in preparation of Go 1.13 update 2020-02-27 11:46:16 +01:00
client
cluster
cmd Migrate from github.com/codegangsta/cli to github.com/urfave/cli 2020-01-24 11:12:07 +01:00
config Added API to set ephemeral port allocator range. 2019-10-11 18:48:07 +00:00
datastore
diagnostic
discoverapi
docs Update design.md 2020-02-18 17:21:39 -08:00
driverapi
drivers Merge pull request #2460 from moby/revert-2450-iptables-policy 2020-03-18 11:22:47 -07:00
drvregistry
etchosts
hostdiscovery
idm
internal
ipam
ipamapi
ipams Fixes moby/moby#40388 2020-03-18 00:09:10 +08:00
ipamutils
iptables vendor godbus/dbus v5 2020-02-28 18:47:00 +09:00
netlabel Support for com.docker.network.host_ipv4 driver label 2019-09-24 22:15:43 -07:00
netutils
networkdb regenerate protobufs with debian buster 2020-02-26 16:03:42 +01:00
ns
options
osl Improving load balancer performance 2020-02-14 13:24:06 -08:00
portallocator Added API to set ephemeral port allocator range. 2019-10-11 18:48:07 +00:00
portmapper
resolvconf
support Resolve "bridge fdb show" hang issue 2019-09-26 21:29:22 +00:00
test/integration
testutils
types
vendor vendor: update moby/ipvs v1.0.1 2020-04-28 17:04:14 +02:00
.dockerignore
.gitignore
agent.go Fix NPE due to null value returned by ep.Iface() 2020-04-02 22:34:55 -07:00
agent.pb.go
agent.proto
CHANGELOG.md
controller.go Merge pull request #2471 from suwang48404/master 2020-04-09 15:01:08 -07:00
default_gateway.go
default_gateway_freebsd.go
default_gateway_linux.go
default_gateway_windows.go
Dockerfile Dockerfile: update to Go 1.13.8 2020-02-27 11:46:18 +01:00
drivers_freebsd.go
drivers_ipam.go
drivers_linux.go
drivers_windows.go
endpoint.go reduce parameters for func JoinOptionPriority 2020-05-15 18:29:54 +08:00
endpoint_cnt.go
endpoint_info.go
endpoint_info_unix.go
endpoint_info_windows.go
endpoint_test.go reduce parameters for func JoinOptionPriority 2020-05-15 18:29:54 +08:00
error.go
errors_test.go
firewall_linux.go DOCKER-USER chain not created when IPTableEnable=false. 2019-11-12 16:32:42 +00:00
firewall_others.go DOCKER-USER chain not created when IPTableEnable=false. 2019-11-12 16:32:42 +00:00
firewall_test.go DOCKER-USER chain not created when IPTableEnable=false. 2019-11-12 16:32:42 +00:00
libnetwork_internal_test.go
libnetwork_linux_test.go
libnetwork_test.go
LICENSE
machines
MAINTAINERS Add Arko to maintainers 2019-12-31 11:04:32 +01:00
Makefile
network.go Fix NPE due to null value returned by ep.Iface() 2020-04-02 22:34:55 -07:00
network_unix.go
network_windows.go
README.md
resolver.go Fixes a panic in the DNS resolver 2020-03-18 13:59:59 -04:00
resolver_test.go
resolver_unix.go
resolver_windows.go
sandbox.go
sandbox_dns_unix.go etchosts: allow adding multiple container ips 2019-08-30 23:49:33 +02:00
sandbox_dns_windows.go etchosts: allow adding multiple container ips 2019-08-30 23:49:33 +02:00
sandbox_externalkey.go
sandbox_externalkey_unix.go Shorten controller ID in exec-root to not hit UNIX_PATH_MAX 2019-08-28 18:59:49 +01:00
sandbox_externalkey_windows.go
sandbox_store.go
sandbox_test.go reduce parameters for func JoinOptionPriority 2020-05-15 18:29:54 +08:00
service.go
service_common.go Cleanup VFP during overlay network removal 2020-03-03 19:48:38 -05:00
service_common_test.go
service_linux.go Use vendored ipvs package 2020-03-11 12:13:37 -07:00
service_unsupported.go
service_windows.go
store.go return immediately on error 2019-09-24 10:58:08 +02:00
store_linux_test.go
store_test.go
Vagrantfile
vendor.conf vendor: update moby/ipvs v1.0.1 2020-04-28 17:04:14 +02:00

libnetwork - networking for containers

Circle CI Coverage Status GoDoc Go Report Card

Libnetwork provides a native Go implementation for connecting containers

The goal of libnetwork is to deliver a robust Container Network Model that provides a consistent programming interface and the required network abstractions for applications.

Design

Please refer to the design for more information.

Using libnetwork

There are many networking solutions available to suit a broad range of use-cases. libnetwork uses a driver / plugin model to support all of these solutions while abstracting the complexity of the driver implementations by exposing a simple and consistent Network Model to users.

import (
	"fmt"
	"log"

	"github.com/docker/docker/pkg/reexec"
	"github.com/docker/libnetwork"
	"github.com/docker/libnetwork/config"
	"github.com/docker/libnetwork/netlabel"
	"github.com/docker/libnetwork/options"
)

func main() {
	if reexec.Init() {
		return
	}

	// Select and configure the network driver
	networkType := "bridge"

	// Create a new controller instance
	driverOptions := options.Generic{}
	genericOption := make(map[string]interface{})
	genericOption[netlabel.GenericData] = driverOptions
	controller, err := libnetwork.New(config.OptionDriverConfig(networkType, genericOption))
	if err != nil {
		log.Fatalf("libnetwork.New: %s", err)
	}

	// Create a network for containers to join.
	// NewNetwork accepts Variadic optional arguments that libnetwork and Drivers can use.
	network, err := controller.NewNetwork(networkType, "network1", "")
	if err != nil {
		log.Fatalf("controller.NewNetwork: %s", err)
	}

	// For each new container: allocate IP and interfaces. The returned network
	// settings will be used for container infos (inspect and such), as well as
	// iptables rules for port publishing. This info is contained or accessible
	// from the returned endpoint.
	ep, err := network.CreateEndpoint("Endpoint1")
	if err != nil {
		log.Fatalf("network.CreateEndpoint: %s", err)
	}

	// Create the sandbox for the container.
	// NewSandbox accepts Variadic optional arguments which libnetwork can use.
	sbx, err := controller.NewSandbox("container1",
		libnetwork.OptionHostname("test"),
		libnetwork.OptionDomainname("docker.io"))
	if err != nil {
		log.Fatalf("controller.NewSandbox: %s", err)
	}

	// A sandbox can join the endpoint via the join api.
	err = ep.Join(sbx)
	if err != nil {
		log.Fatalf("ep.Join: %s", err)
	}

	// libnetwork client can check the endpoint's operational data via the Info() API
	epInfo, err := ep.DriverInfo()
	if err != nil {
		log.Fatalf("ep.DriverInfo: %s", err)
	}

	macAddress, ok := epInfo[netlabel.MacAddress]
	if !ok {
		log.Fatalf("failed to get mac address from endpoint info")
	}

	fmt.Printf("Joined endpoint %s (%s) to sandbox %s (%s)\n", ep.Name(), macAddress, sbx.ContainerID(), sbx.Key())
}

Contributing

Want to hack on libnetwork? Docker's contributions guidelines apply.

Code and documentation copyright 2015 Docker, inc. Code released under the Apache 2.0 license. Docs released under Creative commons.