Ubuntuを別のパーティションにバックアップ/クローンするBashスクリプト


12

Ubuntu 18.04は2018年4月26日にリリースされました。プログラムをアップグレードしてデータを変換するために試してみたいのですが、バグがある場合はコミットしたくありません。

Windowsを410 GBから385 GBに縮小し、Ubuntu 16.04を再起動し、実行gpartedして「Ubuntu18.04」というラベルの付いた新しい25 GBパーティションを作成しました。rm-kernelsUbuntu 16.04で約10 GBを削除するために、約20個のカーネルを実行して削除しました。

ここで、16.04 LTSで新しいパーティションを作成し、それに新しいGrubメニューオプションを作成するスクリプトが必要です。関連するディレクトリのみをコピーする必要があります。たとえば/sys/run/procおよび/dev仮想ディレクトリは、起動時に作成され、コピーされるべきではありません。

また、クローンの起動後にクローンデータの毎日のバックアップが実行されないように/etc/fstab、正しいUUIDとcron再起動ジョブを無効にしてパッチを適用する必要があります。

今後数週間/数か月にわたって何度もスクリプトを実行する予定です。そのため、クローン作成プロセスは簡単に再現できる必要があります。

本番システムに影響を与えることなく、セキュリティ更新および新しいUbuntu Kernel Team更新のテストに同じスクリプトを使用できます。


20カーネルは10GBかかります!!!?カーネル肥大化版を誤ってインストールしましたか?
ライライアン

