"reboot" or "shutdown -r now": what restart command is safer?

91,108

Solution 1

For Red Hat systems, there is no functional difference between reboot and shutdown -r now.

Do whatever is easier for you.

Solution 2

Shutdown is preferable because it allows you to specify the reason for the drastic action -- something you should always do. The message will be recorded in the log(s) for posterity. For example:

shutdown -r now 'Kernel upgrade requires reboot'

You can also perform a scheduled reboot -- by specifying something other than now as the reboot time:

shutdown -r 22:00 'Work around kernel memory leak'

Then your users will get periodic reminders to get out and so on -- the process will be more orderly and professional.

Solution 3

Using reboot is safer.

Using reboot your intent is clear and there is no way to mistype it for something else like shutdown -t now which could leads to a few headache if you are using on a remote server with limited control.

Solution 4

If you take a look, in RHEL 7 both /sbin/shutdown and /sbin/reboot are actually just symlinks to systemd's systemctl command. So, use whatever you want. No functional difference as ewwhite told, not even in earlier RHEL releases which did not yet use systemd.

Solution 5

For modern RHEL you are recommended to use the systemctl command as summarised here: [recent] RHEL distributions should use the new systemctl command to issue poweroff/reboot. As stated in the manpages of reboot and shutdown they are "a legacy command available for compatibility only.".

However, if you use many different distributions, or distributions of various vintages, then perhaps stick with shutdown -r now 'reason for shutdown'.

The main reason to use reboot would be to avoid the risk of forgetting to add the -r when using shutdown -r on a remote machine, which could easily result in not being able to login again and having to use the remote admin (if available) to restart the machine.

Share:
91,108

Related videos on Youtube

dandan
Author by

dandan

Updated on September 18, 2022

Comments

  • dandan
    dandan over 1 year

    We have in our organization around ~500 RedHat Linux machines.

    On all the machines we installed applications and services under /etc/init.d, and oracle RAC servers. We intend to perform yum updates on all machines and after that take a reboot.

    So I was wondering what command is safer:

    reboot
    

    or

    shutdown -r now
    
    • Henrik Pingel
      Henrik Pingel almost 8 years
    • Stefan Lasiewski
      Stefan Lasiewski almost 8 years
      Is this RHEL6 or RHEL7?
    • dandan
      dandan almost 8 years
      we have all kind - as redhat 4,5,6,7
    • underscore_d
      underscore_d almost 8 years
      Let's rewind: Why do you think there might be a difference in safety?
    • Shiva Saurabh
      Shiva Saurabh almost 8 years
      @underscore_d: it's not unreasonable to think that one might be an "internal-use-only" command that doesn't do all the same clean shutdown steps. E.g. maybe one uses the other after doing some initial clean-shutdown steps. Of course, the man page explains that reboot is just a legacy command and still exists only for backwards compat.
    • Insane
      Insane almost 8 years
      @knowhy A question can't be a duplicate of a question on a different site..
  • Insane
    Insane almost 8 years
    But one makes you type more and is fundamentally 'cooler'!
  • ruakh
    ruakh almost 8 years
    I don't find this argument very compelling: it's obvious that /sbin/shutdown and /sbin/reboot do not behave the same in all cases (in particular: /sbin/shutdown doesn't reboot by default!), so if they're symlinked to the same executable, then that executable must be examining its ARGV[0] and adjusting its behavior accordingly. While that certainly reduces the risk of unintentional differences, it's not compelling evidence that there are no intentional functional differences that the OP might want to know about.
  • mckenzm
    mckenzm almost 8 years
    Beware of assuming a symlink implies equivalence, particularly if there are differing names involved.
  • user1686
    user1686 almost 8 years
    ruakh is right – think about it for a moment, even though reboot is symlinked to systemctl, you cannot use e.g. reboot status whatever.service like you would with the latter, can you?
  • Burhan Khalid
    Burhan Khalid almost 8 years
    One requires super user access, the other can be executed by any user (unless restricted) from an X session.
  • user
    user almost 8 years
    At least on Debian (though I'll readily admit I don't know about Red Hat, but Janne Pikkarainen's answer suggests it may be similar but different), halt, reboot and poweroff do not accept a reason message nor a time, as Mikhail T. explained. I think I would consider one tool to be able to do something that another doesn't allow for to be a "functional difference".
  • RoughTomato
    RoughTomato over 5 years
    IMHO underrated answer. Very often we forget how important it is to make intentions clear and how much time and cuss words it saves in the long run!