2. MySQL 多实例

重点:

MySQL 的 三种安装方式:包安装,二进制安装,源码编译安装。

MySQL 的 基本使用

MySQL 多实例

DDLcreate alter drop

DML insert update delete

DQL select

2.5)通用 二进制格式安装 MySQL

2.5.1)实战案例:通用 二进制格式安装 MySQL 5.6( 手动安装 )

官网下载二进制格式安装包

下载链接:MySQL :: Download MySQL Community Server (Archived Versions)

2.5.1.1)准备用户

// 创建用户组与用户

groupadd -r -g 306 mysql

useradd -r -g 306 -u 306 -d /data/mysql mysql

2.5.1.2)准备数据目录,建议使用逻辑卷

// 可选做, 后面的脚本 mysql_install_db 可自动生成此目录

// 创建目录

mkdir /data/mysql -p

chown mysql:mysql /data/mysql

2.5.1.3)准备二进制程序

官方:MySQL :: Download MySQL Community Server (Archived Versions)

国内:Index of /MySQL/Downloads/MySQL-5.6/

国内:Index of mysql-local/Downloads/MySQL-5.6

// 例如: mysql-5.6.50-linux-glibc2.12-x86_64.tar.gz

// 解压压缩包

tar xf mysql-VERSION-linux-glibc2.12-x86_64.tar.gz -C /usr/local


// 创建软链接

cd /usr/local && ln -sv mysql-VERSION mysql

chown -R root:root /usr/local/mysql/

2.5.1.4)准备配置文件

// 拷贝模板配置文件

cd /usr/local/mysql

cp -b support-files/my-default.cnf /etc/my.cnf

vim /etc/my.cnf


// mysql 语句块中添加以下三个选项

[mysqld]

datadir = /data/mysql          # 数据存放目录

innodb_file_per_table = on     # 在 mariadb5.5 以上版的是默认值, 可不加

skip_name_resolve = on         # 禁止主机名解析, 建议使用

2.5.1.5)创建数据库文件

// "报错解决"

yum install perl-Data-Dumper.x86_64 -y

cd /usr/local/mysql/


// 执行脚本    ( "可能会出现报错情况" )

./scripts/mysql_install_db --datadir=/data/mysql --user=mysql


// 验证

[root@centos7 mysql] ls /data/mysql/ -l        ( 默认存放在 /var/lib/mysql 目录 )

total 110604

-rw-rw---- 1 mysql mysql 12582912 Jun  1 16:44 ibdata1

-rw-rw---- 1 mysql mysql 50331648 Jun  1 16:44 ib_logfile0

-rw-rw---- 1 mysql mysql 50331648 Jun  1 16:44 ib_logfile1

drwx------ 2 mysql mysql     4096 Jun  1 16:44 mysql

drwx------ 2 mysql mysql     4096 Jun  1 16:44 performance_schema

drwx------ 2 mysql mysql     4096 Jun  1 16:44 test

2.5.1.6)准备服务脚本,并启动服务

// 配置开机自启服务

cp /usr/local/mysql/support-files/mysql.server /etc/init.d/mysqld

chkconfig --add mysqld

service mysqld start


// 如果有对应的 service 文件可以执行下面

cp /usr/local/mysql/support-files/systemd/mariadb.service

/usr/lib/systemd/system/

systemctl daemon-reload

systemctl enable --now mariadb

2.5.1.7)定义 PATH 路径

echo 'PATH=/usr/local/mysql/bin:$PATH' > /etc/profile.d/mysql.sh

bash /etc/profile.d/mysql.sh


// "推荐"

echo 'PATH=/usr/local/mysql/bin:$PATH' > /etc/profile

source /etc/profile

2.5.1.8)安全初始化

mysql_secure_installation

回车

y

输入密码

重复密码

y

y

y

y

mysql -uroot -pP@ssw0rd123456

2.5.2)实战案例:一键安装 mysql-5.6 二进制包 脚本

2.5.2.1)( 在线安装 ) mysql-5.6 二进制包 脚本

// 1. 编写脚本

[root@centos7 ~] vim install_mysql5.6.sh

#!/bin/bash

. /etc/init.d/functions

DIR=`pwd`

MYSQL_VERSION=5.6.51

NAME="mysql-${MYSQL_VERSION}-linux-glibc2.12-x86_64.tar.gz"

FULL_NAME=${DIR}/${NAME}

# URL=http://mirrors.163.com/mysql/Downloads/MySQL-5.6

URL=https://ftp.ntu.edu.tw/MySQL/Downloads/MySQL-5.6/

# URL=https://mirrors.huaweicloud.com/mysql/Downloads/MySQL-5.6/

DATA_DIR="/data/mysql"


rpm -q wget || yum -y -q install wget

wget $URL/$NAME || { action "下载失败,异常退出" false;exit 10; }

yum install -y -q libaio perl-Data-Dumper autoconf

if [ -f ${FULL_NAME} ];then

    action "安装文件存在"

else

    action "安装文件不存在" false

    exit 3

fi


if [ -e /usr/local/mysql ];then

    action "Mysql 已经安装" false

    exit 3

