12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667 |
- package main
- import (
- "fmt"
- "github.com/docker/libnetwork"
- "github.com/docker/libnetwork/netlabel"
- "github.com/docker/libnetwork/options"
- "github.com/docker/libnetwork/types"
- )
- func main() {
- // Create a new controller instance
- controller, err := libnetwork.New()
- if err != nil {
- return
- }
- // Select and configure the network driver
- networkType := "bridge"
- driverOptions := options.Generic{}
- genericOption := make(map[string]interface{})
- genericOption[netlabel.GenericData] = driverOptions
- err = controller.ConfigureNetworkDriver(networkType, genericOption)
- if err != nil {
- return
- }
- // 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 {
- return
- }
- // 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 {
- return
- }
- // Create the sandbox for the containr.
- sbx, err := controller.NewSandbox("container1",
- libnetwork.OptionHostname("test"),
- libnetwork.OptionDomainname("docker.io"))
- // A sandbox can join the endpoint via the join api.
- // Join accepts Variadic arguments which libnetwork and Drivers can use.
- err = ep.Join(sbx)
- if err != nil {
- return
- }
- // libnetwork client can check the endpoint's operational data via the Info() API
- epInfo, err := ep.DriverInfo()
- mapData, ok := epInfo[netlabel.PortMap]
- if ok {
- portMapping, ok := mapData.([]types.PortBinding)
- if ok {
- fmt.Printf("Current port mapping for endpoint %s: %v", ep.Name(), portMapping)
- }
- }
- }
|