debian13安装PostgreSQL并远程连接

  • 安装

    sudo apt update
    sudo apt install -y postgresql postgresql-contrib

  • 启动并开机自启

    sudo systemctl start postgresql
    sudo systemctl enable postgresql

  • 切换到 postgres 用户登录

    复制代码
    sudo -u postgres psql
  • 设置postgres密码,在 psql 中执行

    复制代码
    \password postgres

输入新密码(如 your_strong_password)。

然后可以用密码登录

复制代码
psql -U postgres -h localhost -W
  • 创建用户myuser

    复制代码
    CREATE USER myuser WITH PASSWORD 'mypass';
  • 创建数据库

    复制代码
    CREATE DATABASE myapp;

-修改数据库所有者为 myuser

复制代码
ALTER DATABASE myapp OWNER TO myuser;

-连接到数据库,需要myuser的密码

复制代码
\c mydb
  • 设置 schema 所有者为myuser

    复制代码
    ALTER SCHEMA public OWNER TO myuser;
  • 授予现有对象权限

    #授予所有表的全部权限
    GRANT ALL PRIVILEGES ON ALL TABLES IN SCHEMA public TO myuser;

    #授予所有序列(常用于自增ID)的全部权限
    GRANT ALL PRIVILEGES ON ALL SEQUENCES IN SCHEMA public TO myuser;

    #授予所有函数的权限(可选
    GRANT ALL PRIVILEGES ON ALL FUNCTIONS IN SCHEMA public TO myuser;

  • 设置未来对象的默认权限

    #设置默认表权限
    ALTER DEFAULT PRIVILEGES IN SCHEMA public GRANT ALL ON TABLES TO myuser;

    #设置默认序列权限
    ALTER DEFAULT PRIVILEGES IN SCHEMA public GRANT ALL ON SEQUENCES TO myuser;

    #设置默认函数权限
    ALTER DEFAULT PRIVILEGES IN SCHEMA public GRANT ALL ON FUNCTIONS TO myuser;

  • 退出 psql

    复制代码
    \q
远程连接
复制代码
 vim /etc/postgresql/17/main/postgresql.conf 

找到并修改:

复制代码
# 将localhost改为*
listen_addresses = 'localhost'   →   listen_addresses = '*'

# 或指定 IP
# listen_addresses = '127.0.0.1,192.168.1.100'

在文件末尾添加一行,允许某个网段访问:

复制代码
 /etc/postgresql/17/main/pg_hba.conf

在最后加入下列内容

复制代码
# TYPE  DATABASE        USER            ADDRESS                 METHOD
  host    myapp   		myuser    		0.0.0.0/0    			scram-sha-256

重启服务

复制代码
sudo systemctl restart postgresql

postgresql默认端口 5432

相关推荐
杨了个杨89824 分钟前
Redis常用命令
数据库·redis·缓存
-XWB-11 分钟前
【MySQL】XtraBackup 全量备份还原操作指南(MySQL 5.7 / 8.0 通用)
数据库·mysql·adb
Tancenter21 分钟前
Mysql和ElasticsSearch
数据库·mysql·elasticsearch
fai厅的秃头姐!28 分钟前
2026-1-13
数据库·mysql
dishugj32 分钟前
【oracle】RMAN Catalog 与 Nocatalog 核心区别及实操指南
数据库·oracle·rman
heartbeat..33 分钟前
MySQL 索引从入门到精通:核心概念、类型与实战优化
java·数据库·mysql·索引
heartbeat..33 分钟前
MySQL 存储引擎解析:InnoDB/MyISAM/Memory 原理与选型
java·数据库·mysql·存储引擎
Freed&36 分钟前
Redis 缓存三大经典问题详解:缓存穿透、缓存击穿与缓存雪崩
数据库·redis·缓存
周杰伦的稻香39 分钟前
mysql “黑名单“
数据库·mysql
gis分享者41 分钟前
Redis 集群的实现原理是什么?
数据库·redis·缓存·集群·扩容·原理·gossip