【Seatable部署安装】Docker安装Seatable 4.3保姆级教程,并且完美实现更换服务器、IP的数据迁移

服务器 0

目录

  • 操作系统选定
    • Docker安装
    • Seatable安装
  • -------王炸篇:服务器、IP更换教程,怎么进行数据迁移?-------
      • 该方法,将可以直接在新服务器、新IP上使用原来数据,无论文字还是图片、文件等都能正常使用,实现100%迁移(数据文件映射目录需要和上文的安装保持一致,如果不一致,请自行从容器中取出数据文件,避免删除没了)
      • 第一步,停掉正在跑的所有容器,并删除
      • 第二步,备份seatable整个文件夹
      • 第三步,删除seatable文件夹下的mysql-data 和 seatable-data
      • 第四步,进入/root/seatable文件夹,编辑docker-compose.yml的环境变量文件.env,将SEATABLE_SERVER_HOSTNAME更改为新的IP,保存退出
      • 第五步,在/root/seatable文件夹运行docker-compose.yml文件,创建seatable容器
      • 第六步,停掉刚创建的容器
      • 第七步,将新创建的容器的数据文件夹,用刚刚进行备份的seatable_bak_20240428的对应数据文件夹进行替换
      • 第八步,启动seatable服务
      • 第九步,域名转换表格中的文件、图片等链接IP,如果不转换则无法在Base表格中查看、下载图片文件等,此步骤非常重要
      • 第九步,浏览器登录网站,验证是否迁移成功!

操作系统选定

目前我用的是Ubuntu-22.04.4-live-server-amd64版本,点击访问Ubuntu官网,点击直接下载Ubuntu-22.04.4-live-server-amd64

当然,只要使用的其他操作系统可以支持Docker,基本都是可以的。

Docker安装

Step 1:根据上述Ubuntu操作系统环境,使用如下命令安装Docker

sudo snap install docker

或者

sudo apt install docker

上述二者命令均可安装docker,使用其中一种即可(建议用snap方式,方便简洁稳定,可直接开机自启动,并可直接运行docker-compose.yml文件)。

Step 2:安装完成后,通过如下命令查看docker版本查看是否成功

docker -v

显示结果为
在这里插入图片描述

Step 3:设置Docker开机自启动

如果通过snap方式安装,则Docker天然为开机自启动,不用额外设置。

如果通过apt方式安装,则按照如下命令进行设置Docker开机自启动:

systemctl enable docker.service

Seatable安装

接下来将通过Docker-compose文件进行安装。

Step 1:编辑docker-compose文件

进入服务器seatable映射目录(我的目录为/root/seatable),新建两个文件.env和docker-compose.yml,其中.env文件是docker-compose.yml的环境变量文件。

  • 新建文件.env
vim .env

因为.env为隐藏文件,“ls”命令无法显示,要想查看需要使用如下命令:

ll -a

.env文件内容填充如下(自己安装的话需至少更改以下文件的SEATABLE_SERVER_HOSTNAME、SEATABLE_ADMIN_EMAIL、SEATABLE_ADMIN_PASSWORD)

COMPOSE_FILE='docker-compose.yml'COMPOSE_PATH_SEPARATOR=','SEATABLE_IMAGE=seatable/seatable-developer:latestSEATABLE_VOLUMES=/root/seatable/seatable-dataSEATABLE_MYSQL_VOLUMES=/root/seatable/mysql-dataSEATABLE_MYSQL_DB_HOST=mariadbSEATABLE_MYSQL_ROOT_PASSWORD=abcd1234TIME_ZONE='Asia/Shanghai'SEATABLE_SERVER_HOSTNAME=XXX.XXX.XXX.XXXSEATABLE_SERVER_PROTOCOL=httpSEATABLE_SERVER_LETSENCRYPT=FalseSEATABLE_SSL_PORT=443SEATABLE_ADMIN_EMAIL=149662365@gmail.comSEATABLE_ADMIN_PASSWORD=abcd1234                                     

