AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / user-24815

Dan's questions

Martin Hope
Dan
Asked: 2024-10-06 05:32:13 +0800 CST

为什么 SQL Server 将恢复重播记录到磁盘而不是 RAM

  • 6
该问题已从 Stack Overflow迁移,因为它可以在 Database Administrators Stack Exchange 上找到答案。 已于 7 天前迁移 。

SQL Server 的文档谈到了在崩溃恢复期间将已提交的事务应用于数据文件,有点像在执行即时检查点。这应该在撤消未提交的事务之前发生,而撤消未提交的事务必须发生才能完成恢复过程。

为什么它会立即将已提交的事务刷新到数据文件中,而不是只将脏数据加载到 RAM 缓存中(与崩溃前数据存储在缓存 + 日志中的方式相同),然后将其作为下一个检查点的一部分写出?这似乎会不必要地延长崩溃恢复时间。

sql-server
  • 1 个回答
  • 89 Views
Martin Hope
Dan
Asked: 2015-04-18 21:03:17 +0800 CST

调试 PostgreSQL 序列化失败

  • 7

我正在尝试将我们的 PostgreSQL 9.4 数据库从事务级别迁移READ COMMITTED到REPEATABLE READor 或SERIALIZABLE. 无论哪种情况,我都会遇到一组新的格式错误:

(for both)
ERROR:  could not serialize access due to concurrent update
(just for SERIALIZABLE)
ERROR:  could not serialize access due to read/write dependencies among transactions

在阅读了有关 SSI 的 wiki 页面和文档后,我彻底了解了可能导致这些错误的错误条件、如何处理它们,甚至是避免它们的最佳实践。

但是,我看不到任何方法可以确定导致它们从 PostgreSQL 可以提供的任何调试输出或任何调试信息中产生的数据依赖性。有没有办法从数据库中获取这些信息,或者通过在回滚时执行额外的查询,或者通过一些日志机制?

拥有这些信息将使我能够进行应用程序级别的更改(锁定、不同的查询等),从而消除一些数据竞争以避免过多的回滚。

postgresql isolation-level
  • 1 个回答
  • 1697 Views
Martin Hope
Dan
Asked: 2013-06-13 17:18:18 +0800 CST

pg_ctl start 给出 FATAL: 角色不存在

  • 1

在我的系统上,whoami返回Dan. 我initdb带着这个--username=PgUser论点跑。然后作为操作系统用户Dan,我pg_ctl start在新初始化的集群上运行,它给出了以下输出:

LOG:  database system was shut down at 2013-06-13 00:54:33 UTC
LOG:  autovacuum launcher started
LOG:  database system is ready to accept connections
FATAL:  role "Dan" does not exist
 done
server started

服务器似乎已正常启动。我相信发生错误是因为它希望我以pg_ctl名为PgUser. 我想知道的是:

  • 这种信念正确吗?
  • 有没有办法将用户指定为PgUser不使用su?我不希望创建一个新的操作系统用户,而是希望使用具有不同用户名的 PostgreSQL 用户(我正在做一些代码重构,使这更方便)。
  • 我开始的实例是否因为我以操作系统用户身份启动而以某种方式瘫痪Dan?
postgresql
  • 1 个回答
  • 1445 Views
Martin Hope
Dan
Asked: 2013-06-11 15:21:28 +0800 CST

PostgreSQL“冻结”/“解冻”命令等价物

  • 8

在 Derby(一个用 Java 编写的嵌入式数据库,主要用于测试或原型设计)中,有可以在在线备份期间使用的“冻结”和“解冻”命令。“冻结”只会导致所有数据库访问阻塞,直到调用“解冻”。这对于使用外部程序进行备份很有用,如果外部程序比使用 Derby 的内部备份解决方案快得多,您可能会这样做。对于我的用例,我可以使用一些内置的文件系统实用程序几乎立即拍摄快照,因此它是一个恒定时间操作(不是O(length of DB files))。

我正在将一个已经超过 Derby 的应用程序迁移到 PostgreSQL,我想知道那里是否有任何类似的东西可以用来停止所有连接。此外,我更愿意从我的应用程序内部知道我的序列化点是什么,这样我就不会陷入某种尴尬的状态,因此能够暂停/恢复所有其他访问对我来说真的很不错。

由于 PostgreSQL 有一个事务日志,我可以只拍摄快照而不“冻结”,但快照需要通过 PostgreSQL 的恢复机制运行才能使用它,因为否则存储在磁盘上的内容与我拉取的内容相同普通文件系统上的插件。这种解决方案并不理想。

编辑我了解到这pg_start_backup()很接近,但它不会导致传入事务阻塞,直到匹配调用pg_stop_backup(),迫使我做一个时间点恢复回到pg_start_backup()从文件系统快照返回的事务 id。不必真正关闭 PostgreSQL 来获得它会很好(也许有一个伪关闭命令可以保持连接打开?)。

postgresql derby
  • 1 个回答
  • 5082 Views

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    连接到 PostgreSQL 服务器:致命:主机没有 pg_hba.conf 条目

    • 12 个回答
  • Marko Smith

    如何让sqlplus的输出出现在一行中?

    • 3 个回答
  • Marko Smith

    选择具有最大日期或最晚日期的日期

    • 3 个回答
  • Marko Smith

    如何列出 PostgreSQL 中的所有模式?

    • 4 个回答
  • Marko Smith

    列出指定表的所有列

    • 5 个回答
  • Marko Smith

    如何在不修改我自己的 tnsnames.ora 的情况下使用 sqlplus 连接到位于另一台主机上的 Oracle 数据库

    • 4 个回答
  • Marko Smith

    你如何mysqldump特定的表?

    • 4 个回答
  • Marko Smith

    使用 psql 列出数据库权限

    • 10 个回答
  • Marko Smith

    如何从 PostgreSQL 中的选择查询中将值插入表中?

    • 4 个回答
  • Marko Smith

    如何使用 psql 列出所有数据库和表?

    • 7 个回答
  • Martin Hope
    Jin 连接到 PostgreSQL 服务器:致命:主机没有 pg_hba.conf 条目 2014-12-02 02:54:58 +0800 CST
  • Martin Hope
    Stéphane 如何列出 PostgreSQL 中的所有模式? 2013-04-16 11:19:16 +0800 CST
  • Martin Hope
    Mike Walsh 为什么事务日志不断增长或空间不足? 2012-12-05 18:11:22 +0800 CST
  • Martin Hope
    Stephane Rolland 列出指定表的所有列 2012-08-14 04:44:44 +0800 CST
  • Martin Hope
    haxney MySQL 能否合理地对数十亿行执行查询? 2012-07-03 11:36:13 +0800 CST
  • Martin Hope
    qazwsx 如何监控大型 .sql 文件的导入进度? 2012-05-03 08:54:41 +0800 CST
  • Martin Hope
    markdorison 你如何mysqldump特定的表? 2011-12-17 12:39:37 +0800 CST
  • Martin Hope
    Jonas 如何使用 psql 对 SQL 查询进行计时? 2011-06-04 02:22:54 +0800 CST
  • Martin Hope
    Jonas 如何从 PostgreSQL 中的选择查询中将值插入表中? 2011-05-28 00:33:05 +0800 CST
  • Martin Hope
    Jonas 如何使用 psql 列出所有数据库和表? 2011-02-18 00:45:49 +0800 CST

热门标签

sql-server mysql postgresql sql-server-2014 sql-server-2016 oracle sql-server-2008 database-design query-performance sql-server-2017

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve