当前位置: 首页 > news >正文

MariaDB-10.8.6安装+主从搭建

【系统版本】

CentOS 7.x
Linux version 3.10.0-1062.18.1.el7.x86_64

【检查系统是否安装过Mysql|mariadb】

【查看是否安装Mysql|mariadb】

#搜索mysql
rpm -qa|grep mysql
#搜索mariadb
rpm -qa|grep mariadb
#搜索MariaDB
rpm -qa|grep MariaDB
#如果安装过Mysql|mariadb,执行下面命令,进行卸载
rpm -ev mysql-community-common-5.7.41-1.el7.x86_64  --nodeps
#然后查找mysql文件夹
find / -name mysql
#直接进行删除即可
rm -rf /var/lib/mysql
rm -rf /var/lib/mysql/mysql
rm -rf /usr/share/mysql
rm -rf /etc/selinux/targeted/active/modules/100/mysql
```
## 【安装MariaDB】
【添加MariaDb的yum源,进行安装】
```
#进入yum仓库文件夹下
cd /etc/yum.repos.d
#将mariadb.repo,命名为MariaDB.repo
mv mariadb.repo MariaDB.repo
#如果mariadb.repo不存在,新建文件mariadb.repo
#编辑文件/etc/yum.repos.d/MariaDB.repo,添加mariadbyum源
[mariadb]
name = MariaDB-10.8.6
baseurl= http://archive.mariadb.org/mariadb-10.8.6/yum/centos/$releasever/$basearch
gpgkey= https://archive.mariadb.org/PublicKey
gpgcheck=1

【清除并重建yum缓存】

yum clean all
yum makecache

【查看yum可以安装的包】

yum list | grep mariadb

【运行下面命令安装】

yum install MariaDB-server MariaDB-client

【安全初始化MariaDB】

【启动|停止|重启MariaDB】

#启动
systemctl start mariadb
#停止
systemctl stop mariadb
#重启
systemctl restart mariadb
#查看mariadb状态
systemctl status mariadb

【MariaDb安全安装】

#启动mariadb服务
systemctl start mariadb
#使用客户端连接mysql
mysql -h 127.0.0.1 -u root
#执行初始化安装
mariadb-secure-installation
#初始化安装是一个交互式的窗口:设置root账号密码、删除匿名用户、删除
测试库
执行完命令:mariadb-secure-installation,你就可以使用root账户登录了,
使用刚刚设置的密码

【使用root账号登录mariadb】

mysql -u root -p
123456qwe

【MariaDB主从搭建】

【==MariaDb主库配置==】

[mysqld]
datadir=/var/lib/mysql
socket=/var/lib/mysql/mysql.sock
port=3306
init_connect='SET collation_connection = utf8_unicode_ci'
init_connect='SET NAMES utf8'
character-set-server=utf8
collation-server=utf8_unicode_ci
skip-character-set-client-handshake
max_allowed_packet = 20M
#下面配置项是主从配置
[mariadb]
log-bin
server_id=1
log-basename=master1
binlog-format=mixed
# Disabling symbolic-links is recommended to prevent assorted security risks
symbolic-links=0
# Settings user and group are ignored when systemd is used.
# If you need to run mysqld under a different user or group,
# customize your systemd unit file for mariadb according to the
# instructions in http://fedoraproject.org/wiki/Systemd
[mysqld_safe]
log-error=/var/log/mariadb/mariadb.log
pid-file=/var/run/mariadb/mariadb.pid
#
# include all files from the config directory
#
!includedir /etc/my.cnf.d

【==MariaDb主库操作==】

#在主库上创建同步用户,并设置密码
CREATE USER 'replication_user'@'%' IDENTIFIED BY '123456qwe';
#为同步用户授权
GRANT REPLICATION SLAVE ON *.* TO 'replication_user'@'%';
#锁定所有表,在此期间不允许有写操作
FLUSH TABLES WITH READ LOCK;
#获取bin-log位置
SHOW MASTER STATUS;
+--------------------+----------+--------------+------------------+
| File               | Position | Binlog_Do_DB | Binlog_Ignore_DB |
+--------------------+----------+--------------+------------------+
| master1-bin.000001 |   126310 |              |                  |
+--------------------+----------+--------------+------------------+
#记录下file和positon,配置从库时需要
#解除表锁
UNLOCK TABLES;

