本文整理匯總了Golang中github.com/juju/juju/container.Initialiser.Initialise方法的典型用法代碼示例。如果您正苦於以下問題:Golang Initialiser.Initialise方法的具體用法?Golang Initialiser.Initialise怎麽用?Golang Initialiser.Initialise使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類github.com/juju/juju/container.Initialiser
的用法示例。
在下文中一共展示了Initialiser.Initialise方法的4個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Golang代碼示例。
示例1: runInitialiser
// runInitialiser runs the container initialiser with the initialisation hook held.
func (cs *ContainerSetup) runInitialiser(containerType instance.ContainerType, initialiser container.Initialiser) error {
if err := cs.initLock.Lock(fmt.Sprintf("initialise-%s", containerType)); err != nil {
return fmt.Errorf("failed to acquire initialization lock: %v", err)
}
defer cs.initLock.Unlock()
return initialiser.Initialise()
}
示例2: runInitialiser
// runInitialiser runs the container initialiser with the initialisation hook held.
func (cs *ContainerSetup) runInitialiser(containerType instance.ContainerType, initialiser container.Initialiser) error {
logger.Debugf("running initialiser for %s containers", containerType)
if err := cs.initLock.Lock(fmt.Sprintf("initialise-%s", containerType)); err != nil {
return errors.Annotate(err, "failed to acquire initialization lock")
}
defer cs.initLock.Unlock()
// Only tweak default LXC network config when address allocation
// feature flag is enabled.
if environs.AddressAllocationEnabled() {
// In order to guarantee stable statically assigned IP addresses
// for LXC containers, we need to install a custom version of
// /etc/default/lxc-net before we install the lxc package. The
// custom version of lxc-net is almost the same as the original,
// but the defined LXC_DHCP_RANGE (used by dnsmasq to give away
// 10.0.3.x addresses to containers bound to lxcbr0) has infinite
// lease time. This is necessary, because with the default lease
// time of 1h, dhclient running inside each container will request
// a renewal from dnsmasq and replace our statically configured IP
// address within an hour after starting the container.
err := maybeOverrideDefaultLXCNet(containerType, cs.addressableContainers)
if err != nil {
return errors.Trace(err)
}
}
if err := initialiser.Initialise(); err != nil {
return errors.Trace(err)
}
return nil
}
示例3: runInitialiser
// runInitialiser runs the container initialiser with the initialisation hook held.
func (cs *ContainerSetup) runInitialiser(abort <-chan struct{}, containerType instance.ContainerType, initialiser container.Initialiser) error {
logger.Debugf("running initialiser for %s containers", containerType)
spec := mutex.Spec{
Name: cs.initLockName,
Clock: clock.WallClock,
// If we don't get the lock straigh away, there is no point trying multiple
// times per second for an operation that is likelty to take multiple seconds.
Delay: time.Second,
Cancel: abort,
}
logger.Debugf("acquire lock %q for container initialisation", cs.initLockName)
releaser, err := mutex.Acquire(spec)
if err != nil {
return errors.Annotate(err, "failed to acquire initialization lock")
}
logger.Debugf("lock %q acquired", cs.initLockName)
defer logger.Debugf("release lock %q for container initialisation", cs.initLockName)
defer releaser.Release()
if err := initialiser.Initialise(); err != nil {
return errors.Trace(err)
}
return nil
}
示例4: runInitialiser
// runInitialiser runs the container initialiser with the initialisation hook held.
func (cs *ContainerSetup) runInitialiser(containerType instance.ContainerType, initialiser container.Initialiser) error {
logger.Debugf("running initialiser for %s containers", containerType)
if err := cs.initLock.Lock(fmt.Sprintf("initialise-%s", containerType)); err != nil {
return errors.Annotate(err, "failed to acquire initialization lock")
}
defer cs.initLock.Unlock()
return initialiser.Initialise()
}