set container links and external links in network

Signed-off-by: Lorena Rangel <lorena.rangel@docker.com>
This commit is contained in:
Lorena Rangel 2021-06-15 11:00:07 +02:00
parent 399f6cde5e
commit b38d35ae1c
3 changed files with 56 additions and 5 deletions

View File

@ -2,6 +2,8 @@ services:
container1: container1:
image: nginx image: nginx
links:
- container2:container
container2: container2:
image: nginx image: nginx

View File

@ -71,7 +71,7 @@ func TestNetworks(t *testing.T) {
}) })
} }
func TestNetworkAliasses(t *testing.T) { func TestNetworkAliassesAndLinks(t *testing.T) {
c := NewParallelE2eCLI(t, binDir) c := NewParallelE2eCLI(t, binDir)
const projectName = "network_alias_e2e" const projectName = "network_alias_e2e"
@ -80,11 +80,16 @@ func TestNetworkAliasses(t *testing.T) {
c.RunDockerCmd("compose", "-f", "./fixtures/network-alias/compose.yaml", "--project-name", projectName, "up", "-d") c.RunDockerCmd("compose", "-f", "./fixtures/network-alias/compose.yaml", "--project-name", projectName, "up", "-d")
}) })
t.Run("curl", func(t *testing.T) { t.Run("curl alias", func(t *testing.T) {
res := c.RunDockerCmd("compose", "-f", "./fixtures/network-alias/compose.yaml", "--project-name", projectName, "exec", "-T", "container1", "curl", "http://alias-of-container2/") res := c.RunDockerCmd("compose", "-f", "./fixtures/network-alias/compose.yaml", "--project-name", projectName, "exec", "-T", "container1", "curl", "http://alias-of-container2/")
assert.Assert(t, strings.Contains(res.Stdout(), "Welcome to nginx!"), res.Stdout()) assert.Assert(t, strings.Contains(res.Stdout(), "Welcome to nginx!"), res.Stdout())
}) })
t.Run("curl links", func(t *testing.T) {
res := c.RunDockerCmd("compose", "-f", "./fixtures/network-alias/compose.yaml", "--project-name", projectName, "exec", "-T", "container1", "curl", "container")
assert.Assert(t, strings.Contains(res.Stdout(), "Welcome to nginx!"), res.Stdout())
})
t.Run("down", func(t *testing.T) { t.Run("down", func(t *testing.T) {
_ = c.RunDockerCmd("compose", "--project-name", projectName, "down") _ = c.RunDockerCmd("compose", "--project-name", projectName, "down")
}) })

View File

@ -20,6 +20,7 @@ import (
"context" "context"
"fmt" "fmt"
"strconv" "strconv"
"strings"
"time" "time"
"github.com/compose-spec/compose-go/types" "github.com/compose-spec/compose-go/types"
@ -317,8 +318,14 @@ func (s *composeService) createMobyContainer(ctx context.Context, project *types
createdContainer := moby.Container{ createdContainer := moby.Container{
ID: created.ID, ID: created.ID,
Labels: containerConfig.Labels, Labels: containerConfig.Labels,
Names: []string{"/" + name},
} }
cState.Add(createdContainer) cState.Add(createdContainer)
links, err := s.getLinks(ctx, service)
if err != nil {
return err
}
for _, netName := range service.NetworksByPriority() { for _, netName := range service.NetworksByPriority() {
netwrk := project.Networks[netName] netwrk := project.Networks[netName]
cfg := service.Networks[netName] cfg := service.Networks[netName]
@ -330,7 +337,7 @@ func (s *composeService) createMobyContainer(ctx context.Context, project *types
} }
} }
err = s.connectContainerToNetwork(ctx, created.ID, netwrk.Name, cfg, aliases...) err = s.connectContainerToNetwork(ctx, created.ID, netwrk.Name, cfg, links, aliases...)
if err != nil { if err != nil {
return err return err
} }
@ -338,7 +345,7 @@ func (s *composeService) createMobyContainer(ctx context.Context, project *types
return nil return nil
} }
func (s *composeService) connectContainerToNetwork(ctx context.Context, id string, netwrk string, cfg *types.ServiceNetworkConfig, aliases ...string) error { func (s *composeService) connectContainerToNetwork(ctx context.Context, id string, netwrk string, cfg *types.ServiceNetworkConfig, links []string, aliases ...string) error {
var ( var (
ipv4ddress string ipv4ddress string
ipv6Address string ipv6Address string
@ -347,10 +354,16 @@ func (s *composeService) connectContainerToNetwork(ctx context.Context, id strin
ipv4ddress = cfg.Ipv4Address ipv4ddress = cfg.Ipv4Address
ipv6Address = cfg.Ipv6Address ipv6Address = cfg.Ipv6Address
} }
err := s.apiClient.NetworkConnect(ctx, netwrk, id, &network.EndpointSettings{ err := s.apiClient.NetworkDisconnect(ctx, netwrk, id, false)
if err != nil {
return err
}
err = s.apiClient.NetworkConnect(ctx, netwrk, id, &network.EndpointSettings{
Aliases: aliases, Aliases: aliases,
IPAddress: ipv4ddress, IPAddress: ipv4ddress,
GlobalIPv6Address: ipv6Address, GlobalIPv6Address: ipv6Address,
Links: links,
}) })
if err != nil { if err != nil {
return err return err
@ -358,6 +371,37 @@ func (s *composeService) connectContainerToNetwork(ctx context.Context, id strin
return nil return nil
} }
func (s *composeService) getLinks(ctx context.Context, service types.ServiceConfig) ([]string, error) {
cState, err := GetContextContainerState(ctx)
if err != nil {
return nil, err
}
links := []string{}
for _, serviceLink := range service.Links {
s := strings.Split(serviceLink, ":")
serviceName := serviceLink
serviceAlias := ""
if len(s) == 2 {
serviceName = s[0]
serviceAlias = s[1]
}
containers := cState.GetContainers()
depServiceContainers := containers.filter(isService(serviceName))
for _, container := range depServiceContainers {
name := getCanonicalContainerName(container)
if serviceAlias != "" {
links = append(links,
fmt.Sprintf("%s:%s", name, serviceAlias))
}
links = append(links,
fmt.Sprintf("%s:%s", name, name),
fmt.Sprintf("%s:%s", name, getContainerNameWithoutProject(container)))
}
}
links = append(links, service.ExternalLinks...)
return links, nil
}
func (s *composeService) isServiceHealthy(ctx context.Context, project *types.Project, service string) (bool, error) { func (s *composeService) isServiceHealthy(ctx context.Context, project *types.Project, service string) (bool, error) {
containers, err := s.getContainers(ctx, project.Name, oneOffExclude, false, service) containers, err := s.getContainers(ctx, project.Name, oneOffExclude, false, service)
if err != nil { if err != nil {