PostgreSQL 系统管理函数详解

PostgreSQL 系统管理函数详解

PostgreSQL 提供了一系列强大的系统管理函数,用于数据库维护、监控和配置。这些函数可分为多个类别,以下是主要功能的详细说明:

一、数据库配置函数

1. 参数管理函数

-- 查看所有配置参数
SELECT name, setting, unit, context FROM pg_settings;-- 动态修改参数(无需重启)
SELECT set_config('log_min_duration_statement', '1000', false);-- 重置参数为默认值
SELECT reset_config('work_mem');

2. 配置文件操作

-- 重载配置文件(等效于pg_ctl reload)
SELECT pg_reload_conf();-- 查看配置文件位置
SELECT pg_current_logfile(), pg_conf_load_time();

二、维护与清理函数

1. VACUUM 相关函数

-- 执行VACUUM(非FULL模式)
SELECT pg_stat_reset();
VACUUM (VERBOSE, ANALYZE) customers;-- 仅收集统计信息(不清理死元组)
VACUUM (ANALYZE, SKIP_LOCKED) orders;-- 查看需要VACUUM的表
SELECT schemaname, relname, n_dead_tup 
FROM pg_stat_user_tables 
WHERE n_dead_tup > 0
ORDER BY n_dead_tup DESC;

2. 冻结事务ID管理

-- 检查事务ID年龄
SELECT datname, age(datfrozenxid) FROM pg_database;-- 手动推进冻结事务ID
VACUUM FREEZE customers;-- 紧急冻结(避免事务ID回卷)
SELECT pg_emergency_freeze('my_table');

三、备份与恢复函数

1. 基础备份控制

-- 开始备份模式
SELECT pg_start_backup('nightly_backup', true, false);-- 结束备份模式
SELECT pg_stop_backup(false, true);-- 检查备份进度
SELECT * FROM pg_stat_progress_basebackup;

2. 时间点恢复(PITR)

-- 创建还原点
SELECT pg_create_restore_point('before_major_update');-- 查看WAL信息
SELECT pg_current_wal_lsn(), pg_walfile_name_offset(pg_current_wal_lsn());-- 强制切换WAL文件
SELECT pg_switch_wal();

四、监控与统计函数

1. 统计信息收集

-- 重置统计计数器
SELECT pg_stat_reset();
SELECT pg_stat_reset_shared('bgwriter');-- 获取后台写入器统计
SELECT * FROM pg_stat_get_bgwriter_stats();-- 用户自定义统计
SELECT pg_stat_get_activity(pg_backend_pid());

2. 会话管理

-- 查看活动会话
SELECT pid, usename, application_name, state 
FROM pg_stat_activity;-- 终止会话
SELECT pg_terminate_backend(pid) 
FROM pg_stat_activity 
WHERE application_name = 'problem_app';-- 取消长时间运行的查询
SELECT pg_cancel_backend(pid)
FROM pg_stat_activity
WHERE state = 'active' AND now() - query_start > interval '5 minutes';

五、扩展与插件管理

1. 扩展操作函数

-- 创建扩展
SELECT pg_available_extensions();
CREATE EXTENSION pg_stat_statements;-- 更新扩展
ALTER EXTENSION pg_partman UPDATE;-- 查看扩展依赖
SELECT * FROM pg_extension_dependencies();

2. 插件控制

-- 加载共享库(需超级用户)
LOAD 'auto_explain';-- 查看已加载库
SELECT * FROM pg_loaded_libraries();

六、存储与文件管理

1. 表空间操作

-- 创建表空间
SELECT pg_tablespace_location(oid), * FROM pg_tablespace;-- 检查表空间使用情况
SELECT pg_tablespace_size('fast_ssd');

2. 大对象管理

-- 创建大对象
SELECT lo_create(0);-- 导入文件为大对象
SELECT lo_import('/path/to/file.pdf');-- 导出大对象到文件
SELECT lo_export(oid, '/path/to/output.pdf') FROM pg_largeobject_metadata;

七、复制与高可用

1. 流复制控制

-- 查看复制状态
SELECT * FROM pg_stat_replication;-- 提升备库为主库
SELECT pg_promote(true, 60);-- 创建物理复制槽
SELECT * FROM pg_create_physical_replication_slot('standby1_slot');

2. 逻辑复制

-- 创建逻辑复制槽
SELECT * FROM pg_create_logical_replication_slot('inventory_slot', 'pgoutput'
);-- 解码WAL变更
SELECT * FROM pg_logical_slot_get_changes('inventory_slot',NULL,NULL
);

八、安全相关函数

1. 加密函数

-- 密码哈希
SELECT crypt('mypassword', gen_salt('bf', 8));-- 数据加密
SELECT pgp_sym_encrypt('secret data', 'aes_key');-- 查看密码哈希算法
SELECT * FROM pg_password_hash_algorithms();

2. 权限检查

