MySQL升級

来源:http://www.cnblogs.com/ivictor/archive/2016/08/16/5776349.html
-Advertisement-
Play Games

MySQL的升級相對來說還是比較簡單的。 它支持兩種方式的升級: 原地升級(In-place Upgrade) 關閉資料庫,替換舊的二進位文件,重啟資料庫,執行mysql_upgrade 邏輯升級(Logical Upgrade) 用mysqldump導出數據,安裝新的資料庫版本,將數據導入到新的數 ...


MySQL的升級相對來說還是比較簡單的。

它支持兩種方式的升級:

原地升級(In-place Upgrade)

關閉資料庫,替換舊的二進位文件,重啟資料庫,執行mysql_upgrade

邏輯升級(Logical Upgrade)

用mysqldump導出數據,安裝新的資料庫版本,將數據導入到新的資料庫中,執行mysql_upgrade

 

但是MySQL版本眾多,不僅有各種大版本,譬如5.1,5.5,5.6,5.7,同一個大版本中也會有各種小版本。

那麼官方支持怎麼的升級路徑呢?

1. 同一個大版本中的小版本升級,譬如5.6.25到5.6.31。

2. 跨版本升級,但只支持跨一個版本升級,譬如5.5到5.6,5.6到5.7。

3. 不支持跨版本的直接升級,譬如直接從5.1到5.6,可以先從5.1升級到5.5,再從5.5升級到5.6。

 

以上均是指MySQL的GA版本,從非GA版本到GA版本的升級並不支持,譬如5.6.9到5.6.10,因為前者並不是一個GA版本。

關於版本信息,可參考官方說明

http://downloads.mysql.com/archives/community/

 

下麵演示一下原地升級

待升級版本MySQL 5.5.30

目標版本MySQL 5.6.32

 

設置參數

mysql> set global innodb_fast_shutdown=0;
Query OK, 0 rows affected (0.00 sec)

innodb_fast_shutdown參數有三個值

0: 在資料庫關閉的時候,會執行purge操作和change buffer合併,也稱為“show shutdown”

1: 預設值,在資料庫關閉的時候,會跳過purge操作和change buffer合併,也稱為“fast shutdown”

2: 在資料庫關閉的時候,只是flush log,然後執行關閉操作。在恢復的時候可能需要較長時間的crash recovery

 

徹底關閉資料庫

# ./bin/mysqladmin shutdown -uroot -p123456 --socket /data/mysql.sock

 

更新MySQL二進位文件

在這裡,我直接使用新的二進位壓縮包

 

使用新的MySQL啟動

此時datadir指向原來的數據目錄

# ./bin/mysqld_safe  --defaults-file=/usr/test/mysql-5.6.32-linux-glibc2.5-x86_64/my.cnf --user=mysql --ledir=/usr/test/mysql-5.6.32-linux-glibc2.5-x86_64/bin  &

其中,配置文件中的內容如下

[mysqld]
basedir = /usr/test/mysql-5.6.32-linux-glibc2.5-x86_64
datadir = /data
port = 3310
socket = /data/mysql.sock

主要是指定了datadir

 

執行mysql_upgrade

# ./bin/mysql_upgrade -uroot -p123456 --socket=/data/mysql.sock
Warning: Using a password on the command line interface can be insecure.
Looking for 'mysql' as: ./bin/mysql
Looking for 'mysqlcheck' as: ./bin/mysqlcheck
Running 'mysqlcheck' with connection arguments: '--socket=/data/mysql.sock' 
Warning: Using a password on the command line interface can be insecure.
Running 'mysqlcheck' with connection arguments: '--socket=/data/mysql.sock' 
Warning: Using a password on the command line interface can be insecure.
mysql.columns_priv                                 OK
mysql.db                                           OK
mysql.event                                        OK
mysql.func                                         OK
mysql.general_log                                  OK
mysql.help_category                                OK
mysql.help_keyword                                 OK
mysql.help_relation                                OK
mysql.help_topic                                   OK
mysql.host                                         OK
mysql.ndb_binlog_index                             OK
mysql.plugin                                       OK
mysql.proc                                         OK
mysql.procs_priv                                   OK
mysql.proxies_priv                                 OK
mysql.servers                                      OK
mysql.slow_log                                     OK
mysql.tables_priv                                  OK
mysql.time_zone                                    OK
mysql.time_zone_leap_second                        OK
mysql.time_zone_name                               OK
mysql.time_zone_transition                         OK
mysql.time_zone_transition_type                    OK
mysql.user                                         OK
Running 'mysql_fix_privilege_tables'...
Warning: Using a password on the command line interface can be insecure.
Running 'mysqlcheck' with connection arguments: '--socket=/data/mysql.sock' 
Warning: Using a password on the command line interface can be insecure.
Running 'mysqlcheck' with connection arguments: '--socket=/data/mysql.sock' 
Warning: Using a password on the command line interface can be insecure.
test.test                                          OK
OK

 

