CentOS7的yum源中默認好像是沒有mysql的。爲了解決這個問題,我們要先下載mysql的repo源。
1. 下載mysql的repo源
1
|
$ wget http: //repo .mysql.com /mysql-community-release-el7-5 .noarch.rpm |
2. 安裝mysql-community-release-el7-5.noarch.rpm包
1
|
$ sudo rpm -ivh mysql-community-release-el7-5.noarch.rpm |
安裝這個包後,會獲得兩個mysql的yum repo源:/etc/yum.repos.d/mysql-community.repo,/etc/yum.repos.d/mysql-community-source.repo。
3. 安裝mysql
1
|
$ sudo yum install mysql-server |
根據步驟安裝就可以了,不過安裝完成後,沒有密碼,需要重置密碼。
4. 重置密碼
重置密碼前,首先要登錄
1
|
$ mysql -u root |
登錄時有可能報這樣的錯:ERROR 2002 (HY000): Can't connect to local MySQL server through socket '/var/lib/mysql/mysql.sock' (2),原因是/var/lib/mysql的訪問權限問題。下面的命令把/var/lib/mysql的擁有者改爲當前用戶:
1
|
$ sudo chown -R openscanner:openscanner /var/lib/mysql |
然後,重啓服務:
1
|
$ service mysqld restart |
接下來登錄重置密碼:
1
|
$ mysql -u root |
1
2
3
|
mysql > use mysql; mysql > update user set password=password( '123456' ) where user= 'root' ; mysql > exit ; |
5. 開放3306端口
1
|
$ sudo vim /etc/sysconfig/iptables |
添加以下內容:
1
|
-A INPUT -p tcp -m state --state NEW -m tcp --dport 3306 -j ACCEPT |
保存後重啓防火牆:
1
|
$ sudo service iptables restart |
6. 創建普通用戶並授權
示例(使用root用戶登錄,並假定已經創建了openscannerstore數據庫):
1
|
mysql > use mysql; |
1
2
3
|
#創建openscanner用戶與密碼並設置爲從安裝mysql服務的機器本地訪問 mysql > grant all on openscannerstore.* to 'openscanner' @ 'localhost' identified by 'scanner888' ; |
1
2
|
#設置openscanner用戶與密碼,並從任何機器都可以訪問mysql mysql > grant all on openscannerstore.* to 'openscanner' @ '%' identified by 'scanner888' ; |
1
|
mysql > flush privileges; #刷新纔會生效 |
現在就可以從客戶機連接mysql服務器了,如果連接報這樣的錯:ERROR 2003 (HY000): Can't connect to MySQL server on '192.168.x.xxx' (113)。因爲我們是centos7,請先確認防火牆是否開啓來,centos7默認是firewall,我們可以把它停止並禁止使用,然後啓動我們熟悉的iptables,這樣就好了!
注:mysql客戶機是需要安裝mysql客戶端的。
轉自:http://my.oschina.net/fhd/blog/383847