(Created page with "Applicable to Fedora Versions All Fedora versions Requirements Explanation of requirements. Make a proper backup of your system before making any major changes. ...") |
No edit summary |
||
Line 1: | Line 1: | ||
Applicable to Fedora Versions | = Applicable to Fedora Versions = | ||
All Fedora versions | All Fedora versions | ||
Requirements | = Requirements = | ||
Explanation of requirements. | Explanation of requirements. | ||
# Make a proper backup of your system before making any major changes. | |||
# Before you begin, please insure that you have current software: su -c "yum update" | |||
# Please read the common bugs link: https://fedoraproject.org/wiki/Common_F17_bugs -or- https://fedoraproject.org/wiki/Common_F18_bugs as appropriate. | |||
# Please read https://fedoraproject.org/wiki/How_to_use_PreUpgrade if you use Preupgrade | |||
# Please read https://fedoraproject.org/wiki/FedUp if you use FedUp | |||
# Please read http://fedoraproject.org/wiki/YumUpgradeFaq if you are planning on using this method. | |||
Doing the Work | = Doing the Work = | ||
Basic description of what will be done and what is expected. | Basic description of what will be done and what is expected. | ||
# Change runlevel to 3 / multiuser (Not graphical. See: https://fedoraproject.org/wiki/Systemd#How_do_I_change_the_runlevel.3F and https://fedoraproject.org/wiki/SysVinit_to_Systemd_Cheatsheet ) (Use the grub method) and login as root. You can use "cnetworkmanager" or "nmcli" if you need to get networking started without the GUI. Do not launch the GUI. This step is critically important. Do not deviate. | |||
# Update your system: (Some warnings at this stage are normal. They should be resolved normally a bit later on.) | |||
<pre> | |||
# rm /var/lib/rpm/__db.00?; | # rm /var/lib/rpm/__db.00?; | ||
# yum clean all; | # yum clean all; | ||
# yum-complete-transaction; | # yum-complete-transaction; | ||
# yum update --skip-broken; | # yum update --skip-broken; | ||
# rpm -a --setugids; rpm -a --setperms; | # rpm -a --setugids; rpm -a --setperms; | ||
</pre> | |||
# If your installed version is higher than Fedora14 or RHEL6, this will reset capabilities: | |||
<pre> | |||
# rpm -Va > /tmp/rpm-Va0.txt 2>&1; | # rpm -Va > /tmp/rpm-Va0.txt 2>&1; | ||
# awk '/^.{8}P /{print$NF}' /tmp/rpm-Va0.txt \ | # awk '/^.{8}P /{print$NF}' /tmp/rpm-Va0.txt \ | ||
Line 40: | Line 37: | ||
# yum install @core @base; | # yum install @core @base; | ||
</pre> | |||
# (Optional) Remove old packages from cache directories | |||
<pre> | |||
# DIST=$(rpm --eval '%{dist}'); find /var/cache/yum/ -type f -name \*.rpm |grep -v $DIST |xargs rm -f; | # DIST=$(rpm --eval '%{dist}'); find /var/cache/yum/ -type f -name \*.rpm |grep -v $DIST |xargs rm -f; | ||
</pre> | |||
# If you have yum-plugin-local installed, you will want to free up spaced it used: | |||
<pre> | |||
# DIST=$(rpm --eval '%{dist}'); find /var/lib/yum/plugins/local/ -type f -name \*.rpm |grep -v $DIST |xargs rm -f; | # DIST=$(rpm --eval '%{dist}'); find /var/lib/yum/plugins/local/ -type f -name \*.rpm |grep -v $DIST |xargs rm -f; | ||
</pre> | |||
# (Optional) Install basic components you would have from a new install: You likely want to include the desktop of your choice as well, such as @gnome-desktop or @kde-desktop or @xfce-desktop or @lxde-desktop | |||
<pre> | |||
# yum install @base-x @base @core @fonts @input-methods @admin-tools @dial-up @hardware-support @printing fpaste memtest86+ @gnome-desktop; | # yum install @base-x @base @core @fonts @input-methods @admin-tools @dial-up @hardware-support @printing fpaste memtest86+ @gnome-desktop; | ||
</pre> | |||
# Correct labels and reboot: (This command takes about 11 minutes to run on my hardware. Yours may be quicker or slower. Give it time to complete.) | |||
<pre> | |||
# fixfiles -R -a restore; restorecon -Rv /home/*/.local/; reboot; | # fixfiles -R -a restore; restorecon -Rv /home/*/.local/; reboot; | ||
</pre> | |||
# The above command only does the files yum/rpm installed. If you would rather relabel all files on the system, use this instead: (Note: It may take longer on reboot) | |||
<pre> | |||
# fixfiles onboot; reboot; | # fixfiles onboot; reboot; | ||
</pre> | |||
# Newer versions of yum include this command. If your version does not yet support it, skip this step: (yum-3.2.28-1 is known to work) | |||
<pre> | |||
# yum distribution-synchronization --disablepresto; | # yum distribution-synchronization --disablepresto; | ||
</pre> | |||
# Login again with runlevel 3 and as root. Install yum-utils and print out a list of all the packages that need review: (This will print out packages that have dependency problems as well as packages that are no longer found in your configured repos and any duplicate packages you might have.) | |||
<pre> | |||
# rpm -Va --nofiles --nodigest; | # rpm -Va --nofiles --nodigest; | ||
# yum install yum-utils; | # yum install yum-utils; | ||
# package-cleanup --problems; | # package-cleanup --problems; | ||
# package-cleanup --orphans; | # package-cleanup --orphans; | ||
# package-cleanup --dupes; | |||
</pre> | |||
# (optionally locate packages you may not need any longer) | |||
<pre> | |||
# package-cleanup --leaves; | # package-cleanup --leaves; | ||
</pre> | |||
# In most cases, you should remove the versions listed above and install the current distribution version of the package instead if you still use it. | |||
# Create a list of all the files that have verify concerns: | |||
<pre> | |||
# . /etc/sysconfig/prelink && /usr/sbin/prelink -av $PRELINK_OPTS >> /var/log/prelink/prelink.log 2>&1; | # . /etc/sysconfig/prelink && /usr/sbin/prelink -av $PRELINK_OPTS >> /var/log/prelink/prelink.log 2>&1; | ||
# /sbin/ldconfig; | # /sbin/ldconfig; | ||
# rpm -Va > /tmp/rpm-Va.txt 2>&1; | # rpm -Va > /tmp/rpm-Va.txt 2>&1; | ||
</pre> | |||
# Using the above, create a list of non-configuration files that need review: | |||
<pre> | |||
# egrep -v '^.{9} c /' /tmp/rpm-Va.txt > /tmp/URGENT-REVIEW.txt; | # egrep -v '^.{9} c /' /tmp/rpm-Va.txt > /tmp/URGENT-REVIEW.txt; | ||
</pre> | |||
# Using the above, create a list of configuration files that need review: | |||
<pre> | |||
# egrep '^.{9} c /' /tmp/rpm-Va.txt > /tmp/REVIEW-CONFIGS.txt; | # egrep '^.{9} c /' /tmp/rpm-Va.txt > /tmp/REVIEW-CONFIGS.txt; | ||
</pre> | |||
# Review the lists above. Consult "man rpm" under the VERIFY section for the meaning of the first column. You can usually ignore lines if they have a "prelink: /usr/bin/somefile: at least one of file's dependencies has changed since prelinking" type message next to it. | |||
# Locate your changed config files and manually merge the changes (If you have yum-plugin-merge-conf installed, you can use it here to assist as well): | |||
<pre> | |||
# yum install rpmconf; rpmconf -a; | # yum install rpmconf; rpmconf -a; | ||
# find /etc /var -name '*.rpm?*' > /tmp/REVIEW-OBSOLETE-CONFIGS.txt; | # find /etc /var -name '*.rpm?*' > /tmp/REVIEW-OBSOLETE-CONFIGS.txt; | ||
</pre> | |||
Troubleshooting | = Troubleshooting = | ||
How to test | How to test | ||
Explanation troubleshooting basics and expectations. | Explanation troubleshooting basics and expectations. | ||
# Recreate an initrd image for F12+: | |||
<pre> | |||
# dracut -f /boot/initramfs-$(uname -r).img $(uname -r); | # dracut -f /boot/initramfs-$(uname -r).img $(uname -r); | ||
</pre> | |||
# Restore the MBR: | |||
<pre> | |||
# grub-install; | # grub-install; | ||
# grub2-mkconfig -o /boot/grub2/grub.cfg; | |||
</pre> | |||
# Xorg refuses to start. This happens typically if you had an old version, or if you had nvidia.ko / fglrx.ko / catalyst.ko drivers. Move the xorg.conf out of the way and regenerate a new one. | |||
<pre> | |||
# mv /etc/X11/xorg.conf /root/xorg.conf.save | # mv /etc/X11/xorg.conf /root/xorg.conf.save | ||
</pre> | |||
Common problems and fixes | = Common problems and fixes = | ||
Go back and read the release notes, common bugs link and upgrade path notes: | |||
* http://docs.fedoraproject.org/release-notes/ | |||
* http://docs.fedoraproject.org/install-guide/ | |||
* https://fedoraproject.org/wiki/Common_bugs | |||
Have an issue not covered here? See https://bugzilla.redhat.com/ | |||
More Information | = More Information = | ||
Always have a clean backup before you begin any major work on your distribution. | Always have a clean backup before you begin any major work on your distribution. | ||
* The absolute best method to upgrade is to backup, and format clean with a fresh install. | |||
* Second best, DVD media - can be on a real DVD or on USB. | |||
* Third best, Preupgrade / FedUp. | |||
* Last resort option, for experienced users only, yum upgrade. | |||
* You cannot use the Livecd media to perform upgrades. | |||
Disclaimer | = Disclaimer = | ||
We test this stuff on our own machines, really we do. But you may run into problems, if you do, come to #fedora on irc.freenode.net | We test this stuff on our own machines, really we do. But you may run into problems, if you do, come to #fedora on irc.freenode.net | ||
Added Reading | Added Reading | ||
* https://fedoraproject.org/wiki/Common_F19_bugs | |||
* https://fedoraproject.org/wiki/Common_F18_bugs | |||
* https://fedoraproject.org/wiki/Common_F17_bugs | |||
* https://fedoraproject.org/wiki/Common_F16_bugs | |||
* https://fedoraproject.org/wiki/Common_F15_bugs | |||
* https://fedoraproject.org/wiki/Common_F14_bugs | |||
* https://fedoraproject.org/wiki/Common_F13_bugs | |||
* http://docs.fedoraproject.org/ | |||
* https://fedoraproject.org/wiki/How_to_use_PreUpgrade and | |||
* https://fedoraproject.org/wiki/Common_F12_bugs#Issues_when_upgrading_from_previous_releases and | |||
* https://fedorahosted.org/fesco/ticket/270 | |||
* http://fedoraproject.org/wiki/YumUpgradeFaq | |||
* http://www.rpm.org/wiki/Docs/RpmRecovery | |||
= Sample Scripts = | |||
* Report what needs review: http://fedorapeople.org/cgit/fenris02/public_git/cleanup.git/plain/rpm-verify.sh | |||
* When you really need a reboot: http://fedorapeople.org/cgit/fenris02/public_git/cleanup.git/plain/raising-elephants.sh | |||
* New disk that you want to inspect: http://fedorapeople.org/cgit/fenris02/public_git/cleanup.git/plain/drivetest.sh | |||
= Questions / Comments? = |
Revision as of 02:53, 29 April 2013
Applicable to Fedora Versions
All Fedora versions
Requirements
Explanation of requirements.
- Make a proper backup of your system before making any major changes.
- Before you begin, please insure that you have current software: su -c "yum update"
- Please read the common bugs link: https://fedoraproject.org/wiki/Common_F17_bugs -or- https://fedoraproject.org/wiki/Common_F18_bugs as appropriate.
- Please read https://fedoraproject.org/wiki/How_to_use_PreUpgrade if you use Preupgrade
- Please read https://fedoraproject.org/wiki/FedUp if you use FedUp
- Please read http://fedoraproject.org/wiki/YumUpgradeFaq if you are planning on using this method.
Doing the Work
Basic description of what will be done and what is expected.
- Change runlevel to 3 / multiuser (Not graphical. See: https://fedoraproject.org/wiki/Systemd#How_do_I_change_the_runlevel.3F and https://fedoraproject.org/wiki/SysVinit_to_Systemd_Cheatsheet ) (Use the grub method) and login as root. You can use "cnetworkmanager" or "nmcli" if you need to get networking started without the GUI. Do not launch the GUI. This step is critically important. Do not deviate.
- Update your system: (Some warnings at this stage are normal. They should be resolved normally a bit later on.)
# rm /var/lib/rpm/__db.00?; # yum clean all; # yum-complete-transaction; # yum update --skip-broken; # rpm -a --setugids; rpm -a --setperms;
- If your installed version is higher than Fedora14 or RHEL6, this will reset capabilities:
# rpm -Va > /tmp/rpm-Va0.txt 2>&1; # awk '/^.{8}P /{print$NF}' /tmp/rpm-Va0.txt \ |xargs rpm --filecaps -qf \ |grep '= cap' \ |while read fileName eq fileCaps; do setcap "${fileCaps}" "${fileName}" done # yum install @core @base;
- (Optional) Remove old packages from cache directories
# DIST=$(rpm --eval '%{dist}'); find /var/cache/yum/ -type f -name \*.rpm |grep -v $DIST |xargs rm -f;
- If you have yum-plugin-local installed, you will want to free up spaced it used:
# DIST=$(rpm --eval '%{dist}'); find /var/lib/yum/plugins/local/ -type f -name \*.rpm |grep -v $DIST |xargs rm -f;
- (Optional) Install basic components you would have from a new install: You likely want to include the desktop of your choice as well, such as @gnome-desktop or @kde-desktop or @xfce-desktop or @lxde-desktop
# yum install @base-x @base @core @fonts @input-methods @admin-tools @dial-up @hardware-support @printing fpaste memtest86+ @gnome-desktop;
- Correct labels and reboot: (This command takes about 11 minutes to run on my hardware. Yours may be quicker or slower. Give it time to complete.)
# fixfiles -R -a restore; restorecon -Rv /home/*/.local/; reboot;
- The above command only does the files yum/rpm installed. If you would rather relabel all files on the system, use this instead: (Note: It may take longer on reboot)
# fixfiles onboot; reboot;
- Newer versions of yum include this command. If your version does not yet support it, skip this step: (yum-3.2.28-1 is known to work)
# yum distribution-synchronization --disablepresto;
- Login again with runlevel 3 and as root. Install yum-utils and print out a list of all the packages that need review: (This will print out packages that have dependency problems as well as packages that are no longer found in your configured repos and any duplicate packages you might have.)
# rpm -Va --nofiles --nodigest; # yum install yum-utils; # package-cleanup --problems; # package-cleanup --orphans; # package-cleanup --dupes;
- (optionally locate packages you may not need any longer)
# package-cleanup --leaves;
- In most cases, you should remove the versions listed above and install the current distribution version of the package instead if you still use it.
- Create a list of all the files that have verify concerns:
# . /etc/sysconfig/prelink && /usr/sbin/prelink -av $PRELINK_OPTS >> /var/log/prelink/prelink.log 2>&1; # /sbin/ldconfig; # rpm -Va > /tmp/rpm-Va.txt 2>&1;
- Using the above, create a list of non-configuration files that need review:
# egrep -v '^.{9} c /' /tmp/rpm-Va.txt > /tmp/URGENT-REVIEW.txt;
- Using the above, create a list of configuration files that need review:
# egrep '^.{9} c /' /tmp/rpm-Va.txt > /tmp/REVIEW-CONFIGS.txt;
- Review the lists above. Consult "man rpm" under the VERIFY section for the meaning of the first column. You can usually ignore lines if they have a "prelink: /usr/bin/somefile: at least one of file's dependencies has changed since prelinking" type message next to it.
- Locate your changed config files and manually merge the changes (If you have yum-plugin-merge-conf installed, you can use it here to assist as well):
# yum install rpmconf; rpmconf -a; # find /etc /var -name '*.rpm?*' > /tmp/REVIEW-OBSOLETE-CONFIGS.txt;
Troubleshooting
How to test Explanation troubleshooting basics and expectations.
- Recreate an initrd image for F12+:
# dracut -f /boot/initramfs-$(uname -r).img $(uname -r);
- Restore the MBR:
# grub-install; # grub2-mkconfig -o /boot/grub2/grub.cfg;
- Xorg refuses to start. This happens typically if you had an old version, or if you had nvidia.ko / fglrx.ko / catalyst.ko drivers. Move the xorg.conf out of the way and regenerate a new one.
# mv /etc/X11/xorg.conf /root/xorg.conf.save
Common problems and fixes
Go back and read the release notes, common bugs link and upgrade path notes:
- http://docs.fedoraproject.org/release-notes/
- http://docs.fedoraproject.org/install-guide/
- https://fedoraproject.org/wiki/Common_bugs
Have an issue not covered here? See https://bugzilla.redhat.com/
More Information
Always have a clean backup before you begin any major work on your distribution.
- The absolute best method to upgrade is to backup, and format clean with a fresh install.
- Second best, DVD media - can be on a real DVD or on USB.
- Third best, Preupgrade / FedUp.
- Last resort option, for experienced users only, yum upgrade.
- You cannot use the Livecd media to perform upgrades.
Disclaimer
We test this stuff on our own machines, really we do. But you may run into problems, if you do, come to #fedora on irc.freenode.net Added Reading
- https://fedoraproject.org/wiki/Common_F19_bugs
- https://fedoraproject.org/wiki/Common_F18_bugs
- https://fedoraproject.org/wiki/Common_F17_bugs
- https://fedoraproject.org/wiki/Common_F16_bugs
- https://fedoraproject.org/wiki/Common_F15_bugs
- https://fedoraproject.org/wiki/Common_F14_bugs
- https://fedoraproject.org/wiki/Common_F13_bugs
- http://docs.fedoraproject.org/
- https://fedoraproject.org/wiki/How_to_use_PreUpgrade and
- https://fedoraproject.org/wiki/Common_F12_bugs#Issues_when_upgrading_from_previous_releases and
- https://fedorahosted.org/fesco/ticket/270
- http://fedoraproject.org/wiki/YumUpgradeFaq
- http://www.rpm.org/wiki/Docs/RpmRecovery
Sample Scripts
- Report what needs review: http://fedorapeople.org/cgit/fenris02/public_git/cleanup.git/plain/rpm-verify.sh
- When you really need a reboot: http://fedorapeople.org/cgit/fenris02/public_git/cleanup.git/plain/raising-elephants.sh
- New disk that you want to inspect: http://fedorapeople.org/cgit/fenris02/public_git/cleanup.git/plain/drivetest.sh