【使用Mariabackup对主库进行全量备份】

#安装MariaDB-backup
yum install -y MariaDB-backup
mkdir -p /var/mariadb/backup/
#对主库执行全量备份操作
mariabackup --backup \--target-dir=/var/mariadb/backup/ \--user=XXXX --password=XXXXX
#备份完成之后可以使用下面命令查看备份文件
ls /var/mariadb/backup/
#在备份的时候每个备份文件的时间都不一样,如果你试图从这些文件恢复,
#InnoDB会注意到不一致并且中止恢复,以保护你不受破坏
#在从恢复备份之前,首先需要对备份进行预准备,以使数据文件保持一致。
mariabackup --prepare \--target-dir=/var/mariadb/backup/;#将备份目录进行打包
tar -cvf /opt/mysql_backup.tar /var/mariadb/backup/
#使用scp命令上传至从服务器,走内网,网速快
scp /opt/mysql_backup.tar root@172.20.235.122:/opt 

【==MariaDB从库配置文件==】

[mysqld]
datadir=/var/lib/mysql
socket=/var/lib/mysql/mysql.sock
port=3306
init_connect='SET collation_connection = utf8_unicode_ci'
init_connect='SET NAMES utf8'
character-set-server=utf8
collation-server=utf8_unicode_ci
skip-character-set-client-handshake
max_allowed_packet = 20M
#下面配置项是主从配置,从库只读
[mariadb]
server_id=2
read-only=1
[mysqld_safe]
log-error=/var/log/mariadb/mariadb.log
pid-file=/var/run/mariadb/mariadb.pid
[client-server]
#
# include *.cnf from the config directory
#
!includedir /etc/my.cnf.d

【==MariaDB从库操作(导入备份文件)==】

#首先停止从服务器mariadb服务
systemctl stop mariadb
#确保目录:/var/lib/mysql是空的,如果目录不为空,执行下面命令,清除它
rm -rf /var/lib/mysql
#将备份文件进行解压
cd /opt
mkdir -p mysql_backup
tar -xvf mysql_backup.tar -C mysql_backup/
#使用mariabackup执行恢复
mariabackup --copy-back \--target-dir=/opt/mysql_backup/var/mariadb/backup/;#恢复完成之后,重新修改mariadb主目录所属用户和所属组
chown -R mysql:mysql /var/lib/mysql/
#一旦数据被导入,就可以启动副本
systemctl start mariadb#使用下面命令设置同步主库信息,注意LOG_FILE、LOG_POS,要填写当时备份主库的信息
CHANGE MASTER TOMASTER_HOST='172.20.235.121',MASTER_USER='同步账号',MASTER_PASSWORD='XXXX',MASTER_PORT=3306,MASTER_LOG_FILE='master1-bin.000001',MASTER_LOG_POS=126310,MASTER_CONNECT_RETRY=10;
# 开启GTID进行复制
CHANGE MASTER TO MASTER_USE_GTID = slave_pos;
#执行下面命令,启动从库  
START SLAVE;
#执行下面命令,查看从库状态
SHOW SLAVE STATUS \G;
#看到下面三个配置项,就证明成功了Slave_IO_Running: YesSlave_SQL_Running: YesUsing_Gtid: Slave_Pos

【开启半同步复制】

==注意:是否开启半同步复制,根据实际情况决定,开启了半同步复制,至少有

一个副本响应成功,主节点才会提交。半同步复制,保证了数据一致性,但会

对业务的吞吐量有一定影响。==

【主服务器开启半同步复制】

SET GLOBAL rpl_semi_sync_master_enabled=ON;
或者在my.cnf配置文件中设置:
[mariadb]
....
rpl_semi_sync_master_enabled=ON

【从服务器开启半同步复制】

SET GLOBAL rpl_semi_sync_slave_enabled=ON;
或者在my.cnf配置文件中配置
[mariadb]
.....
rpl_semi_sync_slave_enabled=ON

