作者:lianghc
在yum安装MariaDB后,有一个实例在使用中,现在想新增一个实例,一般的教程都是在安装mysql的时候直接一次性装好多个实例,那如何新增一个实例并保留原来的实例呢?
在创建多实例之前,先搞清楚yum安装好的mariadb的目录结构:1、数据库目录
/var/lib/mysql/
2、配置文件
/usr/share/mysql(mysql.server命令及配置文件)mysql5.5之后的默认安装路径,mysql5.5之前的是/usr/local/mysql
3、相关命令
/usr/bin(mysqladmin mysqldump等命令)
4、启动脚本
/etc/rc.d/init.d/(启动脚本文件mysql的目录)
此时启动,关闭mysql 可以用:
/etc/init.d/mysql start/stop
或
service mariadb start/stop
一般的安装多实例基本步骤总结(参考http://blog.csdn.net/permike/article/details/51957003 博文):
1. 新建数据目录2. 创建用户,给数据目录授权(最好不要再已经存在的其他用户下创建数据目录)
3. 初始化数据库
4. 创建配置文件
5. 创建自动启动文件
(备注:创建启动文件这一步可有可无,因为可以通过命令来搞定 mysqld_safe --defaults-file=/data/dbdata_${mysql_port}/my.cnf 2>&1 > /dev/null & )
在/home目录下创建multimysql文件夹
[root@ddw ~]# mkdir /home/multimysql
在里面创建etc,socket,bin,datadir这四个文件夹备用
[root@ddw ~]# mkdir /home/multimysql/{etc,socket,bin,datadir}
#在datadir中新增一个实例的数据文件:3307
[root@ddw ~]# mkdir /home/multimysql/datadir/3307
对/home/multimysql进行递归授权防止之后的操作出现权限不够的情况,否则容易出现错误:[ERROR] mysqld: Can't create/write to file '/opt/userhome/icwork/multimysql/datadir3307/aria_log_control' (Errcode: 13 "Permission denied")
[root@ddw ~]# chmod -R 777 /home/multimysql/
[root@ddw ~]# chown -R mysql:mysql /home/multimysql/
用mysql_install_db来生成即将使用的多个实例的数据文件
[root@ddw ~]# mysql_install_db --basedir=/usr --datadir=/home/multimysql/datadir/3307 --user=mysql
1、basedir 参数
原文说明为:
Path to installation directory. All paths are usually resolved relative to this.
解释:
该参数指定了安装 MySQL