在CentOS7中默認安裝有MariaDB,這個是MySQL的分支,但為了需要,還是要在系統中安裝MySQL,而且安裝完成之后可以直接覆蓋掉MariaDB。
安裝jdk的時候,需要將用戶權限切換為root
命令:sudo su
0. 首先檢查centos中是否安裝了mysql
在終端輸入:whereis mysql
[root@izuz61chav73qgz xueheng]# whereis mysql mysql: /usr/bin/mysql /usr/lib64/mysql /usr/share/mysql /usr/share/man/man1/mysql.1.gz [root@izuz61chav73qgz xueheng]#
回車,如果你安裝好了mysql,就會顯示文件安裝的地址
1. 下載並安裝MySQL官方的 Yum Repository
1
|
[root@BrianZhu /]
# wget -i -c http://dev.mysql.com/get/mysql57-community-release-el7-10.noarch.rpm
|
使用上面的命令就直接下載了安裝用的Yum Repository,大概25KB的樣子,然后就可以直接yum安裝了。
1
|
[root@BrianZhu /]
# yum -y install mysql57-community-release-el7-10.noarch.rpm
|
下面就是使用yum安裝MySQL了
1
|
[root@BrianZhu /]
# yum -y install mysql-community-server
|
這步可能會花些時間,安裝完成后就會覆蓋掉之前的mariadb。
出現這樣的提示表示安裝成功
2. MySQL數據庫設置
首先啟動MySQL
1
|
[root@BrianZhu /]
# systemctl start mysqld.service
|
查看MySQL運行狀態,運行狀態如圖:
1
|
[root@BrianZhu /]
# systemctl status mysqld.service
|
此時MySQL已經開始正常運行,不過要想進入MySQL還得先找出此時root用戶的密碼,通過如下命令可以在日志文件中找出密碼:
1
|
[root@BrianZhu /]
# grep "password" /var/log/mysqld.log
|
上面標記的就是初始密碼
如下命令進入數據庫:
1
|
[root@BrianZhu /]
# mysql -uroot -p # 回車后會提示輸入密碼
|
輸入初始密碼,此時不能做任何事情,因為MySQL默認必須修改密碼之后才能操作數據庫:
1
|
mysql>
ALTER
USER
'root'
@
'localhost'
IDENTIFIED
BY
'123456'
;
|
這里有個問題,新密碼設置的時候如果設置的過於簡單會報錯:
原因是因為MySQL有密碼設置的規范,具體是與validate_password_policy的值有關:
解決方法就是修改密碼為規范復雜的密碼:
1
2
3
4
|
mysql>
ALTER
USER
'root'
@
'localhost'
IDENTIFIED
BY
'z?guwrBhH7p>'
;
Query OK, 0
rows
affected (0.00 sec)
mysql>
|
這時候我們要把密碼規則改一下,執行下面sql就可以了:
1
2
3
4
5
6
7
|
mysql>
set
global
validate_password_policy=0;
Query OK, 0
rows
affected (0.00 sec)
mysql>
set
global
validate_password_length=1;
Query OK, 0
rows
affected (0.00 sec)
mysql>
|
設置之后就是我上面查出來的那幾個值了,此時密碼就可以設置的很簡單,例如1234之類的。到此數據庫的密碼設置就完成了。
mysql> ALTER USER 'root'@'localhost' IDENTIFIED BY '1234';
接下來我們退出mysql,輸入新密碼重新連接
mysql> exit Bye
[root@izuz61chav73qgz xueheng]# mysql -uroot -p Enter password:
但此時還有一個問題,就是因為安裝了Yum Repository,以后每次yum操作都會自動更新,需要把這個卸載掉:
1
|
[root@BrianZhu ~]
# yum -y remove mysql57-community-release-el7-10.noarch
|
配置算是完成了