MySQL详解六:备份与恢复

news2024/12/23 14:09:39

文章目录

  • 1. 数据库备份的分类
    • 1.1 从物理和逻辑上分类
      • 1.1.1 物理备份
      • 1.1.2 逻辑备份
    • 1.2 从数据库的备份策略角度上分类
      • 1.2.1 完全备份
      • 1.2.2 差异备份
      • 1.2.3 增量备份
    • 1.3 常见的备份方法
  • 2. MySQL完全备份
    • 2.1 完全备份简介
    • 2.2 优点与缺点
    • 2.3 实现物理冷备份与恢复
      • 2.3.1 实现流程
      • 2.3.2 前置准备
      • 2.3.3 实现物理冷备份
    • 2.4 使用mysqldump备份数据库
    • 2.5 使用source命令恢复数据库
    • 2.6 使用mysql命令恢复数据库
  • 3. MySQL增量备份与恢复
    • 3.1 使用完全备份所带来的问题
    • 3.2 增量备份简介
    • 3.3 特点
    • 3.4 增量备份与日志的关系
      • 3.4.1 二进制日志对备份的意义
    • 3.5 增量恢复方法类别
      • 3.5.1 一般恢复
      • 3.5.2 基于位置恢复
      • 3.5.3 基于时间点恢复
    • 3.6 增量备份
      • 3.6.1 开启二进制日志功能
      • 3.6.2 实现增量备份
      • 2.6.3 一般恢复
      • 3.6.4 端点恢复
        • 3.6.4.1 基于位置恢复
        • 3.6.4.2 基于时间点恢复

1. 数据库备份的分类

1.1 从物理和逻辑上分类

1.1.1 物理备份

对数据库操作系统的物理文件(如:数据文件、日志文件等)的备份

1.1.2 逻辑备份

对数据库逻辑组件(如:表等数据库对象)的备份

1.2 从数据库的备份策略角度上分类

1.2.1 完全备份

每次对数据库进行完整的备份
在这里插入图片描述

1.2.2 差异备份

  • 备份自从上次完全备份之后修改的文件
  • 仅备份最近一次完全备份以来变化的数据,备份较慢,还原简单
    在这里插入图片描述

1.2.3 增量备份

  • 只有在上次完全备份或增量备份后被修改的文件才会备份
  • 仅备份最近一次完全备份或增量备份(如果存在增量)以来变化的数据,备份较快,还原复杂

在这里插入图片描述

1.3 常见的备份方法

  1. 物理冷备
    备份时数据库处于关闭状态,直接打包数据库文件
    备份速度快,恢复时也是最简单的

  2. 专用备份工具mysqldump或mysqlhotcopy
    mysqldump常用的逻辑备份工具
    mysqlhotcopy仅拥有备份MyISAM和ARCHIVE表

  3. 启用二进制日志进行增量备份·
    进行增量备份,需要刷新二进制日志

  4. 第三方工具备份
    免费的MySQL热备份软件Percona XtraBackup

2. MySQL完全备份

2.1 完全备份简介

  • 是对整个数据库、数据库结构和文件结构的备份
  • 保存的是备份完成时刻的数据库
  • 是差异备份与增量备份的基础

2.2 优点与缺点

  • 优点
    备份与恢复操作简单方便

  • 缺点
    数据存在大量重复
    占用大量备份空间
    备份与恢复时间长

2.3 实现物理冷备份与恢复

2.3.1 实现流程

关闭MySQL数据库 > 使用tar命令直接打包数据库文件夹 > 直接替换现有MySQL目录

2.3.2 前置准备

mysql1 :192.168.67.100
mysql2 :192.168.67.101
mysql -uroot -pabc123
#登录数据库

在这里插入图片描述

create datbbase scj;
#新建数据库

use scj;
#进入数据库

create table scj1 (id int, name varchar(10), age int, sex char(2), hobby varchar(50));
#新建表

show tables;
#查看数据库

在这里插入图片描述

#添加数据
insert into scj1 values (1, '张三', 22, '男', 'java');
insert into scj1 values (2, '李四', 23, '男', 'shell');
insert into scj1 values (3, '王五', 24, '男', '云计算');
insert into scj1 values (4, '赵四', 25, '男', 'url');
insert into scj1 values (5, '尼古拉斯', 26, '男', 'html');
insert into scj1 values (6, '日川钢板', 27, '男', 'css');