-- 检查表权限
SELECT has_table_privilege('user1', 'customers', 'INSERT');-- 查看角色权限
SELECT * FROM pg_roles WHERE rolname = 'admin';-- 授予默认权限
ALTER DEFAULT PRIVILEGES IN SCHEMA public
GRANT SELECT ON TABLES TO readonly_role;

九、实用工具函数

1. 系统信息

-- 获取PostgreSQL版本
SELECT version();-- 查看编译选项
SELECT pg_config();-- 服务器启动时间
SELECT pg_postmaster_start_time();

2. 性能诊断

-- 查看锁等待
SELECT * FROM pg_lock_waits();-- 获取当前执行的查询计划
SELECT pg_stat_get_backend_activity(pid) 
FROM pg_stat_activity 
WHERE state = 'active';-- 生成随机数据
SELECT generate_series(1,100), md5(random()::text);

十、最佳实践示例

1. 自动化维护脚本

-- 每周维护脚本
DO $$
BEGIN-- 分析所有用户表EXECUTE format('ANALYZE %I', string_agg(table_schema||'.'||table_name, ', '))FROM information_schema.tablesWHERE table_schema NOT IN ('pg_catalog', 'information_schema');-- 清理碎片严重的表PERFORM vacuum_full_ratio(schemaname, relname, 0.3  -- 碎片率阈值) FROM pg_stat_user_tablesWHERE n_dead_tup > 1000;-- 记录维护日志INSERT INTO maintenance_log VALUES (now(), 'Weekly maintenance completed');
END $$;

2. 紧急情况处理

-- 事务ID回卷紧急处理
DO $$
DECLAREdb record;
BEGINFOR db IN SELECT datname FROM pg_database WHERE datname NOT IN ('template0', 'template1')LOOPEXECUTE format('VACUUM FREEZE %I', db.datname);RAISE NOTICE 'Frozen database: %', db.datname;END LOOP;
END $$;

PostgreSQL 的系统管理函数提供了对数据库各个方面的精细控制,合理使用这些函数可以显著简化管理工作。对于生产环境,建议:

  1. 将常用管理操作封装为PL/pgSQL函数
  2. 通过pgAgent或cron设置定期维护任务
  3. 在执行破坏性操作前创建还原点
  4. 结合监控系统使用统计函数进行性能分析

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/bicheng/80047.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【2025软考高级架构师】——计算机网络(9)

摘要 全文主要围绕计算机网络相关知识展开,包括域名服务器查询方式、网络规划与设计的关键技术、双协议栈与隧道技术、层次化网络设计、网络冗余设计以及高可靠和高可用性等方面,旨在为软考高级架构师的备考提供知识参考。 1. 通信网络架构图 2. 通信架…

yolov8n-obb训练rknn模型

必备: 准备一台ubuntu22的服务器或者虚拟机(x86_64) 1、数据集标注: 1)推荐使用X-AnyLabeling标注工具 2)标注选【旋转框】 3)可选AI标注,再手动补充,提高标注速度 …

前端-HTML+CSS+JavaScript+Vue+Ajax概述

HTML&#xff08;超文本标记语言&#xff09;常见标签 <html><head> <title>这是标题的内容&#xff0c;显示在浏览器的头部</title></head><body><!-- 这里面的内容在浏览器显示给用户看 --><!-- h1 -> h6 : 标题从大到小 …

嵌入式软件--stm32 DAY 5 USART串口通讯(上)

前边我们学的都是通用的功能&#xff0c;例如GPIO、中断&#xff0c;现在我们要学习的是某一个特定的功能。典型的就是通讯功能。其中&#xff0c;最简单的通讯协议就是串口了。 一、串口_通讯基础知识 1.1 串行与并行 按数据传送的方式分类的。 串行通信一位一位传输&…

c++混淆工具Hikari-LLVM15-llvm-18.1.8rel编译安装

目录 1. windows 编译1. 2 编译工具安装1.2.1 下载w64devkit1.2.2 添加环境变量1.2.3 验证一下 1.3 下载llvm-18.1.8rel1.4 编译 2. Android studio增加混淆编译2.1 替换NDK中clang2.2 配置混淆编译项 3. Linux编译安装4. Linux下增加混淆编译4.1 在CMakeLists.txt中设置clang编…

【EasyPan】loadDataList方法及checkRootFilePid方法解析

【EasyPan】项目常见问题解答&#xff08;自用&持续更新中…&#xff09;汇总版 一、loadDataList方法概览 /*** 文件列表加载接口* param session HTTP会话对象* param shareId 必须参数&#xff0c;分享ID&#xff08;使用VerifyParam进行非空校验&#xff09;* param …

Vue3渲染引擎:虚拟DOM与响应式原理

Vue3渲染引擎&#xff1a;虚拟DOM与响应式原理 在当今的前端开发中&#xff0c;Vue.js作为一种流行的JavaScript框架&#xff0c;经常被用来构建用户界面。而Vue.js 3作为其最新版本&#xff0c;在性能和功能上进行了许多优化和改进。其中&#xff0c;Vue3渲染引擎的核心原理—…

