基于CentOS 6.8平台最新源代码包编译安装企业版MariaDB数据库
安装环境
系统:CentOS 6.8 x86_64
MariaDB:enterprise 10.1.16
资源获取
MariaDB企业版下载,访问地址 https://mariadb.com/my_portal/download/mariadb-enterprise 这里需要登录帐号才能下载,可以免费注册。
登录成功后进入MariaDB企业版产品下载页面,这里提供了二进制与源代码等多种安装包。根据实际需求选择版本10.1.16GA,源代码包下载。
确定tar.gz包下载
得到下载地址,复制到CentOS系统里使用wget/curl等工具来下载到/usr/src目录下。
https://downloads.mariadb.com/enterprise/y21n-42b1/mariadb-enterprise/10.1.16/source/mariadb-enterprise-10.1.16.tar.gz
下载完成。
安装过程
安装epel的yum源
rpm -vih http://mirrors.aliyun.com/epel/epel-release-latest-6.noarch.rpm
情况yum缓存,生成新的缓存。
yum clean all
yum makecache
安装必要的软件包
yum install -y ncurses-devel make cmake bison zlib zlib-devel openssl openssl-devel jemalloc gcc gcc-c++
解压安装包,使用cmake配置
tar zxf mariadb-enterprise-10.1.16.tar.gz
cd mariadb-10.1.16/
cmake . -DCMAKE_INSTALL_PREFIX=/usr/local/mysql -DDEFAULT_SYSCONFDIR=/usr/local/mysql/etc -DMYSQL_DATADIR=/usr/local/mysql/data -DMYSQL_TCP_PORT=3306 -DMYSQL_UNIX_ADDR=/usr/local/mysql/mysql.sock -DMYSQL_USER=mysql -DENABLED_LOCAL_INFILE=1 -DEXTRA_CHARSETS=all -DDEFAULT_CHARSET=utf8 -DDEFAULT_COLLATION=utf8_general_ci -DWITH_READLINE=1 -DWITH_SSL=system -DWITH_ZLIB=system -DWITH_LIBWRAP=0
使用make进行编译,由于普通编译时间相当漫长。为了加快编译,这里启用多cpu核心同时工作,-j 4 支持4颗核心cpu同时编译,从而节约时间。
make -j 4
安装
make install
创建MariaDB用户以及相应的目录
useradd -M -s /sbin/nologin mysql
mkdir -p /usr/local/mysql/etc
mkdir -p /usr/local/mysql/log
mkdir -p /usr/local/mysql/run
如果存在/etc/my.cnf文件,请改名或删除。并创建新的配置文件
rm -f /etc/my.cnf
cp support-files/my-large.cnf.sh /usr/local/mysql/etc/my.cnf
编辑配置文件 vi /usr/local/mysql/etc/my.cnf 修改port与socket参数,并在[mysqld]部分添加
log-error = /usr/local/mysql/log/mysqld.log
pid-file = /usr/local/mysql/run/mysqld.pid
修改MariaDB安装目录所有者
chown -R mysql.mysql /usr/local/mysql/
初始化数据库
/usr/local/mysql/scripts/mysql_install_db --user=mysql --basedir=/usr/local/mysql/ --datadir=/usr/local/mysql/data
启动数据库,查看进程情况。
/usr/local/mysql/bin/mysqld_safe &
创建启动脚本文件
cp support-files/mysql.server /etc/init.d/mysql
chmod 755 /etc/init.d/mysql
修改/etc/init.d/mysql
basedir=/usr/local/mysql
datadir=/usr/local/mysql/data
mysqld_pid_file_path=/usr/local/mysql/run/mysqld.pid
添加到chkconfig管理
chkconfig --add mysql
测试脚本启动服务情况
为数据库设置root账户登录密码
/usr/local/mysql/bin/mysqladmin -u root password '3D#d0L7'
登录数据库
/usr/local/mysql/bin/mysql -u'root' -p'3D#d0L7'