wastebin 是一个简洁的 pastebin 📝项目,可以粘贴文本和上传文本文件识别后分享。
介绍
wastebin 作者介绍 wastebin 是一个设计上无耻地复制自 bin 的简约 pastebin。关于 bin 可以参考之前的文章,
相比 bin,wastebin 的首页增加了代码语言选择和设置到期时间和密码功能。
特点
- 使用 axum 和 sqlite3 后端存储压缩的粘贴数据
- 单一可执行文件,内存占用低
- 拖放上传
- 到期、读取或由所有者删除后进行删除
- 根据浏览器设置提供浅色/深色模式
- 可高亮的行号
- 用于在移动设备上浏览粘贴 URL 的二维码
- 使用 argon2 哈希和 ChaCha20Poly1305 加密的可选加密功能
地址
GitHub:https://github.com/matze/wastebin
Wastebin 展示
文本粘贴
分享页面
安装
1. SSH 登入服务器
这里使用一款基础的 1 CPU Core,2G RAM 的 VPS,运行 Debian 12 系统,来进行安装测试 wastebin。
首先使用 SSH 客户端登入 VPS 终端。
下面的步骤也适用于可以安装和使用 Docker 的系统,例如可以安装 Docker Desktop 的 Windows 或 Mac。
2. 安装 Docker 与 Docker Compose
参考下面文章安装好 Docker 与 Docker Compose:
3. 创建安装目录
我们给 wastebin 创建一个安装目录存放 Compose 配置文件,推荐创建在 /home
目录下,
cd /home mkdir wastebin cd wastebin
4. 创建 Compose 配置文件
创建 docker-compose.yml
文件,
touch docker-compose.yml
参考项目给出的配置,使用文本编辑器写入以下内容,
version: "3.3" services: wastebin: environment: - ./db=/data/state.db ports: - 8088:8088 volumes: - ./data:/data image: quxfoo/wastebin:latest
在配置段 '8088:8088'
中,前面的数字是我们访问 wastebin 的端口,可以修改成任意未被占用的端口号。
这里可以通过 Linux 系统上的文本编辑器,如 vi 打开 docker-compose.yml
,
vi docker-compose.yml
按 i 切换到编辑模式,将上面的内容粘贴进去,完成后先按一下 esc,然后输入 :wq
保存退出;
也可以使用 FinalShell 等 SSH 客户端的可视化编辑功能,双击打开 /home/wastebin/docker-compose.yml
,直接将上面的内容粘贴进去。
5. 启动容器
最后 Docker Compose 创建、启动容器,
docker-compose up -d
等待几分钟,打开本地浏览器输入 IP:8088 即可开始访问搭建好的 wastebin。
配置反向代理
搭建好的 wastebin 以IP:端口
的形式暴露访问,为了方便和安全,推荐为 wastebin 配置反向代理,实现使用带 SSL/TLS 证书的域名来访问、使用容器。
为 Docker 容器配置反向代理的时候,假如我们有一个域名 example.com 用来反向代理,最佳实践是通过这个主域名的子域名来访问某个 Docker 容器。例如我有一个域名 044447.xyz,就可以通过子域名 wastebin.044447.xyz 来访问 wastebin。
Cloudflare Tunnel
参考下面文章配置 Cloudflare Tunnel 进行反向代理:
Caddy
参考下面文章配置 Caddy 进行反向代理:
Nginx
暂未更新。
配置完,就可以使用域名访问 wastebin 了。
更新、备份与卸载
更新
进入项目目录,
cd /home/wastebin
拉取最新的容器镜像,
docker-compose pull
热更新容器,
docker-compose up -d
删除所有未被容器使用的镜像。
docker image prune
备份
wastebin 的数据在项目目录的 /db
和 /data
文件夹,我们备份一下这两个文件夹即可,以及 Docker Compose 文件。
卸载
进入项目目录,
cd /home/wastebin
停止正在运行中的容器,
docker-compose down
回到根目录,删除所有停止的容器、镜像及容器数据。