基于Docker部署的Teable应用

发布于:2025-08-31 ⋅ 阅读:(20) ⋅ 点赞:(0)

简介

        Teable 是一款高性能多维表格本地化的解决方案,通过无代码方式快速构建业务管理系统,支持私有部署和精细权限管理。

        对于个人或者小团队使用,可以避免昂贵的集成软件带来的成本压力。

特点

  • Excel 式任意拖拽选区编辑
  • 支持双向关联,关联引用,汇总
  • 支持丰富的公式计算
  • 完善的视图筛选排序分组操作
  • 数据格式化
  • 数据唯一值验证非空验证
  • 冻结列:冻结表格左边的列,滚动时列保持可见。
  • 导入/导出 csv,xlsx
  • 自由查找搜索
  • 撤销和重做
  • 图表和可视化工具:从表格数据创建条形图、饼图、线性图等图表。

图表

  • 表格视图:表格的默认视图,以电子表格格式显示数据。
  • 看板视图:以看板格式显示数据,看板以列和卡片视觉展示数据。
  • 表单视图:以表单格式显示数据,适合收集数据。
  • 日历视图:以日历格式显示数据,适合跟踪日期和事件。
  • 画廊视图:以画廊格式显示数据,适合展示图片等媒体。

前置准备

        Ubuntu24.04版本;

        Linux上已经部署了Docker;

部署安装

1. 检查Docker是否安装成功;

操作命令: systemctl status docker

2. 下载镜像;

docker pull ghcr.io/teableio/teable:latest​

3. 创建 docker-compose 文件

在用户目录位置(我创建的位置为/opt/), 创建并进入 teable 文件夹

mkdir teable
cd teable

创建一个 docker-compose.yaml 以及一个 .env 文件,并粘贴下面内容,已使用国内镜像源以保证正常安装;

services:
  teable:
    image: registry.cn-shenzhen.aliyuncs.com/teable/teable:latest
    restart: always
    ports:
      - '3000:3000'
    volumes:
      - teable-data:/app/.assets:rw
    env_file:
      - .env
    environment:
      - NEXT_ENV_IMAGES_ALL_REMOTE=true
    networks:
      - teable
    depends_on:
      teable-db:
        condition: service_healthy
      teable-cache:
        condition: service_healthy
    healthcheck:
      test: ['CMD', 'curl', '-f', 'http://localhost:3000/health']
      start_period: 5s
      interval: 5s
      timeout: 3s
      retries: 3

  teable-db:
    image: registry.cn-shenzhen.aliyuncs.com/teable/postgres:15.4
    restart: always
    ports:
      - '42345:5432'
    volumes:
      - teable-db:/var/lib/postgresql/data:rw
    environment:
      - POSTGRES_DB=${POSTGRES_DB}
      - POSTGRES_USER=${POSTGRES_USER}
      - POSTGRES_PASSWORD=${POSTGRES_PASSWORD}
    networks:
      - teable
    healthcheck:
      test: ['CMD-SHELL', "sh -c 'pg_isready -U ${POSTGRES_USER} -d ${POSTGRES_DB}'"]
      interval: 10s
      timeout: 3s
      retries: 3

  teable-cache:
    image: registry.cn-shenzhen.aliyuncs.com/teable/redis:7.2.4
    restart: always
    expose:
      - '6379'
    volumes:
      - teable-cache:/data:rw
    networks:
      - teable
    command: redis-server --appendonly yes --requirepass ${REDIS_PASSWORD}
    healthcheck:
      test: ['CMD', 'redis-cli', '--raw', 'incr', 'ping']
      interval: 10s
      timeout: 3s
      retries: 3

networks:
  teable:
    name: teable-network

volumes:
  teable-db: {}
  teable-data: {}
  teable-cache: {}
# 替换下面默认密码。
POSTGRES_PASSWORD=replace_this_password
REDIS_PASSWORD=replace_this_password
SECRET_KEY=replace_this_secret_key

# 请将下面替换为可您的IP地址
PUBLIC_ORIGIN=http://127.0.0.1:3000

# ---------------------

# Postgres
POSTGRES_HOST=teable-db
POSTGRES_PORT=5432
POSTGRES_DB=teable
POSTGRES_USER=teable

# Redis
REDIS_HOST=teable-cache
REDIS_PORT=6379
REDIS_DB=0

# App
PRISMA_DATABASE_URL=postgresql://${POSTGRES_USER}:${POSTGRES_PASSWORD}@${POSTGRES_HOST}:${POSTGRES_PORT}/${POSTGRES_DB}
BACKEND_CACHE_PROVIDER=redis
BACKEND_CACHE_REDIS_URI=redis://default:${REDIS_PASSWORD}@${REDIS_HOST}:${REDIS_PORT}/${REDIS_DB}

4. 启动docker

        docker-compose pull

        docker-compose up -d

备注:

        拉取的镜像一般会存放在这个位置:/var/lib/docker/overlay2#

        

5. 输入网址,登录Teable服务器

创建多维表格,方便数据管理

注意

1. 如果使用外部托管 redis 

  • 删除 service.teable-cache
  • 删除 service.teable.depends_on.teable-cache
  • 删除 volumes.teable-cache
  • 更新 .env 替换为托管redis的配置

2. 可增加存储服务

Teable 默认使用本地存储管理附件资源,可以添加 minio 或云存储来获取更强大、稳定的服务

minio 提供了额外的存储管理界面(9001 端口)以及更强大的稳定的文件服务,如下为docker compose增加的minio服务配置。

services:
  # ...前面的内容
  teable-storage:
    image: registry.cn-shenzhen.aliyuncs.com/teable/minio:RELEASE.2024-02-17T01-15-57Z
    ports:
      - "9000:9000"
      - "9001:9001"
    environment:
      - MINIO_ACCESS_KEY=${MINIO_ACCESS_KEY}
      - MINIO_SECRET_KEY=${MINIO_SECRET_KEY}
    volumes:
      - teable-storage:/data:rw
    networks:
      - teable
    command: server /data --console-address ":9001"
  createbuckets:
    image: registry.cn-shenzhen.aliyuncs.com/teable/mc
    networks:
      - teable
    entrypoint: >
      /bin/sh -c "
      /usr/bin/mc alias set teable-storage http://teable-storage:9000 ${MINIO_ACCESS_KEY} ${MINIO_SECRET_KEY};
      /usr/bin/mc mb teable-storage/public;
      /usr/bin/mc anonymous set public teable-storage/public;
      /usr/bin/mc mb teable-storage/private;
      exit 0;
      "
    depends_on:
      teable-storage:
        condition: service_started

networks:
  teable:
    name: teable-network

volumes:
  teable-db: {}
  teable-cache: {}
  # 增加一个卷
  teable-storage: {}