在这里插入图片描述

create table scj2 like scj1;
insert into scj2 (select * from scj1);
#克隆一个名为scj2的表

show tables from scj;
#查看是否创建成功

在这里插入图片描述

2.3.3 实现物理冷备份

quit
#退出数据库
systemctl stop mysqld
#关闭数据库
cd /usr/local/mysql/data
#前往mysql默认日志目录下

~~~

mkdir /opt/backup
#创建备份日志文件目录

tar zcvf /opt/backup/mysql_full_$(date -d "-1 day" +%Y.%m.%d).tar.gz ./data/
#打包压缩上一天的data目录到/opt/backup目录下,并标上日期
#拓展
date +%Y/%m/%d
#只显示当前日期

date +%Y-%m01
#显示当月第一天

date -d "+1 day" +%Y/%m/%d
#显示明天

date -d "-1 day" +%Y/%m/%d
#显示昨天date -d "1 day ago" +%Y/%m/%d

date -d "$(date +%Y%m01) -1 day" +%Y/%m/%d
#显示上月最后一天

date -d "(date -d "1 mouth" +%Y%m01) -1 day" +%Y/%m/%d
#显示当月最后一天

在这里插入图片描述

cd /opt

scp mysql_full_2023.09.18.tar.gz 192.168.67.101:/opt
#将打包的data目录远程拷贝到另一台mysql主机的opt目录下

在这里插入图片描述

在这里插入图片描述

#前往mysql2
systemctl stop mysqld
#关闭mysql服务

cd /usr/local/mysql
mv data/ data.bak
#将现data目录改名为data.bak

mv  mysql_full_2023.09.18.tar.gz /usr/local/mysql/
#将此压缩包转移到mysql用户目录下

tar xf mysql_full_2023.09.18.tar.gz
#解压缩mysql1的data目录

在这里插入图片描述

systemctl start mysqld
#打开mysql服务

在这里插入图片描述

mysql -uroot -pabc123
#进入数据库
show databases;
#查看现有数据库

show tables from scj;
#查看库中现有数据库

select * from scj.scj1;
#查看表内容

在这里插入图片描述

2.4 使用mysqldump备份数据库

#基本格式
mysqldump -u [用户名] -p[密码] --databases 库名1 [库名2]> /备份路径/备份文件名.sql	
#导出的就是数据库脚本文件

#完全备份一个或多个完整的库(包括其中所有的表)
mysqldump -uXXX -p[XXX] 库名 > XXX.sql
#备份指定库中的所有表数据(不包含创建库的操作)

mysqldump -uroot -pabc123 scj > /opt/backup/scj.sql
#只备份表和表中的内容,并没有备份库

cd /opt/backup
ls

在这里插入图片描述

cat scj.sql |egrep -v "^--|^/\*|^$"
#过滤出需要的信息

在这里插入图片描述

mysqldump -uroot -pabc123 --databases scj > /opt/backup/scj_full.sql
#备份一个完整的库到/opt/backup目录下

在这里插入图片描述

cat scj_full.sql |egrep -v "^--|^/\*|^$"
#过滤出需要的信息

在这里插入图片描述

mysqldump -u [用户名] -p[密码] --all-databases > /备份路径/备份文件名.sql

mysqldump -u root -pabc123 --all-databases > /opt/all_full.sql
#完全备份 MySQL 服务器中所有的库

在这里插入图片描述

cat all_full.sql |grep "^CREATE DATABASE"

在这里插入图片描述

mysqldump -u root -p[密码] 库名 [表名1] [表名2]> /备份路径/备份文件名.sql
#备份指定库中的一个或多个表数据(不包含创建库的操作)

mysqldump -u root -pabc123 scj scj2 > /opt/backup/scj_scj2.sql
#备份scj库中scj2表

cat scj_scj2.sql |egrep -v "^--|^/\*|^$"
#查看备份内容信息

在这里插入图片描述

2.5 使用source命令恢复数据库

#记得提前备份

在这里插入图片描述

#模拟环境
#先登录mysql
mysql -uroot -pabc123

mysql>drop databases scj;
#删除scj库

在这里插入图片描述

source /opt/backup/scj_full.sql
#恢复完整的scj库

#注:一定要用绝对路径

在这里插入图片描述
在这里插入图片描述

#也可以只用表数据进行恢复
create database scj;
#创建新scj库

