增加rustdesk

This commit is contained in:
2026-04-24 11:13:49 +08:00
parent 18949f31ba
commit 3c5246afb5
17 changed files with 1780 additions and 19 deletions

365
joplin/README.md Normal file
View File

@@ -0,0 +1,365 @@
# Joplin Server 部署指南
开源笔记同步服务器,支持端到端加密,配合 Joplin 客户端实现多端同步。
## 功能特性
- 多端同步Windows / macOS / Linux / Android / iOS
- 端到端加密E2EE
- Markdown 编辑,完整笔记本管理
- Web Clipper 浏览器剪藏
- REST API 扩展
- 丰富的插件生态
## 技术栈
| 组件 | 版本 | 说明 |
|------|------|------|
| Joplin Server | latest | 笔记同步服务器 |
| PostgreSQL | 16-alpine | 关系型数据库 |
| Nginx | 系统包 | 反向代理 + HTTPS 接入 |
| Docker | 最新版 | 容器运行环境 |
## 前置条件
1. 一台 Linux 服务器Ubuntu 22.04/24.04 推荐)
2. 一个已解析到服务器的域名(如 `joplin.example.com`
3. 服务器 80/443 端口可从外网访问
4. 至少 512MB 可用内存PostgreSQL + Joplin Server
## 目录结构
```
joplin/
├── docker-compose.yml # 容器编排Joplin Server + PostgreSQL
├── .env.example # 配置模板
├── deploy.sh # 一键部署脚本
├── backup.sh # 备份脚本
├── uninstall.sh # 完全卸载脚本
├── nginx/
│ └── joplin.conf # Nginx 反向代理配置
└── README.md # 本文件
```
服务器上的数据目录:
```
/data/joplin/db/ # PostgreSQL 数据
/var/backups/joplin/ # 备份文件
```
## 快速部署
### 第一步:上传文件到服务器
```bash
# 在本地执行,上传 joplin 目录
scp -r joplin/ root@<服务器IP>:/opt/joplin
# 如果服务器上还没有部署过 base首台服务或全新服务器还需上传 base
scp -r base/ root@<服务器IP>:/opt/base
```
### 第二步:登录服务器执行部署
```bash
ssh root@<服务器IP>
# 如果是全新服务器,先安装基础环境
cd /opt/base
cp .env.example .env
# 可选:编辑 .env 配置 Docker 镜像加速
bash setup.sh
# 部署 Joplin Server
cd /opt/joplin
bash deploy.sh
# 首次运行会生成 .env按提示修改配置后重新运行
vi .env
bash deploy.sh
```
### 第三步:配置域名解析
在域名服务商(如阿里云 DNS添加 A 记录:
| 记录类型 | 主机记录 | 记录值 |
|----------|----------|--------|
| A | joplin | `<服务器公网IP>` |
### 第四步:登录管理后台
1. 浏览器访问 `https://joplin.yourdomain.com`
2. 默认账号: `admin@localhost`
3. 默认密码: `admin`
> **⚠️ 安全提醒:请立即登录并修改默认密码!**
## 配置说明
### .env 配置项
| 变量 | 说明 | 默认值 |
|------|------|--------|
| `JOPLIN_DOMAIN` | 访问域名 | 必填 |
| `CERTBOT_EMAIL` | Let's Encrypt 邮箱 | 必填 |
| `POSTGRES_PASSWORD` | 数据库密码 | 必填 |
| `POSTGRES_DATABASE` | 数据库名 | `joplin` |
| `POSTGRES_USER` | 数据库用户 | `joplin` |
| `JOPLIN_IMAGE` | Joplin Server 镜像 | `joplin/server:latest` |
| `POSTGRES_IMAGE` | PostgreSQL 镜像 | `postgres:16-alpine` |
| `JOPLIN_DB_DIR` | 数据库数据目录 | `/data/joplin/db` |
| `BACKUP_DIR` | 备份目录 | `/var/backups/joplin` |
| `MAILER_ENABLED` | 启用邮件 | `0` |
## 客户端配置
### 桌面端Windows / macOS / Linux
1. 下载 Joplin 桌面客户端https://joplinapp.org/help/install
2. 打开设置 → 同步
3. 同步目标选择 **Joplin Server**
4. 填写:
- **服务器 URL**: `https://joplin.yourdomain.com`
- **邮箱**: `admin@localhost`(或你修改后的邮箱)
- **密码**: 你的登录密码
5. 点击「检查同步配置」确认连接成功
### Android
从以下渠道下载 Joplin Android 客户端:
- **GitHub Releases**: https://github.com/laurent22/joplin-android/releases (下载 `.apk`
- **F-Droid**: 搜索 "Joplin"
- **Google Play**: 搜索 "Joplin"
同步配置与桌面端相同。
### iOS
从 App Store 搜索 "Joplin" 下载,同步配置与桌面端相同。
### 启用端到端加密(推荐)
1. 在任意一个客户端中:设置 → 加密 → 启用端到端加密
2. 设置加密密码(**务必牢记,丢失无法恢复数据**
3. 其他客户端同步后会提示输入加密密码
> **注意**:启用 E2EE 后Web 界面将无法查看笔记内容(因为服务器无法解密),仅客户端可用。
## 日常运维
### 查看日志
```bash
cd /opt/joplin
docker compose logs -f
docker compose logs -f joplin # 仅 Joplin Server
docker compose logs -f joplin-db # 仅 PostgreSQL
docker compose logs --tail 100
```
### 备份
```bash
cd /opt/joplin
bash backup.sh
```
备份内容包括:
- PostgreSQL 数据库(使用 `pg_dump`,格式为 custom
- 部署配置(`docker-compose.yml` + `.env` + `nginx/`
备份文件保存在 `/var/backups/joplin/`,自动清理 30 天前的旧备份。
### 恢复备份
```bash
# 查看可用备份
ls /var/backups/joplin/
# 确保容器运行中
cd /opt/joplin && docker compose up -d
# 恢复数据库
docker compose exec -T joplin-db pg_restore \
-U joplin -d joplin --clean \
< /var/backups/joplin/<日期>/joplin-db.dump
# 重启服务
docker compose restart
```
### 升级
```bash
cd /opt/joplin
# 1. 备份当前数据
bash backup.sh
# 2. 拉取新镜像
docker compose pull
# 3. 停止旧容器并启动新容器
docker compose down
docker compose up -d
# 4. 检查运行状态
docker compose ps
docker compose logs --tail 20
```
### 停止 / 启动
```bash
cd /opt/joplin
docker compose down # 停止
docker compose up -d # 启动
docker compose restart # 重启
```
## 用户管理
### 创建新用户
1. 以管理员登录 Web 界面
2. 进入「Admin」→「Users」→「Add user」
3. 填写邮箱和密码
### 修改管理员密码
1.`admin@localhost` 登录 Web 界面
2. 点击右上角用户图标 → Profile
3. 修改密码
## 完全卸载
如果需要从服务器上完全移除 Joplin Server使用卸载脚本
```bash
cd /opt/joplin
bash uninstall.sh
```
脚本会**交互式确认**每个危险操作,按顺序执行:
| 步骤 | 操作 | 确认方式 |
|------|------|----------|
| 0 | 卸载前备份(可选) | y/N |
| 1 | 停止并删除 Joplin + PostgreSQL 容器 | 输入 YES |
| 2 | 删除 Docker 镜像 | 自动 |
| 3 | 删除 Nginx 站点配置并重载 | 自动 |
| 4 | 删除 Let's Encrypt SSL 证书 | 自动 |
| 5 | 清理 Certbot 定时任务(仅当无其他证书时) | 自动 |
| 6 | 删除数据目录 | 输入 DELETE |
| 7 | 删除部署目录 `/opt/joplin` | y/N |
**备份目录 `/var/backups/joplin/` 始终保留**,不会被删除。
<details>
<summary>手动卸载步骤(不使用脚本)</summary>
```bash
cd /opt/joplin
# 1. 建议先备份
bash backup.sh
# 2. 停止并删除容器
docker compose down -v
# 3. 删除 Docker 镜像(可选)
docker image rm joplin/server:latest postgres:16-alpine
# 4. 删除 Nginx 配置
rm -f /etc/nginx/sites-enabled/joplin /etc/nginx/sites-available/joplin
nginx -t && systemctl reload nginx
# 5. 删除 SSL 证书
certbot delete --cert-name 你的域名
# 6. 删除数据目录(⚠ 不可恢复)
rm -rf /data/joplin
# 7. 删除部署目录(可选)
rm -rf /opt/joplin
# 备份目录保留在 /var/backups/joplin/
```
</details>
## 故障排查
### 容器无法启动
```bash
# 查看容器状态
docker compose ps
# 查看详细日志
docker compose logs --tail 50
# 常见原因PostgreSQL 密码不一致
# 解决:删除数据库目录并重建
docker compose down -v
rm -rf /data/joplin/db
docker compose up -d
```
### SSL 证书申请失败
```bash
# 检查域名解析是否正确
dig joplin.yourdomain.com
# 检查 80 端口是否可访问
curl -I http://joplin.yourdomain.com
# 查看 Certbot 日志
cat /var/log/letsencrypt/letsencrypt.log
```
### 访问返回 502
```bash
# 检查容器是否运行
docker compose ps
# 检查 22300 端口
curl -I http://127.0.0.1:22300/api/ping
# 检查 Nginx 配置
nginx -t
```
### 客户端同步失败
```bash
# 检查服务器是否正常响应
curl https://joplin.yourdomain.com/api/ping
# 应返回类似:{"status":"ok","message":"Joplin Server is running"}
# 检查服务器日志
cd /opt/joplin && docker compose logs --tail 50 joplin
```
### 上传大文件失败
Nginx 默认配置已设置 `client_max_body_size 200m`。如需调整:
```bash
# 修改 /etc/nginx/sites-available/joplin 中的 client_max_body_size
vi /etc/nginx/sites-available/joplin
nginx -t && systemctl reload nginx
```
## 端口说明
| 端口 | 协议 | 说明 |
|------|------|------|
| 80 | TCP | HTTP → HTTPS 重定向 |
| 443 | TCP | HTTPSNginx 反向代理) |
| 22300 | TCP | Joplin Server HTTP仅监听 127.0.0.1 |