else

    tar xf ${FULL_NAME} -C /usr/local/src

    ln -sv /usr/local/src/mysql-${MYSQL_VERSION}-linux-glibc2.12-x86_64 /usr/local/mysql

    if id mysql;then

        action "mysql 用户已经存在,跳过创建用户过程"

    else

        useradd -r -s /sbin/nologin mysql

    fi


    if id mysql;then

        chown -R mysql.mysql /usr/local/mysql/*

        if [ ! -d /data/mysql ];then

            mkdir -pv /data/mysql && chown -R mysql.mysql /data 

            /usr/local/mysql/scripts/mysql_install_db --user=mysql --datadir=/data/mysql --basedir=/usr/local/mysql/

            cp /usr/local/src/mysql-${MYSQL_VERSION}-linux-glibc2.12-x86_64/support-files/mysql.server /etc/init.d/mysqld

            chmod a+x /etc/init.d/mysqld

cat > /etc/my.cnf <<EOF

[mysqld]

socket=/data/mysql/mysql.sock

user=mysql

symbolic-links=0

datadir=/data/mysql

innodb_file_per_table=1

[client]

port=3306

socket=/data/mysql/mysql.sock

[mysqld_safe]

log-error=/var/log/mysqld.log

pid-file=/tmp/mysql.sock

EOF

            ln -sv /usr/local/mysql/bin/mysql /usr/bin/mysql

            /etc/init.d/mysqld start

            chkconfig --add mysqld

        else

            action "MySQL数据目录已经存在" false

            exit 3

        fi

    fi

fi


// 2. 运行脚本

[root@centos7 ~] bash install_mysql5.6.sh


// 3. 验证

[root@centos7 ~] cat /etc/my.cnf

[mysqld]

socket=/data/mysql/mysql.sock

user=mysql

symbolic-links=0

datadir=/data/mysql

innodb_file_per_table=1

[client]

port=3306

socket=/data/mysql/mysql.sock

[mysqld_safe]

log-error=/var/log/mysqld.log

pid-file=/tmp/mysql.sock


[root@centos7 ~] ls

install_mysql5.6.sh my.cnf mysql-5.6.47-linux-glibc2.12-x86_64.tar.gz

// 验证服务

netstat -nltp



// 登录

mysql

2.5.2.2)离线安装 mysql-5.6 二进制包的脚本

( 离线安装 ) mysql-5.6 二进制包的脚本

// 准备安装包, 脚本和 my.cnf 配置文件, "放在同一目录下"

[root@centos8 ~] vim install_mysql-5.6.sh

#!/bin/bash

# wget https://downloads.mysql.com/archives/get/p/23/file/mysql-5.6.50-linux-glibc2.12-x86_64.tar.gz

DIR=`pwd`

NAME="/mysql-5.6.50-linux-glibc2.12-x86_64.tar.gz"

FULL_NAME=${DIR}/${NAME}

DATA_DIR="/data/mysql"

 

yum install libaio perl-devel ncurses-compat-libs -y

# CentOS8 需要安装 ncurses-compat-libs 包提供 libncurses.so.5 库

 

if [ -f ${FULL_NAME} ];then

    echo "install file is exist"

else

    echo "install file isn't exist"

    exit 3

fi

 

if [ -h /usr/local/mysql ];then

    echo "MySQL already install"

    exit 3

else

    tar xvf ${FULL_NAME} -C /usr/local/src/

    ln -sv /usr/local/src/mysql-5.6.50-linux-glibc2.12-x86_64 /usr/local/mysql

    if id mysql;then

        echo "mysql user is exist,skip create user"

    else

        useradd -r -u 306 -d /data/mysql mysql

    fi

 

    if id mysql;then

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

        if [ ! -d /data/mysql ];then

            mkdir -pv /data/mysql && chown -R mysql.mysql /data/mysql/

            /usr/local/mysql/scripts/mysql_install_db --user=mysql --datadir=/data/mysql -basedir=/usr/local/mysql

            cp /usr/local/mysql/support-files/mysql.server /etc/init.d/mysqld

            chmod a+x /etc/init.d/mysqld

            cp ${DIR}/my.cnf /etc/my.cnf

            ln -sv /usr/local/mysql/bin/mysql /usr/bin/mysql

            /etc/init.d/mysqld start

            chkconfig --add mysqld

        else

            echo "MySQL data dir already exist"

            exit 3

        fi

    fi

fi


[root@centos8 ~] vim my.cnf

[mysqld]

socket=/data/mysql/mysql.sock

user=mysql

symbolic-links=0

datadir=/data/mysql

innodb_file_per_table=1

[client]

port=3306

socket=/data/mysql/mysql.sock

[mysqld_safe]

log-error=/var/log/mysqld.log

pid-file=/tmp/mysql.sock


[root@centos8 ~] ls

[root@centos8 ~] bash install_mysql-5.6.sh

2.5.3)实战案例:通用 二进制安装 MySQL 5.7 和 MySQL8.0

2.5.3.1)安装相关包( 手动安装 )

报错解决:mysql: error while loading shared libraries: libncurses.so.5: cannot open shared object file-CSDN博客

yum install libncurses* -

yum install libaio numactl-libs -y

2.5.3.2)用户和组

groupadd mysql

useradd -r -g mysql -s /bin/false mysql

2.5.3.3)准备程序文件

国内:mysql-MySQL-5.7安装包下载_开源镜像站-阿里云

// 下载 MySQL 二进制包

wget https://mirrors.aliyun.com/mysql/MySQL-5.7/mysql-5.7.36-linux-glibc2.12-x86_64.tar.gz



// 解压

tar xf mysql-5.7.36-linux-glibc2.12-x86_64.tar.gz -C /usr/local



// 软链接

cd /usr/local/ && ln -s mysql-5.7.36-linux-glibc2.12-x86_64/ mysql

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

2.5.3.4)准备环境变量

echo 'PATH=/usr/local/mysql/bin:$PATH' > /etc/profile.d/mysql.sh

bash /etc/profile.d/mysql.sh



"推荐"

echo 'PATH=/usr/local/mysql/bin:$PATH' > /etc/profile

source /etc/profile

2.5.3.5)准备配置文件

cp /etc/my.cnf{,.bak}


vim /etc/my.cnf

[mysqld]

datadir=/data/mysql

skip_name_resolve=1

socket=/data/mysql/mysql.sock        

log-error=/data/mysql/mysql.log

pid-file=/data/mysql/mysql.pid


[client]

socket=/data/mysql/mysql.sock

2.5.3.6)初始化数据库文件并提取 root 密码

2.5.3.6.1)方式 1:生成随机密码

mkdir /data/mysql -p

mysqld --initialize --user=mysql --datadir=/data/mysql


grep password /data/mysql/mysql.log

2023-12-30T09:40:49.213204Z 1 [Note] A temporary password is generated for root@localhost: Q.xer?jWC8;O    // 注意生成 root 的初始密码


awk '/temporary password/{print $NF}' /data/mysql/mysql.log

Q.xer?jWC8;O

2.5.3.6.2)方式 2:生成 root 空密码( 省略 )

mysqld --initialize-insecure --user=mysql --datadir=/data/mysql

2.5.3.7)准备服务脚本和启动

cp /usr/local/mysql/support-files/mysql.server /etc/init.d/mysqld

chkconfig --add mysqld

service mysqld start

2.5.3.8)修改口令

// 修改前面生成的随机密码为指定密码

awk '/temporary password/{print $NF}' /data/mysql/mysql.log

Q.xer?jWC8;O

 

mysqladmin -uroot -p'Q.xer?jWC8;O' password P@ssw0rd123456



# 修改前面生成的空密码为指定密码

mysqladmin -uroot password P@ssw0rd123456

2.5.3.9)测试登录

报错解决:mysql: error while loading shared libraries: libncurses.so.5: cannot open shared object file-CSDN博客

mysql: error while loading shared libraries: libncurses.so.5: cannot open shared object file: No such file or directory

mysql -uroot -pP@ssw0rd123456

完成

yum install libncurses* -y

// mysql -uroot -pP@ssw0rd123456

2.5.4)实战案例:一键安装 MySQL5.7 和 MySQL8.0 二进制包的脚本

2.5.4.1)离线 安装脚本( offline )

( 离线安装 ) MySQL5.7 和 MySQL8.0 二进制包的脚本

#!/bin/bash

# MySQL Download URL:

# https://dev.mysql.com/get/Downloads/MySQL-5.7/mysql-5.7.29-linux-glibc2.12-x86_64.tar.gz

#h ttp://mirrors.163.com/mysql/Downloads/MySQL-5.7/mysql-5.7.31-linux-glibc2.12-x86_64.tar.gz

# http://mirrors.163.com/mysql/Downloads/MySQL-8.0/mysql-8.0.23-linux-glibc2.12-x86_64.tar.xz


. /etc/init.d/functions

SRC_DIR=`pwd`


MYSQL='mysql-8.0.28-linux-glibc2.12-x86_64.tar.xz'

#MYSQL='mysql-8.0.23-linux-glibc2.12-x86_64.tar.xz'

MYSQL_ROOT_PASSWORD=123456


COLOR='echo -e \E[01;31m'

END='\E[0m'


check (){

if [ $UID -ne 0 ]; then

  action "当前用户不是root,安装失败" false

  exit 1

fi


cd  $SRC_DIR


if [ !  -e $MYSQL ];then

        $COLOR"缺少${MYSQL}文件"$END

$COLOR"请将相关软件放在${SRC_DIR}目录下"$END

        exit

elif [ -e /usr/local/mysql ];then

        action "数据库已存在,安装失败" false

        exit

else

return

fi

}


install_mysql(){

    $COLOR"开始安装MySQL数据库..."$END

    yum  -y -q install libaio numactl-libs

    tar xf $MYSQL -C /usr/local/

    MYSQL_DIR=`echo $MYSQL| sed -nr 's/^(.*[0-9]).*/\1/p'`

    ln -s  /usr/local/$MYSQL_DIR /usr/local/mysql

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

    id mysql &> /dev/null || { useradd -s /sbin/nologin -r  mysql ; action "创建mysql用户"; }

        

    echo 'PATH=/usr/local/mysql/bin/:$PATH' > /etc/profile.d/mysql.sh

    .  /etc/profile.d/mysql.sh

