關於mysql資料庫遠端訪問功能
阿新 • • 發佈:2019-01-03
預設狀況下,出於安全考慮,mysql資料庫遮蔽了遠端訪問功能。 然而在許多狀況下,你需要在家或者從web程式去訪問遠端資料庫伺服器,這就相當麻煩了。
第一步: 啟用網路設定
你需要編輯mysql配置檔案my.cnf.
通常狀況,my.cnf放置於在以下目錄:
/etc/mysql/my.cnf (Debian linux5·
/etc/my.cnf (Red Hat Linux/Fedora Linux)
/var/db/mysql/my.cnf (FreeBSD)
# vi /etc/my.cnf
然後用vi編輯my.cnf,修改內容從以下行:
[mysqld]
你所需要:
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
第二步, 給遠端ip授訪問許可權
1. 以root身份登陸mysql # mysql -u root -p
2. 授權給新資料庫
如果你有一個新的資料庫名稱為foo。使用者bar需要在客戶端地址為202.54.10.20上訪問。
在伺服器端執行 (授權法):
mysql> CREATE DATABASE foo;
mysql> GRANT ALL ON foo.* TO [email protected]'202.54.10.20' IDENTIFIED BY 'PASSWORD';
如何給以存在的資料庫授權?
如果使用者 webadmin 經常在客戶端地址202.54.10.20 訪問 webd資料庫,那麼在伺服器端執行的命令應該為(改表法):
mysql> update db set Host='202.54.10.20' where Db='webdb';
mysql> update user set Host='202.54.10.20' where user='webadmin';
第三步: 執行exit命令退出mysql環境,
第四步 測試
From remote system type command:
$ mysql -u webadmin –h 65.55.55.2 –p
註解;
-u webadmin: webadmin為mysql的使用者名稱
-h IP or 域名: 65.55.55.2 is MySQL server IP address or hostname (FQDN)
-p : 密碼提示
你也可以使用telnet去連線遠端的3306埠 $ telnet 65.55.55.2 3306
筆者注:
這篇文章解決了我在suse環境中的mysql遠端訪問問題。但是實際操作中,my.cnf似乎並不是特別重要。在我的操作中,my.cnf建立和修改沒有執行(忽略第一步)。最重要的步驟應該是第四步
GRANT ALL ON b2c.* TO [email protected]'5.179.201.86' IDENTIFIED BY '';
其中b2c為所要訪問的遠端資料庫名,5.179.201.86為mysql客戶端主機的ip地址,也就是你的機器ip地址。
有個小細節需要注意。如果你的伺服器裝了防火牆的話,需要開啟3306的訪問,否則也會連線不上。