MYSQL02高級_目錄結構、默認數據庫、表文件、系統獨立表空間

文章目錄

  • ①. MySQL目錄結構
  • ②. 查看默認數據庫
  • ③. MYSQL5.7和8表文件
  • ③. 系統、獨立表空間

①. MySQL目錄結構

  • ①. 如何查看關聯mysql目錄
[root@mysql8 ~]# find / -name mysql
/var/lib/mysql
/var/lib/mysql/mysql
/etc/selinux/targeted/tmp/modules/100/mysql
/etc/selinux/targeted/active/modules/100/mysql
/etc/logrotate.d/mysql
/usr/lib64/mysql
/usr/bin/mysql
[root@mysql8 ~]# 
  • ②. 數據庫文件存放路徑為:/var/lib/mysql/
  1. MYSQL服務器程序在啟動時會到文件系統的某個目錄下加載一些文件,之后在運行過程中產生的數據也都會存儲到這個目錄下的某些文件中,這個目錄就稱為數據目錄
  2. 數據目錄對應著一個系統變量datadir,我們在使用客戶端與服務器建立連接之后查看這個系統變量的值就可以了
mysql> show variables like 'datadir';
+---------------+-----------------+
| Variable_name | Value           |
+---------------+-----------------+
| datadir       | /var/lib/mysql/ |
+---------------+-----------------+
1 row in set (0.05 sec)
[root@mysql8 mysql]# pwd
/var/lib/mysql
[root@mysql8 mysql]# ll
總用量 188888
-rw-r-----. 1 mysql mysql       56 1122 21:42 auto.cnf
-rw-r-----. 1 mysql mysql      350 55 21:09 binlog.000002
-rw-r-----. 1 mysql mysql     1907 57 19:19 binlog.000003
-rw-r-----. 1 mysql mysql      179 57 22:27 binlog.000004
-rw-r-----. 1 mysql mysql      156 512 20:45 binlog.000005
-rw-r-----. 1 mysql mysql       64 512 20:45 binlog.index
-rw-------. 1 mysql mysql     1676 1122 21:42 ca-key.pem
-rw-r--r--. 1 mysql mysql     1112 1122 21:42 ca.pem
-rw-r--r--. 1 mysql mysql     1112 1122 21:42 client-cert.pem
-rw-------. 1 mysql mysql     1676 1122 21:42 client-key.pem
drwxr-x---. 2 mysql mysql     4096 55 22:08 dbtest1
-rw-r-----. 1 mysql mysql   196608 512 20:47 #ib_16384_0.dblwr
-rw-r-----. 1 mysql mysql  8585216 1122 21:42 #ib_16384_1.dblwr
-rw-r-----. 1 mysql mysql     3557 57 22:27 ib_buffer_pool
-rw-r-----. 1 mysql mysql 12582912 512 20:45 ibdata1
-rw-r-----. 1 mysql mysql 50331648 512 20:47 ib_logfile0
-rw-r-----. 1 mysql mysql 50331648 1122 21:42 ib_logfile1
-rw-r-----. 1 mysql mysql 12582912 512 20:45 ibtmp1
drwxr-x---. 2 mysql mysql     4096 512 20:45 #innodb_temp
drwxr-x---. 2 mysql mysql     4096 1122 21:42 mysql
-rw-r-----. 1 mysql mysql 25165824 512 20:45 mysql.ibd
srwxrwxrwx. 1 mysql mysql        0 512 20:45 mysql.sock
-rw-------. 1 mysql mysql        5 512 20:45 mysql.sock.lock
drwxr-x---. 2 mysql mysql     4096 1122 21:42 performance_schema
-rw-------. 1 mysql mysql     1680 1122 21:42 private_key.pem
-rw-r--r--. 1 mysql mysql      452 1122 21:42 public_key.pem
-rw-r--r--. 1 mysql mysql     1112 1122 21:42 server-cert.pem
-rw-------. 1 mysql mysql     1680 1122 21:42 server-key.pem
drwxr-x---. 2 mysql mysql     4096 1122 21:42 sys
-rw-r-----. 1 mysql mysql 16777216 512 20:47 undo_001
-rw-r-----. 1 mysql mysql 16777216 512 20:47 undo_002
  • ③. 相關命令目錄:/usr/bin(mysqladmin、mysqlbinlog、mysqldump等命令)和/usr/sbin
    在這里插入圖片描述
  • ④. 配置文件目錄:/usr/share/mysql-8.0(命令及配置文件)/etc - my.cnf

