开发者社区> 刘小四> 正文

MySQL 多实例安装

简介: 在生产中有时候会遇到一台主机要运行多个MySQL服务器----叫做多实例 下面演示多实例的安装 首先我们规划下 基于二进制安装 1、创建mysql用户 useradd -r -s /sbin/nologin -d /app/mysql -m mysql # # 2、解压下载的二进制mariadb包 tar xvf mariadb-10.
+关注继续查看



在生产中有时候会遇到一台主机要运行多个MySQL服务器----叫做多实例

下面演示多实例的安装

首先我们规划下

image

基于二进制安装

1、创建mysql用户

useradd -r -s /sbin/nologin -d /app/mysql -m mysql
#
#


2、解压下载的二进制mariadb包

tar xvf mariadb-10.2.16-linux-x86_64.tar.gz -C /usr/local/
#
#

3、创建软连接

cd /usr/local/
#
ln -s mariadb-10.2.16-linux-x86_64/ mysql
#

4、修改权限

chown -R root.mysql /usr/local/mysql/
#
#

5、环境变量(少了这步也可)

vim /etc/profile.d/mysql.sh
# 
. /etc/profile.d/mysql.sh
#

如果你已经二进制安装了mariadb包,可以从以下开始

指定数据库位置并初始化数据库

1、创建规划图上的目录

mkdir /mysqldb/{3306,3307,3308}/{etc,bin,data,pid,socket,log} -pv
#
#

2、更改主目录mysqldb的属性

chown -R mysql.mysql /mysqldb/
#

3、3306端口

cd /usr/local/mysql/
#
scripts/mysql_install_db  --datadir=/mysqldb/3306/data --user=mysql
#

4、3307端口

scripts/mysql_install_db  --datadir=/mysqldb/3307/data --user=mysql
#

5、3308端口

scripts/mysql_install_db  --datadir=/mysqldb/3308/data --user=mysql
#


修改配置文件

1、复制配置文件

cp /etc/my.cnf /mysqldb/3306/etc/
#

2、编辑配置文件

vim /mysqldb/3306/etc/my.cnf 
#

image

3、把上面的配置文件当模板传送给3307、3308

cp /mysqldb/3306/etc/my.cnf  /mysqldb/3307/etc/
cp /mysqldb/3306/etc/my.cnf  /mysqldb/3308/etc/
#

4、更改07、08配置文件的端口

sed -i 's/3306/3307/g' /mysqldb/3307/etc/my.cnf 
sed -i 's/3306/3308/g' /mysqldb/3308/etc/my.cnf 
#


启动程序

1、把事先编写的启动脚本复制到06、07、08的bin目录下

cp /root/mysqld /mysqldb/3306/bin/
cp /root/mysqld /mysqldb/3307/bin/
cp /root/mysqld /mysqldb/3308/bin/
#

2、更改7、8的启动脚本进程号为自己的

vim /mysqldb/3307/bin/mysqld
#07的改为3307
vim /mysqldb/3308/bin/mysqld
#08的改为3308

image

3、给启动脚本加执行权限

chown +x /mysqldb/3306/bin/mysqld 
chmod +x /mysqldb/3306/bin/mysqld 
chmod +x /mysqldb/3307/bin/mysqld 
chmod +x /mysqldb/3308/bin/mysqld
#

4、启动服务脚本

/mysqldb/3306/bin/mysqld start
#
/mysqldb/3307/bin/mysqld start
#
/mysqldb/3308/bin/mysqld start

5、ss -ntl查看

image

数据库加固

1、给数据库root用户加密码

mysqladmin  -S /mysqldb/3306/socket/mysql.sock password 'centos'
mysqladmin  -S /mysqldb/3307/socket/mysql.sock password 'centos'
mysqladmin  -S /mysqldb/3308/socket/mysql.sock password 'centos'

2、进入数据库删除匿名登陆

mysql -S /mysqldb/3306/socket/mysql.sock -uroot -p
#
select user,host from mysql.user;
#查看有哪些用户
delete from mysql.user where user='';
#删除匿名用户


OK

exit 重新进入 ,如果不行,就重启下服务