【从服务器重启IO线程】

如果在副本运行的时候,启用半同步复制,则需要重新启动从服务器的I/O线程
STOP SLAVE IO_THREAD;
START SLAVE IO_THREAD;

【设置半同步的超时时间】

#20秒
SET GLOBAL rpl_semi_sync_master_timeout=20000;
或者在my.cnf配置文件中配置:
[mariadb]
....
rpl_semi_sync_master_timeout=20000

【查看半同步被关闭的次数】

show variables like '%Rpl_semi_sync_master_no_times%';

【配置主服务器的等待响应时间点】

#等待点由rpl_semi_sync_master_wait_point系统变量配置:AFTER_SYNC|AFTER_COMMIT。
SET GLOBAL rpl_semi_sync_master_wait_point='AFTER_SYNC';
或者在my.cnf配置文件中配置:
[mariadb]
...
rpl_semi_sync_master_wait_point=AFTER_SYNC

相关文章:

MariaDB-10.8.6安装+主从搭建

【系统版本】CentOS 7.x Linux version 3.10.0-1062.18.1.el7.x86_64【检查系统是否安装过Mysql|mariadb】【查看是否安装Mysql|mariadb】#搜索mysql rpm -qa|grep mysql #搜索mariadb rpm -qa|grep mariadb #搜索MariaDB rpm -qa|grep MariaDB #如果安装过Mysql|mariadb&#…...

Win11系统user profile service服务登录失败解决方法

Win11系统user profile service服务登录失败解决方法分享。有用户在使用电脑的时候遇到了一些问题,系统的user profile service服务无法登录了。出现这个问题可能是系统文件损坏,或者中了病毒。接下来我们一起来看看如何解决这个问题的操作方法分享吧。 …...

Solon2 之基础:四、应用启动过程与完整生命周期

串行的处理过程(含六个事件扩展点 两个函数扩展点),代码直接、没有什么模式。易明 提醒: 启动过程完成后,项目才能正常运行(启动过程中,不能把线程卡死了)AppBeanLoadEndEvent 之前…...

Java性能分析

0、问题代码: 代码问题其实很明显,但是这里主要是为了练习如何使用工具进行分析 所以最好先不要看代码,假装不知道程序逻辑,而是先通过工具去分析,再结合分析数据去看代码,从而推出问题点在哪 import jav…...

2023年阿里云ECS服务器S6/C6/G6/N4/R6/sn2ne/sn1ne/se1ne处理器CPU性能详解

阿里云ECS服务器S6/C6/G6/N4/R6/sn2ne/sn1ne/se1ne处理器CPU性能怎么样?阿里云服务器优惠活动机型有云服务器S6、计算型C6、通用型G6、内存型R6、云服务器N4、云服务器sn2ne、云服务器sn1ne、云服务器se1ne处理器CPU性能详解及使用场景说明。 1、阿里云服务器活动机…...

数据分析与SAS学习笔记8

过程步:一个典型的SAS完整程序: 代码说明: 1)reg:回归分析; 2)model:因变量和自变量。 proc开头部分叫过程步。 常用过程: SORT过程: PRINT过程与FORTMAT…...

切割多个conf文件Nginx和Apache配置多版本PHP

