基于三个原因,我还是决定将自己的吃饭游玩日常打卡和叨逼叨的内容转移到自己的服务器
我一直想把这些内容放在自己的服务器,之前自己也基于 hugo 写了个 hugo buzz(在 GitHub 上开源了),并和自己的博客集成,玩了一段段时间,但有些东西不是很方便,后面就没有继续做下去。
自从马斯克购买了推特后,推特变得越来越莫名其妙,我觉得我的推特迟早会被封号,毕竟以前也被封过一个号。
我还是想再次折腾下分布式社交网络的,其实之前我有折腾股一段时间的 mastodon,但对我一个个人用户来说,mastodon 实在太吃资源太重了,没有必要。碰巧又发现了轻量级的 gotosocial,索性重新折腾。
今天的主角就是 gotosocial 这个东西,关于它的介绍,可以去看其官网或者其在 GitHub 上的项目库,本文后我将附上这两个地址。
VSP: 512M / 40G / Debian 11,因为 GoToSocial 占用资源很少,这个配置足够。
Docker: 本次我是用 Docker 的安装方式,所以,需要在服务器上安装好 Docker,一键安装 Docker 和 Docker Compose 可以用我的脚本 Dockerman。
Caddy: 我是将 GotoSocial 放在代理后面的,我用 Caddy 来对端口进行反代,当然也可以用 nginx 等。
官方有相关的英文教程,具体可以看这里,我这里用中文说下我折腾的过程
创建文件夹
mkdir -p your_folder/data
将官方制作好的 docker-compose.yaml 文件下载下来,这是 demo 文件,可以直接在上面修改
cd your_folder
wget https://raw.githubusercontent.com/superseriousbusiness/gotosocial/main/example/docker-compose/docker-compose.yaml
修改 docker-compose.yaml 文件,我修改后的文件是这样的
services:
gotosocial:
image: superseriousbusiness/gotosocial:latest
container_name: your_containner_name
user: 1000:1000
networks:
- gotosocial
environment:
GTS_HOST: your_domain_name
GTS_DB_TYPE: sqlite
GTS_DB_ADDRESS: /gotosocial/storage/sqlite.db
GTS_LETSENCRYPT_ENABLED: "false"
GTS_LETSENCRYPT_EMAIL_ADDRESS: ""
## For reverse proxy setups:
# GTS_TRUSTED_PROXIES: "172.x.x.x"
GTS_SMTP_HOST:
GTS_SMTP_PORT:
GTS_SMTP_USERNAME:
GTS_SMTP_PASSWORD:
GTS_SMTP_FROM:
GTS_ACCOUNTS_REGISTRATION_OPEN: "true"
ports:
- "8080:8080"
## For letsencrypt:
#- "80:80"
## For reverse proxy setups:
#- "127.0.0.1:8080:8080"
volumes:
- ~/your_folder/data:/gotosocial/storage
- /etc/timezone:/etc/timezone:ro
- /etc/localtime:/etc/localtime:ro
restart: "always"
networks:
gotosocial:
ipam:
driver: default
我修改了 container_name
,GTS_HOST
, ports
和 volumes
的内容,跟着说明酌情修改即可。设置将 container 的时区和母机一致。这里有个重点,user
的内容应该是通过 cat /etc/passwd
获取到的。然后用命令 docker-compose up -d
拉起容器。
配置反向代理的内容,这里将 8080 端口反代即可。
访问域名,这时候就会出现成功的页面。
现在阶段的 gotosocial 还没有完善的网页版管理界面,需要通过命令行来进行用户的设置。
增加用户
docker exec -it your_container_name /gotosocial/gotosocial admin account create --username your_username --email your_email --password '123456'
当增加完用户后,即可访问前面设置的域名地址 your_domain_name/admin
来登录到账户里,登录的用户名是 email,密码是上面增加用户时的密码。如果想将某一个用户设置为管理员,则执行
将用户提升为管理员
docker exec -it your_container_name /gotosocial/gotosocial admin account promote --username your_username
将用户降格成普通用户
docker exec -it your_container_name /gotosocial/gotosocial admin account demote --username your_username
更改某个用户的密码
docker exec -it your_container_name /gotosocial/gotosocial admin account password --username your_username --password your_new_password
恢复 suspended 的用户
目前官方本身不支持这个操作,看这里。
但是可以通过修改数据库的数据来实现
UPDATE accounts
SET suspended_at = NULL
WHERE username = 'suspended_username';
这是恢复本地的用户,如果是恢复另外一个域上的用户,在 where
条件后面增加 AND domain = 'remote_server_domain_name';
即可。
除了 sqlite 的文件之外,还可以将数据导出成一个 json 文件
docker exec -it your_container_name /gotosocial/gotosocial admin export --path db.json
也可以将该文件导入到实例中
docker exec -it your_container_name /gotosocial/gotosocial admin import --path db.json
需要注意的是,导出是导出到容器,而非主机中,如果要将导出的文件存放到主机中,可以使用 docker 的 cp 命令,即
docker cp container_id:/filename /local_path_on_host/
反之则是将主机本地的文件复制到容器里。
现在阶段的 gotosocial 同样也没有一个网页来发内容等,可以用 mastodon 支持的一些应用,比如我在 iOS 上用的是 mastodon,更多能用的应用可以查看 https://joinmastodon.org/apps。更多关于它的玩法,可以多看看 mastodon。
上面 docker-compose.yaml
文件中说到的 user
问题,可能会导致 sqlite 文件无法生成而出错,严格说,官方还没有解决好这个问题,具体看这里,这里也提供了解决办法,简单粗暴的方式是将 user 设置成 root:root
。我有个解决办法
通过 cat /etc/passwd
获取当前用户的用户标识号
和组标识号
将 docker-compose.yaml
文件中 user
内容改成所获取到的用户标识号
和组标识号
docker-compose.yaml
文件中的 volumes
不应该用 ~
,而使用绝对目录 /home/username/***
这样的形式。需要注意的是,如果用户是 admin
,可能没有作用,建议新建个用户。
数据都是保存在容器所映射的本地目录中,及时备份。
修改 docker-compose.yaml
文件后,需要先 docker compose down
,然后再拉起容器。
看到这里有点不容易啊,不过今天,也就是 2024 年 6 月 26 日,我想告诉你的是,到现在为止我不建议使用这个程序。原因是它的问题挺多的,本来一个社交软件最应该做的是信息流通,但它真的阻碍了信息的流通,有点鸡肋。
2024 年 12 月 17 日,这两天又折腾了下这个程序,主要是将它移动到了 Oracle Cloud 的免费小鸡上。也更新了下 STMP 的配置,开启了注册和去掉文件顶部的版本信息(具体看上面的 Docker Compose 文件)。另外就是我抽空在基于它的数据库结构和数据做一个更简单的版本。
GoToSocial 官网: gotosocial.org
GoToSocial 项目地址: superseriousbusiness/gotosocial@GitHub
> 可在 Twitter/X 上评论该篇文章或在下面留言(需要有 GitHub 账号)