一、环境信息: 操作系统版本:CentOS Linux release 7.3.1611 (Core) 内核版本:3.10.0-514.el7.x86_64 MariaDB版本:mariadb-10.2.10 二、安装开发包组工具 查看开发包组是否安装 yum grouplist 设置显示显示方式 localectl set-locale LANG=en_US.UTF-8 安装开发包组工具 yum -y install "Development Tools" 安装依赖包 yum -y install ncurses-devel openssl-devel libevent-devel jemallloc-devel cmake 三、编译安装MariaDB groupadd -r mysql useradd -g mysql -r -d /database mysql tar xf mariadb-10.2.10.tar.gz cd mariadb-10.2.10 cmake . -DCMAKE_INSTALL_PREFIX=/usr/local/mariadb-10.2.10 -DMYSQL_DATADIR=/database/data -DSYSCONFDIR=/etc -DWITH_INNOBASE_STORAGE_ENGINE=1 -DWITH_ARCHIVE_STORAGE_ENGINE=1 -DWITH_BLACKHOLE_STORAGE_ENGINE=1 -DWITH_READLINE=1 -DWITH_SSL=system -DWITH_ZLIB=system -DWITH_LIBWRAP=0 -DMYSQL_UNIX_ADDR=/tmp/mysql.sock -DDEFAULT_CHARSET=utf8 -DDEFAULT_COLLATION=utf8_general_ci make make install cmake指定编译选项的方式不同于make,其实现方式对比如下: ./configure cmake . ./configure --help cmake . -LH or ccmake . 指定安装文件的安装路径时常用的选项: -DCMAKE_INSTALL_PREFIX=/usr/local/mysql -DMYSQL_DATADIR=/database/data -DSYSCONFDIR=/etc 默认编译的存储引擎包括:csv、myisam、myisammrg和heap。若要安装其它存储引擎,可以使用类似如下编译选项: -DWITH_INNOBASE_STORAGE_ENGINE=1 -DWITH_ARCHIVE_STORAGE_ENGINE=1 -DWITH_BLACKHOLE_STORAGE_ENGINE=1 -DWITH_FEDERATED_STORAGE_ENGINE=1 若要明确指定不编译某存储引擎,可以使用类似如下的选项: -DWITHOUT_<ENGINE>_STORAGE_ENGINE=1 比如: -DWITHOUT_EXAMPLE_STORAGE_ENGINE=1 -DWITHOUT_FEDERATED_STORAGE_ENGINE=1 -DWITHOUT_PARTITION_STORAGE_ENGINE=1 如若要编译进其它功能,如SSL等,则可使用类似如下选项来实现编译时使用某库或不使用某库: -DWITH_READLINE=1 -DWITH_SSL=system -DWITH_ZLIB=system -DWITH_LIBWRAP=0 其它常用的选项: -DMYSQL_TCP_PORT=3306 -DMYSQL_UNIX_ADDR=/tmp/mysql.sock -DENABLED_LOCAL_INFILE=1 -DEXTRA_CHARSETS=all -DDEFAULT_CHARSET=utf8 -DDEFAULT_COLLATION=utf8_general_ci -DWITH_DEBUG=0 -DENABLE_PROFILING=1 如果想清理此前的编译所生成的文件,则需要使用如下命令: make clean rm CMakeCache.txt 四、配置MariaDB 1、编辑service文件: vim /etc/systemd/system/mariadb.service 加入如下内容:
[Unit] Description=MariaDB server and services After=syslog.target After=network.target [Service] Type=simple User=mysql Group=mysql ExecStart=/usr/local/mysql/bin/mysqld_safe --basedir=/usr/local/mysql TimeoutSec=300 PrivateTmp=false [Install] WantedBy=multi-user.target
2、重载systemd管理器配置: systemctl daemon-reload 3、创建mysql目录并授权给mysql用户和组 mkdir -pv /database/data chown mysql.mysql /database/data 4、创建mysql的连接文件 cd /usr/local ln -sv mariadb-10.2.10 mysql 5、复制support-files/my-large.cnf到/etc/my.cnf cd mariadb-10.2.10/ cp support-files/my-large.cnf /etc/my.cnf 6、编辑配置文件将datadir修改为/database/data vim /etc/my.cnf 加入: datadir = /database/data 7、配置mysql工作目录的权限 cd /usr/local/mariadb-10.2.10 chown root.mysql ./ -R 8、初始化数据库 scripts/mysql_install_db --user=mysql --datadir=/database/data 9、启动mysql服务 systemctl start mariadb.service systemctl status mariadb.service 10、设置开机自启动 systemctl enable mariadb.service
时间: 2024-10-09 22:05:59