從文件視角看mysql


clip_image001

這里的幾個rpm意義分別是:(http://docs.oracle.com/cd/E17952_01/refman-5.0-en/linux-installation-rpm.html

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-5.5.28-linux2.6-x86_64.tar.gz)

clip_image002

幾個文件夾:

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會從這里面生成

 

下面是bin中存放的工具

clip_image003

這些工具可能很多都沒用過,一個個看看(官方文檔:http://dev.mysql.com/doc/refman/5.1/en/programs-admin-utils.html

 

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

msql2mysql:注意下這里2前面是msql,mini SQL(http://baike.baidu.com/view/1959377.htm)這個是現在很少使用到的數據庫了。這個工具就是將msql的程序轉換為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_secure_installation:這個腳本幫助你做一些mysql的安全方面的設置,主要是賬戶方面,具體可以看http://dev.mysql.com/doc/refman/5.6/en/default-privileges.html

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語法一樣的效果

resolveip:一個resolveip工具,具體使用可以看http://linux.die.net/man/1/resolveip

resolve_stack_dump:系統工具,具體使用看http://linux.die.net/man/1/resolve_stack_dump


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM