当前位置: 首页 > news >正文

Linux——数据库备份与恢复

一,Mysql数据库备份概述

1,数据库备份的重要性

  • 数据灾难恢复:数据库可能会因为各种原因出现故障,如硬件故障、软件错误、误操作、病毒攻击、自然灾害等。这些情况都可能导致数据丢失或损坏。如果有定期的备份,就可以在发生灾难后将数据库恢复到最近的一个正常状态,最大限度地减少数据丢失和业务中断的影响。
  • 误操作恢复:人为的误操作是很常见的,例如误删除数据、错误的更新操作等。备份可以作为一种 “后悔药”,方便及时将数据库恢复到误操作之前的状态,避免因误操作而造成的严重后果。
  • 数据迁移与共享:在进行数据库迁移到新的服务器或系统时,备份可以方便地将数据从旧环境迁移到新环境。此外,备份也可以用于在不同的系统或团队之间共享数据,确保数据的一致性和完整性。
  • 历史数据存档:随着时间的推移,数据库中的数据会不断增加,一些历史数据可能不再经常被访问,但仍然需要保留以备查询和分析。通过备份,可以将这些历史数据存档,减轻生产数据库的存储压力,同时也便于在需要时快速恢复和查询历史数据。

2,数据库备份类型

1,按备份内容分类

  • 完全备份:对整个数据库进行完整的备份,包括所有的数据、表结构、索引、存储过程等数据库对象。这种备份方式的优点是恢复时简单快捷,只需将备份文件恢复到数据库中即可,可一次性将数据库恢复到备份时的状态。缺点是备份时间长,占用存储空间大。
  • 差异备份:备份自上次完全备份以来发生变化的数据。恢复时,只需先恢复完全备份,再恢复最新的差异备份,恢复过程相对简单。与增量备份相比,差异备份不依赖于上一次差异备份的结果,
  • 增量备份:只备份自上次备份(可以是完全备份或增量备份)以来发生变化的数据。其优点是备份速度快,占用存储空间小,可以更频繁地进行备份,从而减少数据丢失的风险。

2,按备份数据库的状态分类

  • 热备份:也称为在线备份,在数据库正常运行、用户可以正常访问和操作数据库的情况下进行备份。热备份不会影响数据库的正常使用,但实现起来相对复杂,需要数据库管理系统提供相应的支持。
  • 温备份:在数据库运行状态下进行备份,但备份过程中会限制部分数据库操作,如暂停一些非关键的写入操作,以确保备份数据的一致性。
  • 冷备份:也称为离线备份,在数据库停止运行的状态下进行备份。这种方式简单直接,能保证备份数据的一致性,因为在备份过程中没有数据的写入和修改。但冷备份期间数据库无法使用,会导致业务中断,

3,按备份数据库的存储位置分类

  • 本地备份:将备份数据存储在与数据库服务器相同的本地存储设备上,如本地硬盘、磁盘阵列等。本地备份的优点是备份和恢复速度快,因为数据传输距离短。缺点是如果本地存储设备出现故障,
  • 异地备份:将备份数据存储在远离数据库服务器的其他地方,如通过网络将备份数据传输到远程的数据中心、云存储或其他服务器上。异地备份可以有效防止本地灾难(如火灾、洪水、地震等)对备份数据的破坏,提高数据的安全性和可靠性。

3,常见的备份方法

  • 物理冷备份:

物理冷备份时需要在数据库处于关闭状态下,能够较好地保证数据库的完整性。物理冷备份一般用于非核心业务,这类业务一般都允许中断,物理冷备份的特点就是速度快,恢复时也是最为简单的。通常通过直接打包数据库文件夹(本章中的数据库文件夹位于/usr/local/mysql/data)来实现备份。

  • 使用第三方工具mysqldump工具

mysqldump 是客户端常用逻辑备份程序,能够产生一组被执行以后再现原始数据库对象定义和表数据的SQL 语句。它可以转储一个到多个 MySQL 数据库,对其进行备份或传输到远程SQL 服务器。mysqldump 更为通用,因为它可以备份各种表。

  • 使用mysqlhotcopy工具:

mysqlhotcopy是一个 Perl 脚本,主要用于对 MyISAM 表进行快速备份。它通过复制表文件的方式来实现备份,在备份时会对表进行锁定,以确保数据的一致性。语法:mysqlhotcopy [选项] 数据库名 [备份目录]。如果不指定备份目录,则默认将备份文件存储在当前目录下。

  • 启用二进制日志进行增量备份:

