MySQL 8.0中與DBA和運維人員相關的10大特性(譯)

来源:https://www.cnblogs.com/wy123/archive/2020/05/12/12877340.html
-Advertisement-
Play Games

原文地址:http://lefred.be/content/top-10-mysql-8-0-features-for-dbas-ops/ 臨時表的改進 MySQL 5.7中,所有內部臨時表都是在名為“ibtmp1”的惟一共用表空間中創建的。此外,臨時表的元數據也將存儲在記憶體中(不再存儲在.frm文 ...


 

原文地址:http://lefred.be/content/top-10-mysql-8-0-features-for-dbas-ops/


臨時表的改進

MySQL 5.7中,所有內部臨時表都是在名為“ibtmp1”的惟一共用表空間中創建的。此外,臨時表的元數據也將存儲在記憶體中(不再存儲在.frm文件中)。
譯者添加截圖 在MySQL 8.0中,內部臨時表預設使用memory存儲引擎(由優化器在JOIN,UNION,…期間創建的表)的引擎,這個新引擎為VARCHAR和VARBINARY列提供了更高效的存儲(記憶體容量最大分配模式)。
譯者添加截圖以及備註:
更加詳細的臨時表相關知識參考:https://www.cnblogs.com/coderyuhui/p/10773143.html MySQL 5.7中只有ibtmp文件,臨時表的數據和undo都在該類文件中,臨時表的session斷開後其空間不會自動回收。 臨時表數據文件
SHOW VARIABLES LIKE '%innodb_temp_tablespaces_dir%';也即#innodb_tmp
臨時表undo文件
SHOW VARIABLES LIKE '%innodb_temp_data_file_path%';也即ibtmp1
session斷開後,其存放數據的臨時表數據文件空間會被自動回收。

全局變數持久化 藉助MySQL 8.0,可以設置變數並可以永久性保留。我寫了一篇專門的博客文章,您可以查看更多信息。將此語法與新的RESTART命令結合使用,可以非常輕鬆地從其shell配置MySQL。這是一個雲友好功能  
不再有MyISAM系統表 有了新的本地數據字典,我們將不再需要MyISAM系統表!這些表和數據字典表現在在數據目錄中的一個名為mysql.idb的InnoDB表空間文件中創建。 這意味著,如果您不顯式使用MyISAM表(如果您關心數據,則完全不建議這樣做),則可以擁有一個沒有任何MyISAM表的MySQL實例。

大事務的UNDO表空間收縮 在MySQL 5.7中,我們已經添加了截斷撤消空間的可能性(innodb_undo_log_truncate,預設情況下禁用)。 在MySQL8中,我們更改了undo磁碟格式以支持每個undo表空間大量回滾段。同樣,預設情況下,現在在兩個單獨的undo表空間中創建了回滾段,而不是在InnoDB系統表空間中創建了(最小為2,並且可以動態設置)。 innodb_undo_tablespaces變數已經被棄用,因為我們將提供SQL命令,為DBA提供與UNDO表空間進行交互的真實介面。預設情況下,現在也啟用了undo表空間的自動截斷功能。
UTF8字元集的性能 預設字元集已從latin1更改為utf8mb4,因為UTF8在特定查詢上的速度現在快得多,快了1800% ! 現在Emojis字元無處不在,MySQL支持他們沒有問題!
Query Cache的移除 在性能審計期間,我一直建議的第一件事是禁用查詢緩存,因為它不是按設計進行伸縮的。MySQL Query Cache產生的問題比解決的問題還多,我們決定在MySQL 8.0中刪除它,因為沒有人應該使用它。 如果您的工作負載需要查詢緩存,那麼您應該查看一下proxysql作為查詢緩存的情況
原子DDL 使用新的數據字典,MySQL 8.0現在支持原子數據定義語句(原子ddl)。 這意味著,當執行DDL時,數據字典更新、存儲引擎操作和二進位日誌中的寫操作被合併到一個原子事務中,該事務要麼完全執行,要麼完全不執行。 這提供了更好的可靠性,未完成的ddl不會留下任何不完整的數據。

更快、更完整的Performance Schema(直方圖、索引、…)和Information Schema 對Performance Schema進行了許多改進,例如偽索引或直方圖。 藉助偽索引,諸如SELECT * FROM sys.session之類的查詢速度提高了30倍。現在,儘可能避免進行表掃描,索引的使用大大縮短了執行時間。 除此之外,Performance Schema還提供語句延遲的直方圖。優化器還可以從這些新的直方圖中受益。 Performance Schema還通過使用數據字典得到了改進。無需更多.frm文件即可瞭解表的定義。而且這允許擴展到超過1,000,000個表!
ROLES(角色) MySQL 8.0中已經添加了SQL角色。角色是一個命名的特權集合。 與用戶帳戶一樣,角色可以擁有授予和撤消的特權。角色可以是預設的,也可以是會話的。也可以將角色設置為強制的。

