首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

『数据库』你以为删库跑路就能让你老板内(lei)牛(liu)满面--数据库的恢复技术

如果只做一个操作,用户逻辑上就会发生错误,总量上少了1千,数据库就处于不一致性状态。 只可能是少不可能是多,因为A操作不发生,B操作也不会发生。...时刻的状态 重新运行自Tb~Tf时刻的所有更新事务,把数据库恢复到故障发生前的一致状态 1.1.2 方法 静态与动态: 静态: 在系统中无运行事务时进行的操作 开始时数据库处于一致性状态...后备副本上的A过时了 小结: 利用动态得到的副本进行故障恢复 需要把动态期间各事务对数据库的修改活动登记下来,建立日志文件 后备副本加上日志文件就能把数据库恢复到某一时刻的正确状态 海量与增量...: 海量: 每次全部数据库 增量: 只上次后更新过的数据 海量与增量比较 从恢复角度看,使用海量得到的后备副本进行恢复往往更方便 如果数据库很大,事务处理又十分频繁...王珊,女,1944年,工学硕士,中国人民大学信息学院教授、博士导师,研究方向是高性能数据库新技术、内存数据库技术、Video数据库技术、数据库信息检索新技术研究、数据仓库与商务智能技术等。

68220

在 Linux 上创建并调试文件

崩溃、内存核心、系统……这些全都会产生同样的产物:一个包含了当应用崩溃时,在那个特定时刻应用的内存状态的文件。...退出,带有如下错误: image.png “Abgebrochen (Speicherabzug geschrieben) ”(LCTT 译注:这是德语,应该是因为本文作者系统是德语环境)大致翻译为“分段故障...(核心)”。...否则,用以下方法纠正限制: ulimit -c unlimited 要禁用创建核心,可以设置其大小为 0: ulimit -c 0 这个数字指定了核心文件的大小,单位是块。 什么是核心?...而如果不是你的应用程序,将核心转发给开发人员将帮助她或他找到并修复问题。

3.3K30
您找到你想要的搜索结果了吗?
是的
没有找到

如何在Linux上获得错误段的核心

步骤1:运行 valgrind 我发现找出为什么我的程序出现段错误的最简单的方式是使用 valgrind:我运行 1. valgrind -v your-program 这给了我一个故障时的堆栈调用序列...当您的程序出现段错误,Linux 的内核有时会把一个核心写到磁盘。 当我最初试图获得一个核心时,我很长一段时间非常沮丧,因为 – Linux 没有生成核心!我的核心在哪里?...%t ulimit:设置核心的最大尺寸 ulimit -c 设置核心的最大尺寸。 它往往设置为 0,这意味着内核根本不会写核心。 它以千字节为单位。...%t 将核心保存到目录 /tmp 下,并以 core 加上一系列能够标识(出故障的)进程的参数构成的后缀为文件名。...我们仍然不知道该程序为什么会出现段错误! 下一步将使用 gdb 打开核心文件并获取堆栈调用序列。

4K20

垃圾收集不健康的JVM,这是一种主动方法

但是,这有一个严重的问题:Java堆被写入并存储在磁盘上,如果我们反复执行自动终止操作,可能会填满磁盘。因此,我们开始研究获取OS本地核心而不是JVM特定的堆的方法。...我们意识到,如果我们可以让一个不健康的JVM发送自己的SIGABRT而不是SIGKILL,则Linux内核将自动为我们编写一个核心。...当Linux进行核心时,默认行为是在崩溃的进程的工作目录中写入一个名为“ core”的文件。...但是,使用kernel.core_pattern sysctl,可以指定应将核心通过管道传输到的程序(请参见核心手册页中的“将核心管道传输到程序” )。...这是一个折衷:我们将核心文件同步上传到S3,而不必考虑是否需要在本地存储核心文件。实际上,我们能够在不到两分钟的时间内可靠地上传16GB核心

1.4K10

内核的设置

