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

测试微信模版消息推送

进入“开发接口管理”--“公众平台测试账号”,无需申请公众账号、可在测试账号中体验并测试微信公众平台所有高级接口。 获取access_token: 自定义模版消息: 关注测试号:扫二维码关注测试号。 发送模版消息: import requests da…...

三维GIS开发cesium智慧地铁教程(5)Cesium相机控制

一、环境搭建 <script src"../cesium1.99/Build/Cesium/Cesium.js"></script> <link rel"stylesheet" href"../cesium1.99/Build/Cesium/Widgets/widgets.css"> 关键配置点&#xff1a; 路径验证&#xff1a;确保相对路径.…...

YSYX学习记录(八)

C语言&#xff0c;练习0&#xff1a; 先创建一个文件夹&#xff0c;我用的是物理机&#xff1a; 安装build-essential 练习1&#xff1a; 我注释掉了 #include <stdio.h> 出现下面错误 在你的文本编辑器中打开ex1文件&#xff0c;随机修改或删除一部分&#xff0c;之后…...

【学习笔记】深入理解Java虚拟机学习笔记——第4章 虚拟机性能监控,故障处理工具

第2章 虚拟机性能监控&#xff0c;故障处理工具 4.1 概述 略 4.2 基础故障处理工具 4.2.1 jps:虚拟机进程状况工具 命令&#xff1a;jps [options] [hostid] 功能&#xff1a;本地虚拟机进程显示进程ID&#xff08;与ps相同&#xff09;&#xff0c;可同时显示主类&#x…...

dify打造数据可视化图表

一、概述 在日常工作和学习中&#xff0c;我们经常需要和数据打交道。无论是分析报告、项目展示&#xff0c;还是简单的数据洞察&#xff0c;一个清晰直观的图表&#xff0c;往往能胜过千言万语。 一款能让数据可视化变得超级简单的 MCP Server&#xff0c;由蚂蚁集团 AntV 团队…...

代理篇12|深入理解 Vite中的Proxy接口代理配置

在前端开发中,常常会遇到 跨域请求接口 的情况。为了解决这个问题,Vite 和 Webpack 都提供了 proxy 代理功能,用于将本地开发请求转发到后端服务器。 什么是代理(proxy)? 代理是在开发过程中,前端项目通过开发服务器,将指定的请求“转发”到真实的后端服务器,从而绕…...

MySQL 知识小结(一)

一、my.cnf配置详解 我们知道安装MySQL有两种方式来安装咱们的MySQL数据库&#xff0c;分别是二进制安装编译数据库或者使用三方yum来进行安装,第三方yum的安装相对于二进制压缩包的安装更快捷&#xff0c;但是文件存放起来数据比较冗余&#xff0c;用二进制能够更好管理咱们M…...

c++第七天 继承与派生2

这一篇文章主要内容是 派生类构造函数与析构函数 在派生类中重写基类成员 以及多继承 第一部分&#xff1a;派生类构造函数与析构函数 当创建一个派生类对象时&#xff0c;基类成员是如何初始化的&#xff1f; 1.当派生类对象创建的时候&#xff0c;基类成员的初始化顺序 …...

Golang——7、包与接口详解

包与接口详解 1、Golang包详解1.1、Golang中包的定义和介绍1.2、Golang包管理工具go mod1.3、Golang中自定义包1.4、Golang中使用第三包1.5、init函数 2、接口详解2.1、接口的定义2.2、空接口2.3、类型断言2.4、结构体值接收者和指针接收者实现接口的区别2.5、一个结构体实现多…...

手机平板能效生态设计指令EU 2023/1670标准解读

手机平板能效生态设计指令EU 2023/1670标准解读 以下是针对欧盟《手机和平板电脑生态设计法规》(EU) 2023/1670 的核心解读&#xff0c;综合法规核心要求、最新修正及企业合规要点&#xff1a; 一、法规背景与目标 生效与强制时间 发布于2023年8月31日&#xff08;OJ公报&…...