搜尋
首頁資料庫mysql教程MySQL数据库Drop Down后的紧急处置_MySQL

前言

今天下午3点,我按照惯例,打开游戏服务器,开新服部署嘛,游戏在腾讯开放平台,简单。闭着眼睛都OK。于是一轮子的复制黏贴拷贝,把服务器加起来,然后启动查看日志。

。。。。突然发现不断的有Exception?搞什么?丢失表Usr_user??刚才不是导了数据库吗?不存在?怎么会?

我瞬间意识到。我摊上事了,我摊上大事了。。检查刚才的复制黏贴,发现我没改数据库名,这一下子把第二个服的数据库整个干掉了。

我擦!!不会吧??背后一凉就软滩在凳子上了。

备份?没有。

数据库还有渣吗?select count(*) ....  0!

备份?真的没有。

怎么能没备份啊!

怎么办?几十个玩家充值了几千元。连个影子也没了。

找玩家求饶?送礼包?? 你觉得玩家会放过你?天真。

linux服务器 + mysql数据库 + 游戏缓存 + flash的as3前端。怎么搞。。。我完蛋了。

HOLD住!

我要HOLD住!冷静,虽然大脑一片空白。马上Google找mysql有无自动备份的。。。没看到。问同事,求助。我靠,他们怎么好像没反应啊。。。

这个时候,有个哥们提示我,用 mysqlbinlog。

这玩意是什么。马上google,知道mysql自身会有个操作的备份。我靠!希望来了。赶快进入mysql目录,查看下。果然看到几十个bin文件。

网上继续搜。大概知道mysql会保存30天内的数据库操作在bin文件。OK。

 

我们达洛克2服才刚运行了2天,算起来应该就是最后2个bin文件。还好。用

 

<ol class="dp-sql"><li class="alt"><span><span>mysqlbinlog </span><span class="comment">--no-defaults mysql-bin.000026 > mysql-bin.000026.txt</span><span> </span></span></li></ol>

导出了SQL,检查下:

<ol class="dp-sql">
<li class="alt"><span><span># </span><span class="keyword">at</span><span> 472331597 </span></span></li>
<li><span>#130619 18:04:23 server id 1  end_log_pos 472331772     Query   thread_id=2657  exec_time=0     error_code=0 </span></li>
<li class="alt"><span><span class="keyword">SET</span><span> </span><span class="keyword">TIMESTAMP</span><span>=1371636263/*!*/; </span></span></li>
<li><span><span class="keyword">UPDATE</span><span> USR_RESOURCE </span><span class="keyword">SET</span><span> MODIDATE = </span><span class="string">'2013-06-19 18:04:23'</span><span>,SILVER = 283 </span><span class="keyword">WHERE</span><span> USERCODE=</span><span class="string">'001UR1371634524003511'</span><span> </span></span></li>
<li class="alt"><span>/*!*/; </span></li>
<li><span># <span class="keyword">at</span><span> 472331772 </span></span></li>
<li class="alt"><span>#130619 18:04:23 server id 1  end_log_pos 472331799     Xid = 226001034 </span></li>
<li><span><span class="keyword">COMMIT</span><span>/*!*/; </span></span></li>
<li class="alt"><span># <span class="keyword">at</span><span> 472331799 </span></span></li>
<li><span>#130619 18:04:23 server id 1  end_log_pos 472331871     Query   thread_id=2657  exec_time=0     error_code=0 </span></li>
<li class="alt"><span><span class="keyword">SET</span><span> </span><span class="keyword">TIMESTAMP</span><span>=1371636263/*!*/; </span></span></li>
<li><span><span class="keyword">BEGIN</span><span> </span></span></li>
</ol>

大概是这种结构。

冷静下来,分析了。我还原数据库,只要从建库开始第一个sql重新执行到最后一个。理论上数据库就会被还原。但是bin文件里面是所有的SQL操作,我要筛选出 达洛克战记2服 的。网上说用 cat / more / less 等命令。我靠,这他妈也太复杂了把?

于是我zip了所有bin文件,回传到本地,用c#写了个过滤代码,找到 use darok2_2,知道这段内容都是 达洛克战记2服 的数据。