@LieRyan実際には、カーネルあたり約400MBであり、数値を丸めると500MBではありません(約20カーネル)。各カーネルの占有量を確認するには(現在のインストールで394MBから419MBに変動します。参照してください。askubuntu.com
questions/949411/

回答:


19

アクティブなUbuntuパーティションを複製してパーティションを複製するBashスクリプト

clone-ubuntu.shbashスクリプトは、シームレスかつ安全18.04 LTSへのアップグレードのためのパーティションに16.04 LTSを複製します。

clone-ubuntu.png

考慮すべき重要な点:

  • Ubuntu 16.04クローンext4を保持するのに十分な大きさの空のパーティションを作成する必要があります
  • スクリプトを呼び出すときclone-ubuntu.sh、パーティションマウントできません。スクリプトは自動的にパーティションをマウントおよびアンマウントします。
  • このコマンドrsync/、ファイルをクローンパーティションにコピーするために使用されます。最初に実行clone-ubuntu.shするのに数分かかります。2回目にスクリプトを実行すると、ファイルの変更のみが更新され、1分もかかりません。
  • このスクリプトを実行し、複数回再起動する場合があります。クローンターゲット上の新しいデータすべて削除され、現在の/ファイルとディレクトリがミラーリングれます。
  • すべてのCron /etc/cron.d(リブート)ジョブはと呼ばれる新しいサブディレクトリに移動され/etc/cron.d/holdます。クローンを起動したらsudo crontab -e、選択したcronジョブが実行されないように実行することを忘れないでください。
  • クローンファイル/etc/fstabは、パーティションの適切なUUIDで変更されます。
  • /boot/grub/grub.cfgクローンブートが正常に行われるように、クローンファイルは適切なUUIDで変更されます。クローンファイルquiet splashはに変更されnosplash、スクロールターミナルメッセージングを取得します。これにより、「リアル」バージョンではなく、クローンの起動を視覚的に認識できます。
  • update-grub クローンパーティションを指す新しいメニューオプションでGrubを更新するために実行されます。
  • クローンファイル/etc/update-manager/release-upgradesは、に変更されるように変更さPrompt=neverPrompt=ltsます。クローンを起動して実行do-release-upgrade -dすると、Ubuntu 16.04が18.04にアップグレードされます。
  • クローンを作成する前に確認画面が表示され(次のセクションを参照)、続行するにはy / Yを入力する必要があります。

確認画面

ターゲットクローンパーティションを選択すると、まずext4パーティションタイプであることが検証され、まだマウントされていません。このテストに合格すると、確認メッセージが表示されます。

=====================================================================
Mounting clone partition /dev/nvme0n1p8 as /mnt/clone16.04

=====================================================================
PLEASE: Carefully confirm Source (Live) and Target (Clone) partitions

SOURCE (BOOT /):  /dev/nvme0n1p5      TARGET (CLONE):  /dev/nvme0n1p8
ID:               Ubuntu              ID:              Ubuntu
RELEASE:          16.04               RELEASE:         16.04
CODENAME:         xenial              CODENAME:        xenial
DESCRIPTION:      Ubuntu 16.04.3 LTS  DESCRIPTION:     Ubuntu 16.04.3 LTS
 Size  Used Avail Use%                 Size  Used Avail Use%
  44G   17G   26G  40%                  24G   17G  5.8G  74%

NOTE: If you are recloning, new files in clone will be deleted,
      modified files are reset to current source content and,
      files deleted from clone are added back from source.

Type Y (or y) to proceed. Any other key to exit: 

この例では、再クローン化のために以前のクローンが選択されています。クローンで使用可能なスペースは、十分なスペースがあることがわかっているため、ミュートポイントです。

複数のUbuntuをインストールしている場合は、/(root)としてマウントされている、現在起動しているUbuntuを複製する適切なパーティションを選択したことを確認してください。

これは、以外の任意のキーを押すことにより中止する最後のチャンスですyY


出力リスト

スクリプトを実行すると、次の出力が得られます(上記に既にリストされている出力を除く)。

=====================================================================
Using rsync to clone / to /dev/nvme0n1p8 mounted as /mnt/clone16.04
          6.11G  38%   86.46MB/s    0:01:07 (xfr#139123, to-chk=0/647700)   

Number of files: 647,700 (reg: 470,100, dir: 104,694, link: 72,903, special: 3)
Number of created files: 127,824 (reg: 72,472, dir: 15,825, link: 39,526, special: 1)
Number of deleted files: 73,318 (reg: 59,766, dir: 9,701, link: 3,847, special: 4)
Number of regular files transferred: 139,123
Total file size: 15.92G bytes
Total transferred file size: 6.11G bytes
Literal data: 6.11G bytes
Matched data: 0 bytes
File list size: 8.50M
File list generation time: 0.001 seconds
File list transfer time: 0.000 seconds
Total bytes sent: 6.14G
Total bytes received: 7.82M

sent 6.14G bytes  received 7.82M bytes  89.74M bytes/sec
total size is 15.92G  speedup is 2.59

Time to clone files: 68 Seconds

=====================================================================
Making changes in: /mnt/clone16.04/etc/update-manager/release-upgrades
     from Prompt=: never
       to Prompt=: lts
Allows running 'do-release-upgrade -d' when rebooting clone target
Consider 'do-release-upgrade -d -f DistUpgradeViewNonInteractive' This
allows you to go to bed or go to lunch whilst upgrade runs.

* * *  When you Upgrade, TURN OFF screen locking for inactivity. * * *

=====================================================================
Making changes in: /mnt/clone16.04/etc/fstab
        from UUID: f3f8e7bc-b337-4194-88b8-3a513f6be55b
          to UUID: 113f9955-a064-4ce2-9cae-74f2a9518550

=====================================================================
Making changes in: /mnt/clone16.04/boot/grub/grub.cfg
        from UUID: f3f8e7bc-b337-4194-88b8-3a513f6be55b
          to UUID: 113f9955-a064-4ce2-9cae-74f2a9518550
Also change 'quiet splash' to 'nosplash' for environmental awareness
Suggest first time booting clone you make wallpaper unique

=====================================================================
Calling 'update-grub' to create new boot menu
Generating grub configuration file ...
Found background: /home/rick/Pictures/1600x900/21.jpg
Found background image: /home/rick/Pictures/1600x900/21.jpg
Found linux image: /boot/vmlinuz-4.14.34-041434-generic
Found initrd image: /boot/initrd.img-4.14.34-041434-generic
Found linux image: /boot/vmlinuz-4.14.31-041431-generic
Found initrd image: /boot/initrd.img-4.14.31-041431-generic
Found linux image: /boot/vmlinuz-4.14.30-041430-generic
Found initrd image: /boot/initrd.img-4.14.30-041430-generic
Found linux image: /boot/vmlinuz-4.14.27-041427-generic
Found initrd image: /boot/initrd.img-4.14.27-041427-generic
Found linux image: /boot/vmlinuz-4.14.15-041415-generic
Found initrd image: /boot/initrd.img-4.14.15-041415-generic
Found linux image: /boot/vmlinuz-4.14.10-041410-generic
Found initrd image: /boot/initrd.img-4.14.10-041410-generic
Found linux image: /boot/vmlinuz-4.14.4-041404-generic
Found initrd image: /boot/initrd.img-4.14.4-041404-generic
Found linux image: /boot/vmlinuz-4.14.2-041402-generic
Found initrd image: /boot/initrd.img-4.14.2-041402-generic
Found linux image: /boot/vmlinuz-4.13.9-041309-generic
Found initrd image: /boot/initrd.img-4.13.9-041309-generic
Found linux image: /boot/vmlinuz-4.10.0-42-generic
Found initrd image: /boot/initrd.img-4.10.0-42-generic
Found linux image: /boot/vmlinuz-4.9.77-040977-generic
Found initrd image: /boot/initrd.img-4.9.77-040977-generic
Found linux image: /boot/vmlinuz-4.4.0-104-generic
Found initrd image: /boot/initrd.img-4.4.0-104-generic
Found linux image: /boot/vmlinuz-3.16.53-031653-generic
Found initrd image: /boot/initrd.img-3.16.53-031653-generic
Found Windows Boot Manager on /dev/nvme0n1p2@/EFI/Microsoft/Boot/bootmgfw.efi
Found Ubuntu 16.04.3 LTS (16.04) on /dev/nvme0n1p8
Found Windows Boot Manager on /dev/sda1@/efi/Microsoft/Boot/bootmgfw.efi
Adding boot menu entry for EFI firmware configuration
done

=====================================================================
Unmounting /dev/nvme0n1p8 as /mnt/clone16.04

rsync 新しいクローンのステータス表示

初めてクローンを作成するときに、rsync作成されたすべてのファイルの0〜100%の更新を提供します。クローンが空であるため、ファイルは削除または変更されません。

clone-ubuntu.sh empty clone.gif

rsync 再クローン時のステータス表示

ときにrsync、それがヒットしたことがないreclones 100%変化したことがないファイルがコピーされないため。rsyncコピーする次のファイルをスキャンし、クローンに作成された元のファイルには存在しなかった新しいファイルを削除するときに、更新の進行に遅延が発生します。

clone-ubuntu-rsync.gif


Bashスクリプト- clone-ubuntu.sh

#!/bin/bash

# NAME: clone-ubuntu.sh
# PATH: /usr/local/bin
# DESC: Written for AU Q&A: /ubuntu/1028604/bash-seemless-safe-script-to-upgrade-16-04-to-18-04/1028605#1028605
# DATE: Apr 27, 2018. Modified May 6, 2018.

# UPDT: May 02 2018 - Display selected parition and get confirmation.
#       May 06 2018 - Revise `do-release-upgrade -d` instructions.
#                     Correct listing of files in empty target partition.
#       Aug 09 2018 - Add --inplace parameter to `rsync`
#                     Comment out disabling `/etc/cron.d` on clone target.
#                     Users may uncomment and/or revise to their needs.

# $TERM variable may be missing when called via desktop shortcut
CurrentTERM=$(env | grep TERM)
if [[ $CurrentTERM == "" ]] ; then
    notify-send --urgency=critical \ 
                "$0 cannot be run from GUI without TERM environment variable."
    exit 1
fi

# Must run as root
if [[ $(id -u) -ne 0 ]] ; then echo "Usage: sudo $0" ; exit 1 ; fi

#
# Create unqique temporary file names
#

tmpPart=$(mktemp /tmp/clone-ubuntu.XXXXX)   # Partitions list
tmpMenu=$(mktemp /tmp/clone-ubuntu.XXXXX)   # Menu list
tmpInf1=$(mktemp /tmp/clone-ubuntu.XXXXX)   # Soucre (Booted) Ubuntu Info
tmpInf2=$(mktemp /tmp/clone-ubuntu.XXXXX)   # Target (Cloned) Ubuntu Info
tmpInf3=$(mktemp /tmp/clone-ubuntu.XXXXX)   # Work file used by DistInfo ()

#
# Function Cleanup () Removes temporary files
#

CleanUp () {
    [[ -f "$tmpPart" ]] && rm -f "$tmpPart" # If we created temp files
    [[ -f "$tmpMenu" ]] && rm -f "$tmpMenu" #  at various program stages
    [[ -f "$tmpInf1" ]] && rm -f "$tmpInf1" #  then remove them before
    [[ -f "$tmpInf2" ]] && rm -f "$tmpInf2" #  exiting.
    [[ -f "$tmpInf3" ]] && rm -f "$tmpInf3"

    if  [[  -d "$TargetMnt" ]]; then        # Did we create a clone mount?
        umount "$TargetMnt" -l              # Unmount the clone
        rm  -d "$TargetMnt"                 # Remove clone directory
    fi
}

#
# Function GetUUID () gets UUIDs of source and clone target partitions in menu.
#

GetUUID () {

    SrchLine="$1"                           # menu line passed to function
    UUID_col=0                              # start column of UUID in line
    lsblk -o NAME,UUID > "$tmpPart"         # Get list of UUID's

    while read -r UUID_Line; do             # Read through UUID list

        # Establish UUID position on line
        if [[ $UUID_col == 0 ]] ; then      # First time will be heading
            UUID_col="${UUID_Line%%UUID*}"  # Establish column number
            UUID_col="${#UUID_col}"         #  where UUID appears on line
            NameLen=$(( UUID_col - 1 ))     # Max length of partition name
            continue                        # Skip to read next line
        fi

        # Check if Passed line name (/dev/sda1, /nvme01np8, etc.) matches.
        if [[ "${UUID_Line:0:$NameLen}" == "${SrchLine:0:$NameLen}" ]] ; then
            FoundUUID="${UUID_Line:UUID_col:999}"
            break                           # exit function
        fi

    done < "$tmpPart"                       # Read next line & loop back
}


#
# Function DistInfo () builds information about source & target partitions
#

DistInfo () {

    Mount="$1"                              # Mount name is '/' or $TargetMnt
    FileName="$2"                           # "$tmpInf1" or "$tmpInf2" work file
    cat "$Mount"/etc/lsb-release >> "$FileName"
    sed -i 's/DISTRIB_//g' "$FileName"      # Remove DISTRIB_ prefix.
    sed -i 's/=/:=/g' "$FileName"           # Change "=" to ":="
    sed -i 's/"//g' "$FileName"             # Remove " around "Ubuntu 16.04...".

    # Align columns from "Xxxx:=Yyyy" to "Xxxx:      Yyyy"
    cat "$FileName" | column -t -s '=' > "$tmpInf3"
    cat "$tmpInf3" > "$FileName"
}


#
# Mainline
#

lsblk -o NAME,FSTYPE,LABEL,SIZE,MOUNTPOINT > "$tmpMenu"

i=0
SPACES='                                                                     '
DoHeading=true
AllPartsArr=()      # All partitions.

# Build whiptail menu tags ($i) and text ($Line) into array

while read -r Line; do
    if [[ $DoHeading == true ]] ; then
        DoHeading=false                     # First line is the heading.
        MenuText="$Line"                    # Heading for whiptail.
        FSTYPE_col="${Line%%FSTYPE*}"           
        FSTYPE_col="${#FSTYPE_col}"         # Required to ensure `ext4`.
        MOUNTPOINT_col="${Line%%MOUNTPOINT*}"
        MOUNTPOINT_col="${#MOUNTPOINT_col}" # Required to ensure not mounted.
        continue
    fi

    Line="$Line$SPACES"                     # Pad extra white space.
    Line=${Line:0:74}                       # Truncate to 74 chars for menu.

    if [[ "${Line:MOUNTPOINT_col:4}" == "/   " ]] ; then
        GetUUID "$Line"
        SourceUUID=$FoundUUID
        # Build "/dev/Xxxxx" FS name from "├─Xxxxx" lsblk line
        SourceDev="${Line%% *}"
        SourceDev=/dev/"${SourceDev:2:999}"
    fi

    AllPartsArr+=($i "$Line")               # Menu array entry = Tag# + Text.
    (( i++ ))

done < "$tmpMenu"                           # Read next "lsblk" line.

#
# Display whiptail menu in while loop until no errors, or escape,
# or valid partion selection .
#

DefaultItem=0

while true ; do

    # Call whiptail in loop to paint menu and get user selection
    Choice=$(whiptail \
        --title "Use arrow, page, home & end keys. Tab toggle option" \
        --backtitle "Clone 16.04 for upgrade.  ONLY CLONES / PARTITION" \
        --ok-button "Select unmounted partition" \
        --cancel-button "Exit" \
        --notags \
        --default-item "$DefaultItem" \
        --menu "$MenuText" 24 80 16 \
        "${AllPartsArr[@]}" \
        2>&1 >/dev/tty)

    clear                                   # Clear screen.
    if [[ $Choice == "" ]]; then            # Escape or dialog "Exit".
        CleanUp
        exit 0;
     fi

    DefaultItem=$Choice                     # whiptail start option.
    ArrNdx=$(( $Choice * 2 + 1))            # Calculate array offset.
    Line="${AllPartsArr[$ArrNdx]}"          # Array entry into $Line.

    # Validation - Don't wipe out Windows or Ubuntu 16.04:
    # - Partition must be ext4 and cannot be mounted.

    if [[ "${Line:FSTYPE_col:4}" != "ext4" ]] ; then
        echo "Only 'ext4' partitions can be clone targets."
        read -p "Press <Enter> to continue"
        continue
    fi

    if [[ "${Line:MOUNTPOINT_col:4}" != "    " ]] ; then
        echo "A Mounted partition cannot be a clone target."
        read -p "Press <Enter> to continue"
        continue
    fi

    GetUUID "$Line"                         # Get UUID of target partition.
    TargetUUID=$FoundUUID

    # Build "/dev/Xxxxx" FS name from "├─Xxxxx" menu line
    TargetDev="${Line%% *}"
    TargetDev=/dev/"${TargetDev:2:999}"

    break                                   # Validated: Break menu loop.

done                                        # Loop while errors.

#
# Mount Clone Target partition
#

Release=$(lsb_release -rs)                  # Source version ie: '16.04'
TargetMnt="/mnt/clone$Release"

echo ""
echo "====================================================================="
echo "Mounting clone partition $TargetDev as $TargetMnt"
mkdir -p "$TargetMnt"                       # '-p' directory may already exist
mount -t auto -v $TargetDev "$TargetMnt" > /dev/null

# Confirm partition is empty. If not empty confirm it's Ubuntu. If not exit.
# If Ubuntu display prompt with the version it contains and get confirmation.

echo ""
echo "====================================================================="
echo "PLEASE: Carefully confirm Source (Live) and Target (Clone) partitions"

# Build source information (our current boot partition)
echo "SOURCE (BOOT /)=$SourceDev"  > "$tmpInf1"
DistInfo "/" "$tmpInf1"                     # /etc/lsb_release information
df -h --output=size,used,avail,pcent "$SourceDev" >> "$tmpInf1"

# Build target information (the partition selected for cloning to)
LineCnt=$(ls "$TargetMnt" | wc -l)
if (( LineCnt > 1 )) ; then 
    # More than /Lost+Found exist so it's not an empty partition.
    if [[ -f "$TargetMnt"/etc/lsb-release ]] ; then
        echo "TARGET (CLONE)=$TargetDev" > "$tmpInf2"
        DistInfo "$TargetMnt" "$tmpInf2"    # /etc/lsb_release information
    else
        # TO-DO: might be cloning /boot or /home on separate partitions.
        #        the source partition is still `/` so can display message.
        echo "Selected partition has data which is not Ubuntu OS. Aborting."
        CleanUp                             # Remove temporary files
        exit 1
    fi
else
    echo "Target (Clone) partition appears empty" > "$tmpInf2"
    echo "/Lost+Found normal in empty partition" >> "$tmpInf2"
    echo "Head of '/Clone/' files & directories:" >> "$tmpInf2"
    ls "$TargetMnt" | head -n2 >> "$tmpInf2"
fi

# Target device free bytes
df -h --output=size,used,avail,pcent "$TargetDev" >> "$tmpInf2"

# Display source and target partitions side-by-side using bold text.
echo $(tput bold)       # Set to bold text
paste -d '|' "$tmpInf1" "$tmpInf2" | column -t -s '|'
echo $(tput sgr0)       # Reset to normal text

echo "NOTE: If you are recloning, new files in clone will be deleted,"
echo "      modified files are reset to current source content and,"
echo "      files deleted from clone are added back from source."
echo ""

read -p "Type Y (or y) to proceed. Any other key to exit: " -n 1 -r
echo    # (optional) move to a new line
if [[ ! $REPLY =~ ^[Yy]$ ]] ; then
    CleanUp             # Remove temporary files
    exit 0
fi

# Copy non-virtual directories to clone. Credit to TikTak's Ask Ubuntu answer:
# /ubuntu/319805/is-it-safe-to-clone-the-current-used-disk?utm_medium=organic&utm_source=google_rich_qa&utm_campaign=google_rich_qa

SECONDS=0
echo ""
echo "====================================================================="
echo "Using rsync to clone / to $TargetDev mounted as $TargetMnt"
rsync -haxAX --stats --delete --info=progress2 --info=name0 --inplace  \
      /* "$TargetMnt"                                                   \
      --exclude={/dev/*,/proc/*,/sys/*,/tmp/*,/run/*,/mnt/*,/media/*,/lost+found}
# For 16GB on Samsung Pro 960: First time 98 seconds, second time 27 seconds.
rsyncTime=$SECONDS  
echo ""
echo "Time to clone files: $rsyncTime Seconds"

# Change /etc/update-manager/release-upgrades prompt from never to LTS
echo ""
echo "====================================================================="
echo "Making changes in: $TargetMnt/etc/update-manager/release-upgrades"
echo "     from Prompt=: never"
echo "       to Prompt=: lts"
echo "Allows running 'do-release-upgrade -d' when rebooting clone target"
echo "Consider 'do-release-upgrade -d -f DistUpgradeViewNonInteractive' This"
echo "allows you to go to bed or go to lunch whilst upgrade runs."
echo ""
echo "* * *  When you Upgrade, TURN OFF screen locking for inactivity. * * *"
echo ""
sed -i 's/Prompt=never/Prompt=lts/' "$TargetMnt"/etc/update-manager/release-upgrades

## This section commented out to prevent surprises. You may uncomment.
## You may want to revise to include `cron.daily`, `cron.hourly`, etc.
# Move `/etc/cron.d` reboot jobs to `/etc/cron.d/hold` to prevent running
# scripts such as daily backup or Ubuntu 16.04 specific problem fixes.
#echo ""
#echo "====================================================================="
#echo "Moving '$TargetMnt/etc/cron.d' to '.../hold' to prevent running."
#echo "After booting clone, move back individual files you want to run"
#if [[ ! -d "$TargetMnt"/etc/cron.d/hold ]]; then
#    mkdir "$TargetMnt"/etc/cron.d/hold
#fi
#cp -p  "$TargetMnt"/etc/cron.d/* "$TargetMnt"/etc/cron.d/hold/
#rm -fv "$TargetMnt"/etc/cron.d/*

# Update /etc/fstab on clone partition with clone's UUID
echo ""
echo "====================================================================="
echo "Making changes in: $TargetMnt/etc/fstab"
echo "        from UUID: $SourceUUID"
echo "          to UUID: $TargetUUID"
sed -i "s/$SourceUUID/$TargetUUID/g" "$TargetMnt"/etc/fstab

# Update /boot/grub/grub.cfg on clone partition with clone's UUID
echo ""
echo "====================================================================="
echo "Making changes in: $TargetMnt/boot/grub/grub.cfg"
echo "        from UUID: $SourceUUID"
echo "          to UUID: $TargetUUID"
echo "Also change 'quiet splash' to 'nosplash' for environmental awareness"
echo "Suggest first time booting clone you make wallpaper unique"
sed -i "s/$SourceUUID/$TargetUUID/g" "$TargetMnt"/boot/grub/grub.cfg
sed -i "s/quiet splash/nosplash/g" "$TargetMnt"/boot/grub/grub.cfg

# Update grub boot menu
echo ""
echo "====================================================================="
echo "Calling 'update-grub' to create new boot menu"
update-grub

# Unmount and exit

echo ""
echo "====================================================================="
echo "Unmounting $TargetDev as $TargetMnt"

CleanUp             # Remove temporary files

exit 0

上記のbashコードをコピーして、という新しいファイルに貼り付けます/usr/local/bin/clone-ubuntu.sh。次に、次を使用して新しいファイルを実行可能にします。

sudo chmod a+x /usr/local/bin/clone-ubuntu.sh

スクリプトを呼び出すには:

sudo clone-ubuntu.sh

16.04 LTSクローンをUbuntu 18.04 LTSにアップグレードする方法

これは、多くの人にとって興味のある「ボーナス」セクションです。

マシンを再起動します。grubメニューには、複製されたパーティションを指して新しいメニューオプションが含まれます。クローンの[ 詳細オプション ]メニューから特定のカーネルバージョンを選択することもできます。

クローン化された16.04 LTSを18.04 LTSに変換する1つの方法は、次を実行することです。

sudo do-release-upgrade

-dフラグは2018年7月26日より前に必要でしたが、もはや必要ではないことに注意してください。

18.04アップグレードの確認を注意深くお読みください

先に進む前に、非アクティブな画面ロックがオフになっていることを確認してください。キーボードの非アクティブが原因でコンピューターがロック画面に移動すると、アップグレードプロセスがクラッシュする可能性があります。

18.04アップグレードプロセスの概要

さまざまなアプリがさまざまなユーザーによってインストールされるため、このセクションはマシン固有です。メモと記憶に基づいて作成した簡単な要約を次に示します。

  1. 続行する確認:ENTER
  2. パッケージが削除されます:Y
  3. longind.confを置き換えます:Y
  4. 構成ファイル「/etc/sane.d/dll.conf」、デフォルトはN、Yを取る
  5. '/etc/NetworkManager/conf.d/default-wifi-powersave-on.conf'デフォルトNを使用
  6. 設定ファイル '/etc/pulse/default.pa'デフォルトN、Yを取る
  7. 構成ファイル「/etc/grub.d/30_os-prober」デフォルトN、Nを取得
  8. 全画面のgrubメニュー設定が表示されます。オプションを取る:現在インストールされているローカルバージョンを保持する
  9. 構成ファイル「/etc/cron.d/anacron」、デフォルトはN、Yを使用して内容を確認
  10. エラーメッセージが複数回:/sbin/ldconfig.real:警告:開くことができない設定ファイルを無視します:/etc/ld.so.conf.d/x86_64-linux-gnu_EGL.conf:そのようなファイルまたはディレクトリはありません
  11. 非標準:構成ファイル '/etc/vnstat.conf'(相違点1.13と1.18を表示)Yを取る
  12. 220個のパッケージが削除されます。(数時間かかる場合があります)Yと入力します
  13. アップグレードを完了するには、再起動が必要です。Yを取る

ほとんどの人が見ることのないステップ10に注意してください。Ubuntu 16.04に古いnVidiaドライバーをインストールしていますが、完全に削除することはできませんでした。同様の古いパッケージが完全に削除されることはないため、含まれています。

GRUBはUEFIでクローンを作成するためにブートメニューを変更します

18.04のアップグレードとは異なり、18.04.1のアップグレードでは、Grub UEFI構成が変更され、この回答に従って元のgrubメニューの代わりにクローンのgrubメニューを使用するようになりました:デュアルブートとファイル/boot/grub/grub.cfg-これは中古?

$ sudo cat /boot/efi/EFI/ubuntu/grub.cfg
search.fs_uuid b40b3925-70ef-447f-923e-1b05467c00e7 root 
set prefix=($root)'/boot/grub'
configfile $prefix/grub.cfg

$ sudo grub-install
Installing for x86_64-efi platform.
Installation finished. No error reported.

sudo update-grub元のパーティションをブートした後に実行するだけでgrub.cfgは、grubによってロードされるパーティションを変更することはできません。sudo grub-installgrubが元のパーティションの構成を使用するように強制するために使用する必要があります。

元のパーティションとクローンパーティションの両方update-grubが独自の/boot/grub/grub.cfgファイルを維持するために使用できますが、ブート中に使用できるのは1つだけです。

もちろん、grubでCloneのgrubメニューを使用する場合は、元のパーティションで上記の手順を実行しないでください。


履歴を編集

2018年5月6日編集 -空のクローン(ターゲット)パーティションの情報表示が修正されました。

2018年8月26日編集 -2 GBのごみ箱ファイルなどの大きなファイルがコピープロセス中に複製時に複製されないように--inplaceオプションを使用 rsyncこれにより、「ディスク容量不足」エラーが発生する可能性があります。/etc/cron.dユーザーが別のディレクトリを完全に保持したい場合や必要な場合があるため、オーバーライドをコメント化します。Ubuntu 18.04.1 LTSがリリースされたため、フラグdo-release-upgradeなしで使用するように手順を更新します-d


1
+1。便利なツールをありがとう:-)
sudodus

1
@sudodus 18.04へのアップグレードを完了する前に、このツールを使用することを願っています。少なくとも、彼らはこれをチュートリアルとして使用し、ライブUSBブートを使用して手動で手順を繰り返すことができます。それは、彼らが最初にテストすることなくアップグレードされ、その前の一掃が犯したので、人々は18.04新しいブランドに持っているので、多くのエラー読み取ることが悲劇的だ16.0417.04、または17.10のインストールを。悲しいことに、私は数十年にわたって何度も似たようなものを見てきました。投票していただきありがとうございます!それは次のような努力に費やされた努力を強化するのに役立ちますが、clone-ubuntu.shとにかく私はこれを自分で4回使っています!
WinEunuuchs2Unix

1
まだスクリプトを使用していませんが、非常に便利であり、使用する予定であることを理解しています。-8.04から10.04に12.04にアップグレードすることができました。これは長い間使用していました。しかし、14.04から16.04を介してアップグレードしようとすると失敗しました。十分なバックアップがあったので、16.04以降のコピーを新規インストールしました。これを保持し、微調整、スクリプト、エイリアス、インストールされたプログラムをチェックしました。-ところで、私は永続的なライブドライブ 'home-rw'を作成およびアップグレードするスクリプトに取り組んでいます。試してみてください:-)
sudodus

1
あなたのリンクの小さな誤植:私はそれらをすべて8.04でテストしましたLTSは最後に18.04 LTSを読むはずです。あなたのツールは、Ubuntu 16.04のクローンを作成するのに十分なHDDスペースを持っていない多くの人々にとって最も人気のあるツールです。また、HDDに新しいパーティションを作成するよりも(遅いですが)簡単です。
WinEunuuchs2Unix

誤字を修正しました、ありがとう:-)あなたはHDDへの複製(またはコンテンツのコピー)について正しいです。しかし、持ちこたえているライブシステムをポケットに入れて持ち運びたい人にとっては、私のツールを使用すると便利です。
sudodus

3

以前のリリースから18.04 LTSへのアップグレードに関する問題

以前のリリースから18.04 LTSにアップグレードするのは簡単ではありません。過去にそのようなアップグレードよりも多くの問題があるかどうかはわかりませんが、リリースアップグレードを行う人々は今や自分自身にリスク負っています。一方、彼らはバグを見つけ、バグが報告された場合、Ubuntu 18.04 LTSシステム自体のデバッグだけでなく、アップグレードツールの開発にも役立ちます。

これは、アップグレードが最初のポイントリリース(18.04.1 LTS)で正式にリリースされるまで待つのに十分な忍耐を持っている人々がよりスムーズに乗ることを意味します。

完全アップグレードを行う前のテスト...

@ WinEunuuchs2Unixがここで説明する方法により、18.04 LTSへのアップグレードがコンピューターハードウェアを備えた現在の[多少変更された]オペレーティングシステムで動作する場合、実際のシステムのコピーでテストできます。

これにより、オペレーティングシステムの破損による複数の災害を防ぐことができます。

@ WinEunuuchs2Unixのスクリプトはまだ使用していませんが、非常に便利であり、使用するつもりであることを理解しています。8.04から10.04に12.04にアップグレードできました。これは長い間使用していました。しかし、14.04から16.04を介してアップグレードしようとすると、失敗し、エラーが見つかりませんでした。

...そして問題が発生した場合は、新規インストールを行います

私が持っていた良いバックアップを私は新鮮で16.04でインストールし、後でコピーした上で作られたので、私は維持したいとの調整、スクリプト、エイリアスやインストールされているプログラムを確認しました。@ WinEunuuchs2Unixの方法を使用していた場合、問題を早期に見ていましたが、新規インストールを直接行いました。

永続的なライブシステムのアップグレード

永続的なライブシステムは、非常にポータブルなUbuntuシステムを取得するために使用されます。Ubuntuシステムは、テストに使用されることもあれば、長期間使用されることもあります。

既知の問題であり、インストールされたシステムで行うようなシステムの更新およびアップグレードは、遅かれ早かれ破損するため、行わないでください。さらに、isoファイルに付属しているカーネルとカーネルドライバーは、オーバーレイシステムが起動する前に起動されるため、スタックしています。

ただし、通常は/home、別の「ホーム」パーティションを使用して新規インストールを行うときに、ディレクトリを保持することができます。home-rwパーティションを作成すると、永続的なライブシステムが起動時に自動的にパーティションを見つけて使用します。

私が開発し、シェルスクリプト、テストしていMK-永続-live_with_home-RW作成することができますと永続的なライブシステムをhome-rwパーティションを、そしてそれは後にアップグレードすることができ、それを

  • isoファイルを新しいものに置き換えます。少なくとも、新しいisoファイルがリリースされたらアップグレードする必要がありますが、LTSシステムを月に1回アップグレードし、テストトラッカーから現在の毎日のisoファイルを使用することもできます。

  • 新しいisoファイルのgrubを変更します。

  • casper-rwオペレーティングシステムの変更を保存するファイルを消去(再フォーマット)します(したがって、システムに追加したプログラムパッケージを再インストールする必要があります)。

  • home-rw個人用ファイル、設定、および微調整でパーティションを保持します。

  • 詳細については、このリンクを参照してください。

追加リンク

Ubuntuの最新かつ最高のバージョンをテストしたい人向けの一般的なヒントは、次のリンクにあります。

Ubuntuのテストと開発に参加する方法


1
追加のリンクはいい感じです。問題を報告する人が多くなればなるほど、他の人にとって解決される問題が増えます。
WinEunuuchs2Unix

1
LTSユーザー(本質的に慎重)にとって、最初のポイントリリース18.04.1を待つのは非常に良いポイントです。大規模な組織では、16.04をテストパーティションに複製し、スタッフトレーニングの目的で18.04にアップグレードしたい場合があります。ユーザーは、慣れているデータにアクセスできます。もちろん、ITスタッフは、7月26日の最初のポイントリリースの数か月前にもクローンデータの広範なテストから恩恵を受けるでしょう。
WinEunuuchs2Unix
弊社のサイトを使用することにより、あなたは弊社のクッキーポリシーおよびプライバシーポリシーを読み、理解したものとみなされます。
Licensed under cc by-sa 3.0 with attribution required.