当前位置: 首页 > article >正文

别再只会用ALTER USER了!PostgreSQL密码管理的5种隐藏技巧

PostgreSQL密码管理的5个高阶技巧安全工程师不会告诉你的秘密如果你还在用ALTER USER命令直接修改PostgreSQL密码那么你可能错过了数据库安全防护中最关键的几个环节。作为一款企业级开源数据库PostgreSQL提供了远比基础密码修改更强大的安全机制但这些功能往往藏在文档的角落不被普通开发者发现。1. 告别历史记录密码文件的正确打开方式每次在命令行直接输入ALTER USER...WITH PASSWORD都会在shell历史中留下密码痕迹。更专业的做法是使用密码文件# 生成随机密码并写入临时文件 NEW_PASS$(openssl rand -base64 16 | tr -d / | cut -c1-12) echo ALTER USER dbadmin WITH PASSWORD $NEW_PASS; /tmp/pg_pass_change.sql # 通过文件执行修改 psql -U postgres -f /tmp/pg_pass_change.sql # 立即销毁密码文件 shred -zu /tmp/pg_pass_change.sql关键改进点使用openssl生成符合PCI DSS标准的强密码密码只在内存中存在不会写入磁盘历史shred确保临时文件无法恢复生产环境建议将密码文件存放在内存文件系统如/dev/shm中2. 自动化密码轮换cron与脚本的完美结合定期更换密码是安全审计的基本要求但手动操作容易遗漏。下面这个脚本可以自动完成整个流程#!/usr/bin/env python3 import psycopg2 from datetime import datetime from subprocess import run import secrets import string def generate_password(length16): alphabet string.ascii_letters string.digits !#$%^* return .join(secrets.choice(alphabet) for _ in range(length)) def update_pg_password(user): new_pass generate_password() conn psycopg2.connect(dbnamepostgres userpostgres hostlocalhost) conn.autocommit True with conn.cursor() as cur: cur.execute(fALTER USER {user} WITH PASSWORD %s, (new_pass,)) # 写入加密密码库 with open(/etc/pgbouncer/userlist.txt, a) as f: f.write(f{user} {new_pass}\n) return new_pass if __name__ __main__: users [app_user, report_user, backup_user] for user in users: update_pg_password(user)部署方法chmod x /usr/local/bin/rotate_pg_passwords.py (crontab -l 2/dev/null; echo 0 3 1 * * /usr/local/bin/rotate_pg_passwords.py) | crontab -3. 加密算法选择MD5 vs SCRAM-SHA-256的深度对比PostgreSQL支持多种密码加密方式选择不当会带来安全隐患加密方式安全性PostgreSQL版本特点MD5低所有版本易受彩虹表攻击仅限内网使用SCRAM-SHA-256高10默认方式符合NIST标准plain text无所有版本绝对禁止在生产环境使用检查当前加密方式SELECT usename, CASE WHEN passwd LIKE md5% THEN MD5 WHEN passwd LIKE SCRAM-SHA-256% THEN SCRAM ELSE plain END AS auth_method FROM pg_shadow;升级到SCRAM-SHA-256-- 全局设置 ALTER SYSTEM SET password_encryption scram-sha-256; SELECT pg_reload_conf(); -- 现有用户迁移 ALTER USER important_user WITH ENCRYPTED PASSWORD new_password;4. 密码生命周期管理时效控制与历史记录企业级安全要求密码必须定期更换PostgreSQL提供了原生支持-- 设置90天有效期 ALTER USER finance_user WITH PASSWORD Temp1234 VALID UNTIL (current_date interval 90 days); -- 查看所有用户密码状态 SELECT usename, valuntil AS expires_at, CASE WHEN valuntil NOW() THEN EXPIRED WHEN valuntil IS NULL THEN NO LIMIT ELSE ACTIVE END AS status FROM pg_user;进阶技巧结合pg_hba.conf实现过期锁定# 在pg_hba.conf中添加 hostssl all finance_user 0.0.0.0/0 scram-sha-256 hostssl all all 0.0.0.0/0 scram-sha-256 rejectif pg_user.valuntil now()5. 密码审计谁在什么时候修改了密码突然的密码变更可能是入侵信号需要完整审计-- 创建审计表 CREATE TABLE password_change_audit ( id SERIAL PRIMARY KEY, username TEXT NOT NULL, changed_by TEXT NOT NULL, change_time TIMESTAMPTZ NOT NULL DEFAULT now(), client_addr INET ); -- 设置事件触发器 CREATE OR REPLACE FUNCTION log_password_change() RETURNS event_trigger AS $$ DECLARE r RECORD; BEGIN FOR r IN SELECT * FROM pg_event_trigger_ddl_commands() LOOP IF r.command_tag ALTER ROLE AND r.object_type ROLE THEN INSERT INTO password_change_audit(username, changed_by, client_addr) VALUES (r.objname, session_user, inet_client_addr()); END IF; END LOOP; END; $$ LANGUAGE plpgsql; CREATE EVENT TRIGGER password_change_trigger ON ddl_command_end WHEN TAG IN (ALTER ROLE) EXECUTE FUNCTION log_password_change();查看审计日志SELECT username, changed_by, change_time AT TIME ZONE Asia/Shanghai AS local_time, client_addr FROM password_change_audit ORDER BY change_time DESC LIMIT 10;这些技巧来自我在金融行业实施PostgreSQL安全加固时的实战经验。曾经有一次安全演练中攻击者通过shell历史获取了数据库密码而采用密码文件方式的管理员账户则安然无恙。密码管理看似简单实则是数据库安全的第一道防线。

