PHP MySQL Linux現(xiàn)在已逐漸成為小型web服務(wù)器的一種經(jīng)典組合。在Windows環(huán)境下構(gòu)筑和調(diào)試MySQL數(shù)據(jù)庫是許多網(wǎng)站研發(fā)者的一種最好選擇。本人在Windows98環(huán)境下初學(xué)MySQL,現(xiàn)將學(xué)習(xí)過程和經(jīng)驗總結(jié)出來供大家參考。 1、下載mysql-3.23.35-win.zip并解壓; 2、運行setup.exe;選擇d:mysql,"tyical install" 3、啟動mysql,有如下方法:方法一:使用winmysqladmin 1)、進入d::mysqlbin目錄,運行winmysqladmin.exe,在屏幕右下角的任務(wù)欄內(nèi)會有一個帶紅色的圖符 2)、鼠標左鍵點擊該圖符,選擇“show me”,出現(xiàn)“WinMySQLAdmin”操作界面;首次運行時會中間會出現(xiàn)一個對話框需要輸入并配置您的用戶名和口令 3)、選擇“My.INI setup” 4)、在“mysqld file”中選擇“mysqld-opt”(win9x)或“mysqld-nt”(winNT) 5)、選擇“Pick-up or Edit my.ini values”能夠在右邊窗口內(nèi)對您的my.ini文檔進行編輯 6)、選擇“Save Modification”保存您的my.ini文檔 7)、假如您想快速使用winmysqladmin(開機時自動運行),選擇“Create ShortCut on Start Menu” 8)、測試: 進入DOS界面; 在d:mysqlbin目錄下運行mysql,進入mysql交互操作界面 輸入show databases并回車,屏幕顯示出當前已有的兩個數(shù)據(jù)庫mysql和test方法二:不使用winmysqladmin 1)、在DOS窗口下,進入d:/mysql/bin目錄 2)、win9X下)運行:mysqld在NT下運行: mysqld-nt --standalone 3)、此后,mysql在后臺運行 4)、測試mysql:(在d:/mysql/bin目錄下) a)、mysqlshow 正常時顯示已有的兩個數(shù)據(jù)庫mysql和test b)、mysqlshow -u root mysql 正常時顯示數(shù)據(jù)庫mysql里的五個表:columns_priv,db,host,tables_priv,user c)、mysqladmin version status proc 顯示版本號、狀態(tài)、進程信息等 d)、mysql test 進入mysql操作界面,當前數(shù)據(jù)庫為test 4、至此,MySQL已成功安裝,接著能夠熟悉MySQL的常用命令并創(chuàng)建自己的數(shù)據(jù)庫了。
創(chuàng)新互聯(lián)是專業(yè)的羅田網(wǎng)站建設(shè)公司,羅田接單;提供成都網(wǎng)站制作、做網(wǎng)站,網(wǎng)頁設(shè)計,網(wǎng)站設(shè)計,建網(wǎng)站,PHP網(wǎng)站建設(shè)等專業(yè)做網(wǎng)站服務(wù);采用PHP框架,可快速的進行羅田網(wǎng)站開發(fā)網(wǎng)頁制作和功能擴展;專業(yè)做搜索引擎喜愛的網(wǎng)站,專業(yè)的做網(wǎng)站團隊,希望更多企業(yè)前來合作!
前幾天看到姜老師的舊文 用 VSCode 編譯和調(diào)試 MySQL,每個 DBA 都應(yīng) get 的小技能[1] , 文末留了一個思考題,如何修改源碼,自定義版本,使得 select version() 輸出自定義內(nèi)容
調(diào)試過程參考 macOS VSCode 編譯調(diào)試 MySQL 5.7[2]
內(nèi)部 Item 對象參考 從SQL語句到MySQL內(nèi)部對象[3]
源碼面前沒有秘密,建義對 DB 感興趣的嘗試 debug 調(diào)試。本文環(huán)境為 mac + vscode + lldb
vscode 插件:
mysql 源碼:
補?。? MySQL = 8.0.21 需要對 cmake/mysql_version.cmake 文件打補丁 (沒有嚴格測試所有版本)
創(chuàng)建 cmake-build-debug 目錄,后續(xù) mysql 編譯結(jié)果,以及啟動后生成的文件都在這里
在 mysql 工程目錄下面創(chuàng)建 .vscode/settings.json 文件
內(nèi)容沒啥好說的,都是指定目錄及 boost 配置,其中 WITH_DEBUG 打開 debug 模式,會在 /tmp/debug.trace 生成 debug 信息
View - Command Palette - CMake: Configure 執(zhí)行后生成 cmake 配置
View - Command Palette - CMake: Build 編譯生成最終 mysql 相關(guān)命令
發(fā)現(xiàn)老版本編譯很麻煩,各種報錯,mysql 5.7 代碼量遠超過 5.5, 只能硬著頭皮看 5.7
首先初始化 my.cnf 配置,簡單的就可以,共它均默認
初始化數(shù)據(jù)文件,非安全模式,調(diào)試用
由于用 vscode 接管 mysql, 所以需要配置 .vscode/launch.json
然后點擊 run and debug mysqld
mysql 啟動,看到輸出日志無異常,此時可以用 mysql-client 連接
首先在 sql_parser.cc:5435 處打斷點
mysql_parse 是 sql 處理的入口,至于 tcp connection 連接先可以忽略
執(zhí)行上述 sql 自動跳轉(zhuǎn)到斷點處, Step Into , Step Over , Step Out 這些調(diào)試熟悉下即可
接下來分別調(diào)用主要函數(shù): mysql_execute_command , execute_sqlcom_select , handle_query , select-join-exec() , Query_result_send::send_data , Item::send , Item_string:val_str , Protocol_text::store , net_send_ok
啟動 mysql 時 init_common_variables 會初始化一堆變量,其中會調(diào)用 set_server_version 生成版本信息,修改這個就可以
看好條件編譯的是哪塊,修改即可, 重新 CMake: Build 編譯再運行
這里不做過深分析,簡單講
sql_yacc.cc 函數(shù) PTI_function_call_generic_ident_sys 解析 sql, 識別出 version() 是一個函數(shù)調(diào)用
find_native_function_builder 查找 hash 表,找到對應(yīng) version 函數(shù)注冊的單例工廠函數(shù)
mysql 啟動時調(diào)用 item_create_init 將這些函數(shù) builder 注冊到 hash 表 native_functions_hash
MySQL 代碼太龐大,5.1 大約 100w 行,5.5 130w 行,5.7 以后 330w 行,只能挑重點讀源碼。最近很多群里的人在背八股,沒必要,有那時間學(xué)著調(diào)試下源碼,讀讀多好
原文出處:
簡介:
大家好,我是xp,我又詐尸了
mvcc ,想必大家都不陌生,每個Java程序員都或多或少的了解過,不過不知道大家都是怎么學(xué)習(xí)的,是不是簡單的百度一下呢?下面,我來帶大家裝個13,調(diào)試 mvcc 。咳,不是源碼哈,但有那味了。
開卷開卷。
首先介紹一下 mvcc 的字面意思,全稱: Multiversion Concurrency Control,翻譯下來就是多版本并發(fā)控制技術(shù)。
臟讀、 不可重復(fù)讀 、幻讀的概念就不多啰嗦了,mvcc具體的含義也不多啰嗦了,可以自行百度。 mvcc 解決了臟讀、 不可重復(fù)讀、部分幻讀 ,包含了3個重要成分:
undo log作用:
在數(shù)據(jù)修改的時候,不僅記錄了 redo log ,還記錄了 undo log 。但是 不同于 redo log , undo log 是邏輯日志。簡單理解成, delete的時候,undo log會出現(xiàn)一條insert,update的時候,undo log會出現(xiàn)一條舊數(shù)據(jù), 用來事務(wù)失敗之后的回滾。
3個隱式字段:
Read View:
好了,理論講完了,讓我們嗨起來。
嗨之前,有一個情況單獨說一下:
可以看到,此時的trx_id非常大,這是因為此時是只讀事務(wù)。對于只讀事務(wù), InnoDB 并不會分配 trx_id,只有發(fā)生dml才會分配。這樣有2個好處:
當commit了之后,我們使用SHOW ENGINE INNODB STATUS查看:
可以看到,顯示該事務(wù)并沒有開始。
好,回到正軌,相信大家都知道, 視圖可見性判斷(不知道的先百度 mvcc ):
整體是這樣的:
第一步我們以 38488 為開始值,把 name 更新成 111 ,并且 commit
第二步以 38490 把 name 更新成 222,333 ,但是不 commit
當 38490 第一次修改為 222 的時候,數(shù)據(jù)結(jié)構(gòu)大致是這樣的:
使用 SHOW ENGINE INNODB STATUS 側(cè)面驗證:
當 38490 第二次修改為 333 的時候,數(shù)據(jù)結(jié)構(gòu)大致是這樣的:
使用 SHOW ENGINE INNODB STATUS 側(cè)面驗證:
第三步以 38491 去查詢,此時生成的 m_ids 應(yīng)該是 [348490,38491]
使用 SHOW ENGINE INNODB STATUS 側(cè)面驗證:
此時 ReadView 的幾個屬性值為:
接下來我們來驗證結(jié)論:
1:不用驗證,當前事務(wù)修改的肯定自己可見
2: 38491查詢id=1的記錄,name為111
38488 348490,所以111可見
3:不用驗證,38492是下個事務(wù)的id,還沒生成呢,當前事務(wù),肯定看不見下個事務(wù)修改的值
4:我們先把38491commit,把id為20的name更新成111
然后再開一個事務(wù)38496:
此時查id為20,是可見的
m_ids:[348490,38496],因為38491已經(jīng)commit了,所以m_ids沒有。此時的38491在m_ids之間,但是在m_ids里面找不到,所以可見。
好了,愉快的裝13結(jié)束了,兄弟們,下次見。
1、MySQL數(shù)據(jù)庫系統(tǒng)允許的最大可連接數(shù)max_connections。這個參數(shù)是可以設(shè)置的。如果不設(shè)置,默認是100。最大是16384。
2、數(shù)據(jù)庫當前的連接線程數(shù)threads_connected。這是動態(tài)變化的。
查看max_connections、max_connections的辦法見后。
如果
threads_connected
==
max_connections
時,數(shù)據(jù)庫系統(tǒng)就不能提供更多的連接數(shù)了,這時,如果程序還想新建連接線程,數(shù)據(jù)庫系統(tǒng)就會拒絕,如果程序沒做太多的錯誤處理,就會出現(xiàn)類似強壇的報錯信息。
因為創(chuàng)建和銷毀數(shù)據(jù)庫的連接,都會消耗系統(tǒng)的資源。而且為了避免在同一時間同時打開過多的連接線程,現(xiàn)在編程一般都使用所謂數(shù)據(jù)庫連接池技術(shù)。
但數(shù)據(jù)庫連接池技術(shù),并不能避免程序錯誤導(dǎo)致連接資源消耗殆盡。
這種情況通常發(fā)生在程序未能及時釋放數(shù)據(jù)庫連接資源或其他原因造成數(shù)據(jù)庫連接資源不能釋放,但強壇系統(tǒng)估計不會發(fā)生這種低級的編程錯誤。
該錯誤的簡便的檢查辦法是,在刷新強壇頁面時,不斷監(jiān)視threads_connected的變化。如果max_connections足夠大,而
threads_connected值不斷增加以至達到max_connections,那么,就應(yīng)該檢查程序了。當然,如果采用數(shù)據(jù)庫連接池技術(shù),
threads_connected增長到數(shù)據(jù)庫連接池的最大連接線程數(shù)時,就不再增長了。
從強壇出錯的情況看,更大的可能性是數(shù)據(jù)庫系統(tǒng)沒能進行適當?shù)嘏渲?。下面提出一點建議。供參考
讓你們的工程師把MySQL的最大允許連接數(shù)從默認的100調(diào)成32000。這就不會老出現(xiàn)連接過多的問題了。
查看max_connections
進入MySQL,用命令:
show
variables
查看數(shù)據(jù)庫最大可連接數(shù)的變量值:
max_connections
查看threads_connected
進入MySQL,用命令:
show
status
查看當前活動的連接線程變量值:
threads_connected
設(shè)置max_connections
設(shè)置辦法是在my.cnf文件中,添加下面的最后紅色的一行:
[mysqld]
port=3306
#socket=MySQL
skip-l
有很多朋友雖然安裝好了mysql但卻不知如何使用它 在這篇文章中我們就從連接MYSQL 修改密碼 增加用戶等方面來學(xué)習(xí)一些MYSQL的常用命令 一 連接MYSQL 格式 mysql h主機地址 u用戶名-p用戶密碼 例 連接到本機上的MYSQL 首先在打開DOS窗口 然后進入目錄 mysqlbin 再鍵入命令mysql uroot p 回車后提示你輸密碼 如果剛安裝好MYSQL 超級用戶root是沒有密碼的 故直接回車即可進入到MYSQL中了 MYSQL的提示符是 mysql 例 連接到遠程主機上的MYSQL 假設(shè)遠程主機的IP為 用戶名為root 密碼為abcd 則鍵入以下命令 mysql h uroot pabcd 退出MYSQL命令 exit (回車) 二 修改密碼 格式 mysqladmin u用戶名 p舊密碼 password 新密碼 例 給root加個密碼ab 首先在DOS下進入目錄mysqlbin 然后鍵入以下命令mysqladmin uroot password ab 注 因為開始時root沒有密碼 所以 p舊密碼一項就可以省略了 例 再將root的密碼改為djg mysqladmin uroot pab password djg 三 增加新用戶 (注意 和上面不同 下面的因為是MYSQL環(huán)境中的命令 所以后面都帶一個分號作為命令結(jié)束符)格式 grant select on 數(shù)據(jù)庫 * to 用戶名@登錄主機 identified by 密碼 例 增加一個用戶test 密碼為abc 讓他可以在任何主機上登錄 并對所有數(shù)據(jù)庫有查詢 插入 修改 刪除的權(quán)限 首先用以root用戶連入MYSQL 然后鍵入以下命令 grant select insert update delete on * * to test @ % Identified by abc ;但例 增加的用戶是十分危險的 你想如某個人知道test 的密碼 那么他就可以在internet上的任何一臺計算機上登錄你的mysql數(shù)據(jù)庫并對你的資料可以為所欲為了 解決辦法見例 例 增加一個用戶test 密碼為abc 讓他只可以在localhost上登錄 并可以對數(shù)據(jù)庫mydb進行查詢 插入 修改 刪除的操作(localhost指本地主機 即MYSQL數(shù)據(jù)庫所在的那臺主機) 這樣用戶即使用知道test 的密碼 他也無法從internet上直接訪問數(shù)據(jù)庫 只能通過MYSQL主機上的web頁來訪問了 grant select insert update delete on mydb * to test @localhost identified by abc ;如果你不想test 有密碼 可以再打一個命令將密碼消掉 grant select insert update delete on mydb * to test @localhost identified by ;注意 你必須首先登錄到MYSQL中 以下操作都是在MYSQL的提示符下進行的 而且每個命令以分號結(jié)束 四一 操作技巧 如果你打命令時 回車后發(fā)現(xiàn)忘記加分號 你無須重打一遍命令 只要打個分號回車就可以了 也就是說你可以把一個完整的命令分成幾行來打 完后用分號作結(jié)束標志就OK 你可以使用光標上下鍵調(diào)出以前的命令 但以前我用過的一個MYSQL舊版本不支持 我現(xiàn)在用的是 mysql beta win 五 顯示命令 顯示數(shù)據(jù)庫列表 show databases;剛開始時才兩個數(shù)據(jù)庫 mysql和test mysql庫很重要它里面有MYSQL的系統(tǒng)信息 我們改密碼和新增用戶 實際上就是用這個庫進行操作 顯示庫中的資料表 use mysql //打開庫 學(xué)過FOXBASE的一定不會陌生吧show tables; 顯示資料表的結(jié)構(gòu) describe 表名; 建庫 create database 庫名; 建表 use 庫名 create table 表名 (字段設(shè)定列表) 刪庫和刪表:drop database 庫名;drop table 表名 將表中記錄清空 delete from 表名; 顯示表中的記錄 select * from 表名; 六 一個建庫和建表以及插入數(shù)據(jù)的實例 drop database if exists school; //如果存在SCHOOL則刪除create database school; //建立庫SCHOOLuse school; //打開庫SCHOOLcreate table teacher //建立表TEACHER(id int( ) auto_increment not null primary key name char( ) not null address varchar( ) default 深圳 year date); //建表結(jié)束//以下為插入字段insert into teacher valuess( glchengang 深圳一中 );insert into teacher valuess( jack 深圳一中 );注 在建表中( )將ID設(shè)為長度為 的數(shù)字字段:int( )并讓它每個記錄自動加一:auto_increment并不能為空:not null而且讓他成為主字段primary key( )將NAME設(shè)為長度為 的字符字段( )將ADDRESS設(shè)為長度 的字符字段 而且缺省值為深圳 varchar和char有什么區(qū)別呢 只有等以后的文章再說了 ( )將YEAR設(shè)為日期字段 如果你在mysql提示符鍵入上面的命令也可以 但不方便調(diào)試 你可以將以上命令原樣寫入一個文本文件中假設(shè)為school sql 然后復(fù)制到c:下 并在DOS狀態(tài)進入目錄mysqlbin 然后鍵入以下命令 mysql uroot p密碼 c:school sql如果成功 空出一行無任何顯示 如有錯誤 會有提示 (以上命令已經(jīng)調(diào)試 你只要將//的注釋去掉即可使用) 七 將文本資料轉(zhuǎn)到數(shù)據(jù)庫中 文本資料應(yīng)符合的格式 字段資料之間用tab鍵隔開 null值用n來代替 例 rose 深圳二中 mike 深圳一中 數(shù)據(jù)傳入命令 load data local infile 文件名 into table 表名;注意 你最好將文件復(fù)制到mysqlbin目錄下 并且要先用use命令打表所在的庫 八 備份數(shù)據(jù)庫 (命令在DOS的mysqlbin目錄下執(zhí)行)mysqldump opt schoolschool bbb注釋:將數(shù)據(jù)庫school備份到school bbb文件 school bbb是一個文本文件 文件名任取 打開看看你會有新發(fā)現(xiàn) 后記 其實MYSQL的對數(shù)據(jù)庫的操作與其它的SQL類數(shù)據(jù)庫大同小異 您最好找本將SQL的書看看 我在這里只介紹一些基本的 其實我也就只懂這些了 呵呵 最好的MYSQL教程還是 晏子 譯的 MYSQL中文參考手冊 不僅免費每個相關(guān)網(wǎng)站都有下載 而且它是最權(quán)威的 可惜不是象 PHP 中文手冊 那樣是chm的格式 在查找函數(shù)命令的時候不太方便 lishixinzhi/Article/program/MySQL/201311/29306
mysql調(diào)試存儲過程具體方法:
在你的存儲過程中加入如下語句:
SELECT
變量1,變量2;
然后用mysql自帶的cmd程序進入mysql
下。
call
你的存儲過程名(輸入?yún)?shù)1,@輸出參數(shù));(注:這里幫助下新同學(xué),如果你的存儲過程有輸出變量,那么在這里只需要加
@
然后跟任意變量名即可);
即可發(fā)現(xiàn)你的變量值被打印到了cmd下