mkdir -p ~/database
cd ~/database
touch docker-compose.yml
127.0.0.1 仅允许本地访问,这是推荐的安全配置。远程连接请使用 SSH 隧道。services:
postgres:
image: postgres:16-alpine
container_name: postgres
restart: always
ports:
- "127.0.0.1:5432:5432"
environment:
POSTGRES_USER: postgres
POSTGRES_PASSWORD: your_postgres_password
POSTGRES_DB: app
TZ: Asia/Shanghai
volumes:
- postgres_data:/var/lib/postgresql/data
redis:
image: redis:7-alpine
container_name: redis
restart: always
ports:
- "127.0.0.1:6379:6379"
command: redis-server --requirepass your_redis_password
volumes:
- redis_data:/var/lib/redis/data
volumes:
postgres_data:
redis_data:
cd ~/database
docker compose up -d
# 检查容器状态
docker ps
# 测试 PostgreSQL
docker exec -it postgres psql -U postgres -c "SELECT version();"
# 测试 Redis
docker exec -it redis redis-cli -a 'your_redis_password' ping
PostgreSQL 成功时显示版本信息,Redis 成功时返回 PONG。
| 方案 | 安全性 | 适用场景 |
|---|---|---|
| 直接暴露端口 | ❌ 低 | 仅测试环境 |
| IP 白名单 | ⚠️ 中 | 固定 IP 用户 |
| SSH 隧道 | ✅ 高 | 动态 IP 用户(推荐) |
打开 Navicat,点击 连接 → PostgreSQL
| 参数 | 值 |
|---|---|
| 主机 | 127.0.0.1 |
| 端口 | 5432 |
| 初始数据库 | app |
| 用户名 | postgres |
| 密码 | your_postgres_password |
勾选 使用 SSH 通道:
| 参数 | 值 |
|---|---|
| 主机 | 服务器公网 IP |
| 端口 | 22 |
| 用户名 | ubuntu(或 root) |
| 验证方法 | 密码 或 公钥 |
点击 连接测试,成功后保存连接。
6379,密码为 your_redis_password。# 进入 psql
docker exec -it postgres psql -U postgres
# 执行 SQL 文件
docker exec -i postgres psql -U postgres -d app < script.sql
# 查看数据库大小
docker exec -it postgres psql -U postgres -c \
"SELECT pg_database.datname, pg_size_pretty(pg_database_size(pg_database.datname)) FROM pg_database;"
\l -- 列出所有数据库
\c dbname -- 切换数据库
\dt -- 列出当前数据库的表
\d tablename -- 查看表结构
\du -- 列出所有用户
\dx -- 列出已安装扩展
\q -- 退出
# 备份数据库
docker exec -it postgres pg_dump -U postgres -d app > backup.sql
# 压缩备份
docker exec -it postgres pg_dump -U postgres -d app | gzip > backup.sql.gz
# 恢复数据库
cat backup.sql | docker exec -i postgres psql -U postgres -d app
# 从压缩文件恢复
gunzip -c backup.sql.gz | docker exec -i postgres psql -U postgres -d app
如需处理地理数据,修改镜像并激活扩展:
services:
postgres:
image: postgis/postgis:16-3.4-alpine
# ... 其余配置保持不变
# 重启服务
docker compose down
docker compose up -d
# 激活扩展
docker exec -it postgres psql -U postgres -d app -c "CREATE EXTENSION postgis;"
# 进入 Redis CLI
docker exec -it redis redis-cli -a 'your_redis_password'
# 基本操作
SET key "value" # 设置键值
GET key # 获取值
DEL key # 删除键
EXPIRE key 60 # 设置过期时间(秒)
# 查看信息
KEYS * # 查看所有键(生产环境慎用)
DBSIZE # 当前数据库键数量
INFO # 服务器信息
INFO memory # 内存使用信息
# 数据库操作
FLUSHDB # 清空当前数据库
# 退出
QUIT
Redis 默认使用 RDB 快照。如需 AOF 持久化,创建自定义配置:
mkdir -p ~/database/redis-conf
# 启用 AOF 持久化
appendonly yes
appendfsync everysec
# RDB 配置
save 900 1
save 300 10
save 60 10000
# 内存限制
maxmemory 256mb
maxmemory-policy allkeys-lru
更新 docker-compose.yml:
services:
redis:
image: redis:7-alpine
container_name: redis
restart: always
ports:
- "127.0.0.1:6379:6379"
command: redis-server /usr/local/etc/redis/redis.conf --requirepass your_redis_password
volumes:
- redis_data:/data
- ./redis-conf/redis.conf:/usr/local/etc/redis/redis.conf:ro
# 查看容器状态
docker ps
# 查看日志
docker logs postgres --tail 50
docker logs redis --tail 50
# 重启服务
cd ~/database
docker compose restart
# 停止服务
docker compose down
# 停止并删除数据卷(危险:会丢失数据)
docker compose down -v
openssl rand -base64 16 生成127.0.0.1 而非 0.0.0.0# 更新镜像
docker compose pull
docker compose up -d