One of routine tasks for system admins is to update installed programs with the latest patches and hotfixes, as well as upgrade software to a more recent release with new bells and whistles. The latest MySQL 5.6 was released early this year, targeting better performance and scalability. For those of you wanting to try out the latest bleeding edge MySQL, I will describe how to upgrade MySQL server on Debian or Ubuntu.
In this tutorial, I assume that you have already set up MySQL with apt-get. As of this writing, MySQL that ships with major Linux distros is version 5.5. Here I am going to demonstrate how to upgrade MySQL 5.5 to 5.6.
1. Back up your MySQL config files.
$ sudo tar cvfvz /backup/mysql_conf.tgz /etc/mysql
2. Export all databases to a .sql file, and back up MySQL data directory.
$ sudo tar cvfvz /backup/mysql_data.tgz /var/lib/mysql
Note: for a consistent backup of a "live" MySQL system, it is recommended to use a single transaction option or explicit locks on the database, as detailed in this tutorial.
3. Stop MySQL server.
4. Uninstall and remove MySQL packages.
$ sudo apt-get autoremove
$ sudo apt-get autoclean
Do not use "purge" option in apt-get as that would remove MySQL config files and other MySQL related data directories as well, which we will continue to use after MySQL upgrade.
5. Install MySQL dependency (kernel asynchronous I/O access library) which is needed for MySQL 5.5 and higher.
6. Download a MySQL Debian package from the official site.
On 32-bit system:
On 64-bit system:
7. Install the downloaded MySQL package.
The MySQL package will be installed under /opt/mysql directory.
8. Add the MySQL bin directory to the PATH variable system-wide.
$ source /etc/profile
On Ubuntu or Linux Mint:
$ source /etc/environment
9. Open the MySQL config file with a text editor, and update the following two entries.
basedir = /opt/mysql/server-5.6 lc-messages-dir = /opt/mysql/server-5.6/share
10. Copy the MySQL startup script to /etc/init.d and install the script into the boot sequence, so that MySQL server starts up automatically upon boot.
$ sudo update-rc.d mysql defaults
11. (Ubuntu-only) There is MySQL AppArmor profile created from the previous MySQL installation, which is not compatible with the new MySQL installation. So you need to reconfigure MySQL AppArmor profile so MySQL server can start.
First, create a symbolic link.
Edit MySQL AppArmor profile.
/opt/mysql/server-5.6/lib/plugin/ r, /opt/mysql/server-5.6/lib/plugin/*.so* mr, /opt/mysql/server-5.6/share/** r,
Reload AppArmor service.
12. (Ubuntu-only) Remove a Upstart configuration for MySQL (which was installed as part of the previous MySQL installation). We will use SysVinit (/etc/init.d/mysql) instead.
13. Start MySQL server.
14. Restore MySQL databases.
15. Finally, upgrade MySQL system tables.
Troubleshooting MySQL Upgrade
If MySQL server fails to start with the following error on Ubuntu, this is because the old MySQL AppArmor profile prevents it from launching. To fix the problem, make sure to update the MySQL AppArmor profile as described in step 11.
Dec 20 19:57:48 ubuntu kernel: [ 5856.960592] type=1400 audit(1387598268.807:39): apparmor="STATUS" operation="profile_replace" name="/usr/sbin/mysqld" pid=25216 comm="apparmor_parser"
Subscribe to Xmodulo
Do you want to receive Linux FAQs, detailed tutorials and tips published at Xmodulo? Enter your email address below, and we will deliver our Linux posts straight to your email box, for free. Delivery powered by Google Feedburner.
Did you find this tutorial helpful? Then please be generous and support Xmodulo!
Latest posts by Dan Nanni (see all)
- How to install Suricata intrusion detection system on Linux - September 3, 2015
- How to switch from NetworkManager to systemd-networkd on Linux - August 31, 2015
- How to set up a system status page of your infrastructure - August 25, 2015