如果表空間被加密,那麼redo log和undo log將被加密 在MySQL 5.7中,可以為存儲在每個表的文件中的表加密一個InnoDB表空間。 在MySQL 8.0中,我們通過為UNDO和REDO日誌添加加密來完成這個功能。另外,改進的列表並沒有在這裡結束。還有許多其他不錯的功能。我想下麵列出一些其他重要的(即使他們都是重要的當然)
  • 自增id列的持久化,persistent auto increment
  • Innodb自我優化,InnoDB self tuning
  • Json欄位類型性能提升,JSON performance
  • 不可見索引,Invisible Indexes
  • 新的備份鎖,new lock for backup
  • 資源組,Resource Groups
  • binlog中的額外元數據,additional metadata into binary logs
  • 社區版的OpenSSL支持,OpenSSL for Community Edition too
請查看線上手冊以獲得關於所有這些新功能的更多信息。https://dev.mysql.com/doc/refman/8.0/en/mysql-nutshell.html

!!更新!! 隨著我們不斷改進MySQL 8.0的發行版,還有另一個原因需要升級到MySQL 8.0,這可能是必須處理大型表時最需要的功能之一。 開發人員將不再害怕在其架構中添加列,並且DBA / 運維將不會害怕運行它們,或者將不需要使用第三方工具來執行此(過去)複雜的任務:即時添加列!
InnoDB即時添加列 藉助新的數據字典,現在可以執行元數據更改並直接在表的末尾添加新列,而無需重建它!這是每次開發人員想要向表中添加列時,alter語句都阻塞所有session的終結者。 而這僅僅是即時ddl之旅的開始。


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

-Advertisement-
Play Games
更多相關文章
  • Linux系統與服務構建運維 1+x初級,項目三 FTP服務的使用 配置YUM源 將CD設備進行連接 將CD設備掛載 # mkdir /opt/centos # mount /dev/cdrom /opt/centosmount: /dev/sr0 防寫,將以只讀方式掛載 配置本地YUM源文件 將 ...
  • 大家好,我是良許。 我們知道,在 Windows 下,有一款非常實用的神器,叫作 ,它可以在極短的時間里,搜索出來你所想要的文件/目錄,如下圖示: Linux 下也有一些類似於 everything 的神器,比如:locate,Catfish,Tracker,等等。這些工具也十分強大,在此就不一一演 ...
  • [root@localhost ~]# cat /etc/redhat-release CentOS release 6.8 (Final) [root@localhost ~]# rpm -qa |grep ntp ntp-4.2.6p5-15.el6.centos.x86_64 fontpack ...
  • 一 Helm概述 1.1 Helm介紹 Helm 是 Kubernetes 的軟體包管理工具。包管理器類似 Ubuntu 中使用的apt、Centos中使用的yum 或者Python中的 pip 一樣,能快速查找、下載和安裝軟體包。通常每個包稱為一個Chart,一個Chart是一個目錄(一般情況下會 ...
  • 1. 下載mysql 1.1 下載地址 https://downloads.mysql.com/archives/community/ 1.2 版本選擇 2. 管理組及目錄許可權 2.1 解壓mysql tar -zxf mysql-5.7.29-linux-glibc2.12-x86_64.tar. ...
  • 安裝各種伺服器軟體 nginx 安裝完成之後,直接使用ip地址訪問伺服器,就可以看到nginx的預設歡迎頁面了。 如果安裝報錯比如80埠占用,說明此前安裝了其它網路伺服器,建議全都關掉再安裝,並且讓nginx獨占80埠作為反向代理伺服器 安裝完成之後配置反向代理,使用whereis nginx命 ...
  • 在如何解決原子性問題的最後,我們賣了個關子,互斥鎖不僅僅只有synchronized關鍵字,還可以用什麼來實現呢? J.U.C包中還提供了一個叫做Locks的包,我好歹英語過了四級,聽名字我就能馬上大聲的說:Locks包必然也可以用作互斥! ReentrantLock 我們可以通過從具體到抽象的方法 ...
  • 我的MySQL安裝在Linux上,如果我要想在Windows上連接linux上的MySQL,可以使用一些工具,如Navicat和SQLyog。我在這裡用SQLyog演示一下Windows遠程連接MySQL。 第一次連接MySQL 首先安裝SQLyog,這裡就不演示了。打開SQLyog,在菜單欄點擊【 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...