欧美一区二区三区老妇人-欧美做爰猛烈大尺度电-99久久夜色精品国产亚洲a-亚洲福利视频一区二区

mysql服務禁用怎么辦 mysql服務無效

面試官:MySQL權限表損壞導致無法啟動怎么辦?

一、背景

創(chuàng)新互聯(lián)建站是一家朝氣蓬勃的網(wǎng)站建設公司。公司專注于為企業(yè)提供信息化建設解決方案。從事網(wǎng)站開發(fā),網(wǎng)站制作,網(wǎng)站設計,網(wǎng)站模板,微信公眾號開發(fā),軟件開發(fā),微信小程序開發(fā),十余年建站對成都柴油發(fā)電機等多個行業(yè),擁有豐富的網(wǎng)站設計經(jīng)驗。

近期,公司RDS云產(chǎn)品的MySQL Server版本進行升級,由目前使用的5.7.26版本升級到最新版本5.7.31;升級后測試同學發(fā)現(xiàn):在MySQL創(chuàng)建用戶后,5.7.31版本重新啟動集群會出現(xiàn)啟動失敗的現(xiàn)象;而5.7.26版本在相同測試場景下是正常啟動的。這到底是為什么呢?

二、問題復現(xiàn)

2.1 實驗環(huán)境

2.2 操作步驟

按照測試同學的測試步驟,首先創(chuàng)建一個用戶:

然后關閉mysqld;這里需要介紹一下,我們集群的關閉方式是如下方式:

這種方式的內(nèi)部實現(xiàn)類似于kill -9模式。所以我在線下環(huán)境使用kill -9的方式來復現(xiàn),操作如下:

然后重啟mysqld,操作如下:

此時問題復現(xiàn)了,mysqld啟動失敗,我們查看了下error日志,信息如下:

根據(jù)報錯信息可以看出:MySQL的權限系統(tǒng)表發(fā)生了損壞,導致了mysqld啟動失敗;由于在MySQL 5.7及其之前版本該表是MyISAM引擎,且該引擎不支持事務,所以在mysqld異常崩潰會導致該類型引擎表的損壞;但在mysqld啟動時是有參數(shù)控制MyISAM引擎的恢復模式,且該參數(shù)在我們產(chǎn)品中也配置到了my.cnf中,如下所示:

2.3 參數(shù)解析

對于該參數(shù)的官方文檔的解釋如下:

設置MyISAM存儲引擎恢復模式。選項值是OFF、DEFAULT、BACKUP、FORCE或QUICK的值的任意組合。如果指定多個值,請用逗號分隔。指定不帶參數(shù)的選項與指定DEFAULT相同,指定顯式值" "將禁用恢復(與OFF值相同)。如果啟用了恢復,則mysqld每次打開MyISAM表時,都會檢查該表是否標記為已崩潰或未正確關閉。(只有在禁用外部鎖定的情況下運行,最后一個選項才起作用。)在這種情況下,mysqld在表上運行檢查。如果表已損壞,mysqld將嘗試對其進行修復。

服務器自動修復表之前,它將有關修復的注釋寫到錯誤日志中。如果您希望能夠在無需用戶干預的情況下從大多數(shù)問題中恢復,則應使用選項BACKUP,F(xiàn)ORCE。即使某些行將被刪除,這也會強制修復表,但是它將舊的數(shù)據(jù)文件保留為備份,以便您以后可以檢查發(fā)生了什么。

全局變量,只讀變量,默認為OFF。

三、問題修復

這類MySQL用戶表損耗的問題解決方式也是有多種,我這里列舉其中一種:

(1)my.cnf中的[mysqld]標簽下添加skip_grant_tables,啟動時跳過加載系統(tǒng)字典。

(2)重啟mysqld,然后修復mysql schema下的所有表。

(3)在[mysqld]標簽下注釋或刪除掉skip_grant_tables,然后重啟mysqld。

此時mysqld是可以正常啟動的,無異常。

四、深入排查

在產(chǎn)品化中,以上修復方式很不優(yōu)雅,只是作為臨時的解決方案;并且也存在一些令人疑惑的點:

帶著這些疑問,我們繼續(xù)排查出現(xiàn)該現(xiàn)象的原因;此時Google也沒有找到一些有效的信息,那么只能通過MySQL源代碼來尋找一些答案。

首先需要下載mysql 5.7.31版本的源代碼,并搭建mysql debug環(huán)境;具體步驟可以自動Google搜索一下,本文就不再贅述了。

在源代碼中搜索一下關鍵詞,用于打斷點的位置,然后進行調(diào)試:

定位到相關代碼,大概是sql/mysqld.cc的4958行,且存在if條件判斷,此時我們開始調(diào)試:

通過以上調(diào)試信息,可以判斷出acl_init函數(shù)返回的值為真;此時我們查看該函數(shù)的代碼 (sql/auth/sql_auth_cache.cc:1365):

根據(jù)該函數(shù)的注釋發(fā)現(xiàn):該函數(shù)是初始化負責用戶/數(shù)據(jù)庫級特權檢查的結構,并從mysql schema中的表中為其加載特權信息;且return值為1代表的是初始化權限失敗。

此后開始逐步調(diào)試,觀察return相關信息,當調(diào)試到lock_table_names函數(shù)時,我們發(fā)現(xiàn)在Phase 3時return值為true,且根據(jù)代碼注釋發(fā)現(xiàn)true代表是Failure;具體代碼如下(sql/sql_base.cc:5549):

調(diào)試信息如下:

可以看到flags的值為0,而MYSQL_OPEN_SKIP_SCOPED_MDL_LOCK為宏定義值0x1000,與flags的值 做按位與操作,結果自然也是0,當然MYSQL_LOCK_IGNORE_GLOBAL_READ_ONLY也是如此;need_global_read_lock_protection是bool類型值,代表是否需要全局讀鎖的保護,這個值是在table- mdl_request.type不為MDL_SHARED_READ_ONLY發(fā)生改變;check_readonly函數(shù)相關信息 下面概述。

此時也查看了下MySQL 5.7.26版本代碼作為對比,發(fā)現(xiàn)lock_table_names函數(shù)下的Phase 3后的部分代 碼是在5.7.29版本后新增的。如果是git clone的MySQL代碼可以用git blame命令查詢文件變化的信息:

上述展示的信息中,最左側的列值為commit id為05824063和0405ebee,有興趣的同學可以詳細看下。

此功能解決的問題是 BUG#28438114: SET READ_ONLY=1 SOMETIMES DOESN'T BLOCK CONCURRENT DDL.;當然這個代碼的變更功能也在5.7 Release Notes中有所體現(xiàn),如下所示( m/doc/relnotes/mysql/5.7/en/news-5-7-29.html ):

最后我們再查看下check_readonly函數(shù),該函數(shù)是基于read_only和super_read_only狀態(tài)執(zhí)行標準化檢查,是禁止(TRUE)還是允許(FALSE)操作。代碼如下(sql/auth/sql_authorization.cc:489):

此時第一反應就是去檢查my.cnf中是否包含read_only相關參數(shù),檢查之后發(fā)現(xiàn)確實是使用了該參數(shù), 如下:

此時注釋掉該參數(shù),然后再次啟動mysqld,發(fā)現(xiàn)MyISAM表可以自動修復,且正常啟動;error log信息如下:

由于docker一些限制,我們在mysqld啟動會涉及兩次;所以解決該問題的方式為:第一次mysqld的啟動時先關閉read_only參數(shù),第二次啟動時開啟read_only參數(shù)。之所以選擇默認開啟read_only參數(shù), 是為了避免在mysqld啟動后,選主邏輯未完成時的保護措施;當然選主完成后,會自動對master執(zhí)行 set global read_only=0 操作。

五、總結

六、附錄

調(diào)試的棧幀信息如下,有興趣的小伙伴可以研究下:

熟悉MySQL體系結構和innodb存儲引擎工作原理;以及MySQL備份恢復、復制、數(shù)據(jù)遷移等技術;專注于MySQL、MariaDB開源數(shù)據(jù)庫,喜好開源技術。

原文鏈接:

Windows下MySQL服務無法停止和刪除的解決辦法

我在

Windows

操作系統(tǒng)上,使用解壓壓縮包的方式安裝

MySQL。這是安裝的具體方法:點擊這里。在執(zhí)行如下命令:

mysqld

--install

MySQL

--defaults-file=[ini配置文件絕對路徑]

在執(zhí)行上面那個命令的時候,輸入了錯誤的配置文件路徑。雖然系統(tǒng)可能會返回

success

。并且命令

mysqld

--initialize

也可以執(zhí)行并生成數(shù)據(jù)文件。但是當我執(zhí)行

net

start

mysql

的時候,系統(tǒng)會一直提示服務正在啟動。原因是我的配置文件路徑錯誤,導致服務啟動的時候出現(xiàn)異常情況。此時MySQL服務無法啟動,也無法通過命令行和控制面板停止。MySQL

服務也無法刪除。

解決方法:

控制面板

右上查看方式選擇大圖標

管理工具

服務

選中MySQL。

這個時候你可以看到,根本沒有停止、重啟和暫停的選項。這時需要這么干:

右鍵MySQL服務

屬性

常規(guī)選項卡

“啟動類型”選擇禁用

重啟電腦

以管理員身份打開命令行

cd命令進入MySQL安裝路徑下的bin文件夾。

