当前位置: 首页 > 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)使用场…...

IDEA运行Tomcat出现乱码问题解决汇总

最近正值期末周,有很多同学在写期末Java web作业时,运行tomcat出现乱码问题,经过多次解决与研究,我做了如下整理: 原因: IDEA本身编码与tomcat的编码与Windows编码不同导致,Windows 系统控制台…...

MySQL 隔离级别:脏读、幻读及不可重复读的原理与示例

一、MySQL 隔离级别 MySQL 提供了四种隔离级别,用于控制事务之间的并发访问以及数据的可见性,不同隔离级别对脏读、幻读、不可重复读这几种并发数据问题有着不同的处理方式,具体如下: 隔离级别脏读不可重复读幻读性能特点及锁机制读未提交(READ UNCOMMITTED)允许出现允许…...

大模型多显卡多服务器并行计算方法与实践指南

一、分布式训练概述 大规模语言模型的训练通常需要分布式计算技术,以解决单机资源不足的问题。分布式训练主要分为两种模式: 数据并行:将数据分片到不同设备,每个设备拥有完整的模型副本 模型并行:将模型分割到不同设备,每个设备处理部分模型计算 现代大模型训练通常结合…...

[Java恶补day16] 238.除自身以外数组的乘积

给你一个整数数组 nums,返回 数组 answer ,其中 answer[i] 等于 nums 中除 nums[i] 之外其余各元素的乘积 。 题目数据 保证 数组 nums之中任意元素的全部前缀元素和后缀的乘积都在 32 位 整数范围内。 请 不要使用除法,且在 O(n) 时间复杂度…...

今日学习:Spring线程池|并发修改异常|链路丢失|登录续期|VIP过期策略|数值类缓存

文章目录 优雅版线程池ThreadPoolTaskExecutor和ThreadPoolTaskExecutor的装饰器并发修改异常并发修改异常简介实现机制设计原因及意义 使用线程池造成的链路丢失问题线程池导致的链路丢失问题发生原因 常见解决方法更好的解决方法设计精妙之处 登录续期登录续期常见实现方式特…...

JVM虚拟机:内存结构、垃圾回收、性能优化

1、JVM虚拟机的简介 Java 虚拟机(Java Virtual Machine 简称:JVM)是运行所有 Java 程序的抽象计算机,是 Java 语言的运行环境,实现了 Java 程序的跨平台特性。JVM 屏蔽了与具体操作系统平台相关的信息,使得 Java 程序只需生成在 JVM 上运行的目标代码(字节码),就可以…...

A2A JS SDK 完整教程:快速入门指南

目录 什么是 A2A JS SDK?A2A JS 安装与设置A2A JS 核心概念创建你的第一个 A2A JS 代理A2A JS 服务端开发A2A JS 客户端使用A2A JS 高级特性A2A JS 最佳实践A2A JS 故障排除 什么是 A2A JS SDK? A2A JS SDK 是一个专为 JavaScript/TypeScript 开发者设计的强大库&#xff…...

ubuntu系统文件误删(/lib/x86_64-linux-gnu/libc.so.6)修复方案 [成功解决]

报错信息:libc.so.6: cannot open shared object file: No such file or directory: #ls, ln, sudo...命令都不能用 error while loading shared libraries: libc.so.6: cannot open shared object file: No such file or directory重启后报错信息&…...

深入解析 ReentrantLock:原理、公平锁与非公平锁的较量

ReentrantLock 是 Java 中 java.util.concurrent.locks 包下的一个重要类,用于实现线程同步,支持可重入性,并且可以选择公平锁或非公平锁的实现方式。下面将详细介绍 ReentrantLock 的实现原理以及公平锁和非公平锁的区别。 ReentrantLock 实现原理 基本架构 ReentrantLo…...

初探用uniapp写微信小程序遇到的问题及解决(vue3+ts)

零、关于开发思路 (一)拿到工作任务,先理清楚需求 1.逻辑部分 不放过原型里说的每一句话,有疑惑的部分该问产品/测试/之前的开发就问 2.页面部分(含国际化) 整体看过需要开发页面的原型后,分类一下哪些组件/样式可以复用,直接提取出来使用 (时间充分的前提下,不…...