核心如何产生 上面说当程序运行过程中异常终止或崩溃时会发生 core dump,但还没说到什么具体的情景程序会发生异常终止或崩溃。...不会生成core dump文件的情况 进程没有写入核心文件的权限。(默认情况下,核心文件称为 core 或 core.pid,其中 pid 是核心的进程的 ID,并在当前工作目录中创建。...一个(可写的、常规的)文件与用于核心的同名文件已经存在,但有多个硬链接到该文件。 将创建核心文件的文件系统已满;或已用完 inode;或以只读方式安装;或者用户已达到文件系统的配额。...要创建核心文件的目录不存在。...此外,如果使用了 madvise(2) MADV_DONTDUMP 标志,则核心可能会排除进程的部分地址空间。 启用内核 使用ulimit命令可以查看当前的内核功能是否生效。

1.7K40

数据库复习题 考试题库(简答题)

把数据的修改写到数据库和把对数据的修改操作写到日志文件是两个不同的操作,在两个操作之间可能会发故障如果先写了数据库修改,而在日志文件中没有登记这个修改,在恢复的时候就无法恢复这个修改了;如果先写日志,...具体地说就是: ⑴ 装入最新的数据库后备副本(离故障发生时刻最近的副本),使数据库恢复到最近一次时的一致性状态。...对于动态的数据库副本,还须同时装入开始时刻的日志文件副本,利用恢复系统故障的方法(即REDO+UNDO),才能将数据库恢复到一致性状态。...当数据库遭到破坏后可以将后备副本重新载入,将数据库恢复到时的状态。 可分为静态和动态。静态是在系统中无运行事务时进行的操作。动态是指期间允许对数据库进行存取或修改。...即和用户事务可以并发执行。 还可分为海量和增量两种方式。 23.什么是日志文件?为什么要设立日志文件? 日志文件是用来记录事务对数据库的更新操作的文件。

3K10

Linux进程信号【信号产生】

,形成 core.pid 这样的二进制文件(核心 文件) 6.1、核心的概念 对于某些信号来说,当终止进程后,需要进行 core dump,产生核心文件 比如:3号 SIGQUIT、4号 SIGILL...,都没有发现 核心 文件啊 难道是我们的环境有问题吗?...,当前系统中的核心文件大小为 0,即不生成核心文件 通过指令手动设置核心文件大小 ulimit -c 1024 现在可以生成核心文件了 就拿之前的 野指针 代码测试,因为它发送的是 11...号信号,会产生 core dump 文件 核心文件是很大的,而有很多信号都会产生核心文件,所以云服务器一般默认是关闭的 云服务器上是可以部署服务的,一般程序发生错误后,会立即重启 如果打开了核心...,不安全 关闭核心很简单,设置为 0 就好了 ulimit -c 0 6.3、核心的作用 如此大的核心文件有什么用呢?

25210

面试必问:如何检测并避免 Java 中的死锁?

经典但核心Java面试问题之一。 如果你没有参与过多线程并发 Java 应用程序的编码,你可能会失败。 如何避免 Java 线程死锁? 如何避免 Java 中的死锁?...另一种方法是在运行应用程序时实际锁定时找到它, 尝试采取线程,在 Linux 中,你可以通过kill -3命令执行此操作, 这将打印应用程序日志文件中所有线程的状态, 并且你可以看到哪个线程被锁定在哪个线程对象上...你可以使用 fastthread.io 网站等工具分析该线程, 这些工具允许你上载线程并对其进行分析。...如果你有兴趣了解故障排除工具和分析线程的过程, 我建议你看看 Uriah Levy 在多元视觉(PluraIsight)上《分析 Java 线程》课程。...旨在详细了解 Java 线程, 并熟悉其他流行的高级故障排除工具。 编写一个将导致死锁的Java程序? 一旦你回答了前面的问题,他们可能会要求你编写代码,这将导致Java死锁。

1.2K10

Windows配置kernel dump和complete dump

SYSTEM\CurrentControlSet\Control\CrashControl 页面文件 页面文件是硬盘上的可选隐藏系统文件,页面文件具有以下功能: RAM 的物理扩展 应用程序要求 支持系统故障...单击“高级”选项卡,在启动和故障恢复区域中,单击“设置”,然后检查在写入调试信息下的是否为核心内存; c. 单击“确定”两次; 2) 创建页面文件 a. ...3)重启计算机,使配置生效 注意: 内存文件所选择的磁盘必须有足够的可用空间。 默认情况下的会将内存写至 %SystemRoot%\Memory.dmp文件。...如果在 %systemroot%驱动器上没有足够的可用空间,可以将该文件重定向到另一个具有足够的可用空间的位置。(所需空间大小请参考您的Pagefile size)。...单击“高级”选项卡,在启动和故障恢复区域中,单击“设置”,然后检查在写入调试信息下的是否为完全内存; c. 单击“确定”两次; 2) 创建页面文件 a.

