- 1、如何設置mysql 允許遠程連接
- 2、怎麼配置雲伺服器mysql遠程
- 3、想知道雲資料庫MySql,是存放在獨立的伺服器上嗎?購買後我們如何查看資料庫數據,是登錄遠程還是通
- 4、騰訊雲伺服器怎麼開啟遠程mysql服務
- 5、怎麼解決mysql遠程連接報10038的錯誤
mysql無法連接總結
1 先弄清楚mysql.user表的host和user列的含義,host列表示ip地址或者hostname,它和user列組成聯合主鍵,host列的約束關係:比如172.%即代表只能172開頭的網段才能登 陸該db;%表示任何網段都能登陸;同一user下如果既有172.%和%的host,那就取並集,即任何網段都能登陸
2 密碼錯誤,一般報1045錯誤
一般是以下誤操作
2.0 首先明確一點,grant方式新建用戶後其實不用flush privileges,而flush privileges刷新全新只對後續的連接有效,對本次連接無效
2.1 可能是update user表的方式修改了密碼以後,忘記flush privileges,這時並沒有生效,斷開重連後沿用的還是舊密碼
2.2 可能是update user表的方式修改了密碼以後,忘記flush privileges,這時並沒有生效,db重啟以後必須用新密碼才能登陸
2.3 就是簡單的修改了密碼,忘記了新密碼,一般可以用skip-grant-tables的方式免密碼登陸,修改回來,這個方法比較簡單,但是需要重啟db;
在雲伺服器中,一般都會保存一個管理賬戶密碼,總是被客戶隨意修改導致備份,監控等失敗,可以通過以下方法在線修改回來,無須重啟db
2.3.1 copy 用戶庫的user表相關的文件到自己測試庫
2.3.2 在測試庫更改用戶密碼或添加用戶
2.3.3 把user表相關的文件copy到用戶庫
2.3.4 kill -SIGHUP 用戶的mysqld進程
3 是否設置了禁用dns解析,即設置了skip_name_resolve卻還是用主機名稱連接
4 是否設置了綁定ip訪問,即設置了bind-address卻還是用其他ip連接
5 確認是否是網路問題,一般直接ping ip的方式確定,這時先解決網路問題
6 確認是否能夠telnet通對應ip的埠,如果不通的話,一般是以下原因
6.1 檢查磁碟空間是否已經滿了,即磁碟不足,這時應該無法telnet
6.2 檢查mysqld進程是否存活,是否正好處於關閉中或者啟動中,看錯誤日誌即可,這時無法telnet
6.3 檢查防火牆,是否開通了對應的db port
6.4 mysqld oom內存不足重啟,這時會有短暫的時間連接不上,通過查看mysqld進程的啟動時間或系統日誌搜索oom關鍵字 /var/log/message
7 確認是否連接數打滿了,一般報too many connections
8 確認是否是本地埠耗盡,這時一般報錯 ERROR 2003 (HY000): Can’t connect to MySQL server on ‘192.168.0.10’ (99),注意最後括弧的數字是99,解決方法一般是增加 local_port的範圍 , /proc/sys/net/ipv4/ip_local_port_range 這裡的值,兩者相減 就是目前的範圍
9 還有一種情況,比如敲的登陸命令為mysql -uxx -pxx -hxxx database1,這時相當於連接到mysql後還有一個use database1的操作,如果卡住了一般就是卡在那不動,也不提示錯誤,這時需要注釋掉database1登錄進去查看是哪個線程卡住了它,或者本身這個db下表太多,本來就慢
最近有一同學問我MySQL無法遠程訪問怎麼呢,但能使用localhost來進行方法,下面腳本之家來給各位介紹一下解決辦法,需要的朋友可以參考下
可能是IP沒設置好
問題:MySQL許可權設置正確,但仍無法遠程訪問。通過telnet發現3306埠未打開。
分析:MySQL默認只綁定127.0.0.1,即:只有在本機才能訪問3306埠。
解決:找到MySQL配置文件,搜索「bind-address」,找到這一行:
bind-address = 127.0.0.1 在前面加一個#,注釋掉這一行,保存,重啟MySQL。再通過遠程訪問就可以了,telnet可以發現埠也打開了。
例我們配置
1. 確保skip-networking被刪除或者屏蔽,否則不支持TCP/IP 訪問
2. 增加行bind-address = 65.55.55.2,替代65.55.55.2 為你的伺服器地址
修改後,配置為:
複製代碼代碼如下:
[mysqld]
user = mysql
pid-file = /var/run/mysqld/mysqld.pid
socket = /var/run/mysqld/mysqld.sock
port = 3306
basedir = /usr
datadir = /var/lib/mysql
tmpdir = /tmp
language = /usr/share/mysql/English
bind-address = 65.55.55.2
# skip-networking
….
..
保存並關閉配置文件
重啟mysql伺服器:# /etc/init.d/mysql restart
如果上面辦法沒有用我們可以通用mysql命令模式進行設置
1。 改表法。
可能是你的帳號不允許從遠程登陸,只能在localhost。這個時候只要在localhost的那台電腦,登入mysql後,更改 “mysql” 資料庫里的 “user” 表裡的 “host” 項,從”localhost”改稱”%”
複製代碼代碼如下:
CODE:mysql -u root -p123
mysqluse mysql;
mysqlupdate user set host = ‘%’ where user = ‘root’;
mysqlselect host, user from user;
2. 授權法。
例如,你想kevin使用mypassword從任何主機連接到mysql伺服器的話。
複製代碼代碼如下:
GRANT ALL PRIVILEGES ON *.* TO ‘kevin’@’%’ IDENTIFIED BY ‘mypassword’ WITH GRANT OPTION;
如果你想允許用戶kevin從ip為192.168.101.234的主機連接到mysql伺服器,並使用mypassword作為密碼
複製代碼代碼如下:
GRANT ALL PRIVILEGES ON *.* TO ‘kevin’@’192.168.101.234’ IDENTIFIED BY ‘mypassword’ WITH GRANT OPTION;
注意了,如果是linux系統防火牆也很重要哦
複製代碼代碼如下:
/* 關閉防火牆 */
service iptables stop
/* 開啟防火牆 */
service iptables start
/* 默認關閉防火牆 */
chkconfig iptables off
移動雲MySQL是基於物理機進行的容器化部署,通過容器提供的資料庫服務。目前實例規格族,包括通用型、獨享型和通用入門型。其中通用型和通用入門型是與同一物理機上其他通用版實例共享CPU⌄磁碟和I/O資源,獨享被分配的內存資源。獨享型是完全獨享被分配的CPU、內存、磁碟和I/O資源。購買成功的MySQL需要下載適配版本的MySQL客戶端程序進行遠程訪問。
了解移動云云資料庫MySql更多詳情,歡迎註冊登錄移動雲官網→
查看Centos版本
[root@VM_0_7_centos ~]# cat /etc/redhat-release
CentOS Linux release 7.3.1611 (Core) 12
查看當前 Ubuntu Server版本
ubuntu@VM-15-131-ubuntu:~$ sudo lsb_release -a
No LSB modules are available.
Distributor ID: Ubuntu
Description: Ubuntu 16.04.1 LTS
Release: 16.04
Codename: xenial123456
修改user表裡面的host項
登入mysql後,更改 「mysql」 資料庫里的 「user」 表裡的 「host」 項,從」localhost」改稱」%」
mysql -uroot -proot
mysqluse mysql;
mysqlupdate user set host = ‘%’ where user = ‘root’;
mysqlselect host, user from user;
1/11
先看報錯窗口。
2/11
通過百度,最終找到的原因是:遠程3306埠未對外開放。於是下面進行遠程3306埠開放操作。
3/11
首先遠程連接伺服器,點擊「開始」-「管理工具」-「高級安全Windows防火牆」。
4/11
在打開的窗口中,左邊選中「入站規則」,右邊點擊「新規則」來新建一個入站規則。
5/11
在「規則類型」中選擇「埠」,然後下一步。
6/11
選中「特定本地埠」,輸入3306,然後下一步。
7/11
選中「允許連接」,然後下一步。
8/11
這一步默認都選中就行,,然後下一步。
9/11
最後輸入新增的入站規則名稱,隨便填,自己明白即可。
10/11
完成後可以在入站規則列表中可以看到新增的入站規則。
11/11
現在再次在本地連接mysql遠程資料庫時,發現已經能正常訪問了。
問題解決。
原創文章,作者:CQFDM,如若轉載,請註明出處:https://www.506064.com/zh-tw/n/126952.html