port.go 1.5 KB

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