<ol class="dp-c">
<li class="alt"><span><span class="keyword">public</span><span> </span><span class="keyword">void</span><span> test() </span></span></li>
<li><span>{ </span></li>
<li class="alt"><span>    FileStream stream = File.OpenRead(@<span class="string">"E:\玩转中国\程序设计\达洛克战记\xtar-backup\svn\达洛克战记2x\svn\server-deploy\mysql-bin.000027.txt\mysql-bin.000027.txt"</span><span>); </span></span></li>
<li><span>    StreamReader reader = <span class="keyword">new</span><span> StreamReader(stream, Encoding.GetEncoding(</span><span class="string">"GBK"</span><span>)); </span></span></li>
<li class="alt"><span> </span></li>
<li><span>    FileStream streamO = File.Create(@<span class="string">"E:\玩转中国\程序设计\达洛克战记\xtar-backup\svn\达洛克战记2x\svn\server-deploy\mysql-bin.000027.txt\000027.out.txt"</span><span>); </span></span></li>
<li class="alt"><span>    StreamWriter writer = <span class="keyword">new</span><span> StreamWriter(streamO, Encoding.GetEncoding(</span><span class="string">"GBK"</span><span>)); </span></span></li>
<li><span> </span></li>
<li class="alt"><span>    Encoding gbk = Encoding.GetEncoding(<span class="string">"GBK"</span><span>); </span></span></li>
<li><span>    Encoding utf = Encoding.Default; </span></li>
<li class="alt"><span> </span></li>
<li><span>    <span class="keyword">string</span><span> strLine = reader.ReadLine(); </span></span></li>
<li class="alt"><span> </span></li>
<li><span>    <span class="keyword">while</span><span> (strLine != </span><span class="keyword">null</span><span>) </span></span></li>
<li class="alt"><span>    { </span></li>
<li><span> </span></li>
<li class="alt"><span>        <span class="keyword">if</span><span> (!strLine.StartsWith(</span><span class="string">"use darok2_2"</span><span>, StringComparison.OrdinalIgnoreCase)) </span></span></li>
<li><span>        { </span></li>
<li class="alt"><span>            strLine = reader.ReadLine(); </span></li>
<li><span>            <span class="keyword">continue</span><span>; </span></span></li>
<li class="alt"><span>        } </span></li>
<li><span> </span></li>
<li class="alt"><span>        <span class="keyword">do</span><span> </span></span></li>
<li><span>        { </span></li>
<li class="alt"><span>            <span class="keyword">if</span><span> (strLine == </span><span class="keyword">null</span><span>) </span></span></li>
<li><span>                <span class="keyword">break</span><span>; </span></span></li>
<li class="alt"><span> </span></li>
<li><span>            <span class="keyword">if</span><span> (strLine.StartsWith(</span><span class="string">"use"</span><span>, StringComparison.OrdinalIgnoreCase) && !strLine.StartsWith(</span><span class="string">"use darok2_2"</span><span>, StringComparison.OrdinalIgnoreCase)) </span></span></li>
<li class="alt"><span>            { </span></li>
<li><span>                strLine = reader.ReadLine(); </span></li>
<li class="alt"><span>                <span class="keyword">break</span><span>; </span></span></li>
<li><span>            } </span></li>
<li class="alt"><span> </span></li>
<li><span>            <span class="keyword">if</span><span> (strLine.StartsWith(</span><span class="string">"INSERT"</span><span>, StringComparison.OrdinalIgnoreCase) || strLine.StartsWith(</span><span class="string">"DELETE"</span><span>, StringComparison.OrdinalIgnoreCase) || strLine.StartsWith(</span><span class="string">"UPDATE"</span><span>, StringComparison.OrdinalIgnoreCase)) </span></span></li>
<li class="alt"><span>            { </span></li>
<li><span>                writer.Write(strLine); </span></li>
<li class="alt"><span>                writer.WriteLine(<span class="string">";"</span><span>); </span></span></li>
<li><span>            } </span></li>
<li class="alt"><span>            <span class="keyword">else</span><span> </span></span></li>
<li><span>            { </span></li>
<li class="alt"><span>            } </span></li>
<li><span>            strLine = reader.ReadLine(); </span></li>
<li class="alt"><span> </span></li>
<li><span>        } </span></li>
<li class="alt"><span>        <span class="keyword">while</span><span> (</span><span class="keyword">true</span><span>); </span></span></li>
<li><span>    } </span></li>
<li class="alt"><span> </span></li>
<li><span>    writer.Flush(); </span></li>
<li class="alt"><span>    writer.Close(); </span></li>
<li><span> </span></li>
<li class="alt"><span>    reader.Close(); </span></li>
<li><span>} </span></li>
</ol>

这样,我就得到过滤出来的SQL文件了。本地我建了个数据库测试下,发现第一句就卡死了??HOLD住!!!

再细心看看,发现中文到了txt全部是乱码了。安静思考了下:

linux数据库用的是GBK。因此bin文件导出的格式一定是GBK。那么代码用GBK读取,然后GBK写入就ok了(代码里面已经修复了)

再导入,顺利了。

进入数据库在看,发现中文还是乱码。。。。奇怪。那可能是mysql设置的问题了,和linux环境下不一致。我只要把这些过滤的SQL在达洛克服务器上走一遍应该就ok了。

上传SQL,运行脚本:

<ol class="dp-sql"><li class="alt"><span><span>mysql -uxxxx -pxxxx darok2_2 <span class="keyword">out</span><span>.txt. </span></span></span></li></ol>