use scj;
#进入scj库

source /opt/backup/scj.sql
#恢复库中表数据

#因为scj.sql中不包含有创建库的操作,所以可以在任意一个库中导入表数据

2.6 使用mysql命令恢复数据库

#基本格式
mysql -uXXX -pXXX [库名] < XXX.sql          #如果sql文件只包含表的备份,要指定库名cat XXX.sql | mysql -uXXX -pXXX [库名]
mysql -uroot -pabc123 scj < scj.sql
#需要提前创建库

mysql -uroot -pabc123  < scj_full.sql
#直接恢复完整的数据库
mysql -uroot -pabc123 -e "drop database scj;"
#-e 执行命令后退出数据库

mysql -uroot -pabc123 -e "show databases;"
#查看是否删除完成

在这里插入图片描述

mysql -uroot -pabc123  < scj_full.sql

mysql -uroot -pabc123 -e "show databases;"
#查看是否恢复完成

在这里插入图片描述

3. MySQL增量备份与恢复

3.1 使用完全备份所带来的问题

  • 备份数据中有重复数据
  • 备份时间与恢复时间过长

3.2 增量备份简介

是自上一次备份后增加和变化的文件或内容

3.3 特点

  • 没有重复数据,备份量不大,时间短
  • 恢复需要上次完全备份及完全备份之后所有的增量备份才能恢复,而且要对所有增量备份进行逐个反推恢复

3.4 增量备份与日志的关系

  • MySQL没有提供直接的增量备份方法
  • 可通过MySQL提供的二进制日志间接实现增量备份

3.4.1 二进制日志对备份的意义

  1. 二进制日志保存了所有更新或者可能更新数据库的操作
  2. 二进制日志在启动MySQL服务器后开始记录,并在文件达到max binlog_size所设置的大小或者接收到flush logs命令后重新创建新的日志文件
  3. 只需定时执行flushlogs方法重新创建新的日志,生成二进制文件序列,并及时把这些日志保存到安全的地方就完成了一个时间段的增量备份

3.5 增量恢复方法类别

3.5.1 一般恢复

  • 将所有备份的二进制日志内容全部恢复

3.5.2 基于位置恢复

  • 数据库在某一时间点可能既有错误的操作也有正确的操作
  • 可以基于精准的位置跳过错误的操作

3.5.3 基于时间点恢复

跳过某个发生错误的时间点实现数据恢复

3.6 增量备份

3.6.1 开启二进制日志功能

vim /etc/my.cnf
#编辑配置文件

#添加
log-bin=mysql-bin
binlog_format = MIXED				#可选,指定二进制日志(binlog)的记录格式为 MIXED
server-id = 1

#二进制日志(binlog)有3种不同的记录格式:STATEMENT(基于SQL语句)、ROW(基于行)、MIXED(混合模式),默认格式是STATEMENT

在这里插入图片描述

systemctl restart mysqld
#重新启动服务

ls /usr/local/mysql/data

在这里插入图片描述

#因为二进制文件内容默认是二进制字符,人是看不懂的
#所以使用mysqlbinlog命令
mysqlbinlog --no-defaults --base64-output=decode-rows -v /usr/local/mysql/data/mysql-bin.000001
#以base64方式进行解码,按行进行读取编码,显示详细内容,指定mysql-bin.000001文件

在这里插入图片描述

#除了可以用重启来刷新mysql二进制文件,还可以使用mysqladmin命令来刷新二进制文件

mysqladmin -uroot -pabc123 flush-logs
#再次生成新的二进制日志文件

在这里插入图片描述

cat mysql-bin.index
#该文件保存着所有的二进制文件的序列号

在这里插入图片描述

3.6.2 实现增量备份

#模拟环境
select * from scj.scj1
#事先准备表

在这里插入图片描述

#当天二进制文件是没有操作数据的
cat /usr/local/mysql/data/mysql-bin.000003  
#查看最新二进制日志文件

在这里插入图片描述

#首先实现完全备份
mkdir /opt/backup

cd /opt/backup
mkdir full bin
#full目录做完全备份,bin做增量备份

在这里插入图片描述

vim /opt/mysqlquan.sh     
#编写完全备份脚本  
#!/bin/bash  
mysqldump -u root -p123456 --all-databases > /bak/all_$(date +%F).sql  

chmod 700 /opt/mysqlquan.sh 
#添加属主的权限

在这里插入图片描述

