本文整理匯總了Golang中github.com/concourse/atc/worker.Worker.CreateContainer方法的典型用法代碼示例。如果您正苦於以下問題:Golang Worker.CreateContainer方法的具體用法?Golang Worker.CreateContainer怎麽用?Golang Worker.CreateContainer使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類github.com/concourse/atc/worker.Worker
的用法示例。
在下文中一共展示了Worker.CreateContainer方法的1個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Golang代碼示例。
示例1: InitWithSources
func (tracker *tracker) InitWithSources(
logger lager.Logger,
metadata Metadata,
session Session,
typ ResourceType,
tags atc.Tags,
sources map[string]ArtifactSource,
) (Resource, []string, error) {
logger = logger.Session("init-with-sources")
logger.Debug("start")
defer logger.Debug("done")
container, found, err := tracker.workerClient.FindContainerForIdentifier(logger, session.ID)
if err != nil {
logger.Error("failed-to-look-for-existing-container", err)
return nil, nil, err
}
if found {
logger.Debug("found-existing-container", lager.Data{"container": container.Handle()})
missingNames := []string{}
for name, _ := range sources {
missingNames = append(missingNames, name)
}
return NewResource(container), missingNames, nil
}
resourceSpec := worker.ResourceTypeContainerSpec{
Type: string(typ),
Ephemeral: session.Ephemeral,
Tags: tags,
Env: metadata.Env(),
}
compatibleWorkers, err := tracker.workerClient.AllSatisfying(resourceSpec.WorkerSpec())
if err != nil {
return nil, nil, err
}
// find the worker with the most volumes
mounts := []worker.VolumeMount{}
missingSources := []string{}
var chosenWorker worker.Worker
for _, w := range compatibleWorkers {
candidateMounts := []worker.VolumeMount{}
missing := []string{}
for name, source := range sources {
volume, found, err := source.VolumeOn(w)
if err != nil {
return nil, nil, err
}
if found {
candidateMounts = append(candidateMounts, worker.VolumeMount{
Volume: volume,
MountPath: ResourcesDir("put/" + name),
})
} else {
missing = append(missing, name)
}
}
if len(candidateMounts) >= len(mounts) {
for _, mount := range mounts {
mount.Volume.Release(0)
}
mounts = candidateMounts
missingSources = missing
chosenWorker = w
} else {
for _, mount := range candidateMounts {
mount.Volume.Release(0)
}
}
}
resourceSpec.Mounts = mounts
container, err = chosenWorker.CreateContainer(logger, session.ID, resourceSpec)
if err != nil {
logger.Error("failed-to-create-container", err)
return nil, nil, err
}
logger.Info("created", lager.Data{"container": container.Handle()})
for _, mount := range mounts {
mount.Volume.Release(0)
}
return NewResource(container), missingSources, nil
}