②. 查看默認數據庫

  • ①. 查看默認的數據庫
mysql> SHOW DATABASES;
+--------------------+
| Database           |
+--------------------+
| information_schema |
| mysql              |
| performance_schema |
| sys                |
+--------------------+
4 rows in set (0.01 sec)
  • ②. mysql:MySQL 系統自帶的核心數據庫,它存儲了MySQL的用戶賬戶和權限信息,一些存儲過程、事件的定義信息,一些運行過程中產生的日志信息,一些幫助信息以及時區信息等

  • ③. information_schema:MySQL系統自帶的數據庫,這個數據庫保存著MySQL服務器 維護的所有其他數據庫的信息 ,比如有哪些表、哪些視圖、哪些觸發器、哪些列、哪些索引。這些信息并不是真實的用戶數據,而是一些描述性信息,有時候也稱之為 元數據 。在系統數據庫 information_schema中提供了一些以innodb_sys開頭的表,用于表示內部系統表

  • ④. performance_schema:MySQL系統自帶的數據庫,這個數據庫里主要保存MySQL服務器運行過程中的一些狀態信息,可以用來監控MySQL服務的各類性能指標 。包括統計最近執行了哪些語句,在執行過程的每個階段都花費了多長時間,內存的使用情況等信息

  • ⑤. sys:MySQL系統自帶的數據庫,這個數據庫主要是通過視圖的形式把information_schema和performance_schema結合起來,幫助系統管理員和開發人員監控 MySQL 的技術性能

③. MYSQL5.7和8表文件

  • ①. 對于innodb,對應的表有兩個文件:.frm + .ibd,存儲了表結構信息和表數據信息,db.opt的文件:這個文件描述了這個數據庫的各種屬性(比如字符集和比較規則是個啥)
    在這里插入圖片描述

  • ②. 對于myisam存儲引擎,會有三個文件,分別是上圖的表結構信息 + 表數據信息 + 表索引信息
    在這里插入圖片描述

  • ③. MYSQL8 - 對于innodb,對應的表只有了.ibd文件,存儲了表結構信息和表數據信息