上面参数备注:
SEATABLE_IMAG:镜像资源标志,将拉取最新的seatable社区版镜像
SEATABLE_VOLUMES:seatable数据文件映射到物理服务器的地址,改为你们自己需要的地址即可,也可沿用我自己的地址
SEATABLE_MYSQL_VOLUMES:同上,是seatable使用的MySQL地址
SEATABLE_MYSQL_ROOT_PASSWORD:数据库密码,用户名默认为root
SEATABLE_SERVER_HOSTNAME:seatable所在服务器的IP地址
SEATABLE_SSL_PORT:Https访问地址
SEATABLE_ADMIN_EMAIL:seatable网站的管理员用户账号
SEATABLE_ADMIN_PASSWORD:seatable网站的管理员用户密码

  • 同级目录下新建文件docker-compose.yml
vim docker-compose.yml

docker-compose.yml填充如下:

services:  seatable-server:    image: ${SEATABLE_IMAGE:-seatable/seatable-developer:latest}    restart: unless-stopped    container_name: seatable    ports:      - 80:80      - ${SEATABLE_SSL_PORT:-}:443    volumes:      - "${SEATABLE_VOLUMES:-/opt/seatable/seatable-data}:/shared"    environment:      - DB_HOST=${SEATABLE_MYSQL_DB_HOST:-mariadb}      - DB_ROOT_PASSWD=${SEATABLE_MYSQL_ROOT_PASSWORD:?Variable is not set or empty}      - SEATABLE_SERVER_HOSTNAME=${SEATABLE_SERVER_HOSTNAME:?Variable is not set or empty}      - SEATABLE_SERVER_PROTOCOL=${SEATABLE_SERVER_PROTOCOL:-http}      - SEATABLE_SERVER_LETSENCRYPT=${SEATABLE_SERVER_LETSENCRYPT:-False}      - SEATABLE_ADMIN_EMAIL=${SEATABLE_ADMIN_EMAIL:-}      - SEATABLE_ADMIN_PASSWORD=${SEATABLE_ADMIN_PASSWORD:-}      - TIME_ZONE=${TIME_ZONE}    depends_on:      mariadb:        condition: service_healthy      memcached:        condition: service_started      redis:        condition: service_started    networks:      - frontend-net      - backend-seatable-net  mariadb:    image: ${SEATABLE_DB_IMAGE:-mariadb:10.11}    restart: unless-stopped    container_name: seatable-mariadb    environment:      - MYSQL_ROOT_PASSWORD=${SEATABLE_MYSQL_ROOT_PASSWORD:?Variable is not set or empty}      - MYSQL_LOG_CONSOLE=true      - MARIADB_MYSQL_LOCALHOST_USER=1      - MARIADB_MYSQL_LOCALHOST_GRANTS=USAGE      - MARIADB_AUTO_UPGRADE=1    volumes:      - "${SEATABLE_MYSQL_VOLUMES:-/opt/seatable/mysql-data}:/var/lib/mysql"    networks:      - backend-seatable-net    healthcheck:      test: ["CMD", "mysqladmin" ,"ping", "-p${SEATABLE_MYSQL_ROOT_PASSWORD}", "-h", "localhost"]      interval: 5s      timeout: 30s      retries: 60  memcached:    image: ${SEATABLE_MEMCACHED_IMAGE:-memcached:1.6.18}    restart: unless-stopped    container_name: seatable-memcached    entrypoint: memcached -m 256    networks:      - backend-seatable-net  redis:    image: ${SEATABLE_REDIS_IMAGE:-redis:5.0.7}    restart: unless-stopped    container_name: seatable-redis    networks:      - backend-seatable-netnetworks:  frontend-net:    name: frontend-net  backend-seatable-net:    name: backend-seatable-net

上述内容均无需修改,默认即可,将在本机服务器映射80端口进行访问网站,建议不要修改成其他端口,否则在后续使用过程中可能会出现seatable表格中的附件和图片无法显示的问题

Step 2:运行docker-compose文件

  • 检查环境
    万事具备只欠东风,我们已经准备好了所有环境,现在只需要进行执行docker-compose.yml文件即可成功访问网站,在执行docker-compose.yml之前,请再三进行环境检查:

  • 确保服务器有网络链接,如果只有内网而无法访问外网,请在可访问外网的环境中,通过docker pull 命令依次拉取seatable、mariadb、redis、memcached的对应版本的镜像,再通过docker save -o命令导出镜像到本地,放到U盘中,再通过docker load < 命令导入到你想安装的服务器即可。

  • 确保服务器IP获取正确,并与.env文件的SEATABLE_SERVER_HOSTNAME值保持一致

  • 确保服务器的80端口无人占用

  • 确保服务器的seatbale映射目录具备可读可写的权限

  • 在docker-compose.yml同级目录下面,执行如下命令,创建并启动程序

