和Windows相比,Linux提供了多种关机、重启的命令,包括reboot/halt/shutdown等,而如果在服务器上,BMC还会提供ipmitool chassis power reset/ipmitool chassis power cycle/ipmitool chassis power off等命令,那么面对这么多可行的命令,该如何选择呢?
由于Linux内核和OS版本众多,不同的OS和内核版本上的reboot/halt/shutdown等命令实现方式可能会有差异,这就需要基于具体的OS和内核进行分析。下面基于CentOS 7,分享一下认识reboot/halt/shutdown差异的过程。
1.确定是否都是链接到同一个命令
通过下面的命令可以看到,在CentOS 7上所有的reboot命令都链接到systemctl:
[root@localhost etc]# which shutdown
/usr/sbin/shutdown
[root@localhost etc]# which poweroff
/usr/sbin/poweroff
[root@localhost etc]# which reboot
/usr/sbin/reboot
[root@localhost etc]# cd /usr/sbin/
[root@localhost sbin]# ls -alrt shutdown
lrwxrwxrwx. 1 root root 16 Apr 5 13:07 shutdown -> ../bin/systemctl
[root@localhost sbin]# ls -alrt poweroff
lrwxrwxrwx. 1 root root 16 Apr 5 13:07 poweroff -> ../bin/systemctl
[root@localhost sbin]# ls -alrt reboot
lrwxrwxrwx. 1 root root 16 Apr 5 13:07 reboot -> ../bin/systemctl
[root@localhost sbin]# which systemctl
/usr/bin/systemctl
2.认识怎样关机保证不造成数据丢失
除了要求能按照期望实现开关机、重启之外,在服务器尤其是存储服务器的工作环境下,用户对关机和重启能否造成数据丢失也特别关心。为此,弄清楚哪种使用方式不会造成数据丢失很有意义。还是以CentOS为例,根据systemctl的说明,reboot、halt与poweroff一样,只要不带 –force --force后缀,就不会造成数据丢失。下面是关于这些命令的具体说明:
halt
Shut down and halt the system. This is mostly equivalent to start halt.target --irreversible, but also prints a wall message to all users. If combined with --force, shutdown of all running services is skipped, however all processes are killed and all file systems are unmounted or mounted read-only, immediately followed by the system halt. If --force is specified twice, the operation is immediately executed without terminating any processes or unmounting any file systems. This may result in data loss.
poweroff
Shut down and power-off the system. This is mostly equivalent to start poweroff.target --irreversible, but also prints a wall message to all users. If combined with --force, shutdown of all running services is skipped, however all processes are killed and all file systems are unmounted or mounted read-only, immediately followed by the powering off. If --force is specified twice, the operation is immediately executed without terminating any processes or unmounting any file systems. This may result in data loss.
reboot [arg]
Shut down and reboot the system. This is mostly equivalent to start reboot.target --irreversible, but also rints a wall message to all users. If combined with --force, shutdown of all running services is skipped, however all processes are killed and all file systems are unmounted or mounted read-only, immediately followed by the reboot. If --force is specified twice, the operation is immediately executed without terminating any processes or unmounting any file systems. This may result in data loss.
Shutdown
如果后面什么参数都不加,效果和shutdown -P +1相同,即先调用wall向所有登录的用户发出即将关机的信息,然后组织新的用户登录,接着等待60s,最后执行poweroff。因此,
区别于halt/poweroff,shutdown更安全,在不带任何参数的情况下,shutdown本质是delayed shutdown,当前我们的CentOS上默认是延迟60s后关机,具体请参考下面的命令和日志文件:
[root@localhost ~]# cat /var/log/messages | tail -n 2
Apr 28 22:50:30 localhost systemd: Started Session 195 of user root.
Apr 28 22:50:30 localhost systemd-logind: New session 195 of user root.
[root@localhost ~]# date
Thu Apr 28 22:51:25 CST 2016
[root@localhost ~]# shutdown -k
Shutdown scheduled for Thu 2016-04-28 22:52:30 CST, use 'shutdown -c' to cancel.
[root@localhost ~]#
Broadcast message from [email protected] (Thu 2016-04-28 22:51:30 CST):
The system is going down for power-off at Thu 2016-04-28 22:52:30 CST!
[root@localhost ~]# cat /var/log/messages | tail -n 4
Apr 28 22:51:30 localhost systemd: Starting Delayed Shutdown Service...
Apr 28 22:51:30 localhost systemd: Started Delayed Shutdown Service.
Apr 28 22:51:30 localhost systemd-shutdownd: Shutting down at Thu 2016-04-28 22:52:30 CST (poweroff)...
Apr 28 22:51:30 localhost systemd-shutdownd: Creating /run/nologin, blocking further log×××...
关于shutdown和poweroff/halt/reboot的关系可参考下面的说明:
SYNOPSIS
shutdown [OPTIONS...] [TIME] [WALL...]
DESCRIPTION
shutdown may be used to halt, power-off or reboot the machine.
The first argument may be a time string (which is usually "now"). Optionally, this may be followed by a wall
message to be sent to all logged-in users before going down.
The time string may either be in the format "hh:mm" for hour/minutes specifying the time to execute the
shutdown at, specified in 24h clock format. Alternatively it may be in the syntax "+m" referring to the
specified number of minutes m from now. "now" is an alias for "+0", i.e. for triggering an immediate
shutdown. If no time argument is specified, "+1" is implied.
Note that to specify a wall message you must specify a time argument, too.
If the time argument is used, 5 minutes before the system goes down the /run/nologin file is created to ensure
that further log××× shall not be allowed.
OPTIONS
The following options are understood:
--help
Print a short help text and exit.
-H, --halt
Halt the machine.
-P, --poweroff
Power-off the machine (the default).
-r, --reboot
Reboot the machine.
-h
Equivalent to --poweroff, unless --halt is specified.
-k
Do not halt, power-off, reboot, just write wall message.
--no-wall
Do not send wall message before halt, power-off, reboot.
-c
Cancel a pending shutdown. This may be used cancel the effect of an invocation of shutdown with a time
argument that is not "+0" or "now".
3.利用IPMI命令开关机
如果机器支持BMC,可以通过BMC使用ipmitool去开关机。这种情况下,BMC直接关掉给host系统的DC电源,如果是chassis power reset/chassis power cycle还会间隔一会重新上电,因此在host系统上运行的应用程序和IO数据都来不及killed掉并同步到硬盘,这就会造成数据丢失。当是它的好处是:快捷,并且可以基于BMC Lan 接口去远程开关、重启机器。
这些命令包括:
ipmitool chassis power off #通过BMC关必DC
ipmitool chassis power on # 通过BMC给DC上电
ipmitool chassis power cycle # 先把DC掉店,间隔约1s后给DC上电
ipmitool chassis power reset # 先把DC掉店,然后给DC上电