史上最细教程-一台服务器上搭建2个MySQL实例

news2024/10/2 12:25:56

史上最细教程-一台服务器上搭建2个MySQL实例

文章目录

  • 史上最细教程-一台服务器上搭建2个MySQL实例
    • 环境准备:
    • 操作步骤:
      • 1.安装MySQL
      • 2.配置搭建3306、3307实例
      • 3.初始化3306、3307实例、远程连接访问支持

环境准备:

服务器:阿里云CentOS7

MySQL数据库:mysql-5.7.36-linux-glibc2.12-x86_64.tar.gz

这里已为您准备安装包(gitee): https://gitee.com/song-rice/devops-and-middleware-module-learning/blob/master/mysql-5.7.36-linux-glibc2.12-x86_64.tar.gz

或者去官网下载:http://dev.mysql.com/get/Downloads


操作步骤:

1.安装MySQL

先看看是否已安装过,如果已安装过,先卸载干净;然后检查安装环境是否支持,重新安装;

# 查找已安装的MySQL软件包
rpm -qa|grep mysql 
rpm -qa|grep mariadb   # CentOS7下还需要查找是否存在mariadb包

# 如果输入上述两个命令后都输出存在有包,则需要执行删除命令
rpm -e --nodeps mysql-libs-xxx.el6.x86_64
rpm -e --nodeps mariadb-libs-xxx.x86_64

# 增加文件操作权限,安装MySQL后MySQL会用户在/tmp目录下新建tmp_db文件,需要给/tmp目录较大的权限操作
chmod -R 777 /tmp

# 检查系统中是否存在一些安装MySQL时需要的依赖库
rpm -qa|grep libaio
rpm -qa|grep net-tools

# 如果不存在则需要安装 
yum install libaio   # 或者 yum -y install libaio net-tools
# MySQL 5.7.19和更高版本对libnuma库具有依赖性 
yum install libnuma

都没有问题后,将MySQL安装包直接解压到指定位置即可。

# 创建mysql用户和用户组
groupadd mysql
useradd -r -g mysql -s /bin/false mysql  # 创建一个名为mysql的系统用户,该用户属于mysql组,但不能登录系统。这通常用于安装和配置MySQL数据库服务时使用。

# 解压安装包
cd /usr/local/  # 进入安装包所在位置 
tar xzvf /mysql-5.7.36-linux-glibc2.12-x86_64.tar.gz   # 解压后出现mysql文件夹

# 解压后查看
cd /mysql
ls -l

(图示:我的安装包位置:/usr/local,我的解压位置:/usr/local/mysql)

image-20231122161737580


2.配置搭建3306、3307实例

到此,MySQL数据库装好了,下面就是创建对应3306、3307端口MySQL实例。

考虑下3306、3307不同实例数据文件放在哪?配置文件放在哪?这些都需要新建文件夹存放,

下面就是创建3306、3307不同实例的数据、配置等文件存放位置。

# 创建数据文件存放路径
mkdir -p /usr/local/mysql/{3306,3307}/data
# 修改文件权限属性
chown -R mysql:mysql /usr/local/mysql

# 创建实例3306、3307配置文件my.cnf,直接复制下面的配置进去即可

/3306/my.cnf 里面就是指定端口、服务目录路径、数据存放路径、日志存放路径、进程文件路径、编码(数据库和服务端的默认字符都是latin1,如果不修改容易出现乱码)等

[mysqld]

port=3306
user=mysql
basedir=/usr/local/mysql 
datadir=/usr/local/mysql/3306/data
lower_case_table_names=1
innodb_buffer_pool_size=128M
socket=/tmp/mysql_3306.sock
explicit_defaults_for_timestamp=true

symbolic-links=0

log-error=/usr/local/mysql/3306/log/mysqld.log
pid-file=/usr/local/mysql/3306/run/mysqld.pid

character_set_server=utf8mb4
init_connect='SET NAMES utf8mb4'

3307/my.cnf

[mysqld]

port=3307
user=mysql
basedir=/usr/local/mysql
datadir=/usr/local/mysql/3307/data
lower_case_table_names=1
innodb_buffer_pool_size=128M
socket=/tmp/mysql_3307.sock
explicit_defaults_for_timestamp=true

symbolic-links=0