MySQL 支持增量备份,进行增量备份时必须启用二进制日志。二进制日志文件为用户 提供复制,对执行备份点后进行的数据库更改所需的信息进行恢复。如果进行增量备份(包含自上次完全备份或增量备份以来发生的数据修改),需要刷新二进制日志。

  • 通过第三方工具备份(如 Percona XtraBackup):

这是一款开源的、高性能的 MySQL 数据库备份工具,主要用于 InnoDB 和 XtraDB 存储引擎的热备份。它通过复制数据文件和日志文件,并在备份过程中应用事务日志,来确保备份数据的一致性。

二,数据库备份操作

1,物理备份与操作

  • 使用完全备份来备份数据
mysql> create database db1;             ##创建数据库
Query OK, 1 row affected (0.01 sec)mysql> use db1;
Database changed
mysql> create table t1(user_name char(20),user_pass char(40));      ##创建表
Query OK, 0 rows affected (0.02 sec) mysql> insert into t1 values('zhangsan','123456');     ##准备要备份的数据
Query OK, 1 row affected (0.03 sec)mysql> insert into t1 values('lisi','123456');
Query OK, 1 row affected (0.01 sec)mysql> select * from t1;
+-----------+-----------+
| user_name | user_pass |
+-----------+-----------+
| zhangsan  | 123456    |
| lisi      | 123456    |
+-----------+-----------+
2 rows in set (0.00 sec)

  • 创建用于存放备份数据的目录
[root@bogon ~]# systemctl stop mysqld    ##因为做的是冷备份所以说需要关闭mysql数据库[root@bogon ~]# mkdir -p /opt/backup     ##创建目录用于存放备份的文件[root@bogon ~]# cd /usr/local/mysql/
[root@bogon mysql]# ls
bin  data  docs  include  lib  LICENSE  man  README  share  support-files
[root@bogon mysql]# tar zcvf back.tar.gz data   ##将数据库文件data压缩为back.tar.gz[root@bogon mysql]# mv back.tar.gz /opt/backup       ##移动到backup目录中
[root@bogon mysql]# ls !$ 
ls /opt/backup
back.tar.gz
  • 验证,模拟数据库故障

[root@bogon data]# cd /usr/local/mysql/data          
[root@bogon data]# lsauto.cnf        ca.pem               ibtmp1                      performance_schemabinlog.000001   client-cert.pem     '#innodb_redo'               private_key.pembinlog.000002   client-key.pem      '#innodb_temp'               public_key.pembinlog.000003   error.log            localhost.localdomain.pid   server-cert.pembinlog.000004  '#ib_16384_0.dblwr'   mysql                       server-key.pembinlog.index   '#ib_16384_1.dblwr'   mysql.ibd                   sysbogon.pid       ib_buffer_pool       mysql.sock                  undo_001ca-key.pem      ibdata1              mysql.sock.lock             undo_002
[root@bogon data]# rm -rf *                           ##将data目录中的数据删除,来模拟故障[root@bogon backup]# cd data
[root@bogon data]# mv * /usr/local/mysql/data/       ##将备份号data文件重新复制过去[root@bogon mysql]# systemctl start mysqld  ##启动mysql数据库mysql> show databases;         ##进入到数据库查看数据
+--------------------+
| Database           |
+--------------------+
| db1  

2,mysqldump备份与恢复

语法:

mysqldump -u(指定用户) -p(指定密码) 库名 [表名1] 表名2]  > /备份路径/备份文件名

mysql> create database mysqldb;       ##创建数据库和表
Query OK, 1 row affected (0.01 sec)mysql> use mysqldb;
Database changed
mysql> create table usert1(user_name char(20),user_pass char(40)); ##在表里面添加数据
Query OK, 0 rows affected (0.02 sec)##将数据备份到/opt/backup中并重命名为mysqldb.sql
[root@bogon backup]# mysqldump -uroot -ppwd123 mysqldb usert1 > /opt/backup/mysqldb.sql
drop table usert1          ##备份完成后删除usert1表[root@bogon backup]# mysql -uroot -ppwd123 mysqldb < mysqldb.sql  ##将备份好的数据进行恢复##查看数据的恢复情况
mysql> show tables;
+-------------------+
| Tables_in_mysqldb |
+-------------------+
| usert1            |
+-------------------+
1 row in set (0.00 sec)mysql> desc usert1;
+-----------+----------+------+-----+---------+-------+
| Field     | Type     | Null | Key | Default | Extra |
+-----------+----------+------+-----+---------+-------+
| user_name | char(20) | YES  |     | NULL    |       |
| user_pass | char(40) | YES  |     | NULL    |       |
+-----------+----------+------+-----+---------+-------+
2 rows in set (0.00 sec)
  • 基于二进制文件进行恢复
[root@bogon ~]# vim /etc/my.cnf         ##在此文件中[mysqld]添加三行
log-bin=/usr/local/mysql/mysql-bin       ##启用二进制日志
binlog_format=MIXED                        ##定义二进制日志的记录格式为混合模式
server-id=1                                    ##为mysql分配一个唯一的服务器标识符
[root@bogon ~]# systemctl restart mysqld   ##重启mysqld服务

[root@bogon /]# cd /usr/local/mysql/           ##/usr/local/mysql/中会生成一个mysql-bin.000001的二进制文件
[root@bogon mysql]# lsmysql-bin.000001  [root@bogon mysql]# mysqlbinlog mysql-bin.000001   ##使用此命令查看文件里面会又之前mysql数据库的命令
create database db1
create table t1(user_name char(20),user_pass char(40))mysql> drop database db1;             ##删除db1数据库
Query OK, 1 row affected (0.01 sec) ##使用命令恢复db1数据库
[root@bogon mysql]# mysqlbinlog --no-defaults mysql-bin.000001 | mysql -uroot -ppwd123mysqladmin -uroot -ppwd123 flush-logs  ##刷新日志会生成新的日志文件mysql-bin.000002
  • 基于二进制文件位置进行恢复
mysql> create database aaa;       ##创建数据库
Query OK, 1 row affected (0.00 sec)mysql> use aaa;
Database changed
mysql> create table bbb(user_name char(20),user_pass char(40));
Query OK, 0 rows affected (0.05 sec)##往表里面添加数据
mysql> insert into bbb values('zhangsan','123'),('lisi','456'),('wangwu','789');
Query OK, 3 rows affected (0.01 sec)
Records: 3  Duplicates: 0  Warnings: 0mysql> select * from bbb;
+-----------+-----------+
| user_name | user_pass |
+-----------+-----------+
| zhangsan  | 123       |
| lisi      | 456       |
| wangwu    | 789       |
+-----------+-----------+
3 rows in set (0.00 sec)mysql> insert into bbb values('ccc','000');    ##单独插入一个用户方便验证
Query OK, 1 row affected (0.00 sec)##刷新日志
[root@bogon mysql]# mysqladmin -uroot -ppwd123 flush-logs

BEGIN          ##开始位置
/*!*/;
# at 1644
#250509  8:36:33 server id 1  end_log_pos 1754 CRC32 0x1919625c 	Query	thread_i
SET TIMESTAMP=1746750993/*!*/;
insert into bbb values('ccc','000')
/*!*/;
# at 1754
#250509  8:36:33 server id 1  end_log_pos 1785 CRC32 0xb5f69b37 	Xid = 74
COMMIT/*!*/;       ##结束位置Database changed
mysql> select * from bbb;
+-----------+-----------+
| user_name | user_pass |
+-----------+-----------+
| zhangsan  | 123       |
| lisi      | 456       |
| wangwu    | 789       |
| ccc       | 000       |
+-----------+-----------+
4 rows in set (0.00 sec)mysql> delete from bbb where user_name="ccc";           ##删除ccc用户
Query OK, 1 row affected (0.00 sec)mysql> select * from bbb;
+-----------+-----------+
| user_name | user_pass |
+-----------+-----------+
| zhangsan  | 123       |
| lisi      | 456       |
| wangwu    | 789       |
+-----------+-----------+
3 rows in set (0.00 sec)

 验证

##恢复指定位置的内容
[root@bogon mysql]# mysqlbinlog --no-defaults --start-position='1644' --stop-position='1754' mysql-bin.000002 | mysql -uroot -ppwd123##查看恢复情况
mysql> select * from aaa.bbb;
+-----------+-----------+
| user_name | user_pass |
+-----------+-----------+
| zhangsan  | 123       |
| lisi      | 456       |
| wangwu    | 789       |
| ccc       | 000       |
+-----------+-----------+
4 rows in set (0.00 sec)

  • 基于二进制文件时间进行恢复