[root@mysql8 etc]# cd /var/lib/mysql
[root@mysql8 mysql]# ll
總用量 188888
-rw-r-----. 1 mysql mysql       56 1122 21:42 auto.cnf
-rw-r-----. 1 mysql mysql      350 55 21:09 binlog.000002
-rw-r-----. 1 mysql mysql     1907 57 19:19 binlog.000003
-rw-r-----. 1 mysql mysql      179 57 22:27 binlog.000004
-rw-r-----. 1 mysql mysql      156 512 20:45 binlog.000005
-rw-r-----. 1 mysql mysql       64 512 20:45 binlog.index
-rw-------. 1 mysql mysql     1676 1122 21:42 ca-key.pem
-rw-r--r--. 1 mysql mysql     1112 1122 21:42 ca.pem
-rw-r--r--. 1 mysql mysql     1112 1122 21:42 client-cert.pem
-rw-------. 1 mysql mysql     1676 1122 21:42 client-key.pem
drwxr-x---. 2 mysql mysql     4096 55 22:08 dbtest1
-rw-r-----. 1 mysql mysql   196608 512 20:47 #ib_16384_0.dblwr
-rw-r-----. 1 mysql mysql  8585216 1122 21:42 #ib_16384_1.dblwr
-rw-r-----. 1 mysql mysql     3557 57 22:27 ib_buffer_pool
-rw-r-----. 1 mysql mysql 12582912 512 20:45 ibdata1
-rw-r-----. 1 mysql mysql 50331648 512 20:47 ib_logfile0
-rw-r-----. 1 mysql mysql 50331648 1122 21:42 ib_logfile1
-rw-r-----. 1 mysql mysql 12582912 512 20:45 ibtmp1
drwxr-x---. 2 mysql mysql     4096 512 20:45 #innodb_temp
drwxr-x---. 2 mysql mysql     4096 1122 21:42 mysql
-rw-r-----. 1 mysql mysql 25165824 512 20:45 mysql.ibd
srwxrwxrwx. 1 mysql mysql        0 512 20:45 mysql.sock
-rw-------. 1 mysql mysql        5 512 20:45 mysql.sock.lock
drwxr-x---. 2 mysql mysql     4096 1122 21:42 performance_schema
-rw-------. 1 mysql mysql     1680 1122 21:42 private_key.pem
-rw-r--r--. 1 mysql mysql      452 1122 21:42 public_key.pem
-rw-r--r--. 1 mysql mysql     1112 1122 21:42 server-cert.pem
-rw-------. 1 mysql mysql     1680 1122 21:42 server-key.pem
drwxr-x---. 2 mysql mysql     4096 1122 21:42 sys
-rw-r-----. 1 mysql mysql 16777216 512 20:47 undo_001
-rw-r-----. 1 mysql mysql 16777216 512 20:47 undo_002
[root@mysql8 mysql]# cd dbtest1/
[root@mysql8 dbtest1]# ll
總用量 224
-rw-r-----. 1 mysql mysql 147456 55 21:46 ssm_shopping_cart.ibd
-rw-r-----. 1 mysql mysql 114688 55 22:08 test1.ibd
  • ④. MYSQL8 - 對于Myisam有三個文件生產
    在這里插入圖片描述

③. 系統、獨立表空間

  • ①. 系統表空間(system tablespace)
  1. 默認情況下,InnoDB會在數據目錄下創建一個名為 ibdata1 、大小為 12M 的文件,這個文件就是對應的系統表空間 在文件系統上的表示。怎么才12M?注意這個文件是 自擴展文件 ,當不夠用的時候它會自己增加文件大小
  2. 如果你想讓系統表空間對應文件系統上多個實際文件,或者僅僅覺得原來的ibdata1這個文件名
    難聽,那可以在MySQL啟動時配置對應的文件路徑以及它們的大小,比如我們這樣修改一下my.cnf 配置文件
[server]
innodb_data_file_path=data1:512M;data2:512M:autoextend

在這里插入圖片描述

  • ②. 獨立表空間(file-per-table tablespace)
  1. 在MySQL5.6.6以及之后的版本中,InnoDB并不會默認的把各個表的數據存儲到系統表空間中,而是為每一個表建立一個獨立表空間 ,也就是說我們創建了多少個表,就有多少個獨立表空間。使用獨立表空間 來存儲表數據的話,會在該表所屬數據庫對應的子目錄下創建一個表示該獨立表空間的文件,文件名和表名相同,只不過添加了一個.ibd 的擴展名而已,所以完整的文件名稱長這樣
  2. MYSQL5.7:比如:我們使用了獨立表空間去存儲數據庫dbtest1下的test1表的話,那么在該表所在數據庫對應的目錄下會為test1表創建這兩個文件:frm + idb文件
    在這里插入圖片描述
  • ③. 系統表空間與獨立表空間的設置
    我們可以自己指定使用系統表空間 還是 獨立表空間來存儲數據,這個功能由啟動參數
    innodb_file_per_table 控制,比如說我們想刻意將表數據都存儲到 系統表空間 時,可以在啟動
    MySQL服務器的時候這樣配置
[server]
innodb_file_per_table=0 # 0:代表使用系統表空間; 1:代表使用獨立表空間
mysql> show variables like 'innodb_file_per_table';
+-----------------------+-------+
| Variable_name | Value |
+-----------------------+-------+
| innodb_file_per_table | ON |
+-----------------------+-------+
1 row in set (0.01 sec)

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/712253.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/712253.shtml
英文地址,請注明出處:http://en.pswp.cn/news/712253.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

前端src中圖片img標簽資源的幾種寫法?

