CentOS7下安裝mysql5.6修改字符集為utf8並開放埠允許遠端訪問
阿新 • • 發佈:2022-05-04
前言
mysql最初的免費戰略已經深入人心,感覺自己一直都在用mysql。今天在centos7下裝mysql。發現原來centos下預設沒有mysql,因為開始收費了,取而代之的是另一個mysql的分支mariadb
,這個是mysql創始人重新主導的分支。But, whatever, I want mysql. 所以,老老實實的解除安裝mariadb,安裝mysql。
解除安裝mariadb
#列出所有被安裝的rpm package rpm -qa | grep mariadb #解除安裝 rpm -e mariadb-libs-5.5.37-1.el7_0.x86_64 錯誤:依賴檢測失敗: libmysqlclient.so.18()(64bit) 被 (已安裝) postfix-2:2.10.1-6.el7.x86_64 需要 libmysqlclient.so.18(libmysqlclient_18)(64bit) 被 (已安裝) postfix-2:2.10.1-6.el7.x86_64 需要 #強制解除安裝,因為沒有--nodeps rpm -e --nodeps mariadb-libs-5.5.37-1.el7_0.x86_64
安裝mariadb
centos下yum暫時沒有mysql-server直接安裝包; MariaDB是MySQL社群開發的分支,也是一個增強型的替代品.
yum -y install mariadb-server mariadb mariadb-devel systemctl start mariadb systemctl enable mariadb mysql_secure_installation firewall-cmd --permanent --add-service mysql systemctl restart firewalld.service iptables -L -n|grep 3306
安裝mysql
centos7中預設沒有mysql的yum源,需要重新下載:
1.下載mysql的repo源
$ wget http://repo.mysql.com/mysql-community-release-el7-5.noarch.rpm
2.安裝mysql-community-release-el7-5.noarch.rpm包
$ sudo rpm -ivh mysql-community-release-el7-5.noarch.rpm
3.安裝mysql
$ sudo yum install mysql-server
4.重置密碼
需要先登入:
$ mysql -u root
我使用的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的擁有者改為當前使用者:
$ sudo chown -R openscanner:openscanner /var/lib/mysql
重啟mysql service:
$ service mysqld restart
接下來設定密碼:
$ mysql -u root
mysql > use mysql;
mysql > update user set password=password(‘123456‘) where user=‘root‘;
mysql > exit;
開放3306埠
由於centos7使用firewalld而不是iptables,所以:
#開放3306
firewall-cmd --permanent --add-port=3306/tcp
systemctl restart firewalld.service
#檢視埠是否開放
firewall-cmd --query-port=3306/tcp
#list
firewall-cmd --list-all
允許mysql遠端訪問
mysql預設是不允許遠端訪問的. mysql -u root -p xxxx
mysql>use mysql
mysql>grant all privileges on *.* to 'root'@'%' identified by 'xxxxx(密碼)';
mysql>flush privileges;
參考
CentOS 7 用yum安裝 MySQL Centos 7 開啟埠 centos7通過yum安裝mysql,並授權遠端連線