mysql> insert into bbb values('ddd','999');
Query OK, 1 row affected (0.00 sec)mysql> select * from aaa.bbb;
+-----------+-----------+
| user_name | user_pass |
+-----------+-----------+
| zhangsan  | 123       |
| lisi      | 456       |
| wangwu    | 789       |
| ccc       | 000       |
| ddd       | 999       |
+-----------+-----------+
5 rows in set (0.00 sec)BEGIN
/*!*/;
# at 929
#250509  8:47:58 server id 1  end_log_pos 1039 CRC32 0xa963fcd4 	Query	thread_id=21	exec_time=0	error_code=0
SET TIMESTAMP=1746751678/*!*/;
insert into bbb values('ddd','999')
/*!*/;
# at 1039
#250509  8:47:58 server id 1  end_log_pos 1070 CRC32 0xe7b5c0fc 	Xid = 126
COMMIT/*!*/;

验证 

mysql> select * from aaa.bbb;
+-----------+-----------+
| user_name | user_pass |
+-----------+-----------+
| zhangsan  | 123       |
| lisi      | 456       |
| wangwu    | 789       |
| ccc       | 000       |
| ddd       | 999       |
+-----------+-----------+
5 rows in set (0.00 sec)mysql> delete from bbb where user_name="ddd";         ##删除ddd用户
Query OK, 1 row affected (0.01 sec)mysql> select * from aaa.bbb;
+-----------+-----------+
| user_name | user_pass |
+-----------+-----------+
| zhangsan  | 123       |
| lisi      | 456       |
| wangwu    | 789       |
| ccc       | 000       |
+-----------+-----------+
4 rows in set (0.00 sec)##基于时间恢复
[root@bogon mysql]# mysqlbinlog --no-defaults --start-datetime='2025-05-09 8:47:58' --stop-datetime='2025-05-09 8:47:58' mysql-bin.000003 | mysql -uroot -ppwd123mysql> select * from aaa.bbb;
+-----------+-----------+
| user_name | user_pass |
+-----------+-----------+
| zhangsan  | 123       |
| lisi      | 456       |
| wangwu    | 789       |
| ccc       | 000       |
| ddd       | 999       |
+-----------+-----------+
5 rows in set (0.00 sec)

相关文章:

Linux——数据库备份与恢复

一&#xff0c;Mysql数据库备份概述 1&#xff0c;数据库备份的重要性 数据灾难恢复&#xff1a;数据库可能会因为各种原因出现故障&#xff0c;如硬件故障、软件错误、误操作、病毒攻击、自然灾害等。这些情况都可能导致数据丢失或损坏。如果有定期的备份&#xff0c;就可以…...

矩阵键盘模块

目录 1.矩阵键盘介绍 2.扫描的概念 数码管扫描&#xff08;输出扫描&#xff09; 矩阵键盘扫描&#xff08;输入扫描&#xff09; 矩阵按键采用逐行扫描&#xff1a; 3.矩阵键盘代码 第一步&#xff1a; 第二步&#xff1a; 第三步&#xff1a; 第四步&#xff1…...

连接词化归律详解

1. 连接词化归律的基本概念 连接词化归律(也称为归结原理)是数理逻辑中用于简化逻辑表达式的重要方法&#xff0c;它允许我们将复杂的逻辑表达式转化为更简单的等价形式&#xff0c;特别是转化为合取范式(CNF)或析取范式(DNF)。 核心思想 连接词化归律基于一系列逻辑等价关系…...

Ubuntu 18.04 iso文件下载

参考&#xff1a;https://blog.csdn.net/Li060703/article/details/106075597 Rufus 官网&#xff1a; https://rufus.ie/zh/ 镜像下载地址 阿里云镜像站&#xff1a;https://mirrors.aliyun.com/ubuntu-releases/18.04/ 网易镜像&#xff1a;http://mirrors.163.com/ub…...

【C#】ToArray的使用

在 C# 中&#xff0c;ToArray 方法通常用于将实现了 IEnumerable<T> 接口的集合&#xff08;如 List<T>&#xff09;转换为数组。这个方法是 LINQ 提供的一个扩展方法&#xff0c;位于 System.Linq 命名空间中。因此&#xff0c;在使用 ToArray 方法之前&#xff0…...

学习日志03 java

最近有点懈怠了&#xff0c;多多实践&#xff0c;多敲代码&#xff0c;多多专注&#xff01; 1 ArithmeticException ArithmeticException 是 Java 中的一个异常类&#xff0c;它继承自 RuntimeException&#xff0c;用于表示在算术运算中出现的错误。这个异常通常在以下情况…...

数据库故障排查指南

对于项目研发来讲&#xff0c;数据库是必不可少的一个重要环节&#xff0c;本文详细总结了项目研发中数据库故障问题排查指南&#xff0c;希望会对大家有所帮助。 数据库连接问题 检查数据库服务是否正常运行&#xff0c;确认网络连接是否畅通&#xff0c;验证数据库配置文件…...