ln -s /usr/local/mysql/bin/* /usr/bin/

    cat > /etc/my.cnf <<-EOF

[mysqld]

server-id=`hostname -I|cut -d. -f4`

log-bin

datadir=/data/mysql

socket=/data/mysql/mysql.sock                                                                                                   

log-error=/data/mysql/mysql.log

pid-file=/data/mysql/mysql.pid

[client]

socket=/data/mysql/mysql.sock

EOF

    [ -d /data ] || mkdir /data

mysqld --initialize-insecure --user=mysql --datadir=/data/mysql

    cp /usr/local/mysql/support-files/mysql.server  /etc/init.d/mysqld

    chkconfig --add mysqld

    chkconfig mysqld on

    service mysqld start

    [ $? -ne 0 ] && { $COLOR"数据库启动失败,退出!"$END;exit; }

    # MYSQL_OLDPASSWORD=`awk '/A temporary password/{print $NF}' /data/mysql/mysql.log`

    # mysqladmin  -uroot -p$MYSQL_OLDPASSWORD password $MYSQL_ROOT_PASSWORD &>/dev/null

sleep 3

    mysqladmin  -uroot  password $MYSQL_ROOT_PASSWORD &>/dev/null

    action "数据库安装完成"

}


check

install_mysql

2.5.4.2)在线 安装脚本( online )

史诗级最强 Shell 脚本

[root@centos7 ~] cat install_online_mysql5.7or8.0_for_centos.sh

#!/bin/bash


. /etc/init.d/functions


SRC_DIR=`pwd`

MYSQL='mysql-5.7.33-linux-glibc2.12-x86_64.tar.gz'

# URL=http://mirrors.163.com/mysql/Downloads/MySQL-5.7

URL=https://repo.huaweicloud.com/mysql/Downloads/MySQL-5.7/

# MYSQL='mysql-8.0.23-linux-glibc2.12-x86_64.tar.xz'

# URL=http://mirrors.163.com/mysql/Downloads/MySQL-8.0

COLOR='echo -e \E[01;31m'

END='\E[0m'

MYSQL_ROOT_PASSWORD=magedu


check (){

if [ $UID -ne 0 ]; then

    action "当前用户不是root,安装失败" false

    exit 1

fi


cd $SRC_DIR

rpm -q wget || yum -y -q install wget

wget $URL/$MYSQL

if [ ! -e $MYSQL ];then

    $COLOR"缺少${MYSQL}文件"$END

    $COLOR"请将相关软件放在${SRC_DIR}目录下"$END

    exit

elif [ -e /usr/local/mysql ];then

    action "数据库已存在,安装失败" false

    exit

else

    return

fi

}


mkdir /data/mysql -p


install_mysql(){

    $COLOR"开始安装MySQL数据库..."$END

    yum  -y -q install libaio numactl-libs libaio &> /dev/null

    cd $SRC_DIR

    tar xf $MYSQL -C /usr/local/

    MYSQL_DIR=`echo $MYSQL| sed -nr 's/^(.*[0-9]).*/\1/p'`

    ln -s /usr/local/$MYSQL_DIR /usr/local/mysql

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

    id mysql &> /dev/null || { useradd -s /sbin/nologin -r mysql ; action "创建 mysql 用户"; }

    

    echo 'PATH=/usr/local/mysql/bin/:$PATH' > /etc/profile.d/mysql.sh

    . /etc/profile.d/mysql.sh

        

 ln -s /usr/local/mysql/bin/* /usr/bin/

 

cat > /etc/my.cnf <<-EOF

[mysqld]

server-id=`hostname -I|cut -d. -f4`

log-bin

datadir=/data/mysql

socket=/data/mysql/mysql.sock                                               

log-error=/data/mysql/mysql.log

pid-file=/data/mysql/mysql.pid

[client]

socket=/data/mysql/mysql.sock

EOF


    mysqld --initialize --user=mysql --datadir=/data/mysql

    cp /usr/local/mysql/support-files/mysql.server /etc/init.d/mysqld

    chkconfig --add mysqld

    chkconfig mysqld on

    service mysqld start

    [ $? -ne 0 ] && { $COLOR"数据库启动失败,退出!"$END;exit; }

    MYSQL_OLDPASSWORD=`awk '/A temporary password/{print $NF}' /data/mysql/mysql.log`

    mysqladmin  -uroot -p$MYSQL_OLDPASSWORD password $MYSQL_ROOT_PASSWORD &>/dev/null

    action "数据库安装完成"

}


check

install_mysql

2.6)源码编译 安装 MySQL( 源码编译安装 )

建议:内存 4G 以上,CPU 核数越多越好

说明:本操作过程适用于以下版本

mysql-5.6.51.tar.gz

mariadb-10.2.18.tar.gz

2.6.1)安装相关依赖包

yum install gcc gcc-c++ cmake bison bison-devel zlib-devel libcurl-devel libarchive-devel boost-devel   ncurses-devel gnutls-devel libxml2-devel openssl-devel libevent-devel libaio-devel perl-Data-Dumper -y

2.6.2)准备好用户和数据目录

useradd -r -s /sbin/nologin -d /data/mysql mysql

2.6.3)准备好数据库目录

mkdir /data/mysql -p

chown mysql.mysql /data/mysql

2.6.4)源码编译安装

编译安装说明

利用 cmake 编译,而利用传统方法。

cmake 的 重要特性 之一是其独立于源码(out-of-source)的编译功能,即编译工作可以在另一个指定的目录中而非源码目录中进行,这可以保证源码目录不受任何一次编译的影响,因此在同一个源码树上可以进行多次不同的编译,如针对于不同平台编译。

编译选项:

https://dev.mysql.com/doc/refman/5.7/en/source-configuration-options.html

2.6.4.1)下载并解压缩源码包

在官网 MySQL :: Download MySQL Community Server (Archived Versions) 下载源码包

上面我们下载的是编译后的二进制包( 二进制安装使用的更为广泛一些 )

源码包很小才 30M 作用。

tar xvf mysql-5.6.51.tar.gz -C /usr/local/src

# mariadb-10.2.18.tar.gz

2.6.4.2)源码编译安装 MySQL

提示:如果出错,执行 rm -rf CMakeCache.txt

// 切换目录

cd /usr/local/src

du -sh mysql-5.6.51


// 使用 cmake 命令进行编译

cd mysql-5.6.51/

cmake . \

-DCMAKE_INSTALL_PREFIX=/apps/mysql \

-DMYSQL_DATADIR=/data/mysql/ \

-DSYSCONFDIR=/etc/ \

-DMYSQL_USER=mysql \

-DWITH_INNOBASE_STORAGE_ENGINE=1 \

-DWITH_ARCHIVE_STORAGE_ENGINE=1 \

-DWITH_BLACKHOLE_STORAGE_ENGINE=1 \

-DWITH_PARTITION_STORAGE_ENGINE=1 \

-DWITHOUT_MROONGA_STORAGE_ENGINE=1 \

-DWITH_DEBUG=0 \

-DWITH_READLINE=1 \

-DWITH_SSL=system \

-DWITH_ZLIB=system \

-DWITH_LIBWRAP=0 \

-DENABLED_LOCAL_INFILE=1 \

-DMYSQL_UNIX_ADDR=/data/mysql/mysql.sock \

-DDEFAULT_CHARSET=utf8 \

-DDEFAULT_COLLATION=utf8_general_ci


// 编译安装 ( 注意: 主机 CPU 核数 )

lscpu | grep Socket

make -j 8 && make install


// 验证编译安装目录    ( 注意: /usr/local/src 为源码存放目录 )

ll /apps/mysql        ( 程序最终存放目录 )

2.6.5)准备 PATH 环境变量

echo 'PATH=/apps/mysql/bin:$PATH' > /etc/profile.d/mysql.sh

bash /etc/profile.d/mysql.sh



'推荐'

echo 'PATH=/apps/mysql/bin:$PATH' > /etc/profile

source /etc/profile

2.6.6)生成数据库文件

// 切换目录

cd /apps/mysql/



// 必须在 /apps/mysql 目录下执行 mysql_install_db 脚本 ( 否则会报错 )

scripts/mysql_install_db --datadir=/data/mysql/ --user=mysql



'验证'

ll /data/mysql/

2.6.7)准备配置文件

// 复制模板配置文件 ( -b 参数会备份被覆盖的文件 )

cp -b /apps/mysql/support-files/my-default.cnf /etc/my.cnf



// 针对旧版本或 mariadb-10.2.18.tar.gz

cp /apps/mysql/support-files/my-huge.cnf /etc/my.cnf

2.6.8)准备启动脚本,并启动服务

// 复制模板文件

cp /apps/mysql/support-files/mysql.server /etc/init.d/mysqld



// 设置开机自启 

chkconfig --add mysqld

service mysqld start



// 验证

netstat -nltp

2.6.9)安全初始化

mysql_secure_installation

回车

y

输入密码

重复密码

y

y

y

y

mysql -uroot -pP@ssw0rd

2.7)基于 Dockcer 容器创建 MySQL

// 1) 低版本 Docker 安装

yum install docker -y


----

// < '推荐' >

// 2) 高版本 Docker 安装

curl -fsSL https://get.docker.com/ | sh


----

// 关闭防火墙

systemctl disable --now firewalld

setenforce 0


// 启用 Docker

systemctl enable --now docker


----

// 3) 安装 Docker-Compose

curl -L https://github.com/docker/compose/releases/download/v2.2.2/docker-compose-linux-x86_64 -o /usr/local/bin/docker-compose

chmod +x /usr/local/bin/docker-compose

docker-compose -v

[root@centos8 ~] docker run --name mysql -d -p 3306:3306 -e MYSQL_ROOT_PASSWORD=123456 mysql:5.7.30

[root@centos8 ~] docker images

[root@centos8 ~] docker ps -a

[root@centos8 ~] yum install mysql -y

[root@centos8 ~] mysql -uroot -p123456 -h127.0.0.1

2.8)MySQL 多实例

2.8.1)多实例 介绍和方案

2.8.1.1)多实例介绍

参考:https://www.cnblogs.com/yangliheng/p/5871215.html

简单地说,Mysql 多实例就是 在一台服务器上同时开启多个不同的服务端口(3306、3307),同时运行多个 Mysql 服务进程,这些服务进程通过不同的 Socket 监听不同的服务端口来提供服务。

这些 Mysql 多实例公用一套 Mysql 安装程序,一般使用不同的 my.cnf(也可以相同)配置文件,启动程序和数据文件。在提供服务时,多实例  Mysql 在逻辑上看来是 各自独立 的,它们根据配置文件的对应设定值,获得服务器相应数量的硬件资源。

打个比方,Mysql 多实例就相当于房子的多个卧室,每个实例可以看作一间卧室,整个服务器就是一套房子,服务器的硬件资源(cpu、mem、disk)、软件资源(centos操作系统)可以看作房子的卫生间、客厅,是房子的公用资源。

什么是数据库多实例

多实例 类似微信多开,多实例的不同端口号 类比微信多开的不同微信账号,数据库类比聊天窗口,表类比聊天记录。

MySQL 多实例 就是在一台服务器上同时开启多个不同的服务端口(如:33063307 等),同时运行多个 MySQL 服务进程,这些服务进程通过不同的 Socket 监听不同的服务端口来提供服务。

多实例可能是 MySQL 的不同版本,也可能是 MySQL 的同一版本实现。

多实例的好处

可有效利用服务器资源。当单个服务器资源有剩余时,可以充分利用剩余资源提供更多的服务,且可以实现资源的逻辑隔离节约服务器资源。例如公司服务器资源紧张,但是数据库又需要各自尽量独立的提供服务,并且还需要到主从复制等技术,多实例就是最佳选择。

多实例弊端

存在资源互相抢占的问题。比如:当某个数据库实例并发很高或者 SQL 查询慢时,整个实例会消耗大量的 CPU、磁盘I/O 等资源,导致服务器上面其他的数据库实例在提供服务的质量也会下降,所以具体的需求要根据自己的实际情况而定。

2.8.1.2)MySQL 多实例常见的 配置方案

单一的配置文件、单一启动程序多实例部署方式

MySQL 官方文档提到的单一配置文件、单一启动程序多实例部署方式

耦合度太高,一个配置文件不好管理。不是很推荐

多配置文件、多启动程序部署方式

多配置文件、多启动程序部署方式是针对每个实例都有独立的配置文件和目录,管理灵活,此方案耦合度较低

工作开发和运维的统一原则:降低耦合度。所以建议的此方式

2.8.2)实战案例 :CentOS 8 实现 MariaDB Yum 安装 多实例实现

Linux 小技巧:实现 MySQL 多实例

实战目的

CentOS 8 Yum 安装 MariaDB-10.3.17 并实现三个实例

环境要求

一台系统 CentOS 8.X 主机

前提准备

关闭 SELinux

关闭防火墙

时间同步

yum install ntpdate -y && ntpdate ntp.aliyun.com

systemctl disable --now firewalld

sed -ri.bak 's/^(SELINUX=).*/\1disabled/' /etc/selinux/config

