本文目錄一覽:
- 1、mysql5.7.12報錯如下情況導致無法連接數據庫應該怎麼辦?
- 2、無法連接MySQL數據庫
- 3、mysql連接數據庫失敗,請確定數據庫用戶名,密碼設置正確
- 4、mySQL數據庫連接不上怎麼辦。。
- 5、MySQL為什麼連接不了?
- 6、連接mysql數據庫出現2003-Can’t connect to MySQL server on ‘localhost'(10061),請問是怎麼回事?
mysql5.7.12報錯如下情況導致無法連接數據庫應該怎麼辦?
一、mysqld 進程沒有正常運行遇到這種情況首先到服務器上看看 mysqld 進程是否活着,採用的命令:
二、客戶端不能和進程 mysqld 通信如果 MySQL 服務器上的 mysqld 進程運行正常,我們再看看客戶端能不能和 mysqld 進行通信,使用下面的命令進行網絡連通的測試:telnet localhost 3306
如果本地能通,再到客戶端的機器上把 localhost 換成 MySQL 服務器的 ip 地址進行測試。如果不能通,通常有兩種原因,一種原因是 OS 或網絡的問題,或者是防火牆;另一種原因是 mysqld 自身根本沒有偵聽客戶端的連接請求, mysqld 啟動後對於客戶端的偵聽是分三種情況。
第一種情況
是使用參數 –skip-networking 跳過偵聽客戶端的網絡連接,用下面的命令我們可以看到 MySQL 根本沒有偵聽 3306 端口。
第二種情況
使用參數 –bind-address 後面增加對客戶端訪問 IP 地址的限制,例如只偵聽本地的連接
三、賬戶密碼的問題最後一種情況是賬戶密碼的問題,應付這種情況我們有個有力的工具就是查看 MySQL 的 error log, error log 記載信息的詳細程度上由參數 –log-error-verbosity 進行控制的
無法連接MySQL數據庫
並不是你的 帳號密碼錯了 而是你的鏈接字符串里 的 host 寫的是IP地址
出現這個問題的原因是因為你的 root 的host權限為 LocalHost
您可以修改 root的 host權限 為 % 就可以了~
UPDATE mysql.user SET HOST=’%’ WHERE USER=’root’;
mysql連接數據庫失敗,請確定數據庫用戶名,密碼設置正確
現象
一線的工程師反映了一個奇怪的現象,剛剛從 MySQL 官網上下載了一個 MySQL 5.7.31。安裝完成後,發現使用任何密碼都能登陸 MySQL,修改密碼也不管用,重新啟動 MySQL 也不能解決。
分析
懷疑使用了 –skip-grant-tables 使用 mysqld –print-defaults 檢查,沒有發現。
檢查登陸用戶,都是 root@localhost,說明和 proxy user 沒有關係。
使用 mysql –print-defaults 檢查客戶端是否設置默認的用戶和密碼,沒有發現。
檢查數據庫中的用戶和密碼的相關字段:
發現一切都正常,再檢查 plugin 字段,發現只有 root 用戶是 auth_socket ,其它的用戶都是 mysql_native_password,問題可能就出在這兒。
對 auth_socket 驗證插件不了解,感覺是這個插件不安全,使用下面的命令修改後,問題解決:
update user set plugin=”mysql_native_password” where user=’root’;
auth_socket 驗證插件的使用場景
問題解決後,又仔細研究了一下 auth_socket 這個插件,發現這種驗證方式有以下特點:
首先,這種驗證方式不要求輸入密碼,即使輸入了密碼也不驗證。這個特點讓很多人覺得很不安全,實際仔細研究一下這種方式,發現還是相當安全的,因為它有另外兩個限制;
只能用 UNIX 的 socket 方式登陸,這就保證了只能本地登陸,用戶在使用這種登陸方式時已經通過了操作系統的安全驗證;
操作系統的用戶和 MySQL 數據庫的用戶名必須一致,例如你要登陸MySQL 的 root 用戶,必須用操作系統的 root用戶登陸。
auth_socket 這個插件因為有這些特點,它很適合我們在系統投產前進行安裝調試的時候使用,而且也有相當的安全性,因為系統投產前通常經常同時使用操作系統的 root 用戶和 MySQL 的 root 用戶。當我們在系統投產後,操作系統的 root 用戶和 MySQL 的 root 用戶就不能隨便使用了,這時可以換成其它的驗證方式,可以使用下面的命令進行切換:
ALTER USER ‘root’@’localhost’ IDENTIFIED WITH mysql_native_password BY ‘test’;
mySQL數據庫連接不上怎麼辦。。
這問題頭疼,是不是要講詳細.。局域網處理方案,一般連接檢查順序:
1.查看數據庫監聽端口;
2.查看該監聽服務啟動沒有;
3.查看驅動包有沒有放(服務器端common-lib,開發工具common開發包[一般自帶有];
4.運行jdbc連接程序,有沒有出異常,出異常上面沒弄好,看看異常,就可以追蹤處理。
5.直接使用開發工具的鏈接測試平台,備好各個屬性,添入驅動包,測試鏈接是否成功,成功你的程序有問題,沒成功換驅動包。
MySQL為什麼連接不了?
MySQL ‘localhost’ (10061)解決方法
MySQL ‘localhost’ (10061)解決方法
首先檢查MySQL 服務沒有啟動》如果沒有啟動,則要啟動這個服務。
昨天,重起服務器後出現MySQL ‘localhost’ (10061)錯誤,開始以為是因為數據庫鏈接打開過多,數據庫資源耗盡的緣故,但是重啟服務器以後,仍舊出現問題,於是在網上查找解決方法。大體如下:
解決辦法:
第一步
刪除c:\windowns下面的my.ini
第二步
打開c:\mysql\bin\winmysqladmin.exe 輸入用戶名 和密碼
第三步 在dos下 輸入 mysqld-nt -remove 刪除服務
在接着輸入 mysqld-nt -install
第四步 輸入mysql 啟動成功。
其它可參考的方法:
1.看看hosts文件中localhost是不是指向127.0.0.1
2.如果是沒啟動mysql服務,則可運行net start mysql。
3.一些相關命令:
mysqld-nt –install #啟動Mysql
mysql #運行Mysql
mysql -h ipAddress -u username -p
或
者:直接去bin里點mysqld.exe或mysqld-nt.exe,看下它的進程能否正常運行,如不行,再去控制面板,服務里去啟動它,看下是什麼
錯誤。如果不行,就在添加刪除里刪去mysql,然後再重裝mysql,一般都能解決問題,可以在安裝前備份一下DATA。
Error: Can’t connect to MySQL server on ‘localhost’ (10061)
Errno.: 2003
錯誤編號:2003
問題分析:
無法連接到 MySQL 服務器,可能的情況為:
1、MySQL 服務沒有啟動,一般是在異常的情況下 MySQL 無法啟動導致的,比如無可用的磁盤空間,my.ini 里 MySQL 的 basedir 路徑設置錯誤等;
2、MySQL 服務器資源緊張,導致無法連接。
解決方法:
1、如果你是虛擬主機用戶(購買的空間),則聯繫空間商檢查 MySQL 是否正常啟動,並確認 MySQL 的配置信息(是否為 localhost);
2、如果你是獨立主機用戶(擁有管理主機權限),則按下面步驟檢查:
1)檢查磁盤空間是否還有剩餘可用空間,盡量保持有足夠的磁盤空間可用。
2)檢查 my.ini 里的 basedir (MySQL 安裝地址) 和 datadir (數據目錄存放地址)等參數設置是否正確,然後重新啟動下 MySQL 服務。
還有一種方法是將服務器的windows補丁。
微軟9月9日發佈了TCP/IP更新補丁(KB967723),如果服務器開啟自動更新或者有自動更新軟件下載更新了這個補丁,那麼就會出現這個問題。
有人可能會問,為什麼9號出現的補丁,到現在才發現問題?
大家都知道,服務器不是每天都重啟的,有的服務器可能一個月或者一年半載重啟一次,有的可能在9月9日以後重啟過服務器,所以補丁生效了(我個人這麼認為)。
補丁卸載方法:登錄服務器,進入控制面板 — 添加和刪除程序 — (勾選上方的「顯示更新」)
在裏面可以看到更新的KB967723這個補丁,然後就想卸載普通軟件一樣卸載,卸載中會提示你,如果卸載可能導致程序運行出錯,沒關係,選擇「是」,繼續卸載。
卸載完成後程序服務器,一切正常!
至於該補丁修補什麼漏洞,卸載後是否會出現服務器安全隱患,這個先不說,要MYSQL正常運行,臨時的解決辦法只有如此。
還有種情況下,你可以這樣解決
Discuz! info: Can not connect to MySQL server
Time: 2007-11-13 6:25pm
Script: /bbs/index.php
Error: Can’t connect to MySQL server on ‘localhost’ (10061)
Errno.: 2003
Similar error report has beed dispatched to administrator before.
正常情況下原因如下:
網站論壇訪問量過大,數據庫連接超過最大連接數.MYSQL數據庫服務停止了.
解決方法(針對WIN系統):
1, 首先到系統服務裏面找到MYSQL服務並啟動MYSQL服務.
2, 到MYSQL安裝目錄找到MY.INI文件,打開MY.INI查找max_connections 修改連接數為1000 重啟IIS與MYSQL服務.
連接mysql數據庫出現2003-Can’t connect to MySQL server on ‘localhost'(10061),請問是怎麼回事?
無法連接到 MySQL 服務器,可能的情況為:
1、MySQL 服務沒有啟動,一般是在異常的情況下 MySQL 無法啟動導致的,比如無可用的磁盤空間,my.ini 里 MySQL 的 basedir 路徑設置錯誤等;
2、MySQL 服務器資源緊張,導致無法連接。
拓展資料:
使用說明
1.如果是用 MySQL + Apache,使用的又是 FreeBSD 網絡操作系統的話,安裝時候你應按注意到FreeBSD的版本問題,在 FreeBSD 的 3.0 以下版本來說,MySQL Source 內含的 MIT-pthread 運行是正常的,但在這版本以上,你必須使用 native threads,也就是加入一個 with-named-thread-libs=-lc_r 的選項。
2.如果在 COMPILE 過程中出了問題,請先檢查你的 gcc版本是否在 2.81 版本以上,gmake 版本是否在3.75以上。
3.如果不是版本的問題,那可能是你的內存不足,請使用 ./configure–with-low-memory 來加入。
4.如果要重新做你的 configure,那麼你可以鍵入 rm config.cache 和 make clean 來清除記錄。
5.把 MySQL 安裝在 /usr/local 目錄下,這是缺省值,您也可以按照你的需要設定你所安裝的目錄。
服務無法啟動
1、首先,查看MySQL的服務是否存在。如果不存在需要先安裝服務。安裝服務的方法是進入MySQL Server的安裝目錄,找到bin目錄,然後找到文件mysqld.exe,使用命令行運行 mysqld –install MySQL57 安裝服務(如果不成功嘗試使用管理員方式運行,MySQL57是服務的名字,默認是MySQL)。
2、如果上述方法安裝服務失敗,則可採用下述方法安裝(成功則跳過此步)。搜索程序「regedit.exe」,即註冊表編輯器,打開後找到 「計算機」——”HKEY_LOCAL_MACHINE”——「SYSTEM」——「CurrentControlSet」——「Services」,然後在該目錄下新建項MySQL57(服務的名字)即可成功建立項目。
3、找到新建的項,然後可以看到其中有ImagePath這一項,這其實是可執行文件的路徑。因為MySQL服務是需要靠mysqld這個命令來啟動的,所以檢查下ImagePath的路徑是否正確。路徑錯誤導致啟動服務時報錯—「無法找到文件」。
4、修改ImagePath的內容為正確的路徑值,正確的值是”D:\MySQL\MySQL Server 5.7\bin\mysqld” –defaults-file=”D:\MySQL\MySQL Server 5.7\my.ini” MySQL 是這種形式的,對照一下,如果路徑不對,修改過來。
5、重啟計算機,再次啟動服務,並可以成功運行MySQL服務。
參考資料:百度百科:mySQL
原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-hk/n/257467.html