等了10分钟。。。进入腾讯朋友网,开启游戏。一切又光明了。

总结:

各位看官,别看我洋洋洒洒几句废话貌似几分钟的事情。在那个接近崩溃,连数据库渣都没的条件下。我是多么惨的度过了2个小时。

mysqlbinlog

各位真心要记在心里。如果有全量备份+这个增量备份,基本上数据是不会丢失的。嗨。真实虚惊一场啊。

原文链接:http://www.cnblogs.com/zc22/p/3145080.html

陳述
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
將用戶添加到MySQL:完整的教程將用戶添加到MySQL:完整的教程May 12, 2025 am 12:14 AM

掌握添加MySQL用戶的方法對於數據庫管理員和開發者至關重要,因為它確保數據庫的安全性和訪問控制。 1)使用CREATEUSER命令創建新用戶,2)通過GRANT命令分配權限,3)使用FLUSHPRIVILEGES確保權限生效,4)定期審計和清理用戶賬戶以維護性能和安全。

掌握mySQL字符串數據類型:varchar vs.文本與char掌握mySQL字符串數據類型:varchar vs.文本與charMay 12, 2025 am 12:12 AM

chosecharforfixed-lengthdata,varcharforvariable-lengthdata,andtextforlargetextfield.1)chariseffity forconsistent-lengthdatalikecodes.2)varcharsuitsvariable-lengthdatalikenames,ballancingflexibilitibility andperformance.3)

MySQL:字符串數據類型和索引:最佳實踐MySQL:字符串數據類型和索引:最佳實踐May 12, 2025 am 12:11 AM

在MySQL中處理字符串數據類型和索引的最佳實踐包括:1)選擇合適的字符串類型,如CHAR用於固定長度,VARCHAR用於可變長度,TEXT用於大文本;2)謹慎索引,避免過度索引,針對常用查詢創建索引;3)使用前綴索引和全文索引優化長字符串搜索;4)定期監控和優化索引,保持索引小巧高效。通過這些方法,可以在讀取和寫入性能之間取得平衡,提升數據庫效率。

mysql:如何遠程添加用戶mysql:如何遠程添加用戶May 12, 2025 am 12:10 AM

ToaddauserremotelytoMySQL,followthesesteps:1)ConnecttoMySQLasroot,2)Createanewuserwithremoteaccess,3)Grantnecessaryprivileges,and4)Flushprivileges.BecautiousofsecurityrisksbylimitingprivilegesandaccesstospecificIPs,ensuringstrongpasswords,andmonitori

MySQL字符串數據類型的最終指南:有效的數據存儲MySQL字符串數據類型的最終指南:有效的數據存儲May 12, 2025 am 12:05 AM

tostorestringsefliceflicyInmySql,ChooSetherightDataTypeBasedyOrneOrneEds:1)USEcharforFixed-LengthStstringStringStringSlikeCountryCodes.2)UseVarcharforvariable-lengtthslikenames.3)USETEXTCONTENT.3)

mysql blob vs.文本:為大對象選擇正確的數據類型mysql blob vs.文本:為大對象選擇正確的數據類型May 11, 2025 am 12:13 AM

選擇MySQL的BLOB和TEXT數據類型時,BLOB適合存儲二進制數據,TEXT適合存儲文本數據。 1)BLOB適用於圖片、音頻等二進制數據,2)TEXT適用於文章、評論等文本數據,選擇時需考慮數據性質和性能優化。

MySQL:我應該將root用戶用於產品嗎?MySQL:我應該將root用戶用於產品嗎?May 11, 2025 am 12:11 AM

No,youshouldnotusetherootuserinMySQLforyourproduct.Instead,createspecificuserswithlimitedprivilegestoenhancesecurityandperformance:1)Createanewuserwithastrongpassword,2)Grantonlynecessarypermissionstothisuser,3)Regularlyreviewandupdateuserpermissions

MySQL字符串數據類型說明了:選擇適合您數據的合適類型MySQL字符串數據類型說明了:選擇適合您數據的合適類型May 11, 2025 am 12:10 AM

mySqlStringDatatAtatPessHouldBechoseBasedondatActarActeristicsAndusecases:1)USEcharforFixed lengthStstringStringStringSlikeCountryCodes.2)usevarcharforvariable-lengtthslikeLikenames.3)usebarnionororvarinyorvarinyorvarybinarydatalgebenedaTalgeextocrabextrapon.4)

See all articles

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver Mac版

Dreamweaver Mac版

視覺化網頁開發工具

MantisBT

MantisBT

Mantis是一個易於部署的基於Web的缺陷追蹤工具,用於幫助產品缺陷追蹤。它需要PHP、MySQL和一個Web伺服器。請查看我們的演示和託管服務。

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

SublimeText3 英文版

SublimeText3 英文版

推薦:為Win版本,支援程式碼提示!