在 Vue 項目中引用圖片路徑有幾種不同的方法,具體取決于你的項目結構和配置。以下是幾種常見的方式: 1. 靜態資源目錄 (Public) 如果你的圖片放在了項目的 public 目錄下(例如,Vite 和 Create Vue App 腳手架工具通常使用這個目…

05 OpenCV圖像混合技術

文章目錄 理論算子示例 理論 其中 的取值范圍為0~1之間 算子 addWeighted CV_EXPORTS_W void addWeighted(InputArray src1, double alpha, InputArray src2, double beta,double gamma, OutputArray dst, int dtype -1 ); 參數1:輸入圖像Mat …

2024年【廣東省安全員A證第四批(主要負責人)】考試試卷及廣東省安全員A證第四批(主要負責人)作業模擬考試

題庫來源:安全生產模擬考試一點通公眾號小程序 廣東省安全員A證第四批(主要負責人)考試試卷根據新廣東省安全員A證第四批(主要負責人)考試大綱要求,安全生產模擬考試一點通將廣東省安全員A證第四批&#x…

釘釘機器人發送折線圖卡片 工具類代碼

釘釘機器人 “創建并投放卡片 接口 ” 可以 發送折線圖、柱狀圖 官方文檔:創建并投放卡片 - 釘釘開放平臺 0依賴、1模板、2機器人放到內部應用、3放開這個權限 、4工具類、5調用工具類 拼接入參 卡片模板 自己看文檔創建,卡片模板的id 有用 0、依賴…

Springboot項目中定時任務的四種實現方式

文章目錄 1. 使用Scheduled注解1.1 時間間隔執行1.2 固定時間點執行 2. 使用EnableScheduling注解啟用定時任務3. 實現SchedulingConfigurer接口4. 使用Quartz框架4.1 配置QuartzScheduler4.2 定義Job類和Trigger類 5. 總結 在開發現代應用時,定時任務是一個非常常見…

地圖可視化繪制 | R-ggplot2 NC地圖文件可視化

在推出兩期數據分享之后,獲取數據的小伙伴們也知道,數據格式都是NetCDF(nc) 格式網格數據,雖然我在推文分享中說明使用Python、R或者GIS類軟件都是可以進行 處理和可視化繪制的,但是,還是有小伙伴咨詢使用編程軟件Pyth…

牛客周賽 Round 34(A,B,C,D,E,F,G)

把這場忘了。。官方也遲遲不發題解 比賽鏈接 出題人題解 A 小紅的字符串生成 思路&#xff1a; 枚舉四種字符串打印出來即可&#xff0c;為了防止重復可以用set先去一下重。 code&#xff1a; #include <iostream> #include <cstdio> #include <cstring&g…

Opencv實戰(4)詳解輪廓

輪廓 Opencv實戰系列&#xff0c;前文&#xff1a; 文章目錄 輪廓(1).查找繪制1.findContours()2.drawContours() (2).層級結構(3).篩選輪廓(4).凸包 (1).查找繪制 預處理&#xff1a; 灰度化&#xff1a;使用cv::cvtColor()圖像去噪&#xff1a;使用高斯濾波cv::Gaussian(…

Acwing-基礎算法課筆記之數學知識(擴展歐幾里得算法)

Acwing-基礎算法課筆記之數學知識&#xff08;擴展歐幾里得算法&#xff09; 一、擴展歐幾里得算法1、裴蜀定理2、過程模擬3、代碼模板 二、線性同余方程1、定義2、模擬過程3、結論證明 一、擴展歐幾里得算法 1、裴蜀定理 對于任意正整數 a a a&#xff0c; b b b&#xff0…

day48 ● 198.打家劫舍 ● 213.打家劫舍II ● 337.打家劫舍III

一遍過。 當前房屋偷與不偷取決于 前一個房屋和前兩個房屋是否被偷了。所以這里就更感覺到&#xff0c;當前狀態和前面狀態會有一種依賴關系&#xff0c;那么這種依賴關系都是動規的遞推公式。 class Solution { public:int rob(vector<int>& nums) {vector<vec…

門店縱深不足、入口有遮擋影響客流準確率?近景客流幫你搞定!

為了優化運營策略、提升門店營收&#xff0c;很多店鋪和商場都會安裝客流攝像機。但是在實際應用中&#xff0c;由于門店縱深受限等原因&#xff0c;導致無法使用之前的常規客流產品。 針對這種情況&#xff0c;悠絡客最新研發了近景客流產品&#xff0c;即使存在入口被遮擋或門…

內網信息搜集

目錄 內網基礎知識 基本流程圖 怎么判斷是否在域內 常規信息類收集-應用&服務&權限等 cs信息搜集 bloodhound安裝及使用 內網基礎知識 工作組&#xff1a;將不同的計算機按照功能分別列入不同的組&#xff0c;想要訪問某個部門的資源&#xff0c;只要在【網絡】里…

pyqt教程

一、組件安裝配置 1.安裝組件 在Anaconda Prompt下進入自己的python環境 pip install PyQt5 pip install PyQt5-tools 2.vscode安裝插件 3.配置路徑 配置Pyuic:Cmd與Qtdesigner:Path路徑 1.Pyuic:Cmd路徑 一般是在你安裝的python環境下的 \Scripts\pyuic5.exe 2.Qtdesigner:P…

anaconda簡介以及安裝(Windows)

介紹 Anaconda是一個開源的Python發行版本&#xff0c;它是一個打包的集合&#xff0c;里面預裝了conda、Python、眾多packages、科學計算工具等。Anaconda的目的是方便使用Python進行數據科學研究&#xff0c;它涵蓋了數據科學領域常見的Python庫&#xff0c;并且自帶了專門用…

Python的循環結構練習

歸納編程學習的感悟&#xff0c; 記錄奮斗路上的點滴&#xff0c; 希望能幫到一樣刻苦的你&#xff01; 如有不足歡迎指正&#xff01; 共同學習交流&#xff01; &#x1f30e;歡迎各位→點贊 &#x1f44d; 收藏? 留言?&#x1f4dd; 生命對某些人來說是美麗的&#xff0c…

我國每年研究生的畢業數量統計分享

本數據集詳細記錄了自1949年至2021年我國每年研究生的畢業數量&#xff08;包括碩士和博士學位的畢業生&#xff09;。在2021年&#xff0c;我國的研究生畢業生人數達到了772,761人&#xff0c;此數字比上一年度增加了44,000人。 統計的數據單位使用的是人數。 數據展示&…

mysql,for循環執行sql

遇到一個問題&#xff0c;我需要模擬上百萬數據來優化sql&#xff0c;線上數據down不下來&#xff0c;測試庫又沒有&#xff0c;寫代碼執行要么慢要么就是sql語句太長。 于是&#xff0c;直接用mysql自帶的功能去實現&#xff01; 簡單而簡單 mysql可以for循環&#xff1f;沒…

Laravel框架: Call to a member function connect() on null 異常報錯處理

Laravel框架&#xff1a; Call to a member function connect() on null 異常報錯處理 Date: 2024.03.01 21:03:11 author: lijianzhan 原文鏈接: https://learnku.com/laravel/t/63721 問題&#xff1a; local.ERROR: Call to a member function connect() on null {"…

【前端素材】推薦優質后臺管理系統 Greeva平臺模板(附源碼)

一、需求分析 1、系統定義 后臺管理系統是一種用于管理網站、應用程序或系統的管理界面&#xff0c;通常由管理員和工作人員使用。它提供了訪問和控制網站或應用程序后臺功能的工具和界面&#xff0c;使其能夠管理用戶、內容、數據和其他各種功能。 2、功能需求 后臺管理系…

使用mininet快速入門ONOS路由交換技術與原理-路由篇

上篇文章 《使用mininet快速入門ONOS路由交換技術與原理-交換篇》 使用mininet搭建了一個簡單的網絡拓撲&#xff0c;并實現了同一交換機下同網段多主機的通信&#xff0c;其中涉及到的通信知識主要以二層mac地址通信為主。 但在蕓蕓網絡的世界中&#xff0c;主機間的通信除了…