setenforce 0

实现步骤

1. 安装 MariaDB

[root@centos8 ~] yum install mariadb-server -y

2. 准备三个实例的目录( 创建各个实例 自的目录 )

// 创建各个实例独自的目录

[root@centos8 ~] mkdir -pv /mysql/{3306,3307,3308}/{data,etc,socket,log,bin,pid}



// 授权目录    ( 都基于 mysql 用户运行 )

[root@centos8 ~] chown -R mysql.mysql /mysql

[root@centos8 ~] tree -d /mysql/

3. 生成数据库初始文件

[root@centos8 ~] mysql_install_db --user=mysql --datadir=/mysql/3306/data

[root@centos8 ~] mysql_install_db --user=mysql --datadir=/mysql/3307/data

[root@centos8 ~] mysql_install_db --user=mysql --datadir=/mysql/3308/data

4. 准备配置文件( 编写各个实例 独自配置文件 )

[root@centos8 ~] vim /mysql/3306/etc/my.cnf

[mysqld]

port=3306

datadir=/mysql/3306/data

socket=/mysql/3306/socket/mysql.sock

log-error=/mysql/3306/log/mysql.log

pid-file=/mysql/3306/pid/mysql.pid


// 重复上面步骤配置 3307, 3308 的配置文件

[root@centos8 ~] sed 's/3306/3307/' /mysql/3306/etc/my.cnf > /mysql/3307/etc/my.cnf