vim /opt/binlog.sh 
#编写增量备份脚本
#!/bin/bash  
filename=$(sed -n '$p' /usr/local/mysql/data/mysql-bin.index | awk -F '/' '{print $2}') 
#使用sed命令打印二进制日志文件最后一行内容作为filename变量的值 
mv /usr/local/mysql/data/$filename /bak/binlog_$(date +%F)
#将二进制日志移动到备份目录下,并将移动后的文件名称加上日期  
mysqladmin -uroot -pabc123 flush-logs  
#生成新的二进制日志文件  

chmod 700 /opt/binlog.sh 
#添加属主的权限

在这里插入图片描述

crontab -e
#做计划任务

在这里插入图片描述
在这里插入图片描述

mysqldump -uroot -pabc123 scj scj1 > /opt/backup/full/scj_scj1-$(date +%Y.%m.%d).sql
#将scj库下scj1表备份到/opt/backup/full下

在这里插入图片描述

mysqladmin -uroot -pabc123 flush-logs
#重新生成一个二进制文件

在这里插入图片描述

#进入数据库
#插入两条数据
insert into scj.scj1 values (7, '小黑子', 25, '男', '黑坤坤');
insert into scj.scj1 values (8, '小仙女', 18, '女', '打拳');

select * from scj.scj1;
#查看内容

在这里插入图片描述

mysqladmin -uroot -pabc123 flush-logs
#保存上一个文件并生成新一个文件

在这里插入图片描述

mv -f mysql-bin.000004 /opt/backup/bin/mysql-bin.000004-$(date -d '1 day' +_%Y.%m.%d)

在这里插入图片描述

#进入数据库
#插入两条数据
insert into scj.scj1 values (9, 'giao桑', 28, '男', 'giao');
insert into scj.scj1 values (10, '翠花', 18, '女', '看打拳');

select * from scj.scj1;
#查看内容

在这里插入图片描述

mysqladmin -uroot -pabc123 flush-logs
#保存上一个文件并生成新一个文件

在这里插入图片描述

mv -f mysql-bin.000005 /opt/backup/bin/mysql-bin.000005-$(date -d '1 day' +_%Y.%m.%d)

在这里插入图片描述

#进入数据库
#模拟被删库跑路了
drop databbase scj;

在这里插入图片描述

2.6.3 一般恢复

#现在进行恢复
create database scj;
#新建库
mysql -uroot -pabc123 scj < /opt/backup/full/scj_scj1-2023.09.20.sql
#首先恢复基础表数据

在这里插入图片描述

#进入数据库
select * from scj.scj1
#查看表内容

在这里插入图片描述

#恢复第二次输入的内容
mysqlbinlog --no-defaults /opt/backup/bin/mysql-bin.000004-_20230921 | mysql -uroot -pabc123

在这里插入图片描述

#进入数据库
select * from scj.scj1
#查看表内容

在这里插入图片描述

#恢复第三次输入的内容
mysqlbinlog --no-defaults /opt/backup/bin/mysql-bin.000005-_2023.09.22 | mysql -uroot -pabc123

在这里插入图片描述

3.6.4 端点恢复

#将二进制文件转译
mysqlbinlog --no-defaults --base64-output=decode-rows -v mysql-bin.000004-_20230921 > mysql-bin-2023.09.21

mysqlbinlog --no-defaults --base64-output=decode-rows -v mysql-bin.000005-_2023.09.22 > mysql-bin-2023.09.22

在这里插入图片描述
在这里插入图片描述

3.6.4.1 基于位置恢复
#基本格式
mysqlbinlog --no-defaults --start-position='位置点' --stop-position='位置点' 二进制日志文件 | mysql -uXXX -pXXX
#示例
#只恢复小黑子那一段

#进入数据库清空表数据
truncate table scj.scj1;

在这里插入图片描述

vim /opt/backup/bin/vim mysql-bin-2023.09.21
#查看具体位置点

在这里插入图片描述

mysqlbinlog --no-defaults --start-position='293' --stop-position='526' /opt/backup/bin/mysql-bin.000004-_20230921 | mysql -uroot -pabc123
#将具体的位置点传往数据库服务器
#注:要使用二进制文件,不要用编码后的二进制文件

在这里插入图片描述

#前往数据库
select * from scj.scj1;
#查看内容

在这里插入图片描述

