二、Mariadb数据库安装
MariaDB数据库管理系统是MySQL的一个分支,主要由开源社区在维护,采用GPL授权许可 MariaDB的目的是完全兼容MySQL,包括API和命令行,使之能轻松成为MySQL的代替品。在存储引擎方面,使用XtraDB(英语:XtraDB)来代替MySQL的InnoDB。 MariaDB由MySQL的创始人Michael Widenius(英语:Michael Widenius)主导开发,他早前曾以10亿美元的价格,将自己创建的公司MySQL AB卖给了SUN,此后,随着SUN被甲骨文收购,MySQL的所有权也落入Oracle的手中。MariaDB名称来自Michael Widenius的女儿Maria的名字。
1.下载
(1.1)下载地址 https://downloads.mariadb.org/ , 选择压缩版下载,然后传到服务器上。
(1.2)或者找到具体的链接,然后在服务器上直接下载。
wget https://downloads.mariadb.com/MariaDB/mariadb-10.2.6/bintar-linux-glibc_214-x86_64/mariadb-10.2.6-linux-glibc_214-x86_64.tar.gz
2.解压缩
注意:不要事先在/usr/local/下创建mariadb目录
将下载的压缩文件解压缩
tar -xzvf mariadb-10.2.6-linux-glibc_214-x86_64.tar.gz
将解压缩的文件移动到/usr/local/mariadb下
mv mariadb-10.2.6-linux-glibc_214-x86_64 /usr/local/mariadb
3.备份原有mysql配置
将/etc/my.cnf名字修改为my.cnf.bak
mv /etc/my.cnf /etc/my.cnf.bak
4.修改配置文件
复制support-files/my-small.cnf 到/etc/my.cnf
cp support-files/my-small.cnf /etc/my.cnf
编辑配置文件
在my.cnf中添加如下内容:
5.创建用户组
添加mysql用户组
groupadd mysql
给mysql组下添加mysql用户
useradd -r -g mysql -s /sbin/nologin mysql
改变文件所有者和所属组
chown -R mysql /usr/local/mariadb/
chgrp -R mysql /usr/local/mariadb/
6.初始化安装
./scripts/mysql_install_db --user=mysql --datadir=/data/mariadb
初始化一直报错,都是和my_print_defaults有关,有可能与glibc有关,或者是系统与数据库的版本不匹配。
使用命令,ldd --version ,发现自己的是2.12 ,与下载的2.14不匹配,此时要么升级glibc,要么选择合适的maridb版本,这里我选择升级下载2.14版本的glibc
解决libc.so.6: version `GLIBC_2.14' not found问题
1、[root@host src]# wget http://ftp.gnu.org/gnu/glibc/glibc-2.14.tar.gz
2、[root@host src]# tar -zxvf glibc-2.14.tar.gz
3、[root@host src]# cd glibc-2.14
4、[root@host glibc-2.14]# mkdir build
[root@host glibc-2.14]# cd build/
5、[root@host build]# ../configure --prefix=/usr/local/glibc-2.14
6
[root@host build]# make -j4
[root@host build]# make install
7、
[root@host build]# cd /usr/local/glibc-2.14/lib
[root@host build]# cp libc-2.14.so /lib64/
8、
[root@host build]# cd /lib64
9、
[root@host build]# /sbin/sln libc-2.14.so /lib64/libc.so.6
7.改变文件所有者和所属组
chown -R root .
chown -R mysql data/
8.启动脚本
bin/mysqld_safe --user=mysql &
9.将服务添加到系统服务中
cp support-files/mysql.server /etc/init.d/mysqld
第一次安装需要启动服务:/etc/init.d/mysqld start
设置自启动:chkconfig mysqld on
查看服务启动状态:
service mysqld status (6版本)
systemctl status mysqld.service(7版本)
10.修改root密码
./bin/mysql
set password for root@localhost = password(‘123456’);
发现没有mysql命令??
原因:这是由于系统默认会查找/usr/bin下的命令,如果这个命令不在这个目录下,当然会找不到命令,我们需要做的就是映射一个链接到/usr/bin目录下,相当于建立一个链接文件。
首先得知道mysql命令或mysqladmin命令的完整路径,比如mysql的路径是:/usr/local/mariadbl/bin/mysql,我们则可以这样执行命令:
# ln -s /usr/local/mariadb/bin/mysql /usr/bin