[root@centos8 ~] sed 's/3306/3308/' /mysql/3306/etc/my.cnf > /mysql/3308/etc/my.cnf


'验证'

[root@centos8 ~] cat /mysql/3307/etc/my.cnf

[root@centos8 ~] cat /mysql/3308/etc/my.cnf

5. 准备启动脚本

[root@centos8 ~] vim /mysql/3306/bin/mysqld

#!/bin/bash

port=3306

mysql_user="root"

mysql_pwd=""

cmd_path="/usr/bin"

mysql_basedir="/mysql"

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


// 重复上述过程, 分别建立 3307, 3308 的启动脚本  

[root@centos8 ~] sed 's/3306/3307/' /mysql/3306/bin/mysqld > /mysql/3307/bin/mysqld

[root@centos8 ~] sed 's/3306/3308/' /mysql/3306/bin/mysqld > /mysql/3308/bin/mysqld


'授权'

[root@centos8 ~] chmod +x /mysql/3306/bin/mysqld

[root@centos8 ~] chmod +x /mysql/3307/bin/mysqld

[root@centos8 ~] chmod +x /mysql/3308/bin/mysqld

6. 启动服务

[root@centos8 ~] /mysql/3306/bin/mysqld start

[root@centos8 ~] /mysql/3307/bin/mysqld start