log-error=/usr/local/mysql/3307/log/mysqld.log
pid-file=/usr/local/mysql/3307/run/mysqld.pid

character_set_server=utf8mb4
init_connect='SET NAMES utf8mb4'

(图示:我的3306、3307实例数据、配置等文件存放位置)

image-20231122162039534

(图示:我的3306、3307目录)

image-20231122164911234

image-20231122164849802

now,3306、3307配置就完成了,现在开始初始化这两个数据库实例,设置mysql系统环境变量,最后启动指定实例,root账号密码登录即可。

# 初始化3306实例数据库  
# 指定配置文件、基础目录路径、数据存放路径
# 注意,初始化结束的最后一行记录了root的密码,记录下来
/usr/local/mysql/bin/mysqld --defaults-file=/usr/local/mysql/3306/my.cnf --initialize --basedir=/usr/local/mysql/ --datadir=/usr/local/mysql/3306/data
# 初始化3307实例数据库
# 注意,初始化结束的最后一行记录了root的密码,记录下来
/usr/local/mysql/bin/mysqld --defaults-file=/usr/local/mysql/3307/my.cnf --initialize --basedir=/usr/local/mysql/ --datadir=/usr/local/mysql/3307/data


# 设置系统环境变量
vim /etc/profile
# 在文件末尾添加下面信息  和java在window中配置系统环境一样
export PATH=/usr/local/mysql/bin:$PATH
#使环境变量生效
source /etc/profile


# 启动数据库
# 将路径下文件都授权给mysql
chown -R mysql:mysql /usr/local/mysql
# 启动数据库实例3306、3307
nohup /usr/local/mysql/bin/mysqld --defaults-file=/usr/local/mysql/3306/my.cnf --user=mysql &
nohup /usr/local/mysql/bin/mysqld --defaults-file=/usr/local/mysql/3307/my.cnf --user=mysql &


# 查看MySQL进程状态  可以看到mysql3个进程(root、mysql/3306、mysql/3307)
ps -ef|grep mysql
# 查看端口使用情况   可以看到3306、3307端口被占用
netstat -ntl


# 登录3306、3307 mysql服务器
mysql -uroot -h127.0.0.1 -p -P3306
Enter password: 输入上面记录的密码(这里输入时不会展示)

(图示:我的3306、3307进程查看)

image-20231122170855943

(图示:我的3306、3307端口查看)

image-20231122170938750

(图示:在服务器上登录3306数据库)

image-20231122171731309

到这里,服务器上安装就结束了!


3.初始化3306、3307实例、远程连接访问支持

然后执行下面这些初始化数据库配置:

修改root账号的初始密码:

ALTER USER 'root'@'localhost' IDENTIFIED BY 'your_new_password';

修改字符集,数据库和服务端默认字符集查看为latin1,不修改会容易出现乱码:

# 查看字符集
show variables like 'character%';
# 修改数据库的字符集(其中mydb为数据库名)
alter database mydb character set 'utf8';
# 修改数据库表的字符集(其中mytbl为表名)
alter table mytbl convert to character set 'utf8';

提供远程访问配置:让远程连接工具如Navicate等能连接到服务器数据库

# 查看MySQL的用户信息  
# host:表示连接类型 user:表示用户名,同一用户通过不同方式链接的权限是不一样的  authentication_string:密码
# 	%:表示所有远程通过 TCP方式的连接 
#   localhost:本地方式通过命令行方式的连接 ,比如mysql -u xxx -p 123xxx 方式的连接。
select host, user, authentication_string from mysql.user;


# 看到都是localhost时,不能继续远程连接,所以要修改root用户连接方式为 % 
update user set host = '%' where user = 'root';
# 刷新权限
FLUSH PRIVILEGES; 
# 退出mysql
exit;

image-20231123085047657

检查服务器安全组、防火墙端口是否开放,如果端口不能通过,也不能远程访问:

# 查看防火墙状态
systemctl status firewalld
# 如果不是显示active状态,需要打开防火墙
systemctl start firewalld


# 查看所有已开放的临时端口(默认为空)
firewall-cmd --list-ports
# 添加临时开放端口(例如:比如我修改ssh远程连接端口是3306,则需要开放这个端口)
firewall-cmd --add-port=3306/tcp
# 添加永久开放的端口(例如:223端口)
firewall-cmd --add-port=3306/tcp --permanent


