簡體   English   中英

版本排序 RPM Kernel 帶數字的字符串 bash 返回不正確的結果

[英]Version sorting RPM Kernel string with numbers in bash returns incorrect result

我需要這 4 個 kernel 版本中的最新版本。

  • 4.18.0-187.el8.x86_64
  • 4.18.0-193.14.3.el8_2.x86_64
  • 4.18.0-193.el8.x86_64
  • 4.18.0-80.el8.x86_64

我最初使用數字排序(錯誤地返回 0-80 版本),然后再進行相同的版本排序

latest_kernel_in_use=$(ls boot/vmlinuz* | sed 's/\/boot\/vmlinuz-//' | sort -V | tail -n1 )

該命令仍然返回 4.18.0-193.el8.x86_64 而不是所需的 4.18.0-193.14.3.el8_2.x86_64 output。

幫助我更正命令。 我另外進行了測試,它確實是 suffixes.el8.x86_64 使排序復雜化。

[編輯] 所以我最終做到了,我刪除了尾隨的字母/字母數字序列,標識符至少涉及一個字母無論 RPM kernel 版本是4.18.0-193.14.3.el8_2.x86_64還是類似4.18.0-193.14 .3-generic如 Ubuntu 所示

latest_kernel_in_use=$(ls boot/vmlinuz* | sed 's/boot\/vmlinuz-//' | sed 's/[.-][[:alpha:]][[:alnum:][:punct:]]*//' | sort -V | tail -n1)

這個Output是4.18.0-193.14.3

我可以在那里工作。

似乎是因為“e”> 1

我想到了這種恐怖,但我相信有更好的方法

#!/bin/bash

# list your kernels and remove "vmlinuz-" prefix
KERNELS=$(find boot/ -iname "vmlinuz*" -exec basename {} \; | sed s/vmlinuz-//g)

# declare empty arrays (this will be arrays to contain our version and suffix strings)
VERSIONS_ARRAY=()
SUFFIXES_ARRAY=()

# we loop thought each kernel version
for KERNEL in $KERNELS;do
  # we will split each part of the kernel version on the dot (".")
  IFS="."
  read -ra KERNEL_VERSION <<< "$(echo $KERNEL)"
  # we define 2 empty strings to collect the kernel parts
  VERSION_STRING=""
  SUFFIX_STRING=""
  # we set back field separator to space
  IFS=" "
  # we loop throug all parts of kernel version
  for KERNEL_PART in ${KERNEL_VERSION[@]};do
    #echo -n $KERNEL_PART
    # if we encounter el8 or el8_2 or x86_64 string we append to the SUFFIX_STRING
    if [[ "$KERNEL_PART" == "el8" ]] || [[ "$KERNEL_PART" == "el8_2" ]] || [[ "$KERNEL_PART" == "x86_64" ]] ;then
      SUFFIX_STRING="${SUFFIX_STRING}${KERNEL_PART}."
    # else, we append to the VERSION_STRING
    else
      VERSION_STRING="${VERSION_STRING}${KERNEL_PART}."
    fi   
  done
  # we append the VERSION_STRING in VERSION_STRINGS
  VERSIONS_ARRAY+=("$VERSION_STRING")
  # we append the SUFFIX_STRING in SUFFIXES_ARRAYS
  SUFFIXES_ARRAY+=("$SUFFIX_STRING") 
done

# we set the field separator to split on linebreaks
IFS=$'\n'
# we find the highest value in version array
HIGHEST_VERSION=$(echo "${VERSIONS_ARRAY[*]}" | sort -V | tail -1)

# we get the position of highest value in array
for INDEX in ${VERSIONS_ARRAY[@]};do
    if [[ "$VERSIONS_ARRAY{[$INDEX]}" = "$HIGHEST_VERSION" ]]; then
        INDEX_OF_HIGHER_VERSION=$INDEX
    fi
done

# we get the corresponding suffix by index
HIGHEST_VERSION_SUFFIX=${SUFFIXES_ARRAY[$INDEX_OF_HIGHER_VERSION]}

# we remove the trailing dot in suffix
len=${#HIGHEST_VERSION_SUFFIX}
HIGHEST_VERSION_SUFFIX=${HIGHEST_VERSION_SUFFIX::len-1}

echo "vmlinuz-${HIGHEST_VERSION}${HIGHEST_VERSION_SUFFIX}"

# we set back field separator to space
IFS=" "

所以我最終做到了,我刪除了尾隨的字母/字母數字序列,標識符至少涉及一個字母,無論 RPM kernel 版本是4.18.0-193.14.3.el8_2.x86_64還是類似4.18.0-193.14.3-通用如 Ubuntu 中所示

latest_kernel_in_use=$(ls boot/vmlinuz* | sed 's/boot\/vmlinuz-//' | sed 's/[.-][[:alpha:]][[:alnum:][:punct:]]*//' | sort -V | tail -n1)

這個Output是4.18.0-193.14.3

我可以在這里工作。

latest_kernel_in_use=$(ls /boot/vmlinuz* | sed 's//boot/vmlinuz-//' | sed 's/[.-][[:alpha:]][[:alnum:][:punct:] ]*//' | 排序 -V | 尾巴 -n1)

(/boot/vmlinux*) + s//boot... )

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM