Podex handling multiple images

This commit is contained in:
jhadvig 2014-10-20 15:06:36 +02:00
parent 8261caedcb
commit 7851f5551c

View File

@ -40,10 +40,11 @@ import (
"gopkg.in/v1/yaml" "gopkg.in/v1/yaml"
) )
const usage = "usage: podex [-json|-yaml] <repo/dockerimage>" const usage = "usage: podex [-json|-yaml] -id=ID username/image1 ... username/imageN"
var generateJSON = flag.Bool("json", false, "generate json manifest") var generateJSON = flag.Bool("json", false, "generate json manifest")
var generateYAML = flag.Bool("yaml", false, "generate yaml manifest") var generateYAML = flag.Bool("yaml", false, "generate yaml manifest")
var podName = flag.String("id", "", "set pod name")
func main() { func main() {
flag.Parse() flag.Parse()
@ -51,60 +52,64 @@ func main() {
if flag.NArg() < 1 { if flag.NArg() < 1 {
log.Fatal(usage) log.Fatal(usage)
} }
if *podName == "" {
imageName := flag.Arg(0) if flag.NArg() > 1 {
if len(imageName) == 0 {
log.Fatal(usage) log.Fatal(usage)
} }
_, *podName = parseDockerImage(flag.Arg(0))
}
if (!*generateJSON && !*generateYAML) || (*generateJSON && *generateYAML) { if (!*generateJSON && !*generateYAML) || (*generateJSON && *generateYAML) {
log.Fatal(usage) log.Fatal(usage)
} }
// Parse docker image name
// IMAGE: [REGISTRYHOST/][USERNAME/]NAME[:TAG]
// NAME: [a-z0-9-_.]
parts := strings.Split(imageName, "/")
baseName := parts[len(parts)-1]
dockerHost := os.Getenv("DOCKER_HOST") dockerHost := os.Getenv("DOCKER_HOST")
if dockerHost == "" { if dockerHost == "" {
log.Fatalf("DOCKER_HOST is not set") log.Fatalf("DOCKER_HOST is not set")
} }
docker, err := dockerclient.NewClient(dockerHost) docker, err := dockerclient.NewClient(dockerHost)
if err != nil { if err != nil {
log.Fatalf("failed to connect to %q: %v", dockerHost, err) log.Fatalf("failed to connect to %q: %v", dockerHost, err)
} }
podContainers := []v1beta1.Container{}
for _, imageName := range flag.Args() {
parts, baseName := parseDockerImage(imageName)
container := v1beta1.Container{
Name: baseName,
Image: imageName,
}
// TODO(proppy): use the regitry API instead of the remote API to get image metadata. // TODO(proppy): use the regitry API instead of the remote API to get image metadata.
img, err := docker.InspectImage(imageName) img, err := docker.InspectImage(imageName)
if err != nil { if err != nil {
log.Fatalf("failed to inspect image %q: %v", imageName, err) log.Fatalf("failed to inspect image %q: %v", imageName, err)
} }
// TODO(proppy): add flag to handle multiple version
manifest := v1beta1.ContainerManifest{
Version: "v1beta1",
ID: baseName + "-pod",
Containers: []v1beta1.Container{{
Name: baseName,
Image: imageName,
}},
RestartPolicy: v1beta1.RestartPolicy{
Always: &v1beta1.RestartPolicyAlways{},
},
}
for p := range img.Config.ExposedPorts { for p := range img.Config.ExposedPorts {
port, err := strconv.Atoi(p.Port()) port, err := strconv.Atoi(p.Port())
if err != nil { if err != nil {
log.Fatalf("failed to parse port %q: %v", parts[0], err) log.Fatalf("failed to parse port %q: %v", parts[0], err)
} }
manifest.Containers[0].Ports = append(manifest.Containers[0].Ports, v1beta1.Port{ container.Ports = append(container.Ports, v1beta1.Port{
Name: strings.Join([]string{baseName, p.Proto(), p.Port()}, "-"), Name: strings.Join([]string{baseName, p.Proto(), p.Port()}, "-"),
ContainerPort: port, ContainerPort: port,
Protocol: v1beta1.Protocol(strings.ToUpper(p.Proto())), Protocol: v1beta1.Protocol(strings.ToUpper(p.Proto())),
}) })
} }
podContainers = append(podContainers, container)
}
// TODO(proppy): add flag to handle multiple version
manifest := v1beta1.ContainerManifest{
Version: "v1beta1",
ID: *podName + "-pod",
Containers: podContainers,
RestartPolicy: v1beta1.RestartPolicy{
Always: &v1beta1.RestartPolicyAlways{},
},
}
if *generateJSON { if *generateJSON {
bs, err := json.MarshalIndent(manifest, "", " ") bs, err := json.MarshalIndent(manifest, "", " ")
if err != nil { if err != nil {
@ -120,3 +125,15 @@ func main() {
os.Stdout.Write(bs) os.Stdout.Write(bs)
} }
} }
// parseDockerImage split a docker image name of the form [REGISTRYHOST/][USERNAME/]NAME[:TAG]
// TODO: handle the TAG
// Returns array of images name parts and base image name
func parseDockerImage(imageName string) (parts []string, baseName string) {
// Parse docker image name
// IMAGE: [REGISTRYHOST/][USERNAME/]NAME[:TAG]
// NAME: [a-z0-9-_.]
parts = strings.Split(imageName, "/")
baseName = parts[len(parts)-1]
return
}