# 关闭临时端口
# firewall-cmd --remove-port=80/tcp
# 关闭永久端口
# firewll-cmd --remove-port=80/tcp --permanent


# 配置结束后需要输入重载命令并重启防火墙以生效配置
firewall-cmd --reload
systemctl restart firewalld


# 检查阿里云安全组放行的端口

(图示:防火墙状态查看)

image-20231123090019258

(图示:防火墙放行端口查看)

(图示:阿里云服务器安全组查看)

image-20231123090621882


最后,navicete 连接mysql 3306\3307两个数据库:

image-20231123091020053

image-20231123091042371

到此,所有恭喜你,完成了服务器上搭建2个数据库!!!

在这里插入图片描述

搭建此环境为了操作ShardingJDBC主从复制等操作,后续出详细教程,各位看官敬请关注!


参考文章:

在一台Linux服务器上安装多个MySQL实例(二)–使用单独的MySQL配置文件 - gegeman - 博客园 (cnblogs.com)

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

斯坦福大学引入FlashFFTConv来优化机器学习中长序列的FFT卷积

斯坦福大学的FlashFFTConv优化了扩展序列的快速傅里叶变换(FFT)卷积。该方法引入Monarch分解,在FLOP和I/O成本之间取得平衡,提高模型质量和效率。并且优于PyTorch和FlashAttention-v2。它可以处理更长的序列,并在人工智能应用程序中打开新的可…

【网络】数据链路层协议

数据链路层协议 一、链路层解决的问题二、以太网协议1、局域网技术2、令牌环网(了解)3、以太网通信原理4、 MAC地址5、以太网帧格式6、碰撞避免7、最大传输单元MTU 二、ARP协议1、ARP数据的格式2、ARP协议的工作流程3、ARP缓存表4、ARP协议中的一些问题7…

力控软件与多台PLC之间ModbusTCP/IP无线通信

Modbus TCP/IP 是对成熟的 Modbus 协议的改编, 因其开放性、简单性和广泛接受性而在工业自动化系统中发挥着举足轻重的作用。它作为连接各种工业设备的通用通信协议,包括可编程逻辑控制器 (PLC)、远程终端单元 (RTU) 和传感器。它提供标准化的 TCP 接口&…

从零开始,用Docker-compose打造SkyWalking、Elasticsearch和Spring Cloud的完美融合

🎏:你只管努力,剩下的交给时间 🏠 :小破站 "从零开始,用Docker-compose打造SkyWalking、Elasticsearch和Spring Cloud的完美融合 前言准备工作编写docker-compose.yml文件为什么使用本机ip为什么skywa…

VL06O报表添加增强字段

业务描述 用户需要在VL06O事务代码下进行批量交货过账,现有的筛选条件不太适用当前公司的业务,需要在报表中新增三个交货单增强字段,方便其筛选(选择屏幕没有加,用户在报表里用标准按钮功能自己筛选) 效果…

百战python01-初识python_turtle绘图

文章目录 简介练习1.简易的进度条学习使用turtle在屏幕上绘制图形注:需要对python有基本了解,可查看本作者python基础专栏,有任何问题欢迎私信或评论(本专栏每章内容都将不定期进行内容扩充与更新) 简介 python简介及方向+pycharm安装使用请转 练习 注:尝试练习。了解…

视频云存储EasyCVR平台国标接入获取通道设备未回复是什么原因?该如何解决?

安防视频监控/视频集中存储/云存储/磁盘阵列EasyCVR平台可拓展性强、视频能力灵活、部署轻快,可支持的主流标准协议有国标GB28181、RTSP/Onvif、RTMP等,以及支持厂家私有协议与SDK接入,包括海康Ehome、海大宇等设备的SDK等。平台既具备传统安…

Windows平台Unity下实现camera场景推送RTMP|轻量级RTSP服务|实时录像

技术背景 我们在对接Unity平台camera场景采集的时候,除了常规的RTMP推送、录像外,还有一些开发者,需要能实现轻量级RTSP服务,对外提供个拉流的RTSP URL。 目前我们在Windows平台Unity下数据源可采集到以下部分: 采集…

如何满足BMW EDI项目的PKT需求?

