Centos6.5操作系统mysql-5.5安装多实例
MySQL多实例就是在一台机器上开启多个不同的服务端口(如:3306,3307,3308),运行多个MySQL服务进程,通过不同的socket监听不同的服务端口来提供各自的服务。各个实例之间是相互独立的,每个实例的datadir, port, socket, pid都是不同的。
解压软件包
[root@Mysql-server tools]# tar -xvf cmake-2.8.8.tar.gz
[root@Mysql-server tools]# tar -xvf mysql-5.5.32.tar.gz
[root@Mysql-server tools]# ll
总用量 29588
drwxr-xr-x. 9 root root 4096 7月 27 14:43 cmake-2.8.8
-rw-r--r--. 1 root root 5691656 7月 27 14:42 cmake-2.8.8.tar.gz
drwxr-xr-x. 31 7161 wheel 4096 7月 2 2013 mysql-5.5.32
-rw-r--r--. 1 root root 24596474 7月 27 14:42 mysql-5.5.32.tar.gz
安装好需要依赖的包
[root@Mysql-server tools]# yum -y install ncurses-devel
[root@Mysql-server tools]# yum -y install libaio-devel
[root@Mysql-server tools]# yum install gcc-c++
创建用户
[root@Mysql-server tools]# groupadd mysql
[root@Mysql-server tools]# useradd -s /sbin/nologin -g mysql -M mysql
cmake软件
cd /home/oldboy/tools/
tar xf cmake-2.8.8.tar.gz
cd cmake-2.8.8
./configure
最后一行显示如下:
---------------------------------------------
CMake has bootstrapped. Now run gmake.
gmake
gmake install
创建目录
mkdir /application/
解压编译MySQL
tar zxf mysql-5.5.32.tar.gz
cd mysql-5.5.32
cmake . -DCMAKE_INSTALL_PREFIX=/application/mysql-5.5.32 \
-DMYSQL_DATADIR=/application/mysql-5.5.32/data \
-DMYSQL_UNIX_ADDR=/application/mysql-5.5.32/tmp/mysql.sock \
-DDEFAULT_CHARSET=utf8 \
-DDEFAULT_COLLATION=utf8_general_ci \
-DEXTRA_CHARSETS=gbk,gb2312,utf8,ascii \
-DENABLED_LOCAL_INFILE=ON \
-DWITH_INNOBASE_STORAGE_ENGINE=1 \
-DWITH_FEDERATED_STORAGE_ENGINE=1 \
-DWITH_BLACKHOLE_STORAGE_ENGINE=1 \
-DWITHOUT_EXAMPLE_STORAGE_ENGINE=1 \
-DWITHOUT_PARTITION_STORAGE_ENGINE=1 \
-DWITH_FAST_MUTEXES=1 \
-DWITH_ZLIB=bundled \
-DENABLED_LOCAL_INFILE=1 \
-DWITH_READLINE=1 \
-DWITH_EMBEDDED_SERVER=1 \
-DWITH_DEBUG=0
#-- Build files have been written to: /home/oldboy/tools/mysql-5.5.32
提示,编译时可配置的选项很多,具体可参考结尾附录或官方文档:
make
#[100%] Built target my_safe_process
make install
ln -s /application/mysql-5.5.32/ /application/mysql
如果上述操作未出现错误,则MySQL5.5.32软件cmake方式的安装就算成功了。
创建多实例的数据文件目录
[root@Mysql-server application]# mkdir -p /data/{3306,3307}/data