因為MySQL服務被設置禁止開機啟動,并重啟了電腦,這個時候MySQL服務是停止狀態(tài)的。

命令行輸入命令:

mysqld

remove

MySQL

命令可以正常執(zhí)行,命令執(zhí)行完后就能把那個錯誤配置的MySQL服務刪除了。然后把MySQL的數(shù)據(jù)文件夾下面的文件全部刪除,重新從頭開始一步一步安裝MySQL即可。

以上所述是小編給大家介紹的Windows下MySQL服務無法停止和刪除的解決辦法,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!

windows 服務禁用怎么開啟

右鍵桌面”電腦“圖標,選擇”管理“,進入”計算機管理“窗口。

注:也可以在”開始“-"運行"里輸入services.msc命令,進入服務窗口。

選擇計算機管理窗口中”服務和應用程序“下面的”服務“,窗口右邊就會展示windows所有的服務。

找到你要打開或禁用的服務,比如我要啟用”MySQL“服務。

找到”MySQL“服務,右鍵菜單,選擇”啟用“,即可。

禁用的操作一樣,右鍵菜單選擇”停止“等相應操作即可。

如果要修改啟動模式,”自動“、”手動“、”禁用“等,右鍵菜單選擇”屬性“,進入服務屬性設置窗口。

選擇相應的啟動類型后確定即可。

mysql被禁用了,大神求救!

mysql配置文件不對,所以服務啟動不了,應該是你改動過了,你查看下mysql下錯誤日志看提示具體什么原因,針對性的修改

mysql的my.ini被禁用了

datadir="F:/Program Files/MySQL/MySQL Server 4.1/Data/"

basedir="F:/Program Files/MySQL/MySQL Server 4.1/"

這兩個路徑 搞正確 就差不多了

可以看看下這個資料

實在不行給我留言

在本地計算機無法啟動MYSQL服務錯誤1067進程意外終止 這種情況一般是my.ini文件配置出錯了,

你可以刪除系統(tǒng)目錄下的my.ini文件,

把下面的內(nèi)容重新寫入my.ini文件試試,

要適當?shù)馗膶懸幌挛募窂?/p>

我的my.ini 2007年12月31日

[WinMySQLAdmin]

Server=C:/MYSQL/mysql/bin/mysqld-opt.exe

user=root

[mysqld]

basedir=C:/MYSQL/mysql

datadir=C:/MYSQL/mysql/data

#bind-address=192.168.0.2

#language=D:/MYSQL/share/chinese

===========================================

[WinMySQLAdmin]

Server=D:/MYSQL/bin/mysqld-opt.exe

user=root

[mysqld]

basedir=D:/MYSQL

datadir=D:/MYSQL/data

#bind-address=192.168.0.2

#language=D:/MYSQL/share/chinese

============================================

查找Windows目錄下的my.ini文件,編輯內(nèi)容(如果沒有該文件,則新建一個),至少包含basedir,datadir這兩個基本的配置。

[mysqld]

# set basedir to installation path, e.g., c:/mysql

# 設置為MYSQL的安裝目錄

basedir=D:/www/WebServer/MySQL

# set datadir to location of data directory,

# e.g., c:/mysql/data

# 設置為MYSQL的數(shù)據(jù)目錄

datadir=D:/www/WebServer/MySQL/data

另外,要注意:

[WinMySQLadmin]

Server=D:/www/WebServer/MySQL/bin/mysqld-nt.exe

user=root

password=xxxxxxxx

#以上是設置WinMySQLadmin的配置

[Client]

user=root

password=xxxxxxxx

將Mysql添加到Windows系統(tǒng)服務中:

1.、 安裝服務。

在Windows2000下,安裝完成后,并沒有把MySQL安裝成服務,我們必須執(zhí)行下面的語句把MySQL注冊為服務:installdir\mysql\bin\mysqld-nt –-install。

Windows98下沒有服務的概念,所以不用安裝服務。

2.、 啟動服務

在Windows2000下,安裝服務后可以啟動MySQL服務:net start mysql。

在Windows98下,可以用下面的命令啟動服務:c:\mysql\bin\mysqld,服務啟動后在后臺運行,并沒有界面。

3.、 停止服務

在Windows2000下,可以通過下面的命令停止MySQL服務:net stop mysql。

在Windows98下,可以通過下面命令停止服務:C:\ C:\mysql\bin\mysqladmin -u root shutdown

網(wǎng)頁名稱:mysql服務禁用怎么辦 mysql服務無效
文章分享:http://chinadenli.net/article2/hpioic.html

成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供企業(yè)網(wǎng)站制作動態(tài)網(wǎng)站品牌網(wǎng)站設計網(wǎng)站導航靜態(tài)網(wǎng)站全網(wǎng)營銷推廣

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

小程序開發(fā)