近期宝马BMW(以下简称BMW)在其部分供应商之间试点推进PKT项目,BMW为什么要启动 PKT 计划呢? 业务系统全面升级统一全球所有宝马工厂的流程 宝马内部的物流供货流程 近期BMW PKT需求主要针对其内部物流供货流程展开: …

linux下流媒体压力测试工具的使用

前言 因为领导要求做linux的推拉流时服务器压力测试,于是在网上找了找。一顿操作下来,发现很多软件盗用一款名为srs-bench的开源软件。 该代码仓库有详细的使用说明,而且可以在issues中找到可能会遇到的问题的解决办法 需要下载该仓库的源…

网页小游戏的开发流程

网页小游戏的开发流程可以分为几个关键步骤。这只是一个一般性的流程概述,具体的步骤可能会根据项目的规模和要求而有所不同。此外,还要考虑法律和版权问题,确保你的游戏开发过程是合法的。下面是一个简要的概述,希望对大家有所帮…

Centos Download

前言 CentOS Linux 是一个社区支持的发行版,源自 CentOS git for Red Hat Enterprise Linux (RHEL) 上免费提供给公众的源代码。因此,CentOS Linux 的目标是在功能上与 RHEL 兼容。CentOS 计划主要更改组件以删除上游供应商的品牌…

【QML】StackView上层页面半透明,显示下层页面

1、 应用场景 有时候需要模拟弹窗效果,需要下层的页面半透明显示。仅仅将上层页面背景设置为透明并不能实现这个效果,下层的页面依然被覆盖。Qt帮助文档中有如下代码,经测试有效果。 2、 代码 重点标记: 下层页面需要设置这个…

220V转12V固定输出12V非隔离芯片WT5106WT5105

220V转12V固定输出12V非隔离芯片WT5106WT5105 今天给大家介绍一款实用芯片,WT5106。它是一款高效率高精度的非隔离降压开关电源恒压控制驱动芯片。 WT5106适用于85VAC~265VAC全范围输入电压的非隔离Buck、Buckboost拓扑结构,小家电、电机驱动、继电器驱…

Django框架环境的搭建(图文详解)

目录 day01 Web框架和Django基础 1.web框架底层 1.1 网络通信​编辑 1.2 常见软件架构 1.3 手撸web框架 2.web框架 2.1 wsgiref 2.2 werkzeug 2.3 各框架的区别 3.快速上手django框架 3.1 安装 3.2 命令行 3.3 Pycharm 4.虚拟环境 4.1 创建虚拟环境 - 命令行 4…

宿主Linux——KVM安装Windows7系统

KVM虚拟技术 KVM(Kernel-based Virtual Machine) 是基于Linux内核的开源虚拟化技术,在一台物理机上可同时运行多个虚拟系统。KVM使用硬件虚拟化扩展,例如Intel的VT和AMD的AMD-V,在性能方面更加高效,可提供更好的计算能力和响应速…

echarts移动markline(拖拽单条markline)

echarts移动markline(拖拽单条markline) 效果 问题由来: 图表中需要一个移动的标线,辅助观察图表; 想法: 意思是在原来点或者原来标线上新增一个图层,拖动图层动态绘制新的点或者新的标线; 参考…

ChatGLM2-6B微调过程说明文档

参考文档: ChatGLM2-6B 微调(初体验) - 知乎 环境配置 下载anaconda,版本是Anaconda3-2023.03-0-Linux-x86_64.sh,其对应的python版本是3.10,试过3.7和3.11版本的在运行时都报错。 执行下面的命令安装anaconda sh Anaconda3-202…

NLP的使用

参考: Apache openNLP 简介 - 链滴 (ld246.com) opennlp 模型下载地址:Index of /apache/opennlp/models/ud-models-1.0/ (tencent.com) OpenNLP是一个流行的开源自然语言处理工具包,它提供了一系列的NLP模型和算法。然而,Open…

让SOLIDWORKS Composer动画在PPT中随意转换

SOLIDWORKS Composer作为一款易学易用的技术图解软件,非常适合用来给客户展示自己的产品。这里我们教大家如何将Composer文件插入大PPT中,并任意切换文件,用以给客户展示不用的方案和产品。 1.首先大家要安装SOLIDWORKS Composer Player 这个…