洛谷 P1955 [NOI2015] 程序自动分析

【题目链接】 洛谷 P1955 [NOI2015] 程序自动分析 【题目考点】 1. 并查集 2. 离散化 【解题思路】 多组数据问题&#xff0c;对于每组数据&#xff0c;有多个 x i x j x_ix_j xi​xj​或 x i ≠ x j x_i \neq x_j xi​xj​的约束条件。 所有相等的变量构成一个集合&…...

音视频学习:使用NDK编译FFmpeg动态库

1. 环境 1.1 基础配置 NDK 22b (r22b)FFmpeg 4.4Ubuntu 22.04 1.2 下载ffmpeg 官网提供了 .tar.xz 包&#xff0c;可以直接下载解压&#xff1a; wget https://ffmpeg.org/releases/ffmpeg-4.4.tar.xz tar -xvf ffmpeg-4.4.tar.xz cd ffmpeg-4.41.3 安装基础工具链 sudo …...

OpenHarmony Linux内核本地管理

概述 写这篇文章的初衷&#xff0c;其实也是作者从事多年Android系统开发中&#xff0c;根深蒂固的目录情节导致的&#xff0c;再开发Harmony系统中&#xff0c;总是想模拟Android系统的开发思路。 对于OpenHarmony这个patch机制&#xff0c;其实我很讨厌它&#xff0c;虽然这样…...

2025最新出版 Microsoft Project由入门到精通(六)

目录 三种资源类型的分配方式 成本类资源的分配方式 第一步&#xff1a;切换视图为”任务分配状况“视图 第二步&#xff1a;选中任务→资源→分配资源&#xff0c;打开分配资源窗口选择资源单击”分配“ 资源成本的修改方式 ​编辑工时类资源的分配方式 工时类资源的…...

Tomcat服务部署

目录 一. Tomcat概述 1.1 什么是Tomcat 1.2 安装Tomcat 1.2.1 CentOS7 安装 1.2.2 ubuntu 安装 1.2.3 使用脚本快速安装 二. 配置文件及核心组件 2.1 配置文件 2.1.1 安装目录下文件介绍 2.1.2 conf子目录 2.2 组件 三. tomcat 处理请求过程 四. 常见配置详解 4.…...

Chrome更新到136以后selenium等自动化浏览器失效

Chrome更新到136以后&#xff0c;已经不再支持对默认浏览器数据文件夹进行自动化调试&#xff0c;从而导致selenium在指定user-data-dir为默认路径“C:\Users\{计算机名}\AppData\Local\Google\Chrome\User Data”会报错&#xff0c;相应地的selenium-wire&#xff0c;undetect…...

数据库原理期末考试速成--最后附带两套题

引言 为什么从3开始呢,毕竟是速成吗,总要放弃一些东西 前两章1.概论 2.关系数据库:这里面都是一些运算符什么的,我感觉都学这个:笛卡尔积之列的都会算 这两章比较重要的我就放在这里了 选择、投影、连接、除、并、交、差,其中选择、投影、并、差、笛卡尔积是5种基本关…...

网络基础1(应用层、传输层)

目录 一、应用层 1.1 序列化和反序列化 1.2 HTTP协议 1.2.1 URL 1.2.2 HTTP协议格式 1.2.3 HTTP服务器示例 二、传输层 2.1 端口号 2.1.1 netstat 2.1.2 pidof 2.2 UDP协议 2.2.1 UDP的特点 2.2.2 基于UDP的应用层…...

使用Spring Boot集成Nacos

Nacos是一个更易于构建云原生应用的动态服务发现、配置管理和服务管理平台。它集成了服务发现、服务配置和服务管理等功能&#xff0c;是微服务架构中一个非常重要的组件。以下是使用Spring Boot集成Nacos的详细步骤。 1. 环境准备 确保你已经安装和配置了以下环境&#xff1…...

破局智算瓶颈:400G光模块如何重构AI时代的网络神经脉络

一、技术演进与市场需求双重驱动 在数字化转型浪潮下&#xff0c;全球互联网流量正以每年30%的复合增长率持续攀升。根据Dell’Oro Group最新报告&#xff0c;2023年400G光模块市场规模已突破15亿美元&#xff0c;预计2026年将占据数据中心光模块市场60%以上份额。这种爆发式增…...

Vue:插值表达

