摘要:PostgreSQL的内存结构 PostgreSQL的内存主要分成两类: 1.本地内存区域:每个后端进程(backend process)自己使用的 2.共享内存区域:所有进程共同使用 本地内存区域 在postgresql中,每个后端进程(backend process)分配一片本地内存用于处理查询 阅读全文
PostgreSQL的内存利用率高时如何检查
2021-03-28 10:45 by abce, 1144 阅读, 0 推荐, 收藏,
摘要:如果内存利用率很高,那么首先应该确认哪个进程产生了内存消耗。 使用linux的top工具 找出哪些或哪个进程消耗了大量的内存。然后再检查进程在执行什么操作! 结合postgresql和系统的日志 比如,如果内存不够,可能会发现类似日志信息: Resource temporarily unavaila 阅读全文
如何调整PostgreSQL的 Out-Of-Memory Killer设置
2021-03-27 15:29 by abce, 1923 阅读, 0 推荐, 收藏,
摘要:当服务器/进程内存不足时,Linux有两种方法来处理,第一种是OS(Linux)崩溃,整个系统宕机;第二种是终止使系统耗尽内存的进程(应用程序)。第二种方法的最佳选择是终止进程,防止OS崩溃。简而言之,Out-Of-Memory Killer是负责终止应用程序以避免内核崩溃的进程,因为它只杀死应用程 阅读全文
postgresql的effective_cache_size
2021-03-26 08:29 by abce, 4139 阅读, 0 推荐, 收藏,
摘要:优化器假设可以用于单个查询的磁盘缓存的有效大小。这个因素会被用到使用索引的成本考虑中:值越大,使用索引扫描的可能性就越大;值越小,使用顺序扫描的可能性就越大。设置该参数的时候,需要同时考虑到shared buffer和内核对磁盘缓存的使用,尽管有些数据会同时存在shared buffer和内核的磁盘 阅读全文
MySQL的binlog_row_image和PostgreSQL的full_page_writes
2021-03-11 10:36 by abce, 528 阅读, 0 推荐, 收藏,
摘要:MySQL的binlog_row_image MySQL基于行的复制中,该变量决定了row images是如何被写入binary log的。在基于行的复制中,每一行的change事件包含两个镜像:一个“前镜像”,其列包含的是更新之前的内容;一个“后镜像”,其列包含更新之后的内容。通常,MySQL在前 阅读全文
PostgreSQL备份和还原的简单测试
2021-02-02 13:38 by abce, 253 阅读, 0 推荐, 收藏,
摘要:1.备份和还原单个数据库备份 $ pg_dump -U pogstgres -d mydb > mydb.sql 还原 $psql -U postgres -d mydb < mydb 2.备份和还原所有的数据库备份 $ pg_dumpall -U postgres > alldbs.sql 还原 阅读全文
PostgreSQL事务中的时间
2021-01-22 17:00 by abce, 546 阅读, 0 推荐, 收藏,
摘要:在同一个事务中,时间是不变的: postgres=# begin; BEGIN postgres=# select now(),current_time,current_timestamp,localtime,localtimestamp,transaction_timestamp(); now | 阅读全文
PostgreSQL的Access control lists
2021-01-22 09:24 by abce, 212 阅读, 0 推荐, 收藏,
摘要:ACL表现行式: grantee=flags/grantor 其中: ·grantee:被授予权限的角色 ·flags:字符串方式表示的权限 ·grantor:授权的用户 FlagDescriptionStatementsApplies to a append, insert new data IN 阅读全文
PostgreSQL auto_explain模块
2021-01-21 11:02 by abce, 975 阅读, 0 推荐, 收藏,
摘要:auto_explain模块提供了一种自动记录慢语句执行计划的方法,而不必手动运行EXPLAIN。这对于在大型应用程序中跟踪未优化的查询特别有帮助。 该模块不提供sql可访问的函数。要使用它,只需将它加载到服务器。你可以将它加载到一个单独的会话中: load 'auto_explain' 如果想在全 阅读全文
PostgreSQL的Event triggers
2021-01-18 14:08 by abce, 1499 阅读, 0 推荐, 收藏,
摘要:PostgreSQL中,常规触发器依附于单个表并捕获dml事件。而Event triggers是数据库全局性的,可以捕获ddl事件。与常规触发器一样,Event triggers可以用任何包含事件触发器支持的过程语言编写,也可以用C编写,但不能用纯SQL编写。 当与事件关联的事件在定义它的数据库中发 阅读全文
浙公网安备 33010602011771号