创建postgres数据库失败

异常:

postgres=# CREATE DATABASE deepflow_agent2;

ERROR: source database "template1" is being accessed by other users

DETAIL: There are 2 other sessions using the database

如何断联这两个session

要解决 PostgreSQL 中因 template1 数据库被占用导致无法创建新数据库的问题,请按以下步骤操作:

1. 查看占用 template1 的会话

复制代码
SELECT 
    pid, 
    usename, 
    application_name, 
    client_addr,
    query_start,
    state
FROM 
    pg_stat_activity 
WHERE 
    datname = 'template1' 
    AND pid <> pg_backend_pid();  -- 排除当前会话

2. 终止占用会话(三种方法)

方法1:逐个终止(推荐)
复制代码
-- 对查询结果中的每个 pid 执行
SELECT pg_terminate_backend(目标pid);  -- 替换为目标pid
方法2:批量终止所有占用会话
复制代码
SELECT pg_terminate_backend(pid)
FROM pg_stat_activity
WHERE datname = 'template1'
  AND pid <> pg_backend_pid();
方法3:使用 template0 模板创建(避免冲突)
复制代码
CREATE DATABASE deepflow_agent2 TEMPLATE template0;  -- 使用空白模板

3. 验证会话是否终止

复制代码
SELECT count(*) 
FROM pg_stat_activity 
WHERE datname = 'template1';
-- 返回 1 表示只剩当前会话

4. 重新创建数据库

复制代码
CREATE DATABASE deepflow_agent2;

预防措施:

  1. 永久解决方案

    复制代码
    ALTER DATABASE template1 ALLOW_CONNECTIONS = OFF;  -- 禁止连接模板库
  2. 设置默认模板

    复制代码
    ALTER DATABASE template1 IS_TEMPLATE = false;  -- 取消模板属性
  3. 使用专用模板

    复制代码
    CREATE DATABASE my_template IS_TEMPLATE = true;
    CREATE DATABASE new_db TEMPLATE my_template;  -- 使用自定义模板

关键说明:

  1. pg_terminate_backend() 需要超级用户权限

  2. 生产环境谨慎操作,终止会话可能导致用户操作中断

  3. 使用 template0 是最安全的替代方案,它是不可修改的干净模板

执行后如果仍有问题,检查 PostgreSQL 日志:

复制代码
tail -n 50 /var/log/postgresql/postgresql-*.log
相关推荐
东风破1371 小时前
达梦DMDRS搭建、以及DMDRS双向同步
数据库·oracle·dm达梦数据库
KaMeidebaby2 小时前
卡梅德生物技术快报|抗独特型抗体开发:半抗原检测技术瓶颈拆解,抗独特型抗体开发工程化实践
前端·数据库·人工智能·其他·百度·新浪微博
NiceCloud喜云2 小时前
Claude Files API 深入:从上传、复用到配额管理的工程化指南
android·java·数据库·人工智能·python·json·飞书
A XMan.3 小时前
域名Whois信息查询V2版API接入指南
数据库
heimeiyingwang3 小时前
【架构实战】可观测性体系:从监控到全链路追踪
网络·数据库·架构
网管NO.13 小时前
SQL 日期函数全套精讲!时间格式化、日期加减、年月日提取,做日报周报直接套用
数据库·sql
杨云龙UP3 小时前
Linux 根分区被日志吃满?一次 58G Broker 日志清理实战_2026-05-20
linux·运维·服务器·数据库·hdfs·apache
sdk大全3 小时前
Studio 3T for MongoDB 2025.13.0
数据库·mongodb
码农阿豪3 小时前
平替MongoDB:金仓多模数据库助力电子证照国产化实践
数据库·mongodb
罗超驿3 小时前
22.深入剖析JDBC架构:从原生API到企业级数据交互核心
java·数据库·mysql·面试