MySQL的备份与恢复
备份与恢复
- 一、备份
- 1.1 数据备份的必要性
- 1.2 数据备份分类
- 1.2.1 物理备份
- 1.2.2 逻辑备份
- 1.3 数据库备份策略
- 1.4 常用的备份方法和工具
- 1.5 数据库上云迁移
- 二、MySQL完全备份
- 2.1 简介
- 2.2 物理冷备份与恢复
- 2.2.1 物理冷备份
- 2.2.2 解压恢复
- 2.3 mysqldump备份与恢复
- 1)完全备份一个或多个完整的库(包括其中所有的表)
- 2)完全备份 MySQL 服务器中所有的库
- 3)完全备份指定库中的部分表
- 4)查看备份文件
- 三、MySQL 完全恢复
- 3.1 恢复数据库
- 3.1.1 通过source命令恢复
- 3.1.2 通过mysql命令
- 3.2 恢复数据表
- 四、MySQL增量备份与恢复
- 4.1 MySQL增量备份
- 4.1.1 开启二进制日志功能
- 4.2.2 通过刷新二进制日志文件间接实现增量备份
- 4.2.3 查看二进制日志文件的内容
- 4.2 MySQL增量恢复
- 4.2.1 一般恢复
- 4.2.2 断点恢复
- 4.3 备份与恢复配置实例(完全+增量)
- 1)录入第一次数据,并进行完全备份
- 2)录入第二次数据,进行增量备份
- 3)录入第三次数据,进行增量备份
- 4)模拟删除表,先进行完全恢复
- 5)进行增量恢复(通过位置+时间)
- 五、MySQL日志管理
- 5.1 日志分类
- 5.2 日志管理
- 小结
一、备份
1.1 数据备份的必要性
备份的主要目的是灾难恢复
在生产环境中,数据的安全性至关重要
任何数据的丢失都可能产生严重的后果
造成数据丢失的原因
程序错误
人为操作错误
运算错误
磁盘故障
灾难(如火灾、地震)和盗窃
1.2 数据备份分类
1.2.1 物理备份
对数据库操作系统的物理文件(如数据文件、日志文件等)的备份。
物理备份的方法 :
- 冷备份(脱机备份):是在关闭数据库的时候进行的;
- 热备份(联机备份):数据库处于运行状态,依赖于数据库的日志文件;
- 温备份:数据库锁定表格(不可写入但可读)的状态下进行备份操作。
1.2.2 逻辑备份
对数据库的表或者对象进行备份。
1.3 数据库备份策略
完全备份:整个数据集,每次都备份完整的数据库。
差异备份:仅备份最近一次完全备份后变化的数据,备份较慢,还原简单
增量备份:仅备份最近一次完全备份或增量备份(如果存在增量)以来变化的数据,备份较快,还原复杂
1.4 常用的备份方法和工具
物理冷备
备份时数据库处于关闭状态,直接打包数据库文件
备份速度快,恢复时也是最简单的。
专用备份工具mysqldump或mysqlhotcopy
mysqldump
常用的逻辑备份工具(逻辑热备)
备份速度较慢(如果数据库超过100G,一般不建议使用mysqldump)
mysqlhotcopy仅拥有备份MyISAM和ARCHIVE表
archive
启用二进制日志进行增量备份
进行增量备份,需要刷新二进制日志
第三方工具备份
免费的MySQL热备份软件Percona;XtraBackup
XtraBackup
(物理热备)
https://mp.weixin.qq.com/s/d3spGhku154dOgWSct-3Ww
1.5 数据库上云迁移
冷迁移
热迁移
二、MySQL完全备份
2.1 简介
优点
备份与恢复操作简单方便
缺点
数据存在大量的重复占用大量的备份空间
备份与恢复时间长
- 完全备份是对整个数据库、数据库结构和文件结构的备份
- 保存的是备份完成时刻的数据库
- 是差异备份与增量备份的基础
2.2 物理冷备份与恢复
- 关闭MySQL数据库
- 使用tar命令直接打包数据库文件夹
- 直接替换现有MySQL目录即可
2.2.1 物理冷备份
#先关闭数据库
systemctl stop mysqld
#建立备份文件存放目录
mkdir /opt/bak#压缩备份
tar zcvf /opt/bak/mysql_full_$(date +%F).tar.gz /usr/local/mysql/data/$(date -d "-1 day" +%Y%m%d)
2.2.2 解压恢复
主机1:192.168.2.106
主机2:192.168.2.105
备份到另一台主机
#先关闭数据库
systemctl stop mysqldscp 192.168.2.106:/opt/bak/* /opt
#将主机1的备份包远程传输到主机2
#先备份数据,防止恢复失败
mv /usr/local/mysql/data /usr/local/mysql/data.bak
tar xf mysql_full_2023-09-18.tar.gzcp -a /../data /usr/local/mysql/data
#不用-a 权限不足,无法启动
systemctl start mysqld
mysql -u root -p
#登录到数据库
2.3 mysqldump备份与恢复
1)完全备份一个或多个完整的库(包括其中所有的表)
mysqldump -u root -p[密码] --databases 库名1 [库名2] … > /备份路径/备份文件名.sql
#导出的就是数据库脚本文件如果不加 --databases ,只备份库中的表,不会备份库
#举个例子#单个数据库
mysqldump -u root -p --databases byyb > /opt/bak/byyb.sql#多个数据库
mysqldump -u root -p --databases byyb byyd > /opt/bak/bd.sql
2)完全备份 MySQL 服务器中所有的库
mysqldump -u root -p[密码] --all-databases > /备份路径/备份文件名.sql
#举个例子
mysqldump -u root -p123123 --all-databases > /opt/bak/all.sqlcat /opt/all.sql | grep "^CERATE DATABASES"
3)完全备份指定库中的部分表
mysqldump -u root -p[密码] 库名 [表名1] [表名2] … > /备份路径/备份文件名.sql
举个例子
#备份byyb的student表
mysqldump -u root -p [-d] byyb student > /opt/bak/byyb-student.sql#使用“-d”选项,说明只保存数据库的表结构
#不使用“-d”选项,说明表数据也进行备份
4)查看备份文件
cat xx.sql|grep -v "^--"| grep -v "^/" | grep -v "^$"egrp -v "^--|^/\*|^$" #或运行符
#举个例子
cat byyb-student.sql|grep -v "^--" | grep -v "^/" | grep -v "^$"
三、MySQL 完全恢复
3.1 恢复数据库
当备份文件中只包含表的备份,而不包括创建库的语句时,必须指定库名,且目标库必须存在。
在生产环境中,可以使用Shell脚本自动实现定时备份
3.1.1 通过source命令恢复
先使用mysqldump工具,生成备份sql脚本;
然后登录到MySQL数据库;
再执行source 备份sql脚本的路径
MySQL[(none)]> source /backup/all-data.sql
举个例子
先备份目标数据库,以byyb为例
mysqldump -uroot -p123123 --databases byyb > /opt/bak/byyb.sql
模拟数据库被删除
mysql -uroot -p123123 -e "drop database byyb;"
mysql -uroot -p123123 -e "show databases;"
source命令执行sql脚本#先登录到数据库
mysql -u root -p
#执行脚本
source /opt/bak/byyb.sql;
3.1.2 通过mysql命令
输入重定向
#先模拟数据库删除,这里不再赘述#恢复数据库
mysql -u root -p123123 < /opt/bak/byyb.sql
mysql -u root -p123123 -e 'show databases;'
管道符
cat byyb.sql | mysql -uroot -p123123
3.2 恢复数据表
当备份文件中只包含表的备份,而不包含创建的库的语句时,执行导入操作时必须指定库名,且目标库必须存在。
#备份byyb的student表
mysqldump -u root -p123123 [-d] byyb student > /opt/bak/byyb-student.sql
#模拟删除表
mysql -u root -p -e 'drop table byyb.student;'
mysql -u root -p -e 'show tables from byyb;'
#恢复表数据
mysql -uroot -p123123 byyb < /opt/bak/byyb-student.sql
#查看表数据,验证是否成功恢复
mysql -uroot -p123123 -e "select * from byyb.student;"
四、MySQL增量备份与恢复
4.1 MySQL增量备份
4.1.1 开启二进制日志功能
vim /etc/my.cnf
[mysqld]
log-bin=mysql-bin
binlog_format = MIXED #可选,指定二进制日志(binlog)的记录格式为 MIXED
server-id = 1#二进制日志(binlog)有3种不同的记录格式:STATEMENT(基于SQL语句)、ROW(基于行)、MIXED(混合模式),默认格式是STATEMENT
systemctl start mysqld
ls -l /usr/local/mysql/data/mysql-bin.*
4.2.2 通过刷新二进制日志文件间接实现增量备份
mysqladmin -uroot -p[密码] flush-logs
4.2.3 查看二进制日志文件的内容
mysqlbinlog --no-defaults --base64-output=decode-rows -v 二进制文件(绝对路径)
#--base64-output=decode-rows:使用64位编码机制去解码并按行读取
#-v:显示详细内容
#举个例子
cp /usr/local/mysql/data/mysql-bin.000001 /opt
mysqlbinlog --no-defaults --base64-output=decode-rows -v /opt/mysql-bin.000001
4.2 MySQL增量恢复
MySQL没有提供直接的增量备份方法,可通过MySQL提供的二进制日志间接实现增量备份。
4.2.1 一般恢复
1)模拟丢失更改的数据的恢复步骤
use byyb;
delete from student where id=3;
delete from student where id=4;mysqlbinlog --no-defaults /opt/mysql-bin.000002 | mysql -u root -p
2)模拟丢失所有数据的恢复步骤
use kgc;
drop table info1;mysql -u root -p kgc < /opt/kgc_info1_2020-11-22.sql
mysqlbinlog --no-defaults /opt/mysql-bin.000002 | mysql -u root -p
4.2.2 断点恢复
#查看二进制文件
mysqlbinlog --no-defaults --base64-output=decode-rows -v /opt/mysql-bin.000002
1)基于位置恢复
mysqlbinlog --no-defaults --start-position='位置点' --stop-position='位置点' 二进制日志文件(绝对路径) | mysql -uroot -p[密码]
#仅恢复到操作 ID 为“623”之前的数据,即不恢复“user4”的数据
mysqlbinlog --no-defaults --stop-position='623' /opt/mysql-bin.000002 | mysql -uroot -p#仅恢复“user4”的数据,跳过“user3”的数据恢复
mysqlbinlog --no-defaults --start-position='623' /opt/mysql-bin.000002 | mysql -uroot -p
2)基于时间点恢复
mysqlbinlog --no-defaults --start-datetime='时间点' --stop-datetime='时间点' 二进制日志文件(绝对路径) | mysql -uroot -p[密码]
#仅恢复到 16∶41∶24 之前的数据,即不恢复“user4”的数据
mysqlbinlog --no-defaults --stop-datetime='2020-11-22 16:41:24' /opt/mysql-bin.000002 |mysql -uroot -p#仅恢复“user4”的数据,跳过“user3”的数据恢复
mysqlbinlog --no-defaults --start-datetime='2020-11-22 16:41:24' /opt/mysql-bin.000002 |mysql -uroot -p
如果恢复某条SQL语句之前的所有数据,就stop在这个语句的位置节点或者时间点
如果恢复某条SQL语句以及之后的所有数据,就从这个语句的位置节点或者时间点start
4.3 备份与恢复配置实例(完全+增量)
为了测试备份数据是否可用,模拟数据丢失故障,进行数据还原。
在数据库表中,分三次录入学生考试成绩。
首次录入成绩后,做该表的完全备份。
后两次成绩的录入之后,分别作增量备份。
模拟数据丢失,并使用增量备份分别基于位置和时间点恢复一班所有学生成绩与二班陈铭与付杰的成绩。
1)录入第一次数据,并进行完全备份
mysql -u root -p
create database byyb;
use byyb;
create table student ("姓名" varchar(10),"班级" varchar(10),"学号" int,'语文' int,"数学" int,"英语" int,"理综" int);
insert into student values ('张三','一班',20170822,110,105,92,235);
insert into student values ('李四','一班',20170820,95,115,110,260);
insert into student values ('王五','一班',20170818,95,103,108,270);
insert into student values ('赵六','一班',20170816,100,109,112,265);
#其余数据添加格式类似
通过mysqldump工具完全备份
mysqldump -uroot -p123123 byyb student > /opt/bak/byyb-student.sql
2)录入第二次数据,进行增量备份
vim /etc/my.cnf
[mysqld]
log-bin=mysql-bin
binlog_format = MIXED #可选,指定二进制日志(binlog)的记录格式为 MIXED
server-id = 1
insert into student values ('李宁','二班',20170824,92,98,105,235);
insert into student values ('陈铭','二班',20170826,111,107,96,204);
#通过刷新日志文件,实现增量备份
mysqladmin -uroot -p123123 flush-logs
#查看二进制日志文件,不是看最新的,看倒数第二个
mysqlbinlog --no-defaults --base64-output=decode-rows -v
/usr/local/mysql/data/mysql-bin.000002
3)录入第三次数据,进行增量备份
再次插入数据
insert into byyb.student values ('付杰','二班',20170828,115,118,116,268);
insert into byyb.student values ('郭尚','二班',20170830,111,99,80,259);insert into byyb.student values ('王云雪','我们班',123321,111,99,80,259);
#通过刷新日志文件,实现增量备份
mysqladmin -uroot -p123123 flush-logs
#查看二进制日志文件
mysqlbinlog --no-defaults --base64-output=decode-rows -v
/usr/local/mysql/data/mysql-bin.000003
4)模拟删除表,先进行完全恢复
模拟删除表
drop table student from byyb;
先完全恢复,一班所有学生的成绩
mysql -u root -p123123 byyb < /opt/bak/byyb.sql
mysql -uroot -p123123 -e "select * from byyb.student;"
5)进行增量恢复(通过位置+时间)
通过位置恢复二班陈铭的成绩
#先查看二进制日志文件
mysqlbinlog --no-defaults --base64-output=decode-rows -v /usr/local/mysql/data/mysql-bin.000002
#根据位置恢复
mysqlbinlog --no-defaults --start-position='616' /usr/local/mysql/data/mysql-bin.000002 | mysql -uroot -p123123
通过时间恢复二班付杰的成绩
#先查看二进制日志文件
mysqlbinlog --no-defaults --base64-output=decode-rows -v /usr/local/mysql/data/mysql-bin.000003
#根据时间恢复
mysqlbinlog --no-defaults --start-datetime='23-09-18 19:38:48' --stop-datetime='23-09-18 19:39:16' /usr/local/mysql/data/mysql-bin.000003 | mysql -uroot -p123123mysql -uroot -p123123 -e " select * from byyb.student;"
五、MySQL日志管理
5.1 日志分类
-
事务日志:transaction log
事务日志的写入类型为"追加",因此其操作为"顺序IO";通常也被称为:预写式日志 write ahead logging事务日志文件: ib_logfile0, ib_logfile1
-
错误日志 error log
-
通用日志 general log
-
慢查询日志 slow query log
-
二进制日志 binary log
-
中继日志 reley log,在主从复制架构中,从服务器用于保存从主服务器的二进制日志中读取的事件
5.2 日志管理
MySQL 的日志默认保存位置为 /usr/local/mysql/data
vim /etc/my.cnf
[mysqld]
##错误日志,用来记录当MySQL启动、停止或运行时发生的错误信息,默认已开启
log-error=/usr/local/mysql/data/mysql_error.log #指定日志的保存位置和文件名##通用查询日志,用来记录MySQL的所有连接和语句,默认是关闭的
general_log=ON
general_log_file=/usr/local/mysql/data/mysql_general.log##二进制日志(binlog),用来记录所有更新了数据或者已经潜在更新了数据的语句,记录了数据的更改,可用于数据恢复,默认已开启
log-bin=mysql-bin #也可以 log_bin=mysql-bin##慢查询日志,用来记录所有执行时间超过long_query_time秒的语句,可以找到哪些查询语句执行时间长,以便于优化,默认是关闭的
slow_query_log=ON
slow_query_log_file=/usr/local/mysql/data/mysql_slow_query.log
long_query_time=5 #设置超过5秒执行的语句被记录,缺省时为10秒systemctl restart mysqld
mysql -u root -p
show variables like 'general%'; #查看通用查询日志是否开启show variables like 'log_bin%'; #查看二进制日志是否开启show variables like '%slow%'; #查看慢查询日功能是否开启
show variables like 'long_query_time'; #查看慢查询时间设置set global slow_query_log=ON; #在数据库中设置开启慢查询的方法
#!/bin/bash
#增量备份Mysql数据库
TODAY=$(date +%Y%m%d)
YESTERDAY=$(date -d "-1 day!+%Y%m%d)MYSQL
HOME=/usr/local/mysglDATA HOME=SMYSQL HOME/data
USERNAME=root
PASSWORD=abc123#备份二进制日志索弓文件 mysgl-bin.index
/usr/bin/cp -f $DATA_HOME/mysgl-bin.index /opt/backup/mysgl-bin-$TODAY.index
#判断是否存在前一天的日志索引文件,如果存在则通过反向查询获取今天生成的二进制日志文件
if [ -f /opt/backup/mysgl-bin-$YESTERDAY.index ]
then
COUNT=$(cat /opt/backup/mysgl-bin-$TODAY.index|grep -v "`cat /opt/backup/mysgl-bin-$YESTERDAY.index`"|awk -F '/' '{print $2}')
else
COUNT=$(cat /opt/backup/mysgl-bin-$TODAY.index | awk -F '/' '{print $2}')
fi
#刷新二进制日志文件
$MYSQL_HOME/bin/mysqladmin -u"$USERNAME"-p"$PASSWORD" flush-logs &> /dev/null
#使用循环备份当天的二进制日志
for BINLOG in $COUNT
/usr/bin/mv -f "$DATA_HOME/$BINLOG" "/opt/backup/$BINLOG-$TODAY"
done
小结
mysqldump逻辑热备
mysqldump -uXXX -p[XXX] --databases 库1 [库2 ...] > XXX.sql 备份一个或多个库及库中的表数据
mysqldump -uXXX -p[XXX] --all-databases > XXX.sql 备份所有的库
mysqldump -uXXX -p[XXX] 库名 > XXX.sql 备份指定库中的所有表数据(不包含创建库的操作)
mysqldump -uXXX -p[XXX] 库名 表1 表2 ... > XXX.sql 备份指定库中的一个或多个表数据(不包含创建库的操作)xtrabackup物理热备完全恢复
先登录到mysql,再执行 source XXX.sql(注:如果sql文件只包含表的备份,需要先创建库并use切换库)mysql -uXXX -pXXX [库名] < XXX.sql #如果sql文件只包含表的备份,要指定库名
cat XXX.sql | mysql -uXXX -pXXX [库名]增量备份
通过刷新二进制日志文件间接实现增量备份
mysqladmin -uXXX -pXXX flush-logs查看二进制日志文件内容
mysqlbinlog --no-defaults --base64-output=decode-rows -v 二进制日志文件使用二进制日志增量恢复
mysqlbinlog --no-defaults 二进制日志文件 | mysql -uXXX -pXXX端点恢复
mysqlbinlog --no-defaults --start-position='位置点' --stop-position='位置点' 二进制日志文件 | mysql -uXXX -pXXXmysqlbinlog --no-defaults --start-datetime='YYYY-mm-dd HH:MM:SS' --stop-datetime='YYYY-mm-dd HH:MM:SS' 二进制日志文件 | mysql -uXXX -pXXX如果需要恢复到某条SQL语句之前的所有数据,就stop在这个语句的位置点或时间点
如果需要恢复某条SQL语句及其之后的所有数据,就从这个语句的位置点或时间点start
相关文章:
MySQL的备份与恢复
备份与恢复 一、备份1.1 数据备份的必要性1.2 数据备份分类1.2.1 物理备份1.2.2 逻辑备份 1.3 数据库备份策略1.4 常用的备份方法和工具1.5 数据库上云迁移 二、MySQL完全备份2.1 简介2.2 物理冷备份与恢复2.2.1 物理冷备份2.2.2 解压恢复 2.3 mysqldump备份与恢复1)…...
Python中的函数未定义的错误
前言: 嗨喽~大家好呀,这里是魔王呐 ❤ ~! python更多源码/资料/解答/教程等 点击此处跳转文末名片免费获取 通过这个解释,我们将了解当Python程序显示类似NameError: name ‘’ is not defined的错误时,即使该函数存在于脚本中&…...
AG35学习笔记(二):安装编译SDK、CMakeLists编译app、Scons编译server
目录 一、概述二、安装SDK2.1 网盘SDK - 权限不够2.2 bj41 - 需要交叉source2.3 mullen - relocate_sdk.py路径有误 三、编译SDK3.1 /bin/sh: 1: gcc: not found3.2 curses.h: No such file or directory 四、CMakeLists - 编译app4.1 cmake - 项目构建4.2 make - 项目编译4.3 …...
多台服务器sessionId共享
目录 多台服务器sessionId共享解决方案:ASP.NET Core 参考代码(NET 7):登录处理登录(请求)过滤器过滤器使用BaseController 多台服务器sessionId共享 session id是服务器首次与浏览器创建连接时,生成的id值,存入浏览器…...
如何在Gazebo中实现多机器人编队仿真
文章目录 前言一、仿真前的配置二、实现步骤1.检查PC和台式机是否通讯成功2.编队中对单个机器人进行独立的控制3、对机器人进行编队控制 前言 实现在gazebo仿真环境中添加多个机器人后,接下来进行编队控制,对具体的实现过程进行记录。 一、仿真前的配置…...
迅为iTOP-iMX6QPLUS-Android6.0下uboot添加网卡驱动
本文档介绍在 iTOP-iMX6Q 和 iTOP-iMX6Q-PLUS 安卓 6.0 的 uboot 上添加网卡驱 动,添加完网卡驱动以后,uboot 就可以正常使用网络了。 1 具体步骤 1.1 修改 mx6sabre_common.h 文件 在 iTOP-iMX6_android6.0.1 源码目录下输入以下命令,打…...
sql server 触发器的使用
看数据库下的所有触发器及状态 SELECT a.name 数据表名 , sysobjects.name AS 触发器名 , sysobjects.crdate AS 创建时间 , sysobjects.info , sysobjects.status FROM sysobjects LEFT JOIN ( SELECT * FROM sysobjects WHERE xtype U ) AS a ON sysobjects.parent_obj a.…...
使用亚马逊云服务器在 G4 实例上运行 Android 应用程序
随着 Android 应用程序和游戏变得越来越丰富,其中有些甚至比 PC 上的软件更易于使用和娱乐,因此许多人希望能够在云上运行 Android 游戏或应用程序,而在 EC2 实例上运行 Android 的解决方案可以让开发人员更轻松地测试和运行 Android 应用程序…...
Direct3D融合技术
该技术能使我们将当前要进行光栅化的像素的颜色与先前已已光栅化并处于同一位置的像素的颜色进行合成,即将正在处理的图元颜色值与存储在后台缓存中的像素颜色值进行合成(混合),利用该技术我们可得到各种各样的效果,尤其是透明效果。 在融合…...
【计算机网络】信号处理接口 Signal API(1)
收发信号思想是 Linux 程序设计特性之一,一个信号可以认为是一种软中断,通过用来向进程通知异步事件。 本文讲述的 信号处理内容源自 Linux man。本文主要对各 API 进行详细介绍,从而更好的理解信号编程。 signal 遵循 C11,POSIX.…...
贝叶斯滤波计算4d毫米波聚类目标动静属性
机器人学中有些问题是二值问题,对于这种二值问题的概率评估问题可以用二值贝叶斯滤波器binary Bayes filter来解决的。比如机器人前方有一个门,机器人想判断这个门是开是关。这个二值状态是固定的,并不会随着测量数据变量的改变而改变。就像门…...
华为hcie认证考试怎么考?
华为HCIE认证考试怎么考? 前文腾科也说了HCIE认证考试的难度会比较大,具体是难在哪里呢?华为HCIE认证的考试需要考一门笔试,笔试主要是单选、多选、判断、填空、拖拽这几个题型,考试时长一般是一个半小时,…...
vue +element 删除按钮操作 (删除单个数据 +删除页码处理 )
1.配置接口deleteItemById: "/api/goods/deleteItemById", //删除商品操作 2.get请求接口 // 删除接口 后台给我们 返iddeleteItemById(params){return axios.get(base.deleteItemById,{params})}3.异步请求接口 async deleteItemById(id){let res await this.…...
更新GitLab上的项目
更新GitLab上的项目 如有需要,请参考这篇:上传项目到gitlab上 1.打开终端,进入到本地项目的根目录。 2.如果你还没有将远程GitLab仓库添加到本地项目,你可以使用以下命令: 比如: git remote add origin …...
K8S群集调度
K8S群集调度 一、调度约束1.概述2.Pod 启动典型创建过程(工作机制 )3.调度过程4.Predicate 的常见的算法5.常见的优先级选项6.指定调度节点: 二、亲和性1.节点亲和性2.Pod 亲和性3.键值运算关系4.示例5.Pod亲和性与反亲和性6.使用 Pod 反亲和…...
完美解决Echarts X坐标轴下方文字最后一个字体加粗颜色加深的问题
之前用Echarts画图的时候,X坐标轴最后一个字存在自动加粗的问题。也是在网上找过解决办法没有找到,后面自己研究明白了后,在某篇文章下评论了如何解决。但是好像大家没有看评论的习惯,所以单独拿出来一篇文章,希望能给…...
WebGL 计算平行光、环境光下的漫反射光颜色
目录 光照原理 光源类型 平行光 点光源 环境光 反射类型 漫反射 漫反射光颜色 计算公式 环境反射 环境反射光颜色 表面的反射光颜色(漫反射和环境反射同时存在时)计算公式 平行光下的漫反射 根据光线和法线方向计算入射角θ(以便…...
解决SpringMVC在JSP页面取不到ModelAndView中数据
版权声明 本文原创作者:谷哥的小弟作者博客地址:http://blog.csdn.net/lfdfhl 问题描述 ModelAndView携带数据跳转到指定JSP页面后在该页面通过EL表达式取不到原本存放在ModelAndView中的数据。 问题原因 在IDEA中创建Maven工程时web.xml中默认的约束…...
Spring 6.0 新特性
文章目录 Spring的发展历史AOTGraalVMSpringBoot实战AOTRuntimeHints案例分析RuntimeHintsRegistrar SpringBoot中AOT核心代码 Spring的发展历史 AOT Spring 6.0的新特性Ahead of Time(AOT)编译是一种技术,可以提前将Spring应用程序编译成原…...
计算机竞赛 深度学习+opencv+python实现昆虫识别 -图像识别 昆虫识别
文章目录 0 前言1 课题背景2 具体实现3 数据收集和处理3 卷积神经网络2.1卷积层2.2 池化层2.3 激活函数:2.4 全连接层2.5 使用tensorflow中keras模块实现卷积神经网络 4 MobileNetV2网络5 损失函数softmax 交叉熵5.1 softmax函数5.2 交叉熵损失函数 6 优化器SGD7 学…...
软件过程能力成熟度评估——CSMM认证
CSMM认证又称为“软件过程能力过程成熟度评估”,由中国电子技术标准化研究院联合五十余家产学研用相关方结合我国实际,自主制定的团体标准,于2021年6月8号发布,目的是为了帮助国内软件企业对自身的软件能力进行评估和判断…...
学内核之二十一:系统调用栈结构分析
目录 一 构建分析环境 二 栈的位置 三 栈开头8字节 四 寄存器环境 五 R4和R5 六 如何确定系统调用的具体函数 一 构建分析环境 为了分析方便,做了如下测试环境: 内核实现一个简单的创建字符设备的驱动 应用层实现一个c程序,操作为打开内…...
互联网3.0 数字原生——数物虚实多维细粒度泛在融合
随着计算机、宽带网、通信技术的飞速发展,互联网技术和软硬件系统也不断演进,催生了一场前所未有的数字化革命。从Web1.0到Web3.0,以及虚拟现实、人工智能和数字孪生等领域的崛起,每一步都勾画出了一个崭新的数字未来,…...
实现AIGC更好的数据存力,这家科技巨头为我们指明了方向
存力即数据存储能力 蕴藏着巨大的发展机会 【全球存储观察 | 热点关注】 2023年,全球被ChatGPT的热潮席卷,拥抱AIGC的创新赛道成为众多企业的新选择。 全球存储观察分析指出,影响AIGC发展的三大因素也日益凸显,即算…...
企业如何在抖音上搞到TOB潜在精准客户流量?
我们都知道,现在互联网上流量都被集中了几个大的平台里。而抖音,一定是绕不开那个!图片在公众号:白杨SEO上去看。 抖音,在很多人的传统印象里,还只是一个娱乐短视频APP,用来打发时间而已。事实…...
JeecgBoot v3.5.5 版本发布,性能大升级版本—开源免费的低代码开发平台
项目介绍 JeecgBoot是一款企业级的低代码平台!前后端分离架构 SpringBoot2.x,SpringCloud,Ant Design&Vue3,Mybatis-plus,Shiro,JWT 支持微服务。强大的代码生成器让前后端代码一键生成! JeecgBoot引领…...
与树上边权、连通块、二分块相关的问题(抓住各连通块之间的联系,考虑增量):CF444E
https://www.luogu.com.cn/problem/CF444E 首先肯定二分 然后是棵树,所以考虑按顺序枚举边权 然后肯定会有连通块和并查集 考虑现在场上有多个连通块,我们只保留大于 m i d mid mid 的边 则每个连通块都必须往外连边 一个很朴素的思路是判定每个连…...
解决VSCode下载速度很慢
这是VSCode的官网: Visual Studio Code - Code Editing. Redefined 按照官网的下载链接,速度实在是感人! 解决办法也很简单,把链接换为CDN加速的链接 把下载链接中的az764295.vo.msecnd.net 替换为👉 vscode.cdn.azu…...
悬赏算命测算源码可以用二维码收款 可以直接拿来运营
首发悬赏算命测算源码可以用二维码收款 可以直接拿来运营吸金!用户可以通过发布悬赏赏金算命,也可以通过升级发布测算任务来吸金 测试环境:php5.6apache2.4mysq5.6 安装教程: 测试环境:php5.6apache2.4mysq5.6 安装&…...
在Linux中安装nginx-1.20.1+php-7.4.28(增加扩展)
NginxPHP安装在公网IP为x.x.x.x的服务器上 需要下载安装的软件版本:nginx-1.20.1php-7.4.28 需要增加的PHP扩展如下: 在编译安装php-7.4.28时加上的pcntl; 单独下载安装的Wxwork_finance_sdk;(在编译安装php-7.4.2…...
广东省外贸网站建设/西安关键词优化排名
无论是中国大妈是商场们抢购实物黄金,还是投资者们依据银行报价在交易平台上购买“纸黄金”。大家更多将黄金作为一个资产储备或者投资理财产品,而不是将它作为一种支付方式,主要原因在于实物黄金不好分割,携带不便,纸…...
网站建设 开发/百度竞价登录
今天,有个哥们在网上买了块二手机械硬盘。回家装好系统发现启动贼慢,开机十几分钟。遂到交流群发问。经过一番诊断最终确定为硬盘坏道导致。哥们失望至极,准备打开京东购买一块全新固态。本来,作为一个沉默宝宝天天在群里采集话题…...
网站网站制作服务/周口网站建设公司
前言(仅看介绍本身的可以略过) 在离职后的一段时间里,个人总结了过去几年工作的心得,结合以往的工作经验。重新思考并重构了前些年做的一些东西(主要是测试相关),产生了设计AutoTest这样的一个测…...
八桂云网站建设/已矣seo排名点击软件
2019独角兽企业重金招聘Python工程师标准>>> 安装gcc sudo apt-get install gcc 安装gcc-c 的编译环境 sudo apt-get install build-essential 安装pcre cd pcre-version ./configure make sudo make install 安装zlib cd zlib-version ./configure make sudo make…...
织梦做网站视频教程/营销推广方案设计
方一 Integer[] xnew Integer[]{4,6,9,10}; Set<Integer> set new HashSet<>() ; Collections.addAll(set,x);for(Integer ele:set){System.out.println(ele); }方二 Set<Integer> set new HashSet<>(Arrays.asList(4,6,9,10)) ;...
沈阳高端网站制作公司哪家好/网络营销策划ppt范例
前言 如果大家之前学过“线性DP”的话,应该已经知道,动态规划的过程是随着“阶段”的增长,在每个状态维度上不断扩展的。在任意时刻,已经求出最优解的状态与尚未求出最优解的状态在各维度上的分界点组成了 DP 扩展的“轮廓“。对…...