mirror of https://github.com/docker/compose.git
set container links and external links in network
Signed-off-by: Lorena Rangel <lorena.rangel@docker.com>
This commit is contained in:
parent
399f6cde5e
commit
b38d35ae1c
|
@ -2,6 +2,8 @@ services:
|
||||||
|
|
||||||
container1:
|
container1:
|
||||||
image: nginx
|
image: nginx
|
||||||
|
links:
|
||||||
|
- container2:container
|
||||||
|
|
||||||
container2:
|
container2:
|
||||||
image: nginx
|
image: nginx
|
||||||
|
|
|
@ -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")
|
||||||
})
|
})
|
||||||
|
|
|
@ -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 {
|
||||||
|
|
Loading…
Reference in New Issue