MySQL密碼忘記,怎麼辦?

来源:http://www.cnblogs.com/ivictor/archive/2016/04/19/5408715.html
-Advertisement-
Play Games

如果哪天你忘記了線上MySQL資料庫的root密碼,怎麼辦? 大家往往會想到skip-grant-tables參數,具體步驟如下: 1. 關閉MySQL資料庫,因為root密碼忘記了,mysqladmin無法使用,此時,只能通過kill pid關閉程式。 在這裡,科普一下kill 和kill -9的 ...


如果哪天你忘記了線上MySQL資料庫的root密碼,怎麼辦?

大家往往會想到skip-grant-tables參數,具體步驟如下:

1. 關閉MySQL資料庫,因為root密碼忘記了,mysqladmin無法使用,此時,只能通過kill pid關閉程式。

在這裡,科普一下kill 和kill -9的區別

預設參數下,kill 發送SIGTERM信號給進程,告訴進程,你需要被關閉,請自行停止運行並退出。
kill -9 發送SIGKILL信號給進程,告訴進程,你被終結了,請立刻退出。與SIGTERM相比,這個信號不能被捕獲或忽略,同時接收這個信號的進程在收到這個信號時不能執行任何清理

所以,萬不得已,不要通過kill -9殺掉進程,這可能導致MySQL資料庫的物理結構損壞,無法重新啟動。

2. 在my.cnf文件[mysqld]部分添加skip-grant-tables參數

3. 登錄資料庫,修改root賬戶的密碼

以下是修改root密碼的三種方式:

    1> mysql> set password for 'root'@'localhost'=password('123'); 無需刷新許可權表

    2> mysql> update mysql.user set password=password("456") where user="root" and host="localhost";

         mysql> flush privileges;

    3> # mysqladmin -u root password "123"

4. 關閉資料庫,註釋掉skip-grant-tables參數,重新啟動資料庫。

 

上面這種方式雖然不錯,但是有個問題,你必須重啟資料庫,對於線上環境,這可能是不被允許的。

下麵來談談另一種方法,有點“黑暗科技”的味道

這個方法利用的是mysql.user表還是MyISAM引擎的特性。

1. 將該實例的mysql.user表copy到另一個實例的目錄下,譬如,test資料庫的目錄下

2. 登錄另一個實例資料庫,修改上述三個文件的許可權,並修改root密碼

mysql> select user,host,password from test.user;
+------+-----------+-------------------------------------------+
| user | host      | password                                  |
+------+-----------+-------------------------------------------+
| root | localhost | *6BB4837EB74329105EE4568DDA7DC67ED2CA2AD9 |
+------+-----------+-------------------------------------------+
1 row in set (0.00 sec)

mysql> update test.user set password=password("hello") where user="root" and host="localhost";
Query OK, 1 row affected (0.15 sec)
Rows matched: 1  Changed: 1  Warnings: 0

3. 將上述三個文件copy回源資料庫

4. 獲取mysqld的pid,通過kill -HUP `pidof mysqld`方式讓mysqld進程重新載入配置文件

[root@keepalived01 ~]# mysql -phello
Warning: Using a password on the command line interface can be insecure.
ERROR 1045 (28000): Access denied for user 'root'@'localhost' (using password: YES)
[root@keepalived01 ~]# kill -HUP 4283
[root@keepalived01 ~]# mysql -phello
Warning: Using a password on the command line interface can be insecure.
Welcome to the MySQL monitor.  Commands end with ; or \g.
Your MySQL connection id is 2528
Server version: 5.6.26 MySQL Community Server (GPL)

Copyright (c) 2000, 2015, Oracle and/or its affiliates. All rights reserved.

Oracle is a registered trademark of Oracle Corporation and/or its
affiliates. Other names may be trademarks of their respective
owners.

Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.

mysql> 

通過上述輸出可以看出,kill -HUP之前,直接用密碼hello登錄被拒絕,kill -HUP之後,就可以直接登錄了。

當然,以上方法僅供參考,在生產上慎用,畢竟安全壓倒一切,天曉得哪裡會出現問題。

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 我們以MySQL中常用的hint來進行詳細的解析,如果你是經常使用Oracle的朋友可能知道,Oracle的hincvt功能種類很多,對於優化sql語句提供了很多方法。 同樣,在MySQL里,也有類似的hint功能。下麵介紹一些常用的。 強制索引 MySQL FORCE INDEX 以上的SQL語句 ...
  • (1) 選擇最有效率的表名順序(只在基於規則的優化器中有效):ORACLE的解析器按照 從右到左的順序處理FROM子句中的表名,FROM子句中寫在最後的表(基礎表 driving table)將被最先處理,在FROM子句中包含多個表的情況下,你必須選擇記錄條數最少的表作為基礎表。如果有3個以上的表連 ...
  • 有時候啊,當我們存放在資料庫裡面的數據,需要明文存放,但是對於前臺查詢出來的,又不太希望明文放出去的時候(比方說客戶的手機啊,郵箱啊)之類有點敏感的信息,之前通常是保存個明文,然後在前臺展現的時候再特殊處理一下,然後就ok了。 而現在呢,在2016提供了data mask的功能,可以遮掩對應列的一些 ...
  • 上一篇說了一下openjson 的一些使用方法,這次再說一下在2016裡面的查詢取值,當然就是 json_query 和 json_value 這2兄弟了 首先 可以看到,對於json_value 來說,如果說取到的屬性並不能直接解析成int,string,bool 這3種類型(那就是說 array ...
  • 引言 SQL Server通過一些工具來監控數據,其中之一的方法就是動態管理管理視圖(DMV). 常規動態伺服器管理對象 dm_db_*:資料庫和資料庫對象 dm_exec_*:執行用戶代碼和關聯的連接 dm_os_*:記憶體、鎖定、時間安排 dm_tran_*:事務和隔離 dm_io_*:網路和磁碟 ...
  • 1、內聯接(典型的聯接運算,使用像 = 或 <> 之類的比較運算符)。包括相等聯接和自然聯接。 內聯接使用比較運算符根據每個表共有的列的值匹配兩個表中的行。例如,檢索 students和courses表中學生標識號相同的所有行。 2、外聯接。外聯接可以是左向外聯接、右向外聯接或完整外部聯接。 在 F ...
  • 今天我們介紹Oracle資料庫中剩餘的查詢方法,今天的查詢方法會比昨天的更為複雜一些(PS:我也是個初學者,請見諒。。)。 一、分組函數 分組函數是為了區分同一個表中的不同數據而建立,其關鍵字為GROUP BY,其中可以包含任意數目的列。 舉例: SELECT DEPTNO.MAX(SAL)FROM ...
  • 在使用Oracle SQL Developer連接遠程伺服器的時候,出現如下的錯誤 在伺服器本地是可以正常連接的。這個讓人想起來,跟SQL Server的一些設計有些類似,伺服器估計預設只在本地監聽,不允許遠程訪問的,這是為了提高安全性。 解決的方法是,添加一個監聽地址 然後,重啟服務 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...