RHEL 또는 CentOS에서 재부팅이 필요한 경우 명령 줄에서 어떻게 확인할 수 있습니까? 사용하고 있습니다. 최근에 설치된

GUI가없는 일부 시스템에서 CentOS 및 Red Hat Enterprise Linux를 사용하고 있습니다. 최근에 설치된 업데이트에 재부팅이 필요한지 어떻게 확인할 수 있습니까? 우분투에서는 /var/run/reboot-required존재 여부를 확인하는 데 익숙합니다 .



답변

https://access.redhat.com/discussions/3106621#comment-1196821

코어 라이브러리 업데이트로 인해 최소한 glibc 인 경우 재부팅해야 할 수도 있습니다. 또한 업데이트 후 서비스를 다시 시작해야 할 수도 있습니다.

yum-utils패키지 를 설치하면 라는 명령을 사용할 수 있습니다 needs-restarting.

커널 또는 코어 라이브러리 업데이트 ( -r옵션 사용)로 인해 전체 재부팅이 필요한지 또는 옵션을 사용하여 다시 시작해야하는 서비스를 모두 확인하는 데 사용할 수 있습니다 -s.

needs-restarting -r0재부팅이 필요하지 않은 경우 반환 하고 필요 1하면 스크립트에서 사용하기에 적합합니다.

예를 들면 :

root@server1:~> needs-restarting  -r ; echo $?
Core libraries or services have been updated:
  openssl-libs -> 1:1.0.1e-60.el7_3.1
  systemd -> 219-30.el7_3.9

Reboot is required to ensure that your system benefits from these updates.

More information:
https://access.redhat.com/solutions/27943
1


답변

설치된 커널과 실행중인 커널을 비교하는 방법 :

#!/bin/bash
LAST_KERNEL=$(rpm -q --last kernel | perl -pe 's/^kernel-(\S+).*/$1/' | head -1)
CURRENT_KERNEL=$(uname -r)

test $LAST_KERNEL = $CURRENT_KERNEL || echo REBOOT

희망이 도움이됩니다!


답변

uname -a 출력을 설치된 커널 패키지 목록과 비교할 수 있습니다.


답변

uname -arpm -q kernelneeds-restarting에서yum-utils


답변

“재부팅 필요”라는 관점에서 볼 때 도움이 될 수있는 한 가지는 업데이트로 제거 / 교체되었지만 활성 프로세스에서 이전 파일을 계속로드 / 사용하는 파일이 있는지 여부입니다.

기본적으로 YUM이 프로세스에서 사용중인 파일을 업데이트하면 파일 자체가 삭제 된 것으로 표시되었을 수 있지만 프로세스는 이전 파일의 inode에 대해 열린 파일 디스크립터가 있으므로 이전 파일을 계속 사용합니다.

여전히 사용중인 오래된 파일 수를 계산하는 명령 :

#lsof | grep "(path inode=.*)" | wc -l

이 명령은 파일 개수를 알려줍니다.

실제로 사용중인 파일을 보려면 이것을 사용하십시오.

#lsof | grep "(path inode=.*)"

이 명령은 YUM 업데이트 상자에서 다음과 유사한 출력을 생성합니다.

COMMAND    PID   USER   FD      TYPE DEVICE SIZE/OFF   NODE NAME
sshd      3782   root  mem       REG   8,17          153427 /lib64/libcrypto.so.0.9.8e (path inode=153253)
mysqld    3883  mysql  mem       REG   8,17          153259 /lib64/libcrypt-2.5.so (path inode=153402)
mingetty  4107   root  mem       REG   8,17          153243 /lib64/libc-2.5.so (path inode=153222)
...
etc


답변

실행중인 커널이 최신 커널인지 확인하십시오.

그렇지 않은 경우 커널 설치 이후 시스템이 다시 시작되었는지 확인하십시오.

그렇지 않은 경우 재부팅하십시오.

CURRENT_KERNEL="$(rpm -q kernel-$(uname -r))"
test -z "$CURRENT_KERNEL" && exit 0     # Current kernel is a custom kernel

LATEST_KERNEL="$(rpm -q kernel | tail -1)"
test -z "$LATEST_KERNEL" && exit 0      # No kernel package installed

LATEST_KERNEL_INSTALLTIME=$(rpm -q kernel --qf "%{INSTALLTIME}\n" | tail -1)
test -z "$LATEST_KERNEL_INSTALLTIME" && exit 1      # Error reading INSTALLTIME

test "$CURRENT_KERNEL" = "$LATEST_KERNEL" && exit 0 # Latest kernel running, no reboot needed

BOOTTIME="$(sed -n '/^btime /s///p' /proc/stat)"
test -z "$BOOTTIME" && exit 1           # Error reading BOOTTIME

test "$LATEST_KERNEL_INSTALLTIME" -lt "$BOOTTIME" && exit 1 # Latest kernel not running, but system was restarted already
                                        # User switched back to an old kernel?

echo reboot


답변

나는이 질문에 이미 답변되어 있으며 사람들은 새로운 커널 검사뿐만 아니라 파일 삭제에 대한 정보를 게시했음을 알고 있지만 최근에 두 가지를 모두 검사하는 스크립트를 작성했습니다. 두 가지 조건 중 하나라도 감지되면 +30 분 동안 재부팅이 예약됩니다.

#!/bin/bash

PATH=/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin

NEW_KERN=0
DEAD_FILES=0

die () {
    printf "Error, exiting: "
    echo $@
    exit 1
}

for X in lsof wc column awk rpm sed head uname dd tr cut date logger shutdown; do
    which "${X}" >/dev/null 2>&1 || die "required application ${X} not found"
done

DATEY="$(date +%Y%m%d-%H%M%S)"
TMPFILE=/tmp/"$(dd if=/dev/urandom bs=1 count=256 2>/dev/null |tr -c -d '0-9a-f' |cut -c-7)"

[ $TMPFILE == "/tmp/" ] && die
echo "### Reboot automation notice: ${DATEY} ###" > "${TMPFILE}"
lsof +c0 -d DEL | grep -v '\s/SYSV' |awk 'NR==1 || !/dev\/zero/ {print $2,$1,$4,$NF}' | column -t >> "${TMPFILE}"

if [ $(cat ${TMPFILE} |wc -l) -gt 2 ]; then
    DEAD_FILES=1
else
    echo "### Reboot automation notice: ${DATEY} ###" > "${TMPFILE}"
fi

C_KERN="kernel-$(uname -r)"
A_KERN="$(rpm -q --last kernel |head -1 |sed 's|\s\+.*$||')"

[ $A_KERN != $C_KERN ] && NEW_KERN=1 && printf "Running $C_KERN, but $A_KERN available\n" >> "${TMPFILE}"

echo "### End of reboot automation notice: ${DATEY} ###" >> "${TMPFILE}"
if [[ $DEAD_FILES -eq 0 && $NEW_KERN -eq 0 ]]; then
    echo reboot not required
else
    logger -t rebooter -p auth.warning -f "${TMPFILE}"
    [ $DEAD_FILES -ne 0 ] && echo "   Processes running with broken links to executables,"
    [ $NEW_KERN -ne 0 ] && echo "   New kernel available,"
    echo Reboot is required
    shutdown -r +30 "System reboot is required.  To cancel use shutdown -c.  But don't because this system needs to be rebooted"
fi

[ -f "${TMPFILE}" ] && rm -f "${TMPFILE}"