Rechercher dans le manuel MySQL
2.11.6 Upgrading MySQL Binary or Package-based Installations on Unix/Linux
This section describes how to upgrade MySQL binary and package-based installations on Unix/Linux. In-place and logical upgrade methods are described.
In-Place Upgrade
An in-place upgrade involves shutting down the old MySQL server, replacing the old MySQL binaries or packages with the new ones, restarting MySQL on the existing data directory, and upgrading any remaining parts of the existing installation that require upgrading. For details about what may need upgrading, see Section 2.11.3, “What the MySQL Upgrade Process Upgrades”.
If you are upgrading an installation originally produced by installing multiple RPM packages, upgrade all the packages, not just some. For example, if you previously installed the server and client RPMs, do not upgrade just the server RPM.
For some Linux platforms, MySQL installation from RPM or Debian packages includes systemd support for managing MySQL server startup and shutdown. On these platforms, mysqld_safe is not installed. In such cases, use systemd for server startup and shutdown instead of the methods used in the following instructions. See Section 2.5.9, “Managing MySQL Server with systemd”.
For upgrades to MySQL Cluster installations, see also MySQL Cluster Upgrade.
To perform an in-place upgrade:
- Review the information in Section 2.11.1, “Before You Begin”. 
- Ensure the upgrade readiness of your installation by completing the preliminary checks in Section 2.11.5, “Preparing Your Installation for Upgrade”. 
- If you use XA transactions with - InnoDB, run- XA RECOVERbefore upgrading to check for uncommitted XA transactions. If results are returned, either commit or rollback the XA transactions by issuing an- XA COMMITor- XA ROLLBACKstatement.
- If there are encrypted - InnoDBtablespaces, rotate the keyring master key by executing this statement:
- If you normally run your MySQL server configured with - innodb_fast_shutdownset to- 2(cold shutdown), configure it to perform a fast or slow shutdown by executing either of these statements:- With a fast or slow shutdown, - InnoDBleaves its undo logs and data files in a state that can be dealt with in case of file format differences between releases.
- Shut down the old MySQL server. For example: - mysqladmin -u root -p shutdown
- Upgrade the MySQL binaries or packages. If upgrading a binary installation, unpack the new MySQL binary distribution package. See Obtain and Unpack the Distribution. For package-based installations, install the new packages. 
- Start the MySQL 8.0 server, using the existing data directory. For example: - mysqld_safe --user=mysql --datadir=/path/to/existing-datadir &- If there are encrypted - InnoDBtablespaces, use the- --early-plugin-loadoption to load the keyring plugin.- When you start the MySQL 8.0 server, it automatically detects whether data dictionary tables are present. If not, the server creates them in the data directory, populates them with metadata, and then proceeds with its normal startup sequence. During this process, the server upgrades metadata for all database objects, including databases, tablespaces, system and user tables, views, and stored programs (stored procedures and functions, triggers, and Event Scheduler events). The server also removes files that previously were used for metadata storage. For example, after upgrading from MySQL 5.7 to MySQL 8.0, you will notice that tables no longer have - .frmfiles.- If this step fails, the server reverts all changes to the data directory. In this case, you should remove all redo log files, start your MySQL 5.7 server on the same data directory, and fix the cause of any errors. Then perform another slow shutdown of the 5.7 server and start the MySQL 8.0 server to try again. 
- In the previous step, the server upgrades the data dictionary as necessary. Now it is necessary to perform any remaining upgrade operations: - As of MySQL 8.0.16, the server will already have done so in the previous step: It makes any changes required in the - mysqlsystem schema between MySQL 5.7 and MySQL 8.0, so that you can take advantage of new privileges or capabilities. It also brings the Performance Schema,- INFORMATION_SCHEMA, and- sysschema up to date for MySQL 8.0, and examines all user schemas for incompatibilities with the current version of MySQL.
- Prior to MySQL 8.0.16, the server upgrades only the data dictionary in the previous step. After the MySQL 8.0 server starts successfully, execute mysql_upgrade to perform the remaining upgrade tasks: - mysql_upgrade -u root -p- Then shut down and restart the MySQL server to ensure that any changes made to the system tables take effect. For example: - mysqladmin -u root -p shutdown mysqld_safe --user=mysql --datadir=/path/to/existing-datadir &- The first time you start the MySQL 8.0 server (in an earlier step), you may notice messages in the error log regarding nonupgraded tables. If mysql_upgrade has been run successfully, there should be no such messages the second time you start the server. 
 