附加启动脚本代码

#!/bin/bash

port=3306
mysql_user="root"
mysql_pwd=""
cmd_path="/usr/local/bin"
mysql_basedir="/mysqldb"
mysql_sock="${mysql_basedir}/${port}/socket/mysql.sock"

function_start_mysql()
{
    if [ ! -e "$mysql_sock" ];then
      printf "Starting MySQL...\n"
      ${cmd_path}/mysqld_safe --defaults-file=${mysql_basedir}/${port}/etc/my.cnf  &> /dev/null  &
    else
      printf "MySQL is running...\n"
      exit
    fi
}


function_stop_mysql()
{
    if [ ! -e "$mysql_sock" ];then
       printf "MySQL is stopped...\n"
       exit
    else
       printf "Stoping MySQL...\n"
       ${cmd_path}/mysqladmin -u ${mysql_user} -p${mysql_pwd} -S ${mysql_sock} shutdown
   fi
}


function_restart_mysql()
{
    printf "Restarting MySQL...\n"
    function_stop_mysql
    sleep 2
    function_start_mysql
}

case $1 in
start)
    function_start_mysql
;;
stop)
    function_stop_mysql
;;
restart)
    function_restart_mysql
;;
*)
    printf "Usage: ${mysql_basedir}/${port}/bin/mysqld {start|stop|restart}\n"
esac

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
阿里云ECS云服务器初始化设置教程方法
阿里云ECS云服务器初始化是指将云服务器系统恢复到最初状态的过程,阿里云的服务器初始化是通过更换系统盘来实现的,是免费的,阿里云百科网分享服务器初始化教程: 服务器初始化教程方法 本文的服务器初始化是指将ECS云服务器系统恢复到最初状态,服务器中的数据也会被清空,所以初始化之前一定要先备份好。
14328 0
阿里云服务器如何登录?阿里云服务器的三种登录方法
购买阿里云ECS云服务器后如何登录?场景不同,阿里云优惠总结大概有三种登录方式: 登录到ECS云服务器控制台 在ECS云服务器控制台用户可以更改密码、更换系.
30390 0
Amazon EC2安装mysql多实例并配置主从复制
版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/qq1010885678/article/details/47955717 1、My...
1306 0
阿里云服务器端口号设置
阿里云服务器初级使用者可能面临的问题之一. 使用tomcat或者其他服务器软件设置端口号后,比如 一些不是默认的, mysql的 3306, mssql的1433,有时候打不开网页, 原因是没有在ecs安全组去设置这个端口号. 解决: 点击ecs下网络和安全下的安全组 在弹出的安全组中,如果没有就新建安全组,然后点击配置规则 最后如上图点击添加...或快速创建.   have fun!  将编程看作是一门艺术,而不单单是个技术。
21338 0
阿里云服务器怎么设置密码?怎么停机?怎么重启服务器?
如果在创建实例时没有设置密码,或者密码丢失,您可以在控制台上重新设置实例的登录密码。本文仅描述如何在 ECS 管理控制台上修改实例登录密码。
23639 0
MySQL 技术篇-mysql数据库的安装、配置与使用实例演示
MySQL 技术篇-mysql数据库的安装、配置与使用实例演示
33 0
阿里云ECS云服务器初始化设置教程方法
阿里云ECS云服务器初始化是指将云服务器系统恢复到最初状态的过程,阿里云的服务器初始化是通过更换系统盘来实现的,是免费的,阿里云百科网分享服务器初始化教程: 服务器初始化教程方法 本文的服务器初始化是指将ECS云服务器系统恢复到最初状态,服务器中的数据也会被清空,所以初始化之前一定要先备份好。
16701 0
+关注
刘小四
记忆是掌心的水,不伦你摊开还是握紧,终究还是会从指缝中一滴一滴流淌干净。只是,那水的凉意。却是可以让人始终无法忘记。
23
文章
0
问答
文章排行榜
最热
最新
相关电子书
更多
JS零基础入门教程(上册)
立即下载
性能优化方法论
立即下载
手把手学习日志服务SLS,云启实验室实战指南
立即下载