這里的幾個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)
幾個文件夾:
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中存放的工具
這些工具可能很多都沒用過,一個個看看(官方文檔: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