【论文阅读】Attentive Collaborative Filtering:

Attentive Collaborative Filtering: Multimedia Recommendation with Item- and Component-Level Attention Attentive Collaborative Filtering (ACF)、隐式反馈推荐、注意力机制、贝叶斯个性化排序 标题翻译&#xff1a;注意力协同过滤&#xff1a;基于项目和组件级注意力的…

【PostgreSQL数据分析实战:从数据清洗到可视化全流程】2.1 数据查询基础(SELECT/WHERE/GROUP BY/HAVING)

👉 点击关注不迷路 👉 点击关注不迷路 👉 点击关注不迷路 文章大纲 第2章 SQL语法进阶:数据查询基础(SELECT/WHERE/GROUP BY/HAVING)2.1 数据查询基础2.1.1 SELECT 语句:从表中提取数据2.1.1.1 基础语法与列选择2.1.1.2 列别名与表达式2.1.1.3 去重与排序2.1.2 WHERE…

深度解析:基于Python的微信小程序自动化操作实现

引言 在当今数字化时代&#xff0c;自动化技术正在改变我们与软件交互的方式。本文将深入解析一个使用Python实现的微信小程序自动化操作脚本&#xff0c;该脚本能够自动识别屏幕上的特定图像并执行点击操作。这种技术在自动化测试、批量操作和效率工具开发中有着广泛的应用前…

layui下拉框输入关键字才出数据

html里这样放 <div class"layui-form-item"><label class"layui-form-label">合同方&#xff1a;</label><div class"layui-input-block rightinline"><input type"text" name"select_text" ids…

bash和zsh的区别

Bash&#xff08;Bourne-Again SHell&#xff09;和 Zsh&#xff08;Z Shell&#xff09;都是 Unix/Linux 系统中的主流 Shell&#xff0c;但它们在功能、配置和用户体验上有显著区别。以下是两者的详细对比&#xff1a; 1. 历史与兼容性 特性BashZsh诞生时间1989 年&#xff…

组件通信-v-model

概述&#xff1a;实现 父↔子 之间相互通信。 前序知识 —— v-model的本质 <!-- 使用v-model指令 --> <input type"text" v-model"userName"><!-- v-model的本质是下面这行代码 --> <input type"text" :value"use…

虚拟机(Virtual Machine, VM)的简单介绍

目录 一、虚拟机的基本概念 二、虚拟化技术的分类 三、虚拟机的核心架构 四、虚拟机的核心应用场景 五、虚拟机的优缺点分析 六、虚拟机与容器技术的对比 七、虚拟机的未来趋势 八、总结 一、虚拟机的基本概念 虚拟机&#xff08;VM&#xff09;是一种通过软件模拟的完…

Xcode16提交App Store审核时提示bitcode报错

提交AppStore时出现bitcode报错&#xff0c;内容如下&#xff1a; Upload was cancelled. 2025-04-30 02:15:48.349 [ContentDelivery.Uploader.600000DB4380] Show Progress: Upload failed. Validation failed Invalid Executable. The executable Blockolot.app/Frameworks/…

Flutter TabBar / TabBarView 详解

目录 一、引言 二、基本用法 代码解析 三、主要属性 3.1 TabBar 3.2 TabBarView 四、进阶定制&#xff1a;突破默认样式 4.1 视觉样式深度定制 4.2 自定义指示器与标签 4.3 动态标签管理 五、工程实践关键技巧 5.1 性能优化方案 5.2 复杂手势处理 5.3 响应式布局…

mathtype转化

mathtype转latex 点击预置 选择剪切和复制预置 点击MathML 或 TeX&#xff0c;选择 LaTeX 2.09 and later mathtype转word自带编码器 与前面都相同&#xff0c;选择 MathML2.0&#xff08;m namespace&#xff09;

AI检测的荒谬性:当规则沦为一场概率游戏

当今高校对AI检测工具的依赖&#xff0c;已经演变成一场标准混乱的闹剧。有的学校指定格子达&#xff0c;有的迷信维普&#xff0c;而同一篇论文在不同的系统里竟能得出天差地别的结果——在格子达AI检测率仅12%的文章&#xff0c;放到维普却可能飙升到60%。这意味着&#xff0…

react-14defaultValue(仅在首次渲染时生效)和value(受 React 状态控制)

在 React 中&#xff0c;defaultChecked/checked 和 defaultValue/value 是用于处理表单元素初始值和受控值的属性对。区别在于表单元素是否受 React 组件状态控制。 1. defaultValue 作用&#xff1a;设置表单元素的初始值&#xff08;仅在首次渲染时生效&#xff09;。特点…

Go语言基础学习详细笔记

文章目录 初步了解Go语言Go语言诞生的主要问题和目标Go语言应用典型代表Go语言开发环境搭建经典HelloWorld 基本程序结构编写学习变量常量数据类型运算符 条件语句if语句switch 语句 跳转语句常用集合和字符串数组切片Map实现Set**字符串** 函数**基本使用用例验证** 面向对象编…