从最新版本的linux系统开始,默认的是 Mariadb而不是mysql!这里依旧以mysql为例进行展示
1、先检查系统是否装有mysql
rpm -qa | grep mysql
这里返回空值,说明没有安装
这里执行安装命令是无效的,因为centos-7默认是Mariadb,所以执行以下命令只是更新Mariadb数据库
yum install mysql
删除可用
yum remove mysql
2、下载mysql的repo源
# wget http://repo.mysql.com/mysql-community-release-el7-5.noarch.rpm
安装mysql-community-release-el7-5.noarch.rpm包
# sudo rpm -ivh mysql-community-release-el7-5.noarch.rpm
安装这个包后,使用命令:
cd /etc/yum.repos.d/
会获得两个mysql的yum repo源:
mysql-community.repo
mysql-community-source.repo
3、安装mysql
# sudo yum install mysql-server
根据步骤安装就可以了,不过安装完成后,没有密码,需要重置密码。
安装后再次查看mysql
如果报错,内容含有:
Error: Package: mysql-community-libs-5.6.35-2.el7.x86_64 (mysql56-community)
Requires: libc.so.6(GLIBC_2.17)(64bit)
Error: Package: mysql-community-server-5.6.35-2.el7.x86_64 (mysql56-community)
Requires: libc.so.6(GLIBC_2.17)(64bit)
Error: Package: mysql-community-server-5.6.35-2.el7.x86_64 (mysql56-community)
Requires: systemd
Error: Package: mysql-community-server-5.6.35-2.el7.x86_64 (mysql56-community)
Requires: libstdc++.so.6(GLIBCXX_3.4.15)(64bit)
Error: Package: mysql-community-client-5.6.35-2.el7.x86_64 (mysql56-community)
Requires: libc.so.6(GLIBC_2.17)(64bit)
You could try using --skip-broken to work around the problem
You could try running: rpm -Va --nofiles --nodigest
4、重置密码
重置密码前,首先要登录
# mysql -u root
登录时有可能报这样的错:
ERROR 2002 (HY000): Can’t connect to local MySQL server through socket ‘/var/lib/mysql/mysql.sock’
原因是/var/lib/mysql
的访问权限问题。下面的命令把/var/lib/mysql
的拥有者改为当前用户:
# sudo chown -R openscanner:openscanner /var/lib/mysql
如果报 chown: 无效的用户: "openscanner:openscanner"
错误,更换命令,并用 ll 查看目录权限列表
chown root /var/lib/mysql/
ll
然后,重启服务:
service mysqld restart
接下来登录重置密码:
mysql -u root -p
注意:开始数据库默认没有密码的,直接回车键就行。
mysql > use mysql;
mysql > update user set password=password('123456') where user='root';
mysql > exit;
重启mysql服务后才生效# service mysqld restart
必要时加入以下命令行,为root添加远程连接的能力。链接密码为 “root”(不包括双引号)
mysql> GRANT ALL PRIVILEGES ON *.* TO root@"%" IDENTIFIED BY "root";
6、查询数据库编码格式,确保是 UTF-8
show variables like "%char%";
需要修改编码格式为UTF-8,导入数据库sql的时候,请确保sql文件为utf8编码
进入mysql命令行后 输入
set names utf8;
本例子是博主亲自试验过的,当初也是花很多时间琢磨的,现在整理出来,希望大家少走些弯路。