51740

中高级Java开发面试题,最难的几道Java面试题,看看你跪在第几个

由于任何有权访问内存的人都可以以明文形式找到密码,这是另一个原因,你应该始终使用加密密码而不是纯文本。...你可以使用 fastthread.io 网站等工具分析该线程, 这些工具允许你上载线程并对其进行分析。...如果你有兴趣了解故障排除工具和分析线程的过程, 我建议你看看 Uriah Levy 在多元视觉(PluraIsight)上《分析 Java 线程》课程。...旨在详细了解 Java 线程, 并熟悉其他流行的高级故障排除工具。 8. 如果你的Serializable类包含一个不可序列化的成员,会发生什么?你是如何解决的?...为什么Java中 wait 方法需要在 synchronized 的方法中调用? ---- 另一个棘手的核心 Java 问题,wait 和 notify。

1.5K10

如何获取JVM堆文件

有很多很不错的的工具,例如Eclipse MAT和Heap Hero,可以分析堆。但是,您需要为这些工具提供以正确的格式和正确的时间点捕获的堆。 本文为您提供了捕获堆的多个选项。...如果传递了此选项,则仅将内存中的存活的对象写入堆文件。如果未通过此选项,则所有对象,即使是准备进行垃圾回收的对象,都将打印在堆文件中。它将大大增加堆文件的大小。这也将使分析变得乏味无聊。...最佳实践:始终保持在所有应用程序中配置此属性,因为您永远不知道何时会发生OutOfMemoryError。 jcmd jcmd工具用于将诊断命令请求发送到JVM。它打包为JDK的一部分。...例: jcmd 37320 GC.heap_dump /opt/tmp/heapdump.bin JVisualVM JVisualVM是一个监视,故障排除工具,打包在JDK中。...使用JConsole作为JMX客户端来生成堆 编程代码 除了使用工具之外,您还可以以编程方式从应用程序中捕获堆。在某些情况下,您可能希望基于应用程序中的某些事件来捕获堆

1.1K30

PostgreSQL从入门到精通教程 - 第39讲:数据库完全恢复

使用操作系统命令tar/cp数据文件 使用pg_ctl start对数据文件进行恢复非归档模式恢复在非归档模式下,必须恢复数据目录下所有的文件和目录: 所有$PGDATA目录下的子目录 base、...所有$PGDATA目录下的文件 postgresql.conf、pg_hba.conf...非归档模式恢复优缺点优势 易于执行,出错风险低 恢复时间是所有文件所需的时间缺点 数据丢失,必须手动重新应用...)归档模式完全恢复优缺点优势 将所有数据恢复到最新点(故障点) 恢复时间是数据文件和应用所有归档日志文件所需的时间缺点 必须具有自您要从中恢复的备份以来的所有归档日志文件执行一个基于数据库备份的完全恢复示例...LSN –发生WAL段切换的LSN位置 reason –人类可读的时间线为什么改变的解释。...1、储备份的表空间目录到目标位置 cp -rf /backup/PG_12_201909212 /home/postgres/tblspc/2、backup_lable文件到$PGDATA目录下

