從檔案視角看mysql

2021-09-22 13:11:48 字數 3698 閱讀 8591

這裡的幾個rpm意義分別是:(

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 ***檢視裡面包含哪些檔案)

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

幾個資料夾:

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

這些工具可能很多都沒用過,乙個個看看(官方文件:

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

msql2mysql:注意下這裡2前面是msql,mini sql(這個是現在很少使用到的資料庫了。這個工具就是將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_secure_installation:這個指令碼幫助你做一些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語法一樣的效果

resolveip:乙個resolveip工具,具體使用可以看

resolve_stack_dump:系統工具,具體使用看

從微觀視角看消費問題

一位忙著裝修新居的朋友這兩天到處看家具,轉了北京多個賣場竟然很難找到沒有刺鼻的甲醛味道的產品,最後還是乾脆到宜家購買一套家具了事。我也稱不上是宜家的粉絲,但是宜家的東西質量上過得去,設計得簡潔明瞭,讓我放心 省心。我是被那些賣爛貨的店趕去宜家的。原來是一種 驅趕效應 難怪宜家店裡的客人總是那麼多,直...

從企業架構視角看生鮮電商

一 生鮮電商額外的關注點 前幾天,易觀資料,對生鮮電商2020的內外部環境 行業環境 發展趨勢等做了分析。拉出來很多的資料,無論資料真實與否,實屬行業市場分析的經典,畢竟國內很多行業的研究分析報告,可取之處和不可取之處基本上對開。不過易觀畢竟有它的資料分析和諮詢能力,其實已經將生鮮電商分析的有點透徹...

120度視角看PD

跟著師傅做了幾個日常,參加了幾次需求的討論,漸漸感覺到做需求還是需要花費不少精力的。如果說對原來的業務非常熟悉,相對來說做起來就輕鬆一些,而要是從來都沒接觸過這塊內容,就會感覺有點像丈二和尚摸不著頭腦 知道使用者想要什麼,但是卻不知道如何跟現有的系統更好的結合起來,我們到底能夠提供什麼?使用者的需求...