PostgreSQL初学注意点:

这是一些PostgreSQL初学者需要注意的有用信息:

1)元组tuples是行的物理版本;你可以通过选择隐藏列ctid、xmin、xmax开始了解它们(所有表都有);尽早开始关注这个,以后你就不会对缓慢的大量DELETE不回收磁盘空间、自动真空和臃肿问题感到惊讶了。

  1. 总是使用BUFFERS检查EXPLAIN ANALYZE - 正确的命令是: EXPLAIN (ANALYZE, BUFFERS)

3)扔掉pgAdmin--坚持使用tmux&psql,或者,如果你确实需要UI,使用DBeaver或DataGrip或Postico(但仍然要学习psql-fu,会有回报的)

4)启用尽可能多的日志记录: log_checkpoints = 0,log_autovacuum_min_duration = 0,log_temp_files = 0,log_lock_waitits = on, 以及尽可能低的非负的log_min_duration_statement,比如200ms(注意过多日志记录引起的观察者效应)

5)安装pg_stat_statements: 这是必须的; 如果可以,安装pg_stat_kcache和psg_wait_sampling(或psentinel)以及auto_explain(这些家伙需要在设置上做一些决定)。

  1. 使用PostgreSQL的Database_Lab瘦克隆和分支来开发和测试 (是的,ChatGPT可能会有帮助,但它经常会产生幻觉,所以一定要检查它)

7)确保启用数据校验和

  1. 调整autovacuum,使其频繁运行并加快速度

9)查询优化最终会比配置调整更重要,也更经常需要: 调整.conf到 "足够好",然后专注于持续使用pg_stat_statements和EXPLAIN(ANALYZE,BUFFERS)。

10)不幸的是,索引需要重建,因为它们的健康状况会随着时间的推移而下降: 即使是在PG14+中经过良好调优的autovacuum中也是如此; 为此做好准备,最好以自动化的方式进行;并定期清理未使用的和冗余的索引。

相关推荐
coderyi1 小时前
LLM Agent 浅析
前端·javascript·人工智能
我叫黑大帅1 小时前
TypeScript 6.0 弃用选项错误 TS5101 解决方法
javascript·后端·面试
科雷软件测试1 小时前
使用python+Midscene.js AI驱动打造企业级WEB自动化解决方案
前端·javascript·python
We་ct2 小时前
LeetCode 120. 三角形最小路径和:动态规划详解
前端·javascript·算法·leetcode·typescript·动态规划
changshuaihua0014 小时前
React 入门
前端·javascript·react.js
掘金安东尼5 小时前
本周前端与 AI 技术情报|前端下一步 #462
前端·javascript·面试
qq_12084093715 小时前
Three.js 工程向:实例化渲染 InstancedMesh 的批量优化
前端·javascript
WebInfra5 小时前
Rspack 2.0 正式发布!
前端·javascript·前端框架
Highcharts.js6 小时前
在 React 中使用 useState 和 @highcharts/react 构建动态图表
开发语言·前端·javascript·react.js·信息可视化·前端框架·highcharts
|晴 天|7 小时前
Vue 3 实战:打造可拖拽歌词、播放列表的嵌入式音乐播放器
前端·javascript·vue.js