port.go 1.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859
  1. package client
  2. import (
  3. "fmt"
  4. "strings"
  5. Cli "github.com/docker/docker/cli"
  6. flag "github.com/docker/docker/pkg/mflag"
  7. "github.com/docker/go-connections/nat"
  8. )
  9. // CmdPort lists port mappings for a container.
  10. // If a private port is specified, it also shows the public-facing port that is NATed to the private port.
  11. //
  12. // Usage: docker port CONTAINER [PRIVATE_PORT[/PROTO]]
  13. func (cli *DockerCli) CmdPort(args ...string) error {
  14. cmd := Cli.Subcmd("port", []string{"CONTAINER [PRIVATE_PORT[/PROTO]]"}, Cli.DockerCommands["port"].Description, true)
  15. cmd.Require(flag.Min, 1)
  16. cmd.ParseFlags(args, true)
  17. c, err := cli.client.ContainerInspect(cmd.Arg(0))
  18. if err != nil {
  19. return err
  20. }
  21. if cmd.NArg() == 2 {
  22. var (
  23. port = cmd.Arg(1)
  24. proto = "tcp"
  25. parts = strings.SplitN(port, "/", 2)
  26. )
  27. if len(parts) == 2 && len(parts[1]) != 0 {
  28. port = parts[0]
  29. proto = parts[1]
  30. }
  31. natPort := port + "/" + proto
  32. newP, err := nat.NewPort(proto, port)
  33. if err != nil {
  34. return err
  35. }
  36. if frontends, exists := c.NetworkSettings.Ports[newP]; exists && frontends != nil {
  37. for _, frontend := range frontends {
  38. fmt.Fprintf(cli.out, "%s:%s\n", frontend.HostIP, frontend.HostPort)
  39. }
  40. return nil
  41. }
  42. return fmt.Errorf("Error: No public port '%s' published for %s", natPort, cmd.Arg(0))
  43. }
  44. for from, frontends := range c.NetworkSettings.Ports {
  45. for _, frontend := range frontends {
  46. fmt.Fprintf(cli.out, "%s -> %s:%s\n", from, frontend.HostIP, frontend.HostPort)
  47. }
  48. }
  49. return nil
  50. }