Vue 的插值表达式是数据绑定的基础形式&#xff0c;它通过 {{ }} 将 JavaScript 数据动态渲染到模板中。下面通过代码示例&#xff0c;直观感受它的用法和限制。 基础用法 <template>&#xff1c;div&#xff1e;<!-- 直接显示数据 --><p&#xff1e;{{ messag…...

26考研|数学分析:函数列与函数项级数

前言 函数列与函数项级数这一章虽然课本安排章节较少&#xff0c;只要两小节&#xff0c;但是在具体学习过程中&#xff0c;确实会有一定的难度&#xff0c;首先难点便是在对于函数列与函数项级数的理解&#xff0c;其次关于一致收敛性质的理解与判断&#xff0c;也是难点所在…...

设置环境变量启动jar报

1. 环境变量设置 set PATHC:\Program Files\java17\jdk-17.0.9\bin;%PATH%2. 启动jar java -jar jar包名3. 记录原因 PATH路径前添加java执行文件路径才会管用。添加后可以试试以下命令 直接输入PATH 回车 PATH进行java版本测试 java -version...

项目售后服务承诺书,软件售后服务方案,软件安装文档,操作文档,维护文档(Word原件)

一、系统安全性保障 &#xff08;一&#xff09;设计原则 &#xff08;二&#xff09;应用安全 &#xff08;三&#xff09;数据安全 &#xff08;四&#xff09;用户安全 &#xff08;五&#xff09;管理安全 二、售后服务 &#xff08;一&#xff09;服务总体要…...

Arduino快速入门

Arduino快速入门指南 一、硬件准备 选择开发板&#xff1a; 推荐使用 Arduino UNO&#xff08;兼容性强&#xff0c;适合初学者&#xff09;&#xff0c;其他常见型号包括NANO&#xff08;体积小&#xff09;、Mega&#xff08;接口更多&#xff09;。准备基础元件&#xff1a…...

每日一题——樱桃分级优化问题:最小化标准差的动态规划与DFS解决方案

文章目录 一、问题描述输入格式输出格式 二、问题本质分析三、解题思路1. 前缀和预处理2. DFS 枚举与剪枝3. 剪枝策略4. 标准差计算 四、代码实现五、样例解析样例 1样例 2 六、一行行代码带你敲dfs 七、总结 一、问题描述 某大型樱桃加工厂使用自动化机械扫描了一批樱桃的尺寸…...

C++类与对象(二):六个默认构造函数(一)

在学C语言时&#xff0c;实现栈和队列时容易忘记初始化和销毁&#xff0c;就会造成内存泄漏。而在C的类中我们忘记写初始化和销毁函数时&#xff0c;编译器会自动生成构造函数和析构函数&#xff0c;对应的初始化和在对象生命周期结束时清理资源。那是什么是默认构造函数呢&…...

荣耀手机,系统MagicOS 9.0 USB配置没有音频来源后无法被adb检测到,无法真机调试的解决办法

荣耀手机&#xff0c;系统MagicOS 9.0 USB配置没有音频来源后无法被adb检测到&#xff0c;无法真机调试的解决办法 前言环境说明操作方法 前言 一直在使用的uni-app真机运行荣耀手机方法&#xff0c;都是通过设置USB配置的音频来源才能成功。突然&#xff0c;因为我的手机的系…...

每日分享-Python哈希加盐加密实战分享

没事找事干&#xff0c;找到本地有个hashdemo.py&#xff0c;那就来分享一下代码吧&#xff0c;主要内容就是使用python实现哈希加盐加密方式。 1、导入所需库 不多BB&#xff0c;先打开我们的 pychram 然后导入所需要用到的库 import hashlib import random import strin…...

Webpack中Compiler详解以及自定义loader和plugin详解

Webpack Compiler 源码全面解析 Compiler 类图解析&#xff1a; 1. Tapable 基类 Webpack 插件系统的核心&#xff0c;提供钩子注册&#xff08;plugin&#xff09;和触发&#xff08;applyPlugins&#xff09;能力。Compiler 和 Compilation 均继承此类&#xff0c;支持插件…...

deepseek-coder-6.7b-instruct安装与体验-success

目录 步骤1:安装环境 步骤2:下载模型 步骤3:安装依赖 步骤4:运行模型 报错NameError: name torch is not defined 步骤5:运行结果 步骤1:安装环境 pip install modelscope 步骤2:下载模型 modelscope download --model deepseek-ai/deepseek-coder-6.7b-instruct --lo…...

对抗进行性核上性麻痹,健康护理筑牢生活防线