20510

数据库升级-成为MySQL DBA 博客系列(之二)

数据库供应商通常每个月都会发布一些有bug /安全性修补程序的补丁,我们为什么要关心这些?...执行升级的推荐方式是并重新加载数据—这需要一些时间(取决于数据库的大小),但是在从站不再旋转的情况下执行升级通常是不可行的。...所有这些问题都通过执行/重新加载过程来解决。所以,虽然运行二进制升级也许可以,但是您也可能遇到严重的问题—这是您的要求,最终是您的决定。...那么是时候加载 - 这个过程也可能需要很长时间。一旦完成,你应该有一个新的和干净的MySQL 5.6节点。...要执行单个MySQL服务器的升级,您需要执行脱机升级(使其不能轮换,数据,将MySQL升级到5.6,加载数据,重新启动它)或创建一个从属服务器,升级它并最终故障转移到它(我们在上一节讨论MySQL复制升级时描述的过程

1.4K30

【千里之行始于足下】谈Oracle的system表空间

SYSTEM表空间及root dba 在系统表空间文件头存在一个重要的数据结构root dba,我们可以通过数据文件头获得这个信息。...在5.2.2中我们曾经提到过,文件头可以通过如下命令: alter session set events 'immediate trace nameFILE_HDRS level 10' 从生成的trace...再来看看1.417对象中存储的信息,数据块可以使用如下命令: alter system dump datafile 1 block 417 检查生成的跟踪文件,可以获得主要信息如下: ?...即所谓的一二,二三,三万物。...了解了SYSTEM表空间的重要作用,也就可以理解:为什么系统表空间的文件头损坏,或者如果启动对象的数据块损坏后,Oracle数据库就将无法启动。

1.6K50

数据库管理工具:如何使用 Navicat Premium (导出)和运行(导入)*.sql 文件?

文章目录 前言 一、(导出)数据库 SQL 文件 1.1、选择“ SQL 文件” 1.2、选择导出文件存放位置 1.3、查看 SQL 文件界面 1.4、查看 SQL 输出文件 1.5、查看输出文件详情信息...---- 一、(导出)数据库 SQL 文件 说明:即导出,运行即导入 SQL 文件,以下不另作说明。...1.1、选择“ SQL 文件” 双击需要导出的数据库,鼠标右键,选择“ SQL 文件”,如下图所示: 1.2、选择导出文件存放位置 选择导出文件存放位置,点击保存即可,如下图所示: 1.3、...查看 SQL 文件界面 查看 SQL 文件界面,查看信息,待进度条到达 100% 我们点击关闭即可, SQL 文件 OK,如下图所示: 1.4、查看 SQL 输出文件 打开我们刚才选择的...但是请注意,可能版本不同的时候会产生个别错误,比如相同的 SQL 文件你导进你的数据库会发现少了几张表?

4.8K30

MySQL 数据库如何使用 Navicat 导出和导入 *.sql 文件

文章目录 前言 一、(导出)数据库 SQL 文件 1.1、选择“ SQL 文件” 1.2、选择导出文件存放位置 1.3、查看 SQL 文件界面 1.4、查看 SQL 输出文件 1.5、查看输出文件详情信息...---- 一、(导出)数据库 SQL 文件 说明:即导出,运行即导入 SQL 文件,以下不另作说明。...1.1、选择“ SQL 文件” 双击需要导出的数据库,鼠标右键,选择“ SQL 文件”,如下图所示: ? 1.2、选择导出文件存放位置 选择导出文件存放位置,点击保存即可,如下图所示: ?...1.3、查看 SQL 文件界面 查看 SQL 文件界面,查看信息,待进度条到达 100% 我们点击关闭即可, SQL 文件 OK,如下图所示: ?...但是请注意,可能版本不同的时候会产生个别错误,比如相同的 SQL 文件你导进你的数据库会发现少了几张表?

13.5K31
领券