有时候我们的项目不可能都是同一个PHP版本,需要每个项目都配置不同版本的PHP,宝塔和PHPStudy就是通过以下配置实现的:Nginx切割conf(非选)在nginx.conf添加include vhosts/*.conf;这样Nginx会自动引入当前目录->vho…...

使用Navicat进行SSH加密方式连接MySQL数据库

前言近年来网络安全形式日趋严峻,为保障企业信息安全和业务连续性,越来越多的要求业务系统上线前需要满足等保要求。其中数据库作为存储数据的载体,安全更是重中之重。部分等保要求,mysql数据库不能通过直连方式连接,需…...

大数据Hadoop教程-学习笔记04【数据仓库基础与Apache Hive入门】

视频教程:哔哩哔哩网站:黑马大数据Hadoop入门视频教程 总时长:14:22:04教程资源: https://pan.baidu.com/s/1WYgyI3KgbzKzFD639lA-_g 提取码: 6666【P001-P017】大数据Hadoop教程-学习笔记01【大数据导论与Linux基础】【17p】【P018-P037】大…...

20230223 刚体上的两个点速度之间的关系

刚体上的两个点速度之间的关系 注意:这里所讨论的都是投影在惯性坐标系上的。 dMAdMOdOAdMOdCA−dCOd_{_{MA}}d_{_{MO}}d_{_{OA}}d_{_{MO}}d_{_{CA}}-d_{_{CO}}dMA​​dMO​​dOA​​dMO​​dCA​​−dCO​​ 求导 d˙MAd˙MOd˙CA−d˙CO\dot d_{_{MA}}\dot d_{_…...

17.1 Display system tasks

系统任务的显示组分为三类:显示和写入任务、选通监视任务和连续监视任务。17.1.1 The display and write tasks $display和$write系统任务的语法如语法17-1所示。 display_tasks ::display_task_name [ ( list_of_arguments ) ] ; display_task_name ::$display | …...

【4】linux命令每日分享——cd切换路径

大家好,这里是sdust-vrlab,Linux是一种免费使用和自由传播的 类UNIX操作系统,Linux的基本思想有两点:一切都是文件;每个文件都有确定的用途;linux涉及到IT行业的方方面面,在我们日常的学习中&am…...

诚邀您体验人工智能AI

近期,人工智能(AI)领域动作频频,OPENAI公司Chat GPT的出现,标志着人工智能的研究与应用已经进入了一个崭新的发展阶段,国内腾讯、阿里巴巴、百度、易网、国外微软、谷歌、苹果、IBM、Amazon,等互…...

【蓝桥杯集训·每日一题】AcWing 2058. 笨拙的手指

文章目录一、题目1、原题链接2、题目描述二、解题报告1、思路分析2、时间复杂度3、代码详解三、知识风暴哈希表秦九韶算法一、题目 1、原题链接 2058. 笨拙的手指 2、题目描述 奶牛贝茜正在学习如何在不同进制之间转换数字。 但是她总是犯错误,因为她无法轻易的用两…...

运维排查篇 | Linux 连接跟踪表满了怎么处理

nf_conntrack (在老版本的 Linux 内核中叫 ip_conntrack )是一个内核模块,用于跟踪一个网络连接的状态 一旦内核 netfilter 模块 conntrack 相关参数配置不合理,导致 nf_conntrack table full ,就会出现丢包、连接无法建立的问题 这个问题其…...

docker网络基

本文简单介绍下,容器之间的网络访问、容器与宿主机之间的网络访问、宿主机上有哪些网络接口。lolocal的简写,本地回环地址,127.0.0.1,它代表本地虚拟设备接口,默认被看作是永远不会宕掉的接口eth0ethernet的简写&#…...

C++:谈谈单例模式的多种实现形式

文章目录实现 1:静态成员实现 2:atexit 懒汉模式实现 3:原子变量 懒汉模式实现4:atexit 饿汉模式* 实现5:magic static单例模式:保证一个类仅有一个实例,并提供一个该实例的全局访问点。 稳…...

【Spring Cloud Alibaba】007-Nacos 配置*

【Spring Cloud Alibaba】007-Nacos 配置* 文章目录【Spring Cloud Alibaba】007-Nacos 配置*一、概述1、概述2、对比 spring cloud config二、基本使用1、在管理界面新建配置2、启动权限3、 搭建 nacos-config 服务第一步:引入依赖第二步:修改 yaml 配置…...

《安富莱嵌入式周报》第304期:开源硬件耳机设计,AI单片机STM32N6已确定为M55内核,另外还有新品STM32H5, H50X, H7R, H7S发布

往期周报汇总地址:嵌入式周报 - uCOS & uCGUI & emWin & embOS & TouchGFX & ThreadX - 硬汉嵌入式论坛 - Powered by Discuz! 更新一期视频教程: 第6期ThreadX视频教程:图文并茂吃透RTOS运行机制,任务管理&…...

vuex篇

1.简介(1)vuexVuex 是一个专为 Vue.js 应用程序开发的状态管理模式 库vuex是为vue.js开发的状态管理模式、组件状态集中管理(2)单页面数据流状态发生变化, 视图就重新渲染state发生变化时, 导致view视图发生改变, 视图通过操作action行为, 又会使得state状态发生变化(3)使用场…...

STM32单片机技术解析与应用实践

1. STM32的崛起背景与市场格局演变在2007年之前,单片机市场呈现"三足鼎立"的格局:以STC为代表的51系列8位机占据教学和工业控制领域,MSP430在低功耗应用场景表现突出,AVR和PIC则在特定细分市场各有所长。这些8位和16位单…...

2026届最火的六大降重复率神器实际效果

Ai论文网站排名(开题报告、文献综述、降aigc率、降重综合对比) TOP1. 千笔AI TOP2. aipasspaper TOP3. 清北论文 TOP4. 豆包 TOP5. kimi TOP6. deepseek 目前人工智能生成内容大范围运用的情形下,致使 AIGC 检测识别率降低的工具适时出…...

2025届学术党必备的六大降重复率神器横评

Ai论文网站排名(开题报告、文献综述、降aigc率、降重综合对比) TOP1. 千笔AI TOP2. aipasspaper TOP3. 清北论文 TOP4. 豆包 TOP5. kimi TOP6. deepseek 当前,人工智能技术快速发展,这为毕业论文写作提供了新的辅助路径&…...

一台机器也能玩转StarRocks?手把手教你搭建单机测试环境(附避坑指南)

一台机器玩转StarRocks:单机测试环境搭建实战与避坑指南 当你想快速验证StarRocks的功能特性,或者进行本地开发测试时,单机部署是最便捷的选择。虽然官方并不推荐在生产环境中使用单机模式,但对于个人开发者、学生或测试场景来说&…...

如何从零搭建Cubli_Mini:开源自平衡机器人完整制作指南

如何从零搭建Cubli_Mini:开源自平衡机器人完整制作指南 【免费下载链接】Cubli_Mini 项目地址: https://gitcode.com/gh_mirrors/cu/Cubli_Mini Cubli_Mini是一款令人惊叹的开源自平衡立方体机器人项目,它通过三个正交安装的飞轮实现姿态控制&am…...

哪款工具能把AI率从80%降到20%?实测3款对比

这篇文章的起点是一个具体问题:AI率80%以上的论文,用哪款工具降,能稳定降到20%以下? 我用3篇不同专业、不同AI率的论文(AI率分别为82%、86%、91%),分别测试了嘎嘎降AI、比话降AI、率零三款工具…...

2025 年12月9日-KB5072033(操作系统内部版本 26200.7462和26100.7462)

🔥个人主页:杨利杰YJlio❄️个人专栏:《Sysinternals实战教程》《Windows PowerShell 实战》《WINDOWS教程》《IOS教程》《微信助手》《锤子助手》 《Python》 《Kali Linux》《那些年未解决的Windows疑难杂症》🌟 让复杂的事情更…...

2026届毕业生推荐的十大降AI率网站横评

Ai论文网站排名(开题报告、文献综述、降aigc率、降重综合对比) TOP1. 千笔AI TOP2. aipasspaper TOP3. 清北论文 TOP4. 豆包 TOP5. kimi TOP6. deepseek 达成降低AIGC率这一目标,也就是要削减文本里那种能够被辨认作是人工智能生成内容…...

智能家居集成新方案:Home Assistant与小米设备的跨平台控制实现

智能家居集成新方案:Home Assistant与小米设备的跨平台控制实现 【免费下载链接】ha_xiaomi_home Xiaomi Home Integration for Home Assistant 项目地址: https://gitcode.com/GitHub_Trending/ha/ha_xiaomi_home 【突破生态限制】智能家居跨平台集成方案 …...

告别重复造轮子:用快马一键生成tokenp钱包交互模块,极速提升dApp开发效率

告别重复造轮子:用快马一键生成tokenp钱包交互模块,极速提升dApp开发效率 在开发涉及tokenp功能的dApp时,最让人头疼的就是每次都要重复编写钱包连接、交易发送等通用代码。这些基础功能虽然不复杂,但写起来确实费时费力。最近我…...