3.6.4.2 基于时间点恢复
#基本格式
mysqlbinlog --no-defaults --start-datetime='YYYY-mm-dd HH:MM:SS' --stop-datetime='YYYY-mm-dd HH:MM:SS' 二进制日志文件 | mysql -uXXX -pXXX
#示例
#只恢复小仙女那一段

#进入数据库清空表数据
truncate table scj.scj1;

在这里插入图片描述

vim /opt/backup/bin/vim mysql-bin-2023.09.21
#查看具体时间点

在这里插入图片描述

mysqlbinlog --no-defaults --start-datetime='2023-09-20 0:37:43' --stop-datetime='2023-09-20 0:40:35' /opt/backup/bin/mysql-bin.000004-_20230921 | mysql -uroot -pabc123
#将具体时间点范围内的数据传往数据库服务器内

在这里插入图片描述

#前往数据库
select * from scj.scj1;
#查看内容

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1034290.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

备受以太坊基金会青睐的 Hexlink,构建亿级用户涌入 Web3的入口

早在2021年9月&#xff0c;以太坊创始人Vitalik Buterin就曾提出了EIP-4337&#xff08;账户抽象&#xff09;提案&#xff0c;并在去年10月对该提案进一步更新&#xff0c;引发行业的进一步关注。在今年3月&#xff0c;EIP-4337提案正式通过审计&#xff0c;并成为了ERC-4337标…

conda常用指令

常用conda指令 查看当前有哪些环境&#xff0c;有base环境 conda env list 创建环境 # conda create -n 你的环境名 python版本号 # 创建python3.10&#xff0c;名为env虚拟环境 conda create -n env python3.10 激活环境 conda activate env

java框架-Spring-AOP

AOP:动态代理 开发步骤&#xff1a; 导入aop模块定义业务逻辑类定义切面类&#xff1b; -. 切面类标注&#xff1a;Aspect -. 切面类注解&#xff1a; Before: 前置通知, 在方法执行之前执行 After: 后置通知, 在方法执行之后执行 。 AfterRunning: 返回通知, 在方法返回结果之…

[杂谈]-快速了解半波和全波整流

快速了解半波和全波整流 文章目录 快速了解半波和全波整流1、滤波2、半波整流器3、全波整流器4、常见问题 整流器是一种将交流信号转换为脉动直流信号以及将交流电转换为直流电的电子电路。 我们日常生活中几乎所有的电子项目都会用到它。 根据周期传导&#xff0c;本文我们介绍…

【Python】ModuleNotFoundError: No module named ‘Crypto‘

今天在使用一个新的库Crypto时发生了报错 Crypto安装成功~ 导入Crypto模块也没有问题 运行时却发生了报错&#xff1a; 没有这个模块&#xff1f; 我明明安装成功了&#xff0c;为什么报错没有这个库呢&#xff1f; 于是我去查看了一下是不是没有安装上呢&#xff1f; 为什么…

sql注入挖掘

出现的条件 只要是和数据库有交互 没有过滤拼接的sql语句可以执行 判断 这个是在url筐里的

想要精通算法和SQL的成长之路 - 双指针【数组】

想要精通算法和SQL的成长之路 - 双指针【数组】 前言一. 合并两个有序数组二. 删除有序数组中的重复项 II 前言 想要精通算法和SQL的成长之路 - 系列导航 一. 合并两个有序数组 原题链接 抓住重点信息&#xff1a; 两个数组都是非递减顺序排列。num1数组&#xff0c;末尾包…

在Bat To Exe Converter,修改为当异常结束或终止时,程序重新启动执行

在Bat To Exe Converter&#xff0c;修改为当异常结束或终止时&#xff0c;程序重新启动执行 .bat中的代码部分&#xff1a; .bat中的代码echo offpython E:\python\yoloProjectTestSmallLarge\detect.pypause&#xff0c;我想你能帮在Bat To Exe Converter&#xff0c;修改成…

JAVA入坑之嵌套类

一、嵌套类入门 1.1概述 Java嵌套类是指在一个类中定义另一个类的一种方式&#xff0c;它可以提高代码的可读性、可维护性和封装性。Java嵌套类分为两种类型&#xff1a;静态嵌套类和非静态嵌套类。 静态嵌套类&#xff1a;Static nested classes,即类前面有static修饰符 非静…

【进阶C语言】字符串与内存库函数认识与模拟实现