docker-compose up -d

等待创建和启动成功

Step 3:验证是否安装成功

  • 查看docker运行情况看服务状态
docker ps
  • 浏览器输入服务器IP,端口80即可访问
    在这里插入图片描述

-------王炸篇:服务器、IP更换教程,怎么进行数据迁移?-------

该方法,将可以直接在新服务器、新IP上使用原来数据,无论文字还是图片、文件等都能正常使用,实现100%迁移(数据文件映射目录需要和上文的安装保持一致,如果不一致,请自行从容器中取出数据文件,避免删除没了)

第一步,停掉正在跑的所有容器,并删除

docker stop seatable seatable-mariadb seatable-memcached seatable-redis
docker rm seatable seatable-mariadb seatable-memcached seatable-redis

第二步,备份seatable整个文件夹

cp -r /root/seatable /root/seatable_bak_20240428

第三步,删除seatable文件夹下的mysql-data 和 seatable-data

rm -rf /root/seatable/mysql-data /root/seatable/seatable-data

第四步,进入/root/seatable文件夹,编辑docker-compose.yml的环境变量文件.env,将SEATABLE_SERVER_HOSTNAME更改为新的IP,保存退出

vim /root/seatable/.env

第五步,在/root/seatable文件夹运行docker-compose.yml文件,创建seatable容器

docker-compose up -d

第六步,停掉刚创建的容器

docker stop seatable seatable-mariadb seatable-memcached seatable-redis

第七步,将新创建的容器的数据文件夹,用刚刚进行备份的seatable_bak_20240428的对应数据文件夹进行替换

替换文件夹1:mysql-data
-位置:/root/seatable/mysql-data/
-删除:rm -rf /root/seatable/mysql-data/
-替换:cp -r /root/seatable_bak_20240428/mysql-data/ /root/seatable/

替换文件夹2:seafile-data
-位置:/root/seatable/seatable-data/seatable/seafile-data/
-删除:rm -rf /root/seatable/seatable-data/seatable/seafile-data/
-替换:cp -r /root/seatable_bak_20240428/seatable-data/seatable/seafile-data/ /root/seatable/seatable-data/seatable/

替换文件夹3:seahub-data
-位置:/root/seatable/seatable-data/seatable/seahub-data/
-删除:rm -rf /root/seatable/seatable-data/seatable/seahub-data/
-替换:cp -r /root/seatable_bak_20240428/seatable-data/seatable/seahub-data/ /root/seatable/seatable-data/seatable/

替换文件夹4:storage-data
-位置:/root/seatable/seatable-data/seatable/storage-data/
-删除:rm -rf /root/seatable/seatable-data/seatable/storage-data/
-替换:cp -r /root/seatable_bak_20240428/seatable-data/seatable/storage-data/ /root/seatable/seatable-data/seatable/

第八步,启动seatable服务

docker start seatable seatable-mariadb seatable-memcached seatable-redis

第九步,域名转换表格中的文件、图片等链接IP,如果不转换则无法在Base表格中查看、下载图片文件等,此步骤非常重要

  • 进入seatable容器:docker exec -it seatable /bin/bash
  • 找到dtable-web文件夹:find / -name dtable-web
    结果为:/opt/seatable/seatable-server-4.3.0/dtable-web
  • 进入上述搜索到的对应文件夹:cd /opt/seatable/seatable-server-4.3.0/dtable-web
  • 通过命令执行域名转换(-od参数为老IP,-nd参数为新IP,需要替换成你们自己的新老IP,不要看都不看直接贴命令):seatable.sh python-env manage.py domain_transfer -all -od http://xxx.xxx.xxx.xxx -nd http://xxx.xxx.xxx.xxx
  • 退出容器:exit

第九步,浏览器登录网站,验证是否迁移成功!

100%是成功的,如果没有成功请回头看哪一步骤没有正确进行

也许您对下面的内容还感兴趣: