前言
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 –add-port=3306/tcp
#检视埠是否开放
firewall-cmd –query-port=3306/tcp
允许 mysql 远端访问
mysql 预设是不允许远端访问的.
mysql -u root -p xxxx
mysql>use mysql
mysql>grant all privileges on *.* to ‘root’@’%’ identified by ‘xxxxx(密码)’;
mysql>flush privileges;