代码改变世界

多配置文件部署mysql单机多实例

  abce  阅读(354)  评论(0编辑  收藏  举报

1.安装gcc-c++、ncurses依赖包

1
# yum install gcc-c++  ncurses-devel

2.安装cmake,用来编译mysql

1
2
3
4
5
6
7
8
# tar -xvf cmake-3.2.0-.tar.gz
# mv cmake-3.2.0 cmake
# mv cmake /tmp/
# cd /tmp/cmake/
# ./bootstrap
# make
# make install
# cmake --version

3.安装bison

1
2
3
4
5
6
7
8
# tar -xvf bison-3.0.tar.gz
# mv bison-3.0 bison
# mv bison /tmp
# cd /tmp/bison/
# ./cofigure
# make
# make install
# bison --version

4.创建mysql用户

1
2
# /usr/sbin/groupadd mysql
# useradd -s /sbin/nologin -g  mysql -M mysql

5.编译安装

配置

1
2
3
4
5
6
7
8
9
10
11
# cmake -DCMAKE_INSTALL_PREFIX=/usr/local/mysql \
-DMYSQL_UNIX_ADDR=/tmp/mysqld.sock \
-DDEFAULT_CHARSET=utf8 \
-DDEFAULT_COLLATION=utf8_general_ci \
-DEXTRA_CHARSETS=all \
-DWITH_EXTRA_CHARSETS:STRING=utf8,gbk \
-DWITH_MYISAM_STORAGE_ENGINE=1 \
-DWITH_INNOBASE_STORAGE_ENGINE=1 \
-DENABLED_LOCAL_INFILE=1 \
-DMYSQL_TCP_PORT=3306 \
-DMYSQL_USER=mysql \

生成可执行文件

1
# make

安装

1
# make install

6.创建多实例的数据文件目录

1
2
3
4
5
6
7
8
9
10
11
12
# mkdir -p /data/{3306,3307}/data/
# mkdir -p /data/{3306,3307}/log/
# tree /data
/data                            #多实例的根目录
├── 3306                         #3306实例的根目录
│   ├── data                     #3306实例的数据目录
│   └── log                      #3306实例的日志目录
│   └── tmp                      #3306实例的临时文件目录
└── 3307                         #3307实例的根目录
    ├── data                     #3307实例的数据目录
    └── log                      #3307实例的日志目录
    └── tmp                      #3307实例的临时文件目录

data  - 存放数据文件:数据,索引,二进制日志(bin log),重放日志(replay log)。
log    - 存放日志文件:慢查询日志,错误日志。
tmp  - 存放临时文件:进程ID文件。

7.配置多实例的配置文件
为每个实例建立一个配置文件

8.配置mysql命令的环境变量

方法一:

1
# echo 'export PATH=/usr/local/mysql/bin:$PATH' >> /etc/profile<br><br># source /etc/profile

方法二:
把/usr/local/mysql/bin/下面的命令拷贝到全局系统命令路径/usr/local/sbin/下,或者做个link

9.初始化数据库,创建基础的数据库文件

1
2
3
4
5
# cd /usr/local/mysql/scripts/
 
#./mysql_install_db --defaults-file=/data/3306/my.cnf --user=mysql --basedir=/usr/local/mysql
 
#./mysql_install_db --defaults-file=/data/3307/my.cnf --user=mysql --basedir=/usr/local/mysql

10.配置多实例的文件权限
授权mysql用户和组管理多实例目录/data

1
# chown -R mysql.mysql /data

11.启动

1
2
3
# mysqld_safe --defaults-file=/data/3306/my.cnf 2>&1 > /dev/null &
 
# mysqld_safe --defaults-file=/data/3307/my.cnf 2>&1 > /dev/null &

12.修改的root用户的密码并且限制只能本机登陆

1
2
3
# mysqladmin -S /data/3306/tmp/mysql.sock -u root -h 'localhost' password 'xxxx'
 
# mysqladmin -S /data/3307/tmp/mysql.sock -u root -h 'localhost' password 'xxxx'

13.使用root用户登陆

1
2
3
# mysql -S  /data/3306/tmp/mysql.sock -u root -p
 
# mysql -S  /data/3307/tmp/mysql.sock -u root -p

14.停止实例

1
2
3
# mysqladmin -S /data/3306/tmp/mysql.sock -u root -p shutdown
 
# mysqladmin -S /data/3307/tmp/mysql.sock -u root -p shutdown

  

编辑推荐:
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
阅读排行:
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· .NET10 - 预览版1新功能体验(一)
点击右上角即可分享
微信分享提示