mariadb的目的是完全兼容mysql,包括api和命令行,使之能轻松成为mysql的代替品。在存储引擎方面,使用xtradb来代替mysql的innodb。
mariadb由mysql的创始人麦克尔·维德纽斯主导开发,他早前曾以10亿美元的价格,将自己创建的公司mysql ab卖给了sun,此后,随着sun被甲骨文收购,mysql的所有权也落入oracle的手中。mariadb名称来自麦克尔·维德纽斯的女儿玛丽亚(英语:maria)的名字
1.设置yum源
参考:https://downloads.mariadb.org/mariadb/repositories/
选择操作系统的类型、版本、mariadb的版本,会自动生成yum源
# mariadb 5.5 redhat repository list - created 2014-02-20 01:40 utc
# http://mariadb.org/mariadb/repositories/
[mariadb]
name = mariadb
baseurl = http://yum.mariadb.org/5.5/rhel6-amd64
gpgkey=https://yum.mariadb.org/rpm-gpg-key-mariadb
gpgcheck=1
2.安装mariadb(installing mariadb with yum)
参考:https://mariadb.com/kb/en/installing-mariadb-with-yum/
yum install mariadb-server mariadb-client
yum remove mariadb-galera-server
yum install mariadb-galera-server mariadb-client galera
3.启动
/etc/init.d/mysql start
4.手工导入mariadb signing key
rpm --import https://yum.mariadb.org/rpm-gpg-key-mariadb
5.卸载mariadb
rpm -aq|grep -i mariadb|xargs rpm -e --nodeps
如果报:running transaction
error in preun scriptlet in rpm package mariadb-server
mariadb-server-5.5.35-1.x86_64 was supposed to be removed but is not!
需要运行如下命令:
rpm -u --noscripts mariadb-server-5.5.35-1.x86_64
rm -rf /var/lib/mysql*
rm -rf /usr/share/mysql*
rm -rf /etc/rc.d/init.d/mysql
rm -rf /etc/my.cnf
6.修改root初始密码
mysqladmin -u root password 'root'
7.删除空用户,增强安全
delete from mysql.user where user='';
刷新权限表,以便可以使更改立即生效。
flush privileges;
8.远程登录配置
grant all privileges on *.* to root@'%' identified by 'root' ;
9.修改数据库目录
由于mysql数据库目录占用磁盘比较大,而mysql默认的数据文件存储目录为/"var/lib/mysql",所以我们要把目录移到"/data"根目录下的"mysqldata"目录中
cd /data
mkdir mysqldata
把mysql服务进程停掉
service mysql stop
或
mysqladmin -u root -p shutdown
复制数据库目录
把mysql的数据文件移动到了"/data/mysqldata/mysql"下
mv /var/lib/mysql /data/mysqldata
修改my.conf文件
如果"/etc/"目录下没有my.cnf配置文件,请到"/usr/share/mysql/"下找到*.cnf文件,拷贝其中一个合适的配置文件到"/etc/"并改名为"my.cnf"中
cp /usr/share/mysql/my-default.cnf /etc/my.cnf
修改后的内容如下:
[client]
port = 3306
socket = /data/mysqldata/mysql/mysql.sock
default-character-set=utf8
[mysqld]
socket = /data/mysqldata/mysql/mysql.sock
datadir = /data/mysqldata/mysql
character-set-server=utf8
lower_case_table_names=1
sql_mode=no_engine_substitution,strict_trans_tables
vim /etc/rc.d/init.d/mysql
datadir=/data/mysqldata/mysql
启动mysql(如果不能启动,打开/etc/selinux/config,把selinux=enforcing改为selinux=disabled后存盘退出重启机器试试,必须要重启)
service mysql start
注意:aria存储引擎的一些配置,如aria_pagecache_buffer_size
相关的参数可以通过命令查到:show variables like '%aria%'
10. java源代码样例