【Docker学习】重启容器的docker restart

命令:

docker container restart

描述:

重启一个或多个容器

用法:

docker container restart [OPTIONS] CONTAINER [CONTAINER...]

别名:

docker restart(docker的一些命令可以简写,docker restart就等同于docker container restart)

选项:

选项描述
-s, --signal给容器发送信号
-t, --time在容器启动后,等待多少秒之后,如果容器没有按预期运行,则自动终止(kill)容器

实战:

如上图所示,我通过docker ps -a显示所有停止的容器,通过docker restart nginx重启nginx容器,最后docker ps显示nginx的状态为Up。

--signal,--time:

经过多次测试,没有迹象表明这个选项起了作用。网上查询,没有发现有对restart的这个-s选项的任何实战说明。为了一探究竟,只能查看docker源码了。

docker分为客户端和服务器两部分,其中客户端有关restart部分关键源码如下所示:

func runRestart(ctx context.Context, dockerCli command.Cli, opts *restartOptions) error {
	var errs []string
	var timeout *int
	if opts.timeoutChanged {
		timeout = &opts.timeout
	}
	for _, name := range opts.containers {
		err := dockerCli.Client().ContainerRestart(ctx, name, container.StopOptions{
			Signal:  opts.signal,
			Timeout: timeout,
		})
		if err != nil {
			errs = append(errs, err.Error())
			continue
		}
		_, _ = fmt.Fprintln(dockerCli.Out(), name)
	}
	if len(errs) > 0 {
		return errors.New(strings.Join(errs, "\n"))
	}
	return nil
}

可以看到Signal和Timeout都是处于StopOptions结构体内。

// StopOptions holds the options to stop or restart a container.
type StopOptions struct {
	// Signal (optional) is the signal to send to the container to (gracefully)
	// stop it before forcibly terminating the container with SIGKILL after the
	// timeout expires. If not value is set, the default (SIGTERM) is used.
	Signal string `json:",omitempty"`

	// Timeout (optional) is the timeout (in seconds) to wait for the container
	// to stop gracefully before forcibly terminating it with SIGKILL.
	//
	// - Use nil to use the default timeout (10 seconds).
	// - Use '-1' to wait indefinitely.
	// - Use '0' to not wait for the container to exit gracefully, and
	//   immediately proceeds to forcibly terminating the container.
	// - Other positive values are used as timeout (in seconds).
	Timeout *int `json:",omitempty"`
}

从结构体成员Signal上面的的注释可以看到,只有重启失败,经过timeout时间后,signal才会起作用,优雅地停止容器,然后再用 SIGKILL 强制终止容器。如果没有设置值,则使用默认值(SIGTERM)。

若是自己的容器项目经常因为一些原因而停止,这时可以使用这两个选项控制停止时长,以更快地进行后面的调试(这是我能想到的使用这个选项的一种情境)。

关于--signal和--time的使用,在我上一篇【Docker学习】docker stop深入研究有更为深入的使用,这里就不再演示了。

  • 5
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 3
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值