使用本地postgresql/redis安装remnawave

matthew , 6 十一月 2025

remnawave的安装文档指导使用全docker容器的方式去安装,其中包括remnawave本身、remnawave使用的数据库postgresql和redis。但对于搭建了其他网站的主机来说,其本身就可能已经安装了postgresql/redis。为了避免资源的浪费,本文介绍了如何在host主机上使用现成的postgresql/redis安装remnawave的方法。

  • postgresql/redis 配置确认
  • postgresql 数据库建立并赋权
  • 下载 Remnawave 配置文件并修改
  • 启动 Remnawave 控制面板
  • Nginx 反向代理 Remnawave 控制面板

Heading level 1: postgresql/redis 配置确认

确认postgresql/redis 配置文件正确,对于内部通信建议使用Unixsocket优化性能。

对于宝塔/aapanel,postgresql的配置文件位于/www/server/pgsql/data

nano /www/server/pgsql/data/postgresql.conf
port = 5432 # 运行端口
unix_socket_directories = '/dev/shm' # Unixsocket 目录
unix_socket_permissions = 0777 # 访问权限设置为所有人都可以访问

对于宝塔/aapanel,redis的配置文件位于/www/server/redis

nano /www/server/redis/redis.conf
unixsocket /dev/shm/redis.sock # Unixsocket 文件
unixsocketperm 777 # 访问权限设置为所有人都可以访问

Heading level 1: postgresql 数据库建立并赋权

  • 切换到postgres用户 su - postgres
  • 运行postgresql终端 psql --host=/dev/shm(启用了Unixsocket需要明确其位置)
  • 数据库赋权

postgresql 数据库建立需要确保其权限分配正确

生成24位密码 openssl rand --hex 24

CREATE USER remnawave WITH PASSWORD '3ff167e6c519c2bf1157c022711d48321863d04228604baf';
CREATE DATABASE remnawave OWNER remnawave;
GRANT ALL PRIVILEGES ON DATABASE remnawave TO remnawave;
GRANT USAGE ON schema public TO remnawave;
GRANT ALL PRIVILEGES ON all tables in schema public to remnawave;
GRANT ALL PRIVILEGES ON all sequences in schema public to remnawave;
grant select,insert,update,delete on all tables in schema public to remnawave;
grant all on schema public to remnawave;

Heading level 1: 下载 Remnawave 配置文件并修改

  • 创建 remnawave 项目文件夹 mkdir /opt/remnawave && cd /opt/remnawave
  • 下载 .env 文件
curl -o .env https://raw.githubusercontent.com/remnawave/backend/refs/heads/main/.env.sample
  • 修改用于身份验证和相关安全功能的 JWT_AUTH_SECRET 和 JWT_API_TOKENS_SECRET
sed -i "s/^JWT_AUTH_SECRET=.*/JWT_AUTH_SECRET=$(openssl rand -hex 64)/" .env && sed -i "s/^JWT_API_TOKENS_SECRET=.*/JWT_API_TOKENS_SECRET=$(openssl rand -hex 64)/" .env
sed -i "s/^METRICS_PASS=.*/METRICS_PASS=$(openssl rand -hex 64)/" .env && sed -i "s/^WEBHOOK_SECRET_HEADER=.*/WEBHOOK_SECRET_HEADER=$(openssl rand -hex 64)/" .env
  • 更改 postgresql/redis 连接地址 nano .env
### DATABASE ###
# postgresql://用户名:密码@数据库名?host=/dev/shm
DATABASE_URL="postgresql://remnawave:3ff167e6c519c2bf1157c022711d48321863d04228604baf@remnawave?host=/dev/shm"

### REDIS ###
REDIS_HOST=127.0.0.1
REDIS_PORT=6379
REDIS_DB=5 # Redis 数据库序号,防止与其他项目混用数据库
  • 创建 docker-compose.yml
services:
  remnawave:
    image: remnawave/backend:2
    container_name: 'remnawave'
    hostname: remnawave
    restart: always
    network_mode: host
    env_file:
      - .env
    volumes:
      - /dev/shm:/dev/shm:rw

Heading level 1: 启动 Remnawave 控制面板

docker compose up -d && docker compose logs -f -t

Heading level 1: Nginx 反向代理 Remnawave 控制面板

upstream remnawave {
    server remnawave:3000;
}

server {
    server_name REPLACE_WITH_YOUR_DOMAIN;

    listen 443 ssl reuseport;
    listen [::]:443 ssl reuseport;
    http2 on;

    location / {
        proxy_http_version 1.1;
        proxy_pass http://remnawave;
        proxy_set_header Host $host;
        proxy_set_header X-Real-IP $remote_addr;
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
        proxy_set_header X-Forwarded-Proto $scheme;
    }

    # SSL Configuration (Mozilla Intermediate Guidelines)
    ssl_protocols          TLSv1.2 TLSv1.3;
    ssl_ciphers ECDHE-ECDSA-AES128-GCM-SHA256:ECDHE-RSA-AES128-GCM-SHA256:ECDHE-ECDSA-AES256-GCM-SHA384:ECDHE-RSA-AES256-GCM-SHA384:ECDHE-ECDSA-CHACHA20-POLY1305:ECDHE-RSA-CHACHA20-POLY1305:DHE-RSA-AES128-GCM-SHA256:DHE-RSA-AES256-GCM-SHA384:DHE-RSA-CHACHA20-POLY1305;

    ssl_session_timeout 1d;
    ssl_session_cache shared:MozSSL:10m;
    ssl_session_tickets    off;
    ssl_certificate "/etc/nginx/ssl/fullchain.pem";
    ssl_certificate_key "/etc/nginx/ssl/privkey.key";
    ssl_trusted_certificate "/etc/nginx/ssl/fullchain.pem";

    ssl_stapling           on;
    ssl_stapling_verify    on;
    resolver               1.1.1.1 1.0.0.1 8.8.8.8 8.8.4.4 208.67.222.222 208.67.220.220 valid=60s;
    resolver_timeout       2s;

    # Gzip Compression
    gzip on;
    gzip_vary on;
    gzip_proxied any;
    gzip_comp_level 6;
    gzip_buffers 16 8k;
    gzip_http_version 1.1;
    gzip_min_length 256;
    gzip_types
        application/atom+xml
        application/geo+json
        application/javascript
        application/x-javascript
        application/json
        application/ld+json
        application/manifest+json
        application/rdf+xml
        application/rss+xml
        application/xhtml+xml
        application/xml
        font/eot
        font/otf
        font/ttf
        image/svg+xml
        text/css
        text/javascript
        text/plain
        text/xml;
}
server {
    listen 443 ssl default_server;
    listen [::]:443 ssl default_server;
    server_name _;

    ssl_reject_handshake on;
}

评论