關於mysql_upgrade的作用,官方文檔說明如下:

mysql_upgrade examines all tables in all databases for incompatibilities with the current version of MySQL Server. mysql_upgrade also upgrades the system tables so that you can take advantage of new privileges or capabilities that might have been added.

If mysql_upgrade finds that a table has a possible incompatibility, it performs a table check and, if problems are found, attempts a table repair. 

主要是升級系統表和修複不相容的表。

 

參考

1. http://dev.mysql.com/doc/refman/5.6/en/upgrading.html

 

 

 

 

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 新人剛學習Android兩周,寫一個隨筆算是對兩周學習成果的鞏固,不足之處歡迎各位建議和完善。 這次寫的是一個簡單登錄案例,大概功能如下: 註冊的賬戶信息用SharedPreferences存儲; 登錄成功後跳轉到成功頁面,在成功頁面聯網請求圖片並寫入到外部存儲; 然後讀出顯示在成功頁面; 註冊xm ...
  • Swift - EasingAnimation繪製圓環動畫 效果 源碼 https://github.com/YouXianMing/Swift-Animations ...
  • 一個懶人如何做到有條理、有效率的學習? 作為一個懶人,對於費事費力的學習我是拒絕的,那麼我就該考慮,怎麼才能做到高效快速的學習呢?於是在不斷總結中找到自己的學習方法,在這裡發出來給大家借鑒一下,取其精華去其糟粕,不喜勿噴哦。 我的學習方法就是帶著問題去學習理解,然後實戰應用並做好筆記。這四點缺一不可 ...
  • 要點: 1、多種形態,引用的多種形態對於一個引用變數,可以指向任何類的對象。對於一個父類的引用(類與類之間有一種繼承關係),可以指向子類,也可以指向本類,指向的類型不同。當通過此引用向對象發送消息,調用的方法是不同的,此時方法的調用就是多態。 2、類與類之間有關係,繼承關係父類的引用可以指向子類的引 ...
  • 工作筆記記錄,會持續更新.... 目錄: apply tapply lapply sapply merge apply函數: apply:apply的中文意思是應用,這個函數的意思是通過將一個函數應用到矩陣或數組中,返回一個向量或數組 語法:apply(X, MARGIN, FUN, ...) , ...
  • 在我的實際工作中,數據來源一方面是關係型資料庫MS SqlServer, 別一方面是HBase。本節主要介紹通過RODBC訪問MS SqlServer 安裝配置,參見資料(https://msdn.microsoft.com/en-us/library/hh568454(v=sql.110).asp ...
  • 前幾章對R語言的運行原理、基本語法、數據類型、環境部署等基礎知識作了簡單介紹,本節將結合具體案例進行驗證測試。 案例場景:從互聯網下載全國三甲醫院數據,以地圖作為背景,展現各醫院在地圖上的分佈圖。全國三甲醫院數據來源 http://www.wxmp.cn/cms/detail-51610-23480 ...
  • 問題分析 當數據量很大的時候,所有數據都集中在一個文本文件中的話,讀寫會很困難,記憶體消耗大,速度很慢 操作很麻煩,因為讀寫都要根據指定的格式盡心解析,不通用 每次獲取數據都要全部數據重新讀寫,不能通過對索引對指定的數據進行讀寫 數據衝突的解決方案要完全依賴Java app去實現 更多的功能,像排序, ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...