天天看點

從檔案視角看mysql下面就需要看下這個壓縮包的具體内容。(mysql-5.5.28-linux2.6-x86_64.tar.gz)下面是bin中存放的工具

從檔案視角看mysql下面就需要看下這個壓縮包的具體内容。(mysql-5.5.28-linux2.6-x86_64.tar.gz)下面是bin中存放的工具

mysql-client:包含最少的通路mysql伺服器所需要的用戶端指令。裡面包含的是像mysql,mysqladmin這樣的工具。

mysql-devel:包含開發mysql用戶端所需要的庫。裡面沒有包含工具,都是包含.a這樣的庫連結檔案

mysql-server:包含安裝mysql所需要的所有工具。裡面包含的像是mysqld_safe,mysqld_multi這樣的伺服器啟動安裝工具。裡面并不包含mysql這樣的用戶端工具。

mysql-shared:包含開發mysql用戶端所需要的動态連結庫。裡面并沒有工具,都是像libmysqlclient.so*這樣的動态庫檔案。

mysql-shared-compact:上面動态連結庫的以前各個版本的檔案。就是進行這個安裝會在lib64中放上之前所有release版本的libmysqlclient.so

mysql-test:mysql的測試套件

(以上的幾個rpm包有興趣可以自己使用rpm -qpl xxx檢視裡面包含哪些檔案)

mysql-xxx.tar.gz 這個壓縮包就包含了所有以上所有的包。在mysql5.5.28中這個已經不以rpm形式提供了,以壓縮包的方式提供。一般伺服器要安裝mysql就是使用這個壓縮包。

從檔案視角看mysql下面就需要看下這個壓縮包的具體内容。(mysql-5.5.28-linux2.6-x86_64.tar.gz)下面是bin中存放的工具

幾個檔案夾:

bin: 存放編譯好的工具

data:存放資料庫資料的位置

docs:存放文檔的地方,比如changelog,還有mysql的詳細文檔mysql.info

include:存放用戶端開發的庫,實際上就是mysql-devel裡面的東西

lib:這裡就相當于mysql-shared,裡面的包含libmysqlclient.so*

man:mysqld指令幫助說明文檔

mysql-test:mysql測試套件,相當于mysql-test.rpm

script:裡面隻包含一個mysql_install_db,這個腳本的作用是建立mysql最初需要的幾個系統表,它的建表sql檔案在share目錄中(網上有的文章說這個隻是建立一個授權表,其實是不對的)

share:存放幾個初始表檔案和每種語言的errmsg.sys錯誤日志

sql-bench:如其名,對資料庫進行壓力測試的工具

support-files:存放一些配置檔案,比如很出名的my-huge.cnf, my-small.cnf等,最後使用的預設cnf會從這裡面生成

從檔案視角看mysql下面就需要看下這個壓縮包的具體内容。(mysql-5.5.28-linux2.6-x86_64.tar.gz)下面是bin中存放的工具

innochecksum:檢查innodb的表空間檔案的完整性。這個主要由于斷電或關機等意外情況,可能導緻innodb的表空間出現損壞頁。如果損壞頁沒有被及時發現,當程式運作到這個損壞頁的時候,mysql服務就會不可用了。這個工具主要是為了防止這種情況。

myisamchk:對myisam類型的表進行檢查和檢視狀态使用

myisam_ftdump:展示myisam中fulltext索引資訊。

myisamlog:展示myisam的log檔案内容

myisampack:這個工具對myisam的表進行壓縮處理。這個工具對myisam中每行進行壓縮,這樣好處除了減少硬碟存儲空間之外,也會對查詢少量行的操作性能有提升,因為操作減少了查詢表時間,也隻需要對那幾個少量的行再進行解壓縮。

my_print_defaults:列印出my.cnf中對各個指令的配置,實際沒啥用,你也可以直接vi看/etc/my.cnf

mysql:登入mysql的用戶端

mysqlaccess:判斷使用者是否有權限

mysqlaccess.conf:mysqlaccess的預設設定(不直接在工具裡面寫死是為了能讓使用者自己設定)

mysqladmin:mysql的管理工具,如建立資料庫等操作

mysqlbinlog:處理mysql的binlog,這個工具在主從同步的時候很有用

mysqlbug:當有bug的時候調用這個工具會收集你的系統消息發送個bug

mysqlcheck:對資料庫進行檢查,修複,優化和分析。這個工具隻能在資料庫運作的時候運作,這點和mysqlcheck很不一樣。而且會耗時較長。

mysql_client_test:對mysql資料庫進行基本的測試。

mysql_client_test_embedded:對嵌入式mysql伺服器進行基本的測試

mysql_config:擷取mysql的配置資訊

mysql_convert_table_format:如其名,轉換mysql中表的類型

mysqld:啟動mysql伺服器,這個就是我們啟動mysql需要使用的指令,其中的參數很多

mysqld-debug:啟動mysql伺服器的調試模式,好像是和mysqld --debug的效果一樣

mysqld_multi:當配置檔案中有設定多個庫,就用這個指令一次啟動多個庫

mysqld_safe:安全模式啟動mysql伺服器,會在mysql伺服器啟動後繼續監控它的情況,并在當機的時候重新啟動。用這個指令啟動mysql伺服器的做法是最常用的

mysqdump:将一個資料庫或者表導出。這裡導出的是sql語句,是以如果一個表過大的話,這個導出的資料可能會非常大。

mysqldumpslow:導出慢查詢日志,這個指令經常被dba使用,作為優化程式的必要步驟

mysql_embedded:連接配接嵌入式mysql資料庫

mysql_find_rows:根據sql語句查詢資料庫,幾乎用不到,直接mysql登入不就完了麼

mysql_fix_extensions:将資料庫存儲檔案的字尾規範化(全部大寫)

mysqlhotcopy:資料庫熱備份(隻能熱備myisam和archive類型的表)

mysqlimport:将格式化的檔案導入到mysql表中

mysql_plugin:配置mysql伺服器的插件(如果你有寫的話)

mysql_setpermission:設定mysql的賬戶資訊,和grant指令實作的功能一樣,同樣很少用

mysqlshow:用這個工具能很容易看到資料庫,表等資訊,其實就是和進入到mysql之後的show **操作一樣

mysqlslap:mysql自帶的壓力測試工具

mysqltest:對mysql進行測試,這個測試主要是流程的測試,比如可以換個使用者來試試sql的語句等

mysqltest_embedded:對嵌入式mysql進行測試

mysql_tzinfo_to_sql:讀取timezone的表

mysql_upgrade:mysql更新的時候會使用到的指令

mysql_waitpid:發送kill殺死mysql程序并等待程序結束

mysql_zap:殺死滿足格式的程序

perror:檢視錯誤的詳細資訊

replace:不知道,猜測應該和mysql的replace文法一樣的效果

上一篇: NUMA的取舍
下一篇: Go中的閉包