相关文章:

别再只会用ALTER USER了!PostgreSQL密码管理的5种隐藏技巧

PostgreSQL密码管理的5个高阶技巧:安全工程师不会告诉你的秘密 如果你还在用ALTER USER命令直接修改PostgreSQL密码,那么你可能错过了数据库安全防护中最关键的几个环节。作为一款企业级开源数据库,PostgreSQL提供了远比基础密码修改更强大的…...

皇冠CAD(CrownCAD2026R2):提取U/V线(等参数曲线)

根据给定的参数方向和参数值从曲面上提取出一条或多条曲面流线。根据给定的参数方向和参数值从曲面上提取出一条或多条曲面流线(等参考线),此曲面若为裁剪面,则提取的是其原始面上的流线。要生成的流线(等参数线&#…...

树莓派4B新手指南:从零搞定libcamera驱动的CSI摄像头

1. 树莓派4B与CSI摄像头初体验 第一次拿到树莓派4B和CSI摄像头时,我完全是个小白。看着那些密密麻麻的接口和配件,心里直打鼓——这玩意儿真的能用来做视觉项目吗?事实证明,只要按照正确步骤操作,从零开始配置一套完整…...

VScode+esp-idf:深入解析ESP32-CAM开发板SD卡文件系统操作

1. ESP32-CAM开发板与SD卡基础认知 第一次拿到ESP32-CAM开发板时,最吸引我的就是那个小小的SD卡槽。这个火柴盒大小的开发板竟然能拍照、录像还能存数据,简直就像个瑞士军刀。不过在实际操作中,我发现很多新手容易忽略几个关键点:…...

RexUniNLU惊艳效果:中文社交媒体文本ABSA细粒度情感抽取作品集

RexUniNLU惊艳效果:中文社交媒体文本ABSA细粒度情感抽取作品集 1. 引言:当AI学会读懂社交媒体的"言外之意" 你有没有遇到过这样的情况:刷着社交媒体,看到一条"这家餐厅环境不错,但服务真的太慢了&quo…...

告别重复编码:用快马AI为clowdbot自动生成状态管理与API集成模块,效率翻倍

最近在优化我的聊天机器人项目clowdbot时,我遇到了一个典型的开发瓶颈:随着对话逻辑越来越复杂,我需要编写大量重复的、结构类似的代码。比如,管理用户在多轮对话中的状态、调用各种外部API(天气、翻译等)、…...

基于 MATLAB GUI 的语音信号滤波系统功能说明

基于MATLAB的数字滤波器设计及其语音信号去噪应用。 (供学习交流)其中数字滤波器包括IIR和FIR的低通、高通、带通、带阻四大类型及其多种设计方法。 GUI界面中有语音信号输入模块,滤波器设计模块,语音信号分析及加噪去噪输出模块。…...

群晖DSM7.0权限管理实战:从账号创建到精细化控制

1. 群晖DSM7.0权限管理入门指南 第一次接触群晖DSM7.0的权限系统时,我完全被各种选项搞晕了。直到有一次团队协作项目,因为权限设置不当导致重要文件被误删,才真正意识到权限管理的重要性。现在我就把这几年的实战经验分享给你,让…...

ACO蚁群算法优化KELM核极限学习机(ACO-KELM)回归预测MATLAB代码 代码注释清...

ACO蚁群算法优化KELM核极限学习机(ACO-KELM)回归预测MATLAB代码 代码注释清楚。 main为主程序,可以读取EXCEL数据。 很方便,容易上手。 (电厂运行数据为例)老铁们今天带大家玩点硬核的——用蚂蚁找食物的…...

48Tools:多平台直播录制与视频下载工具的技术架构深度解析

48Tools:多平台直播录制与视频下载工具的技术架构深度解析 【免费下载链接】48tools 48工具,提供公演、口袋48直播录源,公演、口袋48录播下载,封面下载,B站直播抓取,B站视频下载,A站直播抓取&am…...

AWS CDN配置实战:如何让不带www的域名自动跳转到www版本(附完整代码)

AWS CDN实战:优雅实现非www域名跳转www的技术方案 当用户输入yourdomain.com时,如何自动跳转到www.yourdomain.com?这个看似简单的需求背后,涉及到用户体验、SEO权重集中和技术实现的多重考量。对于使用AWS CloudFront CDN的企业来…...

ROS软件包安装避坑指南:从源配置到版本匹配的完整流程(以Noetic/Melodic为例)

ROS软件包安装避坑指南:从源配置到版本匹配的完整流程(以Noetic/Melodic为例) 如果你曾在ROS开发中遇到过Unable to locate package的报错,这篇文章将为你彻底解决这个困扰。作为机器人操作系统(ROS)开发者…...

5个专业级方案:解决xiaomusic小爱音箱本地音乐无声问题

5个专业级方案:解决xiaomusic小爱音箱本地音乐无声问题 【免费下载链接】xiaomusic 使用小爱同学播放音乐,音乐使用 yt-dlp 下载。 项目地址: https://gitcode.com/GitHub_Trending/xia/xiaomusic xiaomusic作为一款能够让小爱同学播放本地音乐的…...

Xilinx PCIe高速接口实战:FPGA配置时序的规范解析与设计约束

1. PCIe高速接口与FPGA配置时间的核心关系 第一次接触PCIe高速接口设计时,我完全没意识到FPGA配置时间会成为项目成败的关键。直到某次调试中,主板始终无法识别我们的FPGA板卡,排查三天才发现是配置时序超标了5毫秒。这个教训让我深刻理解到&…...

HALCON实战:如何用add_metrology_object_line_measure精准抓取图像中的直线(附完整代码)

HALCON实战:工业视觉中的高精度直线测量技术解析 在工业自动化检测领域,图像处理技术的精准度直接决定了产品质量控制的可靠性。HALCON作为业界领先的机器视觉开发平台,其强大的测量工具集为工程师提供了实现亚像素级精度的可能。本文将深入探…...

GPT-SoVITS应用教程:打造个人数字人,让你的虚拟形象开口说话

GPT-SoVITS应用教程:打造个人数字人,让你的虚拟形象开口说话 1. 什么是GPT-SoVITS? GPT-SoVITS 是一个开源的文本到语音(TTS)和语音转换模型,它结合了 GPT 的生成能力和 SoVITS 的语音转换技术。这个项目…...

分子对接避坑:AutoDock Vina中Box Size和Exhaustiveness的常见误区与最佳实践

分子对接避坑指南:AutoDock Vina参数优化的科学方法论 在药物发现和生物分子相互作用研究中,分子对接技术已成为不可或缺的工具。AutoDock Vina作为当前最流行的开源对接软件之一,其易用性和计算效率深受研究者青睐。然而,许多初次…...

Win7网络卡顿?3个netsh命令让你的TCP连接速度翻倍(附实测对比)

Win7网络卡顿终极优化指南:netsh命令实战与性能翻倍秘诀 Windows 7作为一代经典操作系统,至今仍有大量忠实用户。但随着时间的推移,网络性能问题逐渐显现——视频缓冲转圈、文件传输龟速、在线会议卡顿...这些困扰其实大多源于系统默认的TCP参…...

企业微信内部应用开发实战:从零到一用UniApp搞定授权登录(附完整代码)

企业微信内部应用开发实战:UniApp授权登录全流程解析 企业微信作为国内领先的企业级通讯工具,其内部应用开发能力正成为企业数字化转型的重要抓手。对于熟悉UniApp框架但初次接触企业微信生态的开发者而言,如何高效实现授权登录往往是项目落地…...

IBM X3850 X6电源告警避坑指南:从硬件检查到VMware集群恢复

IBM X3850 X6电源告警深度解析与实战修复指南 当红色警报亮起:一次真实的电源告警排查经历 凌晨三点,数据中心监控系统突然响起刺耳的警报声。大屏上显示三台IBM X3850 X6服务器同时亮起红色电源状态警告,而我们的VMware生产集群正运行在这些…...

HMCL启动器终极指南:轻松解决你的Minecraft启动烦恼

HMCL启动器终极指南:轻松解决你的Minecraft启动烦恼 【免费下载链接】HMCL huanghongxun/HMCL: 是一个用于 Minecraft 的命令行启动器,可以用于启动和管理 Minecraft 游戏,支持多种 Minecraft 版本和游戏模式,可以用于开发 Minecr…...

深度解析:OpenClaw如何通过AI+RPA重构物流货代应收账款账龄分析与财务对账流程

【前言】在物流货代行业,财务结算一直是效率的“重灾区”。面对动辄数千票的业务量,应收账款回收慢、账龄核算不准、费用对账耗时长等痛点,不仅拖累了企业的现金流,更成为了数字化转型的隐形枷锁。研究显示,传统的半手…...

MTKClient全平台配置与使用指南

MTKClient全平台配置与使用指南 【免费下载链接】mtkclient MTK reverse engineering and flash tool 项目地址: https://gitcode.com/gh_mirrors/mt/mtkclient 一、准备阶段:系统与环境检查 1.1 系统兼容性验证 在开始配置MTKClient前,请确认你…...

告别依赖烦恼:在Windows上使用vcpkg一站式部署Protobuf C++开发环境

1. 为什么选择vcpkg管理Protobuf依赖? 在Windows上进行C开发时,最让人头疼的莫过于第三方库的依赖管理。我至今还记得第一次手动编译Protobuf时的崩溃经历——下载源码、配置编译选项、解决依赖冲突,整个过程花了整整两天时间。直到发现了vcp…...

终端报错:bashrc文件缺失的快速诊断与修复指南

1. 遇到bashrc文件缺失报错怎么办? 刚打开终端就蹦出一行红字"bash: /某路径/bashrc: No such file or directory",这可能是每个Linux用户都会遇到的经典报错。我第一次碰到这个错误时也是一头雾水,后来才发现这其实是环境变量配置…...

别再踩坑了!Jackson里这两个反序列化配置,90%的Java开发者都理解错了

深度解析Jackson反序列化:ACCEPT_EMPTY_*配置的真相与实战避坑指南 你是否曾在处理外部API返回的JSON数据时,遇到过空字符串或空数组导致反序列化失败的情况?比如PHP服务返回的{"address":""}让Java对象属性出现意外值&a…...

RISC-V C语言驱动调试最后防线:自研轻量级printf-free日志注入框架(仅237行代码,支持CSR实时dump,业内首次开源)

第一章:RISC-V C语言驱动调试最后防线:自研轻量级printf-free日志注入框架(仅237行代码,支持CSR实时dump,业内首次开源)在裸机RISC-V驱动开发中,传统printf依赖完整libc与UART初始化栈&#xff…...

老旧Mac升级指南:让2012-2015款Mac重获新生

老旧Mac升级指南:让2012-2015款Mac重获新生 【免费下载链接】OpenCore-Legacy-Patcher 体验与之前一样的macOS 项目地址: https://gitcode.com/GitHub_Trending/op/OpenCore-Legacy-Patcher 您的Mac是否因为系统版本过旧而无法安装最新应用?是否觉…...

DeepSeek-OCR-2新手入门:3步搭建智能OCR工具,告别手动排版

DeepSeek-OCR-2新手入门:3步搭建智能OCR工具,告别手动排版 1. 为什么需要智能OCR工具? 在日常办公和学习中,我们经常遇到需要将纸质文档或图片中的文字转换为电子版的情况。传统OCR工具虽然能提取文字,但往往丢失了文…...

SpringMVC(1)学习内容

一、SpringMVC 基本概述 1.1 三层架构和MVC 1.1.1 三层架构 三层架构是软件设计中经典的分层架构模式,其核心思想是将应用程序划分为三个职责明确的逻辑层次,实现 "高内聚,低耦合" 的设计目标。 表现层(Presentatio…...