The upgrade process does not upgrade the contents of the time zone tables. For upgrade instructions, see Section 5.1.13, “MySQL Server Time Zone Support”.
If the upgrade process uses mysql_upgrade (that is, prior to MySQL 8.0.16), the process does not upgrade the contents of the help tables, either. For upgrade instructions in that case, see Section 5.1.14, “Server-Side Help Support”.
A logical upgrade involves exporting SQL from the old MySQL instance using a backup or export utility such as mysqldump or mysqlpump, installing the new MySQL server, and applying the SQL to your new MySQL instance. For details about what may need upgrading, see Section 2.11.3, “What the MySQL Upgrade Process Upgrades”.
For some Linux platforms, MySQL installation from RPM or Debian packages includes systemd support for managing MySQL server startup and shutdown. On these platforms, mysqld_safe is not installed. In such cases, use systemd for server startup and shutdown instead of the methods used in the following instructions. See Section 2.5.9, “Managing MySQL Server with systemd”.
Applying SQL extracted from a previous MySQL release to a new MySQL release may result in errors due to incompatibilities introduced by new, changed, deprecated, or removed features and capabilities. Consequently, SQL extracted from a previous MySQL release may require modification to enable a logical upgrade.
To identify incompatibilities before upgrading to the latest MySQL 8.0 release, perform the steps described in Section 2.11.5, “Preparing Your Installation for Upgrade”.
To perform a logical upgrade:
- Review the information in Section 2.11.1, “Before You Begin”. 
- Export your existing data from the previous MySQL installation: - mysqldump -u root -p --add-drop-table --routines --events --all-databases --force > data-for-upgrade.sqlNote- Use the - --routinesand- --eventsoptions with mysqldump (as shown above) if your databases include stored programs. The- --all-databasesoption includes all databases in the dump, including the- mysqldatabase that holds the system tables.Important- If you have tables that contain generated columns, use the mysqldump utility provided with MySQL 5.7.9 or higher to create your dump files. The mysqldump utility provided in earlier releases uses incorrect syntax for generated column definitions (Bug #20769542). You can use the - INFORMATION_SCHEMA.COLUMNStable to identify tables with generated columns.
- Shut down the old MySQL server. For example: - mysqladmin -u root -p shutdown
- Install MySQL 8.0. For installation instructions, see Chapter 2, Installing and Upgrading MySQL. 
- Initialize a new data directory, as described in Section 2.10.1, “Initializing the Data Directory”. For example: - mysqld --initialize --datadir=/path/to/8.0-datadir- Copy the temporary - 'root'@'localhost'password displayed to your screen or written to your error log for later use.
- Start the MySQL 8.0 server, using the new data directory. For example: - mysqld_safe --user=mysql --datadir=/path/to/8.0-datadir &
- Reset the - rootpassword:- shell> mysql -u root -p Enter password: **** <- enter temporary root password
- Load the previously created dump file into the new MySQL server. For example: - mysql -u root -p --force < data-for-upgrade.sqlNote- It is not recommended to load a dump file when GTIDs are enabled on the server ( - gtid_mode=ON), if your dump file includes system tables. mysqldump issues DML instructions for the system tables which use the non-transactional MyISAM storage engine, and this combination is not permitted when GTIDs are enabled. Also be aware that loading a dump file from a server with GTIDs enabled, into another server with GTIDs enabled, causes different transaction identifiers to be generated.
- Perform any remaining upgrade operations: - In MySQL 8.0.16 and higher, shut down the server, then restart it with the - --upgrade=FORCEoption to perform the remaining upgrade tasks:- mysqladmin -u root -p shutdown mysqld_safe --user=mysql --datadir=/path/to/8.0-datadir --upgrade=FORCE &- Upon restart with - --upgrade=FORCE, the server makes any changes required in the- mysqlsystem schema between MySQL 5.7 and MySQL 8.0, so that you can take advantage of new privileges or capabilities. It also brings the Performance Schema,- INFORMATION_SCHEMA, and- sysschema up to date for MySQL 8.0, and examines all user schemas for incompatibilities with the current version of MySQL.
- Prior to MySQL 8.0.16, execute mysql_upgrade to perform the remaining upgrade tasks: - mysql_upgrade -u root -p- Then shut down and restart the MySQL server to ensure that any changes made to the system tables take effect. For example: - mysqladmin -u root -p shutdown mysqld_safe --user=mysql --datadir=/path/to/8.0-datadir &
 
The upgrade process does not upgrade the contents of the time zone tables. For upgrade instructions, see Section 5.1.13, “MySQL Server Time Zone Support”.
If the upgrade process uses mysql_upgrade (that is, prior to MySQL 8.0.16), the process does not upgrade the contents of the help tables, either. For upgrade instructions in that case, see Section 5.1.14, “Server-Side Help Support”.
          Loading a dump file that contains a MySQL 5.7
          mysql schema re-creates two tables that are
          no longer used: event and
          proc. (The corresponding MySQL 8.0 tables
          are events and routines,
          both of which are data dictionary tables and are protected.)
          After you are satisfied that the upgrade was successful, you
          can remove the event and
          proc tables by executing these SQL
          statements:
        
The information in this section is an adjunct to the in-place upgrade procedure described in In-Place Upgrade, for use if you are upgrading MySQL Cluster.
As of MySQL 8.0.16, a MySQL Cluster upgrade can be performed as a regular rolling upgrade, following the usual three ordered steps:
- Upgrade MGM nodes. 
- Upgrade data nodes one at a time. 
- Upgrade API nodes one at a time (including MySQL servers). 
        The way to upgrade each of the nodes remains almost the same as
        prior to MySQL 8.0.16 because there is a separation between
        upgrading the data dictionary and upgrading the system tables.
        There are two steps to upgrading each individual
        mysqld:
- Import the data dictionary. - Start the new server with the - --upgrade=MINIMALoption to upgrade the data dictionary but not the system tables. This is essentially the same as the pre-MySQL 8.0.16 action of starting the server and not invoking mysql_upgrade.- The MySQL server must be connected to - NDBfor this phase to complete. If any- NDBor- NDBINFOtables exist, and the server cannot connect to the cluster, it exits with an error message:- Failed to Populate DD tables.
- Upgrade the system tables. - Prior to MySQL 8.0.16, the DBA invokes the mysql_upgrade client to upgrade the system tables. As of MySQL 8.0.16, the server performs this action: To upgrade the system tables, restart each individual mysqld without the - --upgrade=MINIMALoption.
Deutsche Übersetzung
Sie haben gebeten, diese Seite auf Deutsch zu besuchen. Momentan ist nur die Oberfläche übersetzt, aber noch nicht der gesamte Inhalt.Wenn Sie mir bei Übersetzungen helfen wollen, ist Ihr Beitrag willkommen. Alles, was Sie tun müssen, ist, sich auf der Website zu registrieren und mir eine Nachricht zu schicken, in der Sie gebeten werden, Sie der Gruppe der Übersetzer hinzuzufügen, die Ihnen die Möglichkeit gibt, die gewünschten Seiten zu übersetzen. Ein Link am Ende jeder übersetzten Seite zeigt an, dass Sie der Übersetzer sind und einen Link zu Ihrem Profil haben.
Vielen Dank im Voraus.
Dokument erstellt 26/06/2006, zuletzt geändert 26/10/2018
Quelle des gedruckten Dokuments:https://www.gaudry.be/de/mysql-rf-upgrade-binary-package.html
Die Infobro ist eine persönliche Seite, deren Inhalt in meiner alleinigen Verantwortung liegt. Der Text ist unter der CreativeCommons-Lizenz (BY-NC-SA) verfügbar. Weitere Informationen auf die Nutzungsbedingungen und dem Autor.
Referenzen
Diese Verweise und Links verweisen auf Dokumente, die während des Schreibens dieser Seite konsultiert wurden, oder die zusätzliche Informationen liefern können, aber die Autoren dieser Quellen können nicht für den Inhalt dieser Seite verantwortlich gemacht werden.
Der Autor dieser Website ist allein dafür verantwortlich, wie die verschiedenen Konzepte und Freiheiten, die mit den Nachschlagewerken gemacht werden, hier dargestellt werden. Denken Sie daran, dass Sie mehrere Quellinformationen austauschen müssen, um das Risiko von Fehlern zu reduzieren.
 
  
  
  
 