[root@centos8 ~] /mysql/3308/bin/mysqld start

[root@centos8 ~] netstat -nltp

7. 登录实例

[root@centos8 ~] /mysql/3308/bin/mysqld start


'两种连接方法'

[root@centos8 ~] mysql -h127.0.0.1 -P3308

[root@centos8 ~] mysql -uroot -S /mysql/3308/socket/mysql.sock


// 确认连接的端口

MariaDB [(none)]> show variables like 'port';

+---------------+-------+

| Variable_name | Value |

+---------------+-------+

| port          | 3308  |

+---------------+-------+

1 row in set (0.001 sec)

MariaDB [(none)]>


// '测试多实例效果'

MariaDB [(none)]> create database test3308;

Query OK, 1 row affected (0.001 sec)


MariaDB [(none)]> show databases;

+--------------------+

| Database           |

+--------------------+

| information_schema |

| mysql              |

| performance_schema |

| test               |

| test3308           |

+--------------------+

5 rows in set (0.001 sec)


// 我们在 3308 实例创建的数据库

// 其他实例是看不到的, '数据库实例间相互独立.'

[root@centos8 ~] mysql -uroot -S /mysql/3307/socket/mysql.sock

MariaDB [(none)]> show databases;

+--------------------+

| Database           |

+--------------------+