进行性核上性麻痹是一种复杂的神经退行性疾病&#xff0c;主要影响患者的运动、平衡及吞咽等功能&#xff0c;随着病情进展&#xff0c;患者生活质量会受到严重影响。除规范治疗外&#xff0c;科学的健康护理是提高患者生活质量、延缓病情发展的重要手段。 日常活动护理是基础。…...

科学养生,拥抱健康生活

在生活节奏日益加快的今天&#xff0c;养生不再是遥不可及的概念&#xff0c;而是可以融入日常的健康生活方式。即使抛开中医理念&#xff0c;通过科学的生活方式选择&#xff0c;也能为身体注入源源不断的活力。 从营养管理开始&#xff0c;构建科学的饮食体系。采用 “321 饮…...

基于若依框架的岗位名称查询模块实现

表名&#xff1a;sys_post&#xff08;若依自带的一个表&#xff09; 目标&#xff1a;获取post_name中所有的名字 模块结构说明 src/ ├── main/ │ ├── java/ │ │ └── com/ │ │ └── ruoyi/ │ │ └── nametraversal/ │ │…...

(2)Python爬虫--requests

文章目录 前言一、 认识requests库1.1 前情回顾1.2 为什么要学习requests库1.3 requests库的基本使用1.4 响应的保存1.5 requests常用的方法1.6 用户代理1.7 requests库&#xff1a;构建ua池(可以先跳过去)1.8 requests库&#xff1a;带单个参数的get请求1.9 requests库&#x…...

springboot旅游小程序-计算机毕业设计源码76696

目 录 摘要 1 绪论 1.1研究背景与意义 1.2研究现状 1.3论文结构与章节安排 2 基于微信小程序旅游网站系统分析 2.1 可行性分析 2.1.1 技术可行性分析 2.1.2 经济可行性分析 2.1.3 法律可行性分析 2.2 系统功能分析 2.2.1 功能性分析 2.2.2 非功能性分析 2.3 系统…...

TCPIP详解 卷1协议 七 防火墙和网络地址转换

7.1——防火墙和网络地址转换 为防止终端系统不被攻击&#xff0c;需要一种方法来控制互联网中网络流量的流向。这项工作由防火墙来完成&#xff0c;它是一种能够限制所转发的流量类型的路由器。 随着部署防火墙来保护企业&#xff0c;另一个问题变得越来越重要&#xff1a;可…...

Golang 应用的 CI/CD 与 K8S 自动化部署全流程指南

一、CI/CD 流程设计与工具选择 1. 技术栈选择 版本控制&#xff1a;Git&#xff08;推荐 GitHub/GitLab&#xff09;CI 工具&#xff1a;Jenkins/GitLab CI/GitHub Actions&#xff08;本文以 GitHub Actions 为例&#xff09;容器化&#xff1a;Docker Docker Compose制品库…...

Jenkins:库博静态工具CI/CD 的卓越之选

在当今快节奏的软件开发领域&#xff0c;高效的持续集成&#xff08;CI&#xff09;和持续交付&#xff08;CD&#xff09;流程对于项目的成功至关重要。Jenkins 作为开源 CI/CD 软件的领导者&#xff0c;以其强大的功能、丰富的插件生态和高度的可扩展性&#xff0c;成为众多开…...

Maven私服搭建与登录全攻略

目录 1.背景2.简介3.安装4.启动总结参考文献 1.背景 回顾下maven的构建流程&#xff0c;如果没有私服&#xff0c;我们所需的所有jar包都需要通过maven的中央仓库或者第三方的maven仓库下载到本地&#xff0c;当一个公司或者一个团队所有人都重复的从maven仓库下载jar包&#…...

大模型数据分析破局之路20250512

大模型数据分析破局之路 本文面向 AI 初学者、数据分析从业者与企业技术负责人&#xff0c;围绕大模型如何为数据分析带来范式转变展开&#xff0c;从传统数据分析困境谈起&#xff0c;延伸到 LLM MCP 的协同突破&#xff0c;最终落脚在企业实践建议。 &#x1f30d; 开篇导语…...

数据结构-树(1)

一、树的基本概念 二&#xff0c;树的抽象数据结构 三&#xff0c;树的存储结构 1.双亲表示法 数组存储结点&#xff0c;含数据域和双亲下标&#xff08;根结点双亲为 - 1&#xff09; 代码示例 include <stdio.h> #include <stdlib.h>#define MAX_TREE_SIZE 10…...

什么是ERP?ERP有哪些功能?小微企业ERP系统源码,SpringBoot+Vue+ElementUI+UniAPP