本章内容大致目录&#xff1a; 1.strlen函数 2.strcpy函数 3.strcmp函数 4.strcat函数 5.strstr函数 6.strtok函数 7.strerror与perror函数 8.字符操作函数 9.内存操作函数 10.总结 以上函数均属于库函数&#xff0c;有的函数则会介绍如何模拟实现。 一、strlen函数…

conda创建虚拟环境安装aix360

目录 创建虚拟环境查看已有虚拟环境进入所创建的虚拟环境查看已安装的程序查看已安装的python模块配置镜像pipconda 安装aix360将环境添加到jupyter删除虚拟环境 创建虚拟环境 建议装python3.7python3.7python3.7python3.7python3.7python3.7python3.7python3.7python3.7pytho…

YTM32的LIN通信协议引擎LinFlexD外设模块详解

YTM32的LIN通信协议引擎LinFlexD外设模块详解 文章目录 YTM32的LIN通信协议引擎LinFlexD外设模块详解LINFlexD外设简介LINFlexD工作机制初始化主机模式从机模式错误状态标志位超时错误&#xff08;Timeout Error&#xff09;ID过滤机制接收器检测帧间隔段和帧间隔段分隔符产生波…

[游戏开发][Shader]GLSLSandBox转Unity-CG语言

官网 GLSL Sandbox Galleryhttps://glslsandbox.com/ 屏幕坐标计算 fragCoord与_ScreenParams mat2矩阵转换 vec2向量 在GLSL里mat2(a, b, c, d)函数返回vec2但是在CG语言里 没有mat2函数&#xff0c;用下面的值替换mat2方法vec2(a * 1. c * 1., b * 1. d * 1.);举例&…

一台电脑远程内网的另外一台电脑,禁止远程的电脑连接外网,只允许内网连接

一台电脑远程内网的另外一台电脑&#xff0c;禁止远程的电脑连接外网&#xff0c;只允许内网连接 1.找到右下角网卡图标&#xff0c;右键图标选择“打开网络和共享中心”。 3、点击“更改适配器设置”。 4、右键正在使用的网卡“本地连接”打开属性 5、找到“internet协…

vue简单案例----小张记事本

小张记事本 具体效果如图所示&#xff0c;这里就简单展示&#xff0c;还有很多不足的地方&#xff0c;希望大家可以对这个小项目进行改进&#xff0c;话不多说可以参考下面的代码 源代码如下 <html lang"en"><head><meta charset"UTF-8"…

1786_MTALAB代码生成把通用函数生成独立文件

全部学习汇总&#xff1a; GitHub - GreyZhang/g_matlab: MATLAB once used to be my daily tool. After many years when I go back and read my old learning notes I felt maybe I still need it in the future. So, start this repo to keep some of my old learning notes…

1400*C. No Prime Differences(找规律数学)

解析&#xff1a; 由于 1 不是质数&#xff0c;所以我们令每一行的数都相差 1 对于行间&#xff0c;分为 n、m之中有存在偶数和都为奇数两种情况。 如果n、m存在偶数&#xff0c;假设m为偶数。 如果都为奇数&#xff0c;则&#xff1a; #include<bits/stdc.h> using name…

解决0-1背包问题(方案二):一维dp数组(滚动数组)

往期文章&#xff1a;解决0-1背包问题&#xff08;方案一&#xff09;:二维dp数组_呵呵哒(&#xffe3;▽&#xffe3;)"的博客-CSDN博客https://blog.csdn.net/weixin_41987016/article/details/133207350?spm1001.2014.3001.5501 >>探索一维dp数组和二维dp数组的…

基于Spring Boot的医院预约挂号系统设计与实现(源码+lw+部署文档+讲解等)

前言 &#x1f497;博主介绍&#xff1a;✌全网粉丝10W,CSDN特邀作者、博客专家、CSDN新星计划导师、全栈领域优质创作者&#xff0c;博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java、小程序技术领域和毕业项目实战✌&#x1f497; &#x1f447;&#x1f3fb;…

想搭建数字藏品平台怎么做?

搭建数字藏品平台涉及多个步骤和技术方面的考虑。以下是创建数字藏品平台的一般步骤&#xff1a; 技术架构 选择合适的技术架构和平台。您可以选择使用现有的电子商务平台、自定义开发、或使用数字藏品管理系统等。云托管服务如Amazon Web Services 或Microsoft Azure也可以提…