MariaDB数据库管理系统是MySQL的一个分支,主要由开源社区在维护,采用GPL受权许可。开发这个分支的缘由之一是:甲骨文公司收购了MySQL后,有将MySQL闭源的潜在风险,所以社区采用分支的方式来避开这个风险。MariaDB的目的是彻底兼容MySQL,包括API和命令行,使之能轻松成为MySQL的代替品。CentOS 7 版本将MySQL数据库软件从默认的程序列表中移除,用mariadb代替了。node
#列出全部被安装的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.56-2.el7.x86_64mysql
mysql下载地址:https://dev.mysql.com/downloads/mysql/sql
下载完以后解压:tar -xf mysql-5.7.21-1.el7.x86_64.rpm-bundle.tar数据库
解压出来的东西:centos
libaio-0.3.109-13.el7.x86_64.rpm 下载地址:http://mirror.centos.org/centos/6/os/x86_64/Packages/libaio-0.3.107-10.el6.x86_64.rpmtcp
安装相互依赖的包要安装顺序安装:ide
rpm -ivh mysql-community-common-*.rpm
rpm -ivh mysql-community-libs-*.rpm
rpm -ivh mysql-community-client-*.rpmpost
rpm -ivh libaio-0.3.107-10.el6.x86_64.rpmui
rpm -ivh mysql-community-server-*.rpmthis
安装最后一步的时候可能会提示缺乏依赖net-toos和perl 使用yum install perl来安装便可。
安装完成以后要先设置一下mysql的登录密码
首先修改/etc/my.cnf来禁用密码,经过mysql -uroot登陆进去后设置新密码,而后再重启一下就能够用新密码正常登陆了。
vi /etc/my.cnf 在最后一行添加skip-grant-tables 保存 退出
重启mysql:systemctl restart mysqld.service
此时便可用mysql -uroot登录
登录以后修改root密码:use mysql;
update user set authentication_string=password("TYU!@#ert") where user="root";//这个密码必定要设置的复杂一点 符合mysql密码强度要求 以避免之后操做的时候 提示密码不符合mysql规则
最后要去vi /etc/my.cnf 将添加的skip-grant-tables 去掉
此时mysql是没法被远程链接的
firewall-cmd --zone=public --add-port=3306/tcp --permanent
firewall-cmd --reload
systemctl stop firewalld.service #中止
systemctl disable firewalld.service #禁用
最后还要容许远程链接
能够经过修改表来实现远程:
mysql -uroot -p
mysql> use mysql;
mysql> update user set host = '%' where user = 'root';
mysql> select host, user from user;
设置完以后要给root帐户设置权限
grant all privileges on *.* to 'root'@'%' identified by 'TYU!@#ert' with grant option;
flush privileges;
这个时候mysql就能够被远程链接 可是 连上以后作任何操做都会提示:
ERROR 1820 (HY000): You must reset your password using ALTER USER statement before executing this statement.
mysql5.7第一次登陆修改root密码
使用下面语句去修改密码:alter user 'root'@'localhost' identified by 'xxx' PASSWORD EXPIRE NEVER account unlock;
有个密码过时,你不指定,就是默认的值是default_password_lifetime指定的360天,须要注意下。
若是设置的密码过于简单会提示:ERROR 1819 (HY000): Your password does not satisfy the current policy requirements
就是密码不符合规则 密码要设置的尽可能复杂 要有数字 大写字母 特殊符号等。