什么是ERP&#xff1f; ERP翻译过来叫企业资源计划&#xff0c;通俗的讲&#xff0c;应该叫企业的全面预算控制&#xff0c;其通常包括三个部分&#xff1a;工程预算、投资预算和经营预算&#xff08;即产销存预算&#xff09;。之所以做预算控制&#xff0c;是因为企业运作的…...

视觉-语言-动作模型:概念、进展、应用与挑战(上)

25年5月来自 Cornell 大学、香港科大和希腊 U Peloponnese 的论文“Vision-Language-Action Models: Concepts, Progress, Applications and Challenges”。 视觉-语言-动作 (VLA) 模型标志着人工智能的变革性进步&#xff0c;旨在将感知、自然语言理解和具体动作统一在一个计…...

C++ 与 Go、Rust、C#:基于实践场景的语言特性对比

目录 ​编辑 一、语法特性对比 1.1 变量声明与数据类型 1.2 函数与控制流 1.3 面向对象特性 二、性能表现对比​编辑 2.1 基准测试数据 在计算密集型任务&#xff08;如 10⁷ 次加法运算&#xff09;中&#xff1a; 在内存分配测试&#xff08;10⁵ 次对象创建&#xf…...

RDB和AOF的区别

Redis提供两种主要的持久化机制&#xff1a;RDB&#xff08;Redis Database&#xff09;和AOF&#xff08;Append Only File&#xff09;&#xff0c;它们在数据持久化方式、性能影响及恢复策略上各有特点。以下是两者的对比分析及使用建议&#xff1a; RDB&#xff08;快照持久…...

因子分析基础指南:原理、步骤与地球化学数据分析应用解析

前言 在看深度学习成矿预测以及地球化学数据分析的文献的时候很多引言部分的内容会提到一些老的技术&#xff0c;正所谓&#xff1a;知其然知其所以然。所以我把关于一些老技术的基础铺垫的内容作为&#xff1a;研究生基础指南部分进行记录。 这部分讲述的是因子分析&#xf…...

采用AI神经网络降噪算法的通信语音降噪(ENC)模组性能测试和应用

采用AI降噪的语言通话环境抑制模组性能效果测试 随着AI时代来临.通话设备的环境噪音抑制也进入AI降噪算法时代. AI神经网络降噪技术是一款革命性的语音处理技术&#xff0c;他突破了传统单麦克风和双麦克风降噪的局限性,利用采集的各种日常环境中的噪音样本进行训练学习.让降噪…...

面试题 - Kafka、RabbitMQ、RocketMQ如何选型?

在当今的高并发、大数据时代&#xff0c;系统架构的复杂性呈指数级增长。你是否曾遇到过这样的问题&#xff1a;用户订单提交后&#xff0c;系统响应缓慢甚至卡顿&#xff1f;或者在业务高峰期&#xff0c;消息积压导致系统崩溃&#xff1f; 这些问题的背后&#xff0c;往往隐…...

【落羽的落羽 C++】stack和queue、deque、priority_queue、仿函数

文章目录 一、stack和queue1. 概述2. 使用3. 模拟实现 二、deque三、priority_queue1. 概述和使用2. 模拟实现 四、仿函数 一、stack和queue 1. 概述 我们之前学习的vector和list&#xff0c;以及下面要认识的deque&#xff0c;都属于STL的容器&#xff08;containers&#x…...

Golang 空结构体特性与用法

文章目录 1.简介2.核心特性2.1 零内存占用2.2 值比较语义2.3 类型隔离2.4 值地址 3.作用3.1 实现集合&#xff08;Set&#xff09;3.2 不发送数据的信道3.3 无状态方法接收者3.4 作为 context 的 value 的 key 4.小结参考文献 1.简介 在 Go 语言中&#xff0c;空结构体是一个不…...

企业对数据集成工具的需求及 ETL 工具工作原理详解

当下&#xff0c;数据已然成为企业运营发展过程中的关键生产要素&#xff0c;其重要性不言而喻。 海量的数据分散在企业的各类系统、平台以及不同的业务部门之中&#xff0c;企业要充分挖掘这些数据背后所蕴含的巨大价值&#xff0c;实现数据驱动的精准决策&#xff0c;数据集…...

基于HTTP头部字段的SQL注入:SQLi-labs第17-20关

前置知识&#xff1a;HTTP头部介绍 HTTP&#xff08;超文本传输协议&#xff09;头部&#xff08;Headers&#xff09;是客户端和服务器在通信时传递的元数据&#xff0c;用于控制请求和响应的行为、传递附加信息或定义内容类型等。它们分为请求头&#xff08;Request Headers&…...