From de7d4de59d3b9475284e7645c81a85d739cfe61e Mon Sep 17 00:00:00 2001 From: tonic Date: Wed, 19 Apr 2017 12:42:22 +0800 Subject: [PATCH] =?UTF-8?q?=E8=AE=A9=E8=BF=99=E4=B8=AA=E9=80=89=E9=A1=B9?= =?UTF-8?q?=E5=8F=AF=E9=85=8D=E7=BD=AE=E5=90=A7,=20=E4=B9=9F=E5=A5=BD?= =?UTF-8?q?=E8=B0=83=E6=95=B4systemctl=E7=9A=84=E8=B6=85=E6=97=B6?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- cluster/calcium/run_and_wait.go | 7 +------ main.go | 4 ++++ types/config.go | 21 +++++++++++---------- 3 files changed, 16 insertions(+), 16 deletions(-) diff --git a/cluster/calcium/run_and_wait.go b/cluster/calcium/run_and_wait.go index 307022237..251210779 100644 --- a/cluster/calcium/run_and_wait.go +++ b/cluster/calcium/run_and_wait.go @@ -13,11 +13,6 @@ import ( "golang.org/x/net/context" ) -// TODO 这里还是有个问题啊 -// 如果在这个等待的过程中重启了core, 那岂不是又有容器没有回收的? -// 有啥方法避免这个问题么? -const defaultWaitTimeout = 1200 - func (c *calcium) RunAndWait(specs types.Specs, opts *types.DeployOptions) (chan *types.RunAndWaitMessage, error) { ch := make(chan *types.RunAndWaitMessage) @@ -30,7 +25,7 @@ func (c *calcium) RunAndWait(specs types.Specs, opts *types.DeployOptions) (chan // 没别的地方好传了, 不如放这里好了, 不需要用的就默认0或者不传 waitTimeout := entry.RunAndWaitTimeout if waitTimeout == 0 { - waitTimeout = defaultWaitTimeout + waitTimeout = c.config.RunAndWaitTimeout } // 创建容器, 有问题就gg diff --git a/main.go b/main.go index 4178535ad..2e7b1c06e 100644 --- a/main.go +++ b/main.go @@ -54,6 +54,10 @@ func initConfig(configPath string) (types.Config, error) { return config, err } + if config.RunAndWaitTimeout == 0 { + config.RunAndWaitTimeout = 1200 + } + if config.Docker.APIVersion == "" { config.Docker.APIVersion = "v1.23" } diff --git a/types/config.go b/types/config.go index cd3d4711a..e68e88349 100644 --- a/types/config.go +++ b/types/config.go @@ -2,16 +2,17 @@ package types // Config holds eru-core config type Config struct { - Bind string `yaml:"bind"` // HTTP API address - AgentPort string `yaml:"agent_port"` // Agent HTTP port, may not be used - AppDir string `yaml:"appdir"` // App directory inside container - PermDir string `yaml:"permdir"` // Permanent dir on host - BackupDir string `yaml:"backupdir"` // Backup dir on host - EtcdMachines []string `yaml:"etcd"` // etcd cluster addresses - EtcdLockPrefix string `yaml:"etcd_lock_prefix"` // etcd lock prefix, all locks will be created under this dir - ResourceAlloc string `yaml:"resource_alloc"` // scheduler or cpu-period TODO give it a good name - Statsd string `yaml:"statsd"` // Statsd host and port - Zone string `yaml:"zone"` // zone for core, e.g. C1, C2 + Bind string `yaml:"bind"` // HTTP API address + AgentPort string `yaml:"agent_port"` // Agent HTTP port, may not be used + AppDir string `yaml:"appdir"` // App directory inside container + PermDir string `yaml:"permdir"` // Permanent dir on host + BackupDir string `yaml:"backupdir"` // Backup dir on host + EtcdMachines []string `yaml:"etcd"` // etcd cluster addresses + EtcdLockPrefix string `yaml:"etcd_lock_prefix"` // etcd lock prefix, all locks will be created under this dir + ResourceAlloc string `yaml:"resource_alloc"` // scheduler or cpu-period TODO give it a good name + Statsd string `yaml:"statsd"` // Statsd host and port + Zone string `yaml:"zone"` // zone for core, e.g. C1, C2 + RunAndWaitTimeout int `yaml:"run_and_wait_timeout"` // timeout for run and wait Git GitConfig `yaml:"git"` Docker DockerConfig `yaml:"docker"`