mysql 半同步复制模式使用详解
目录
一、前言
二、mysql主从架构简介
2.1 mysql主从复制架构概述
2.2 为什么使用主从架构
2.2.1 提高数据可用性
2.2.2 提高数据可靠性
2.2.3 提升数据读写性能
2.3 主从架构原理
2.4 主从架构扩展
2.4.1 双机热备(AB复制)
2.4.2 级联复制
2.4.3 并联复制(一主多从)
三、搭建mysql主从
3.1 环境准备
3.2 搭建mysql主节点
3.2.1 配置yum源
3.2.2 安装mysql源
3.2.3 检查mysql源是否安装成功
3.2.4 安装mysql
3.2.5 启动mysql服务
3.2.5 mysql目录介绍
3.2.6 修改root账户密码
3.2.7 修改配置文件
3.3 搭建mysql从节点
3.4 主从节点配置
3.4.1 master配置
3.4.2 slave配置
3.5 创建同步账号
3.6 slave开启同步
3.7 测试与验证
四、搭建半同步复制
4.1 主从复制架构问题
4.2 什么是半同步复制
4.3 半同步复制搭建流程
4.3.1 前置准备
4.3.2 安装mysql插件
4.3.3 激活插件
4.3.4 slave节点重启IO线程
4.4 半同步复制效果测试
4.4.1 master插入一条数据
4.4.2 slave模拟发生故障
4.4.3 重新启动半同步复制
4.4.4 修改master等待时间
4.4.5 卸载半同步复制插件
4.4.6 补充说明
五、写在文末
一、前言
mysql主从架构对很多同学来说并不陌生,mysql主从模式是很多集群架构的基础,基于mysql主从模式可以衍生出更复杂的集群架构,从而解决大规模甚至超大规模的数据问题,因此是每个学习者必须掌握的技能。但在实际业务中,单一的主从复制并不能很好的满足业务,因为mysql主从模式的数据同步是异步的,这就造成从节点可能会同步失败,于是就有了半同步复制模式。但是在开始学习半同步复制模式之前,让我们全面深入的了解下经典的mysql主从模式吧。
二、mysql主从架构简介
2.1 mysql主从复制架构概述
MySQL主从复制是指,将一个MySQL数据库数据同步到另一个MySQL数据库的过程。其中一个数据库是主库,另一个或多个数据库作为从数据库。主数据库负责写入和更新数据,而从数据库则复制主数据库的数据。
2.2 为什么使用主从架构
使用mysql主从架构,可以提高数据的可用性、可靠性和性能。
2.2.1 提高数据可用性
主从复制可以提高数据可用性。
如果主数据库出现故障,从数据库可以接管并提供服务,从而保障业务正常运行。主从复制还可以帮助实现数据备份和恢复,从而避免数据丢失和损坏。
2.2.2 提高数据可靠性
主从复制可以提高数据可靠性。
当主数据库发生故障时,从数据库可以接管并提供服务,从而避免数据的丢失和损坏。主从复制还可以实现数据的近实时同步,从而避免数据的不一致性和错误。
2.2.3 提升数据读写性能
主从复制可以提高数据性能。
当主数据库处理大量的并发请求时,可以通过配置读写分离的方式将一部分读请求分给从库,从而缓解主数据库压力,提高整个系统的性能。
2.3 主从架构原理
简单来说,master将数据库的改变写入二进制日志,slave同步这些二进制日志,并根据这些二进制日志进行数据重演操作,实现数据异步同步。如下图所示为主从复制的过程。
结合上图,其详细的执行流程如下:
- slave端的IO线程发送请求给master端的binlog dump线程;
- master端binlog dump线程获取二进制日志信息(文件名和位置信息)发送给slave端的IO线程;
- salve端IO线程获取到的内容依次写到slave端relay log(中继日志)里,并把master端的bin-log文件名和位置记录到master.info里;
- salve端的SQL线程,检测到relay log中内容更新,就会解析relay log里更新的内容,并执行这些操作,从而达到和master数据一致;
relay log :中继日志;
relay log 作用:记录从(slave)服务器接收来自主(master)服务器的二进制日志
2.4 主从架构扩展
由主从架构,结合实际业务,还可以扩展出更多的架构模式,下面列举几种由主从复制扩展出来的架构。
2.4.1 双机热备(AB复制)
在这种模式下,master 接受读写请求,而slave只接受读请求以减轻master的压力。
2.4.2 级联复制
即多个slave互相串联成一个链条的模式,后面的slave从前面的一个slave复制数据;
优点:可进一步分担读压力;
缺点:slave1(或中间某个slave) 出现故障,后面的所有级联slave服务器都会同步失败;
2.4.3 并联复制(一主多从)
即一个master下面挂载多个slave节点;
特点:
从命名来看,两台master好像都能接受读、写请求,但实际上,往往运作的过程中,同一时刻只有其中一台master会接受写请求,另外一台接受读请求。
基于这种思想,如果想要实现多节点数据强一致性,业界也产生了其他成熟的解决方案,比如PXC集群模式,MGR集群模式,都属于多主模式,即多个节点均作为master同时对外提供读写服务。
三、搭建mysql主从
3.1 环境准备
本文使用云服务器,最低配置 2核2G,带宽4mb/s
编号 | IP地址 | 角色 | 操作系统 | 配置 |
---|---|---|---|---|
1 | 101.34.111.131 | 主节点(Master) | centos7.6 | 2核4G |
2 | 101.34.111.132 | 从节点(Slave) | centos7.6 | 2核2G |
3.2 搭建mysql主节点
下面基于rpm方式搭建,mysql版本为5.7,主从两个节点安装的过程基本相同,只在最后配置主从关系时有所不同,后面会重点说明,先演示在主节点使用rpm的方式安装mysql。
3.2.1 配置yum源
下载rpm包
wget http://dev.mysql.com/get/mysql57-community-release-el7-8.noarch.rpm
如果出现-bash: weget: command not found,需要yum install -y wget
如果安装不了,就使用wget配置镜像仓库(阿里云、网易云等),具体操作步骤如下:
1)备份CentOS-Base.repo:mv /etc/yum.repos.d/CentOS-Base.repo /etc/yum.repos.d/CentOS-Base.repo.backup;
2)下载阿里云镜像:wget -O /etc/yum.repos.d/CentOS-Base.repo http://mirrors.aliyun.com/repo/Centos-7.repo;
3)清理缓存:yum clean all;
4)生成缓存:yum makeache;
5)更新最新源设置:yum update -y;
3.2.2 安装mysql源
yum localinstall mysql57-community-release-el7-8.noarch.rpm
3.2.3 检查mysql源是否安装成功
yum repolist enabled
3.2.4 安装mysql
yum -y install mysql-community-server --nogpgcheck
3.2.5 启动mysql服务
与mysql启停相关的命令如下
systemctl start mysqld
systemctl stop mysqld
systemctl restart mysqld
执行启动命令之后,查看启动状态
systemctl status mysqld
3.2.5 mysql目录介绍
yum安装mysql默认文件路径(在my.cnf不做其他配置的情况下)
默认配置文件路径: 配置文件:/etc/my.cnf
日志文件:/var/log/mysqld.log
服务启动脚本:/usr/lib/systemd/system/mysqld.service
socket文件:/var/run/mysqld/mysqld.pid
插件目录:/usr/lib64/mysql/plugin;
3.2.6 修改root账户密码
mysql安装完后,在文件中给生成一个默认密码,如果后续需要在其他客户端登录,需要重新修改密码并授权,通过下面的方式找到这个密码:
grep 'temporary password' /var/log/mysqld.log
找到这个密码之后,使用命令登录进去,但是从mysql5.7之后的某个版本开始,登录之后使用下面的命令直接修改的话,可能会报下面的错误;
set password=password('123456');
这个意思是说,mysql5.7默认安装了密码安全检查插件,默认密码检查策略要求密码必须包含:大小写字母、数字和特殊符号,并且长度不能少于8位。通过下面的命令可以查看密码策略的相关信息
show variables like '%password%';
关于参数具体含义,可以查阅相关的资料,网上比较丰富,为了简化后续的操作,这里提供一种比较简单的修改方式;
密码修改策略
在/etc/my.cnf文件添加validate_password_policy配置,指定密码策略,配置如下:
validate_password_policy=0
# 选择0(LOW),1(MEDIUM),2(STRONG)其中一种,选择2需要提供密码字典文件
如果不需要密码策略,添加my.cnf文件中添加如下配置禁用即可:
validate_password=off
上面的配置完成之后,最后重启mysql服务,再次登录到mysql客户端,重新修改mysql的root密码
set password=password('123456');
grant all on *.* to root@'%' identified by '123456';
flush privileges;
3.2.7 修改配置文件
mysql主从的配置中,主节点必不可少的配置,一个是开启二进制日志,另一个是主从节点的server-id不能一样,首先在主节点添加下面的配置信息
log-bin=mysql-bin
binlog-format=ROW
server_id=1
修改完成后,重启主节点服务,然后在mysql安装目录下就可以看到bin-log的文件了
3.3 搭建mysql从节点
整个搭建的过程基本相同,执行步骤一直到启动mysql从节点的服务即可,这里就不再赘述了,参考上面的步骤执行即可;
3.4 主从节点配置
分别在master节点和slave节点的my.cnf中做如下配置
3.4.1 master配置
参照上面步骤如果配置过了可忽略
3.4.2 slave配置
在/etc目录下找到my.cnf,添加下面的配置,确保主从节点的server-id不同
server-id=2
3.5 创建同步账号
在master节点上面执行创建slave用于同步数据的账号
create user master@'从数据库IP' identified with mysql_native_password by 'master_pass';
grant replication slave on *.* to master@'从数据库IP' identified by 'master_pass';
flush privileges;
查看master状态
show master status;
3.6 slave开启同步
从服务器登录进客户端之后依次执行下面的命令
#停止本机的同步
stop slave;#配置从服务器连接主服务器的配置项
change master to master_host='master 的IP',master_user='master',master_password='123456',master_log_file='mysql-bin.000001',master_log_pos=864;#刷新
flush privileges;查看同步状态
show slave status\G;#开启slave状态
start slave;show slave status\G;
当看到下面的这两个位置都为 Yes的时候说明主从环境配置完成;
3.7 测试与验证
在master上面创建一个数据库,创建一张表,并写入几条数据,检查是否能在从节点完成同步
create database test;
use test;
CREATE TABLE `tb_user` (`id` int(12) NOT NULL,`name` varchar(32) DEFAULT NULL,`age` int(12) DEFAULT NULL,`subject` varchar(32) DEFAULT NULL,PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
insert into tb_user values (1,'liubei',33,'java');
到这里主从复制的环境就基本上搭建完成,接下来我们将基于该环境搭建出半同步复制的环境。
四、搭建半同步复制
4.1 主从复制架构问题
深入了解过主从模式的同学应该知道,在主从模式下,数据写入master时,并不关注后续数据是否成功写入到slave,即这是一个异步的过程,这样的一个比较明显的问题就是,假如数据同步过程中发生什么问题,master是无感知的,这样就造成了数据的不一致,此时假如请求发到slave上,可能造成读取数据失败的问题。有没有什么机制可以保证同步数据的准确性呢?可以考虑使用半同步复制的模式。
4.2 什么是半同步复制
所谓的半同步复制就是master每commit一个事务(简单来说就是做一个改变数据的操作),要确保slave接受完主服务器发送的binlog日志文件并写入到自己的中继日志relay log里,然后会给master信号,告诉对方已经接收完毕,这样master才能把事物成功commit。
这样就保证了master-slave的数据绝对一致(但是以牺牲master的性能为代价),不过由于slave的同步写入数据需要一定时间,所以整个过程的时间会拉长,但等待slave响应的时间也是可以调整的。可以结合下面这张半同步复制的流程图进行理解。
4.3 半同步复制搭建流程
4.3.1 前置准备
完成mysql主从架构的搭建(上面已经完成);
4.3.2 安装mysql插件
半同步复制模式的实现需要借助mysql插件,其实在安装完成mysql之后,就默认带了一些插件工具,基于上述rpm的方式安装,插件的目录位置:/usr/lib64/mysql/plugin
master节点安装如下插件,进入客户端命令行,执行下面的语句;
install plugin rpl_semi_sync_master soname 'semisync_master.so';
检查是否安装成功,安装成功后,就能看到该插件相关的选项信息;
show global variables like 'rpl_semi_sync%';
slave节点安装如下插件,进入客户端命令行,执行下面的语句;
install plugin rpl_semi_sync_slave soname 'semisync_slave.so';
show global variables like 'rpl_semi_sync%';
4.3.3 激活插件
上面在master和slave节点分别安装了半同步复制的插件,此时状态均为OFF,接下来需要对插件进行激活;
master节点执行如下命令激活,在上一步的基础上执行,激活后再次确认状态;
set global rpl_semi_sync_master_enabled=on;
show global variables like 'rpl_semi_sync%';
slave节点执行如下命令激活,在上一步的基础上执行,激活后再次确认状态;
set global rpl_semi_sync_slave_enabled=on;
show global variables like 'rpl_semi_sync%';
4.3.4 slave节点重启IO线程
在上面的基础上,即slave客户端窗口执行下面的语句重启IO线程
stop slave IO_THREAD;
start slave IO_THREAD;
4.4 半同步复制效果测试
从上文关于半同步复制原理了解到,当slave从库的IO_Thread 线程将binlog日志接受完毕后,要给master一个确认,如果超过10s未收到slave的接收确认信号,那么就会自动转换为传统的异步复制模式。接下来看具体的操作步骤。
4.4.1 master插入一条数据
基于上面环境,master中test库下给tb_user表插入一条数据
insert into tb_user values (2,'zhaoyun',23,'flink');
如果插入成功,使用下面的语句,查看slave是否有成功返回
show global status like 'rpl_semi_sync%_yes_tx';
Value为1:表示这次事物成功从slave返回一次确认信号 ,以后每成功一次,数字会依次递增
同时检查slave这边,可以看到数据同步写入成功
4.4.2 slave模拟发生故障
假如环境中此时slave发生故障会怎么样呢?停止slave的mysql
systemctl stop mysqld
再次向master插入一条新数据
insert into tb_user values (3,'guanyu',35,'go');
从效果不难发现,sql语句执行等待了10秒钟,这就是在半同步复制模式下,master等待slave响应默认的等待时间,此时再次在master插入一条数据;
insert into tb_user values (5,'zhangliao',28,'hadoop');
这一次很快就执行完成了,因为基于 这种模式下,在上一步master这边发现slave挂掉了,于是就自动转成了原来的异步模式。
4.4.3 重新启动半同步复制
重新启动slave的mysql服务,并开启半同步复制,依次执行下面的语句
systemctl restart mysqld
set global rpl_semi_sync_slave_enabled=on;
stop slave IO_THREAD;
start slave IO_THREAD;
当上面的步骤完成后,主从半同步复制又开启了,同时,slave服务停掉期间在master上面插入的两条数据也再次同步过来了;
master需要等到slave确认后才能提交,如果等不到确认消息,master等待10s种后自动变成异步同步;slave启起来后,master上改变的数据还是会自动复制过来,数据又回到一致。
此时再次在master节点上再次插入一条数据,slave中能够查到,说明数据同步功能也恢复正常;
insert into tb_user values (6,'zhangfei',38,'python');
4.4.4 修改master等待时间
在上面的故障模拟中,第一次master默认的等待时间为10s,如果觉得太长,可以通过执行下面的语句调整
set global rpl_semi_sync_master_timeout=5000;
show global variables like 'rpl_semi_sync%';
4.4.5 卸载半同步复制插件
如果不想再使用该插件了,可以通过下面的命令进行卸载
#查看系统中的插件
select plugin_name,load_option from information_schema.plugins;
#卸载某个插件
uninstall plugin 插件名称;
4.4.6 补充说明
在某些情况下,当使用上面的命令先停止slave的mysql服务,然后再重新启动,登录到客户端之后,使用 show slave status命令的时候,发现下面两个参数的状态均为NO;
Slave_IO_Running NO
Slave_SQL_Running: NO
这种情况表明,mysqld重启后,主从同步也会随之关闭,需要手动重新开启,执行下面的命令即可重新建立slave与master的关系;
start slave;
五、写在文末
本文通过较大的篇幅详细阐述了mysql主从复制的相关技术,以及基于mysql主从复制基础上如何搭建和配置mysql半同步复制模式,在生产实践中具有一定的参考性,希望对看到的你有用哦,本篇到此结束,感谢观看。
相关文章:
mysql 半同步复制模式使用详解
目录 一、前言 二、mysql主从架构简介 2.1 mysql主从复制架构概述 2.2 为什么使用主从架构 2.2.1 提高数据可用性 2.2.2 提高数据可靠性 2.2.3 提升数据读写性能 2.3 主从架构原理 2.4 主从架构扩展 2.4.1 双机热备(AB复制) 2.4.2 级联复制 2…...
以太坊代币标准ERC20、ERC721
两个概念 ERC(Ethereum Request for Comment) 以太坊意见征集稿EIP(Ethereum Improvement Proposals)以太坊改进提案 ERC和EIP用于使得以太坊更加完善;在ERC中提出了很多标准,用的最多的标准就是它的Token标准; 有哪些标准详细见https://eips.ethereum…...
编写基于冒泡排序算法的qsort函数
目录 1.简单认识冒泡排序 2.进入正文分析如何实现函数 3.1比较两个相邻元素的大小 3.2比较两个相邻元素大小后要换函数 4.my_qsort函数: 5.总结: 1.简单认识冒泡排序 冒泡排序的步骤如下: 比较相邻的两个元素,如果第一个元素比…...
有什么推荐使用的企业上网行为管理软件?
在当今信息化社会,企业的上网行为管理越来越重要。企业上网行为软件是一种能够监控和管理企业员工上网行为的工具,它可以帮助企业更好地管理网络资源,提高工作效率,保护企业信息安全,并符合相关的法律法规。本文将深入…...
机器学习第五课--广告点击率预测项目以及特征选择的介绍
这个项目的主要的目的是通过给定的广告信息和用户信息来预测一个广告被点击与否。 如果广告有很大概率被点击就展示广告,如果概率低,就不展示。 因为如果广告没有被点击,对双方(广告主、平台)来讲都没有好处。所以预测…...
细说tcpdump的妙用
原文地址:EMC中文支持论坛https://community.emc.com/go/chinese 介绍 tcpdump命令最初设计用于观察TCP/IP性能问题,它是一个用于截取网络分组,并输出分组内容的工具。tcpdump可以将网络中传送的数据包的报文头完全截获下来提供分析,它支持针…...
【深度学习实验】前馈神经网络(七):批量加载数据(直接加载数据→定义类封装数据)
目录 一、实验介绍 二、实验环境 1. 配置虚拟环境 2. 库版本介绍 三、实验内容 0. 导入必要的工具包 1. 直接加载鸢尾花数据集 a. 加载数据集 b. 数据归一化 c. 洗牌操作 d. 打印数据 2. 定义类封装数据 a. __init__(构造函数:用于初始化数据集对象) b.…...
气体放电模拟装置中1Pa~101kPa范围内的真空度控制技术
摘要:针对微间隙气体放电特性分析中需要对不同真空压力进行精密控制的要求,本文提出了相应的解决方案。解决方案采用了双路调节技术,由真空计、电控针阀和真空压力控制器组成进气和排气控制回路,可实现真空度1Pa~101kPa全量程范围…...
华为OD机试 - 构成正方形的数量 - 数据结构map(Java 2023 B卷 100分)
目录 专栏导读一、题目描述二、输入描述三、输出描述四、Java算法源码五、效果展示1、输入2、输出3、说明 华为OD机试 2023B卷题库疯狂收录中,刷题点这里 专栏导读 本专栏收录于《华为OD机试(JAVA)真题(A卷B卷)》。 …...
sql on条件判断是要注意null值
我是因为用了merge into语法,然后on条件中判断的字段是可配置的,这就导致了,有时候判断条件多的情况下,判断的字段会碰到有null值的情况,如果on两边的字段都是null,null和null对比就会导致结果为false&…...
9.22(一):数组扁平化
ES6的flat方法 const arr[1,2,[33,44,5,[6,7]],3]// es6中的flat方法function arr1() { //数组自带的扁平化方法,flat的参数代表的是需要展开几层, //如果是Infinity的话,就是不管嵌套几层,全部都展开return arr.flat(Infinity) } let resul…...
【vue2第十九章】手动修改ESlint错误 和 配置自动化修改ESlint错误
目标:认识代码规范 代码规范:一套写代码的约定规则。例如:“赋值符号的左右是否需要空格”,"一句结束是否是要加;”等 为什么要使用代码规范? 在团队开发时,提高代码的可读性。 在创建项目时,我们选择的就是一套完整的代码…...
计算机网络常见面试题
目录 一、谈一谈对OSI七层模型和TCP/IP四层模型的理解? 答:OSI七层模型主要分为: TCP/IP四层协议: 二、谈谈TCP协议的3次握手过程? 三、TCP协议为什么要3次握手?2次,4次不行吗? …...
springboot整合MeiliSearch轻量级搜索引擎
一、Meilisearch与Easy Search点击进入官网了解,本文主要从小微型公司业务出发,选择meilisearch来作为项目的全文搜索引擎,还可以当成来mongodb来使用。 二、starter封装 1、项目结构展示 2、引入依赖包 <dependencies><dependenc…...
禁用鼠标的侧边按键
新买了个鼠标,整体都不错,就是鼠标左侧有两个按键,大拇指经常无意触碰到,造成误操作。 就想着关闭侧边按键功能。以下这批文章帮了大忙! 鼠标侧键屏蔽,再也不用担心按到侧键了。_禁用鼠标侧键_挣扎的蓝藻…...
【C语言】数组和指针刷题练习
指针和数组我们已经学习的差不多了,今天就为大家分享一些指针和数组的常见练习题,还包含许多经典面试题哦! 一、求数组长度和大小 普通一维数组 int main() {//一维数组int a[] { 1,2,3,4 };printf("%d\n", sizeof(a));//整个数组…...
2023年中国研究生数学建模竞赛D题解题思路
为了更好的帮助大家第一天选题,这里首先为大家带来D题解题思路,分析对应赛题之后做题阶段可能会遇到的各种难点。 稍后会带来D题的详细解析思路,以及相关的其他版本解题思路 成品论文等资料。 赛题难度评估:A、B>C>E、F&g…...
在编译源码的环境下,搭建起Discuz!社区论坛和WordPress博客的LNMP架构
目录 一.编译安装nginx 二.编译安装MySQL 三.编译安装PHP 四.安装论坛 五.安装wordpress博客 六.yum安装LNMP架构(简要过程参考) 一.编译安装nginx 1)关闭防火墙,将安装nginx所需软件包传到/opt目录下 systemctl stop fire…...
腾讯面试题:无网络环境,如何部署Docker镜像?
亲爱的小伙伴们,大家好!我是小米,很高兴再次和大家见面。今天,我要和大家聊聊一个特别有趣的话题——腾讯面试题:无网络环境,如何部署Docker镜像?这可是一个技术含量颇高的问题哦!废…...
医学影像信息(PACS)系统软件源码
PACS系统是PictureArchivingandCommunicationSystems的缩写,与临床信息系统(ClinicalInformationSystem,CIS)、放射学信息系统(RadiologyInformationSystem,RIS)、医院信息系统(HospitalInformationSystem,HIS)、实验室信息系统(L…...
【01】FISCOBCOS的系统环境安装
我们选择ubuntu系统 01 https://www.ubuntu.org.cn/global 02 03下载最新版 04等待下载 00提前准备好VM,点击创建新的虚拟机 01选择自定义安装 02一直下一步到 03 04 05其他的默认即可 06 07 08 09 10 11一直默认到下面 12 13等待安装 安装后重启即可…...
flutter 权限和图片权限之前的冲突
权限插件 permission_handler: ^9.2.0想调起相册和视频,这个插件只有Permission.storage.request().,获取存储权限。 问题是android 13的一些手机,系统设置没有存储权限,用了上面这个权限,三次拒绝后就永久拒绝了&…...
OpenCV(四十八):读取视频和保存视频
OpenCV(Open Source Computer Vision Library)是一个功能强大的开源计算机视觉库,它提供了丰富的功能,包括读取和保存视频。下面分别演示如何使用OpenCV来读取视频和保存视频。 1. 读取视频: 在OpenCV中我们要获取一…...
如何在react/next.js app中的同级组件间传递数据
这篇文章也可以在我的博客中查看 问题 为什么会有这么奇怪的需求?在事情真正发生前真的难说,但真遇到一个需要这么做的情况。 最近想做一个网页时钟,它的结构如下: 时钟(计算时间,组织各个要素ÿ…...
软件需求文档、设计文档、开发文档、运维文档大全
在软件开发过程中,文档扮演着至关重要的角色。它不仅记录了项目的需求、设计和开发过程,还为项目的维护和管理提供了便利。本文将详细介绍软件开发文档的重要性和作用,以及需求分析、软件设计、开发过程、运维管理和项目管理等方面的文档要求…...
排序算法-----归并排序
目录 前言: 归并排序 1. 定义 2.算法过程讲解 2.1大致思路 2.2图解示例 拆分合成步骤 编辑 相关动态图 3.代码实现(C语言) 4.算法分析 4.1时间复杂度 4.2空间复杂度 4.3稳定性 前言: 今天我们就开始学习新的排序算法…...
docker 配置 gpu版pytorch环境--部署缺陷检测--Anomalib
目录 一、docker 配置 gpu版pyhorch环境1、显卡驱动、cuda版本、pytorch cuda版本三者对应2、拉取镜像 二、部署Anomalib1、下载Anomalib2、创建容器并且运行3、安装Anomalib进入项目路径安装依赖测试: 一、docker 配置 gpu版pyhorch环境 1、显卡驱动、cuda版本、p…...
为什么定时发朋友圈会更有效呢?
这是因为在同一时段 发送的好友朋友圈 无法有效分散用户的注意力 导致曝光度难以提升 而通过推广定时发朋友圈 可根据自己的粉丝活跃度 设置发圈时间 让每一条朋友圈都能高效 传递到更多的好友手中 这样,曝光度自然而然地就大大提升了! 1.多个号…...
【跟小嘉学 PHP 程序设计】一、PHP 开发环境搭建
系列文章目录 【跟小嘉学 PHP 程序设计】一、PHP 开发环境搭建 文章目录 系列文章目录@[TOC](文章目录)前言一、PHP介绍二、Centos 安装 PHP2.1、安装并启动 Nginx2.2、安装并启动 mariadb2.3、安装 rh-php2.4、添加 Nginx 配置2.5、Nginx 服务三、使用 Docker 为 PHP 部署开发…...
【zookeeper】zk选举、使用与三种节点简介,以及基于redis分布式锁的缺点的讨论
这里我准备了4台虚拟机,从node1到node4,其myid也从1到4. 一,zk server的启动和选举 zk需要至少启动3台Server,按照配置的myid,选举出参与选举的myid最大的server为Leader。(与redis的master、slave不同&a…...
wordpress媒体库插件/网站外链分析工具
本科生毕业论文 基于Python校园网站系统(Django框架) 开题报告 学 院: 专 业: 计算机科学与技术 年 级: 学生姓名: …...
做网络销售怎么建立网站/搜索大全引擎入口
#include<stdio.h> void zy1() {int a;printf("请输入题目序号(1-3):\n实验1-1:求最大值\n要求由键盘输入两个整数a和b,程序输出其中较大的数。\n实验1-2:求m到n之和\n要求程序计算并输出m~n&am…...
进一步加大网站集约化建设力度/关键词看片
一、百度百科“简单工厂模式”的描述简单工厂模式是属于创建型模式,又叫做静态工厂方法(Static Factory Method)模式,但不属于23种GOF设计模式之一。简单工厂模式是由一个工厂对象决定创建出哪一种产品类的实例。简单工厂模式是工…...
高端网站建设哪家更专业/网站推广排名服务
介绍如果要在使用启动器或批处理脚本启动Houdini的同时在渲染场的远程客户端上运行由Houdini创建的HIP文件,请对环境变量的状态进行快照并进行快照。设置并运行它。当时的脚本说明。注意:当前,以下是个人备忘,并且执行结果不能完全…...
盛泽网站建设/网站优化最为重要的内容是
/*** 用户登录接口* * * 1明确事务方法前的命名规则* 2保证事务方法执行的时间尽可能的短,不允许出现循环操作,不允许出现RPC等网络请求操作* 3不允许所有的方法都使用事务,节省服务器性能和缩短数据库连接时间* 4如果出现有多个地方需要事务…...
做外汇网站代理赚钱吗/重庆发布的最新消息今天
此方法可以将复选框的默认样式替换成任意样式。如图: 未选择: 选择时: 思路:将复选框隐藏,利用lebal元素的焦点传递特性,用lebal的样式替代复选框。 代码如下: <!DOCTYPE html> <html&…...