| information_schema |

| mysql              |

| performance_schema |

| test               |

+--------------------+

4 rows in set (0.001 sec)


8. 修改 root 密码

// 加上 root 的口令

[root@centos8 ~] mysqladmin -uroot -S /mysql/3306/socket/mysql.sock password 'P@ssw0rd'

[root@centos8 ~] mysqladmin -uroot -S /mysql/3307/socket/mysql.sock password 'P@ssw0rd'

[root@centos8 ~] mysqladmin -uroot -S /mysql/3308/socket/mysql.sock password 'P@ssw0rd'



// '或者' 登录 mysql, 执行如下 SQL 语句也可以

Mariadb> update mysql.user set password=password("P@ssw0rd") where user='root';

Mariadb> flush privileges;

// 重复步骤, 分别修改别外两个实例 3307, 3308 对应 root 口令



---

// '关闭实例', 需要手动输入 root 的密码

[root@centos8 ~] /mysql/3308/bin/mysqld stop

Stoping MySQL...

Enter password:



// 当然, 我们也可以将密码写入到 mysqld 服务文件中    ( 不安全 )

vim /mysql/3308/bin/mysqld

mysql_pwd="P@ssw0rd"

// 重复上述过程,  分别在 3306, 3307 的启动脚本中填写密码信息

   

[root@centos8 ~] /mysql/3308/bin/mysqld start

MySQL is running...



// 再次关闭实例, '无需再手动输入密码啦'

[root@centos8 ~] /mysql/3308/bin/mysqld stop

Stoping MySQL...

9. 测试连接

// 提示输入口令才能登录

[root@centos8 ~] mysql -uroot -p -S /mysql/3306/socket/mysql.sock

Enter password:

10. 开机启动

[root@centos8 ~] vim /etc/rc.d/rc.local

// 在最后一行加下面内容

for i in {3306..3308};do /mysql/$i/bin/mysqld start;done



'授权'

[root@centos8 ~] chmod +x /etc/rc.d/rc.local



'验证'

[root@centos8 ~] bash /etc/rc.d/rc.local

[root@centos8 ~] netstat -nltp



'重启验证'

[root@centos8 ~] reboot

[root@centos8 ~] netstat -nltp

大功告成~

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/350961.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

JavaScript学习-原型和原型链

原型和原型链 示例代码 //创建一个Person类 class Person {constructor(name) {this.name name;}drink() {console.log(喝水);} } //创建一个Teacher类&#xff0c;继承Person class Teacher extends Person {constructor(name, subject) {super(name);this.subject subjec…

微信小程序 仿微信聊天界面

1. 需求效果图 2. 方案 为实现这样的效果&#xff0c;首先要解决两个问题&#xff1a; 2.1.点击输入框弹出软键盘后&#xff0c;将已有的少许聊天内容弹出&#xff0c;导致看不到的问题 点击输入框弹出软键盘后&#xff0c;将已有的少许聊天内容弹出&#xff0c;导致看不到的问…

FFMPEG解析ts流

三篇相关联的文章&#xff1a; ffmpeg下HLS解析过程-CSDN博客TS文件格式详解及解封装过程-CSDN博客 FFMPEG解析ts流-CSDN博客 一、简介 关于TS格式解析&#xff0c;可以参考《TS文件格式详解及解封装过程-CSDN博客》&#xff0c;本文主要代码部分解读。建议大家熟读iso138…

【JaveWeb教程】(30)SpringBootWeb案例之《智能学习辅助系统》的详细实现步骤与代码示例(3)员工管理的实现

目录 SpringBootWeb案例033. 员工管理3.1 分页查询3.1.1 基础分页3.1.1.1 需求分析3.1.1.2 接口文档3.1.1.3 思路分析3.1.1.4 功能开发3.1.1.5 功能测试3.1.1.6 前后端联调 3.1.2 分页插件3.1.2.1 介绍3.1.2.2 代码实现3.1.2.3 测试 3.2 分页查询(带条件)3.2.1 需求3.2.2 思路分…

电流检测电路设计方案汇总

电流检测电路设计方案&#xff08;一&#xff09; 低端检流电路的检流电阻串联到地&#xff08;图1&#xff09;&#xff0c;而高端检流电路的检流电阻是串联到高电压端&#xff08;图2&#xff09;。两种方法各有特点&#xff1a;低端检流方式在地线回路中增加了额外的线绕电…

内网穿透natapp使用教程(Linux)

我的使用场景&#xff1a;在家访问学校服务器&#xff0c;由于不在一个局域网&#xff0c;所以需要使用内网穿透&#xff0c;我使用的是natapp。需要在有局域网的时候做好以下步骤。 &#xff08;natapp官网&#xff1a;https://natapp.cn/&#xff09; 1. 下载客户端 &#x…

开发微信小程序,将图片下载到相册的方法,saveImageToPhotosAlbum怎么用

在开发微信小程序的时候&#xff0c;经常能看到小程序里面有下载按钮&#xff0c;如何将小程序中的图片下载到手机相册中那&#xff0c;下面给大家说一下怎么做&#xff0c;代码如何去写。 一、到微信小程序后台开启“用户隐私保护指引” 1.进入小程序后台&#xff0c;侧拉拉到…

第16章_网络编程(网络通信要素,TCP与UDP协议,网络编程API,TCP网络编程,UDP网络编程,URL编程)

文章目录 第16章_网络编程本章专题与脉络1. 网络编程概述1.1 软件架构1.2 网络基础 2. 网络通信要素2.1 如何实现网络中的主机互相通信2.2 通信要素一&#xff1a;IP地址和域名2.2.1 IP地址2.2.2 域名 2.3 通信要素二&#xff1a;端口号2.4 通信要素三&#xff1a;网络通信协议…

[C#]winform部署yolov5实例分割模型onnx

【官方框架地址】 https://github.com/ultralytics/yolov5 【算法介绍】 YOLOv5实例分割是目标检测算法的一个变种&#xff0c;主要用于识别和分割图像中的多个物体。它是在YOLOv5的基础上&#xff0c;通过添加一个实例分割模块来实现的。 在实例分割中&#xff0c;算法不仅…

自动化软件开发常用代码分享!

随着科技的发展&#xff0c;自动化软件开发已经成为现代企业不可或缺的一部分&#xff0c;自动化软件可以帮助企业提高生产效率、降低成本、优化业务流程。 而在自动化软件开发中&#xff0c;代码是实现这些功能的基础&#xff0c;本文将分享一些常用的自动化软件开发代码&…

苍穹外卖-前端部分(持续更新中)

d 第二种&#xff1a;cmd中输入 vue ui进入图形化界面选择npm,vue2进行创建 先将创建的Vue框架导入Vsocde开发工具 然后ctrshiftp 输入npm 点击serve将项目启动 下这种写法跨域会报错&#xff1a; 解决方法&#xff1a;

虚拟机内使用 archinstall 安装 arch linux 2024.01.01

文章目录 [toc]前言碎语安装 arch linuxArchinstall languageMirrorsLocalesDisk configurationBootloaderSwapHostnameRoot passwordUser accountProfileAudioKernelsAdditional packagesNetwork configurationTimezoneAutomatic time syncOptional repositoriesInstall 进入桌…

OceanMind海睿思入选《2023大数据产业年度创新技术突破奖》,并蝉联多项图谱

近日&#xff0c;由数据猿和上海大数据联盟主办&#xff0c;上海市经济和信息化委员会、上海市科学技术委员会指导的“第六届金猿季&魔方论坛——大数据产业发展论坛”在上海成功举行&#xff0c;吸引了数百位业界精英的参与。中新赛克海睿思作为国内数字化转型优秀厂商代表…

基于springboot+vue的校园资料分享平台(前后端分离)

博主主页&#xff1a;猫头鹰源码 博主简介&#xff1a;Java领域优质创作者、CSDN博客专家、公司架构师、全网粉丝5万、专注Java技术领域和毕业设计项目实战 主要内容&#xff1a;毕业设计(Javaweb项目|小程序等)、简历模板、学习资料、面试题库、技术咨询 文末联系获取 项目背景…

include文件包含

include 文件包含利用日志文件什么是日志文件 之所以会burp抓包上传就可以成功的原因&#xff0c;是因为burp可以绕过url编码&#xff0c;导致写入日志文件中的代码没有进行编码&#xff0c;可以直接解析成php文件 声明&#xff1a;其中图片并非本人实操&#xff0c;而是直接截…

软件包管理:在CentOS 7中部署Tengine

目录 下载&#xff1a; 方法一&#xff1a; 方法二&#xff1a; 部署&#xff1a; 实验操作 下载&#xff1a; 方法一&#xff1a; 1、打开浏览器搜索tengine并点击官网 2、选择需要安装的版本并复制链接链接 标题栏处可以更改为中文界面 下滑选择版本单击下载 在远程连…

matlab appdesigner系列-图窗3-菜单

菜单&#xff0c;常用来作为软件界面上方的菜单栏&#xff0c;可用来集成多种功能 示例&#xff1a;创建菜单栏的file选项&#xff0c;设置open&#xff0c;save&#xff0c;exit三个选项 操作步骤&#xff1a; 1&#xff09;将菜单、图像拖拽到画布上&#xff0c;并修改对应…

【Midjourney】绘画风格关键词

1.松散素描(Loose Sketch) "Loose sketch"&#xff08;松散素描&#xff09;通常指的是一种艺术或设计中的手绘风格&#xff0c;其特点是线条和形状的表现相对宽松、自由&#xff0c;没有过多的细节和精确度。这样的素描通常用于表达创意、捕捉概念或者作为设计的初步…

《WebKit 技术内幕》学习之十五(5):Web前端的未来

5 Crosswalk项目 Crosswalk项目是由英特尔公司发起的一个开源项目&#xff0c;该项目基于WebKit&#xff08;Blink&#xff09;和Chromium等开源项目打造&#xff0c;其目的是提供一个跨不同操作系统的Web运行环境&#xff0c;包括Android、Tizen、Linux、Windows、MacOS等众多…

Docker容器(自定义镜像,Dockerfile,网桥,DockerCompose)

自定义镜像 镜像就是包含了应用程序、程序运行的系统函数库、运行配置等文件的文件包。构建镜像的过程其实就是把上述文件打包的过程。 构建步骤 镜像结构 Dockerfile 它是一个文本文件&#xff0c;包含很多指令&#xff0c;用指令来说明要执行什么操作来构建镜像。 官网&am…