
在追求高效資料與知識共享的過程中,許多企業和團隊面臨工具選擇的挑戰。我們嘗試了多種知識庫工具,但從工程師的反饋來看,這些工具仍存在不少限制。經過多方評估與尋找,最終發現 Outline 是一款非常適合團隊協作的知識庫解決方案,能有效提升工作效率與資訊管理。
Outline 是一款簡潔且功能強大的知識庫管理工具,介面與使用體驗類似 Notion。它支援 Markdown 編輯、全文檢索、以及多種第三方登入方式,非常適合企業或團隊搭建共享知識庫。Outline 是開源軟體,功能完整,專為團隊打造,能大幅提升知識管理與協作效率。
以下為使用 Docker Compose 快速架設 Outline 的範例設定:
version: '3' services: outline: image: outlinewiki/outline:latest ports: - "27777:3000" environment: - DATABASE_URL=postgres://postgres:postgres@postgres:5432/outline - REDIS_URL=redis://redis:6379 - SECRET_KEY=你的隨機字串 - UTILS_SECRET=你的隨機字串 - URL=http://localhost:27777 - NODE_ENV=production - FORCE_HTTPS=false - PORT=3000 - AWS_ACCESS_KEY_ID=minio - AWS_SECRET_ACCESS_KEY=minio123 - AWS_REGION=us-east-1 - AWS_S3_UPLOAD_BUCKET_URL=http://localhost:9000 - AWS_S3_UPLOAD_BUCKET_NAME=uploads - AWS_S3_FORCE_PATH_STYLE=true - AWS_S3_ACL=private - AWS_S3_UPLOAD_MAX_SIZE=26214400 - PGSSLMODE=disable - OIDC_CLIENT_ID=你的OIDC客戶端ID - OIDC_CLIENT_SECRET=你的OIDC客戶端密鑰 - OIDC_AUTH_URI=https://github.com/login/oauth/authorize - OIDC_TOKEN_URI=https://github.com/login/oauth/access_token - OIDC_SCOPES=read:user user:email - OIDC_USERINFO_URI=https://api.github.com/user - OIDC_USERNAME_CLAIM=name - OIDC_DISPLAY_NAME=GitHub depends_on: - postgres - redis - minio postgres: image: postgres:13 environment: - POSTGRES_USER=postgres - POSTGRES_PASSWORD=postgres - POSTGRES_DB=outline volumes: - postgres_data:/var/lib/postgresql/data redis: image: redis:6 volumes: - redis_data:/data minio: image: minio/minio ports: - "9000:9000" - "9001:9001" environment: - MINIO_ROOT_USER=minio - MINIO_ROOT_PASSWORD=minio123 volumes: - minio_data:/data command: server /data --console-address ":9001" volumes: postgres_data: redis_data: minio_data:
啟動服務指令:
docker-compose up -d
P.S. 如果無法上傳 Create Bucket > “uplaods”
http://localhost:9001/
Outline 不支援帳密登入,僅支援多種第三方帳號登入,以下為主要選項及注意事項:
Google 登入 需使用 Google Workspace(企業帳號),不支援個人 Gmail 帳號。
GitHub 登入 支援個人Github 帳號:GitHub 應用授權設定
Microsoft 登入
支援 Azure AD(企業帳號)及個人 Microsoft 帳號。
參考資料
# 1. 進入 Minio 容器 docker exec -it outline-wiki-minio-1 sh # 2. 設定 mc 別名 mc alias set myminio http://localhost:9000 account password # 3. 設定 uploads bucket 為匿名可讀 mc anonymous set download myminio/uploads # 4. 檢查設定是否成功 mc anonymous get myminio/uploads # 5. 離開容器 exit
Outline 主要包含兩部分資料:
http://localhost:27777/
登出後,需要關閉瀏覽器頁籤才有辦法重新登入。
docker exec -t $(docker ps -qf name=postgres) pg_dump -U postgres outline > outline_backup.sql
注意:
- 匯出檔案為 SQL 格式,會存放於執行目錄。
- 若容器名稱非
postgres
,請使用docker ps
查詢並替換。
docker run --rm -v minio_data:/volume -v $(pwd):/backup alpine tar czf /backup/minio_backup.tar.gz -C /volume .
注意:
- 會將 MinIO volume 內所有檔案壓縮為
.tar.gz
。minio_data
為 MinIO 的 volume 名稱,請依實際情況調整。
cat outline_backup.sql | docker exec -i $(docker ps -qf name=postgres) psql -U postgres -d outline
docker run --rm -v minio_data:/volume -v $(pwd):/backup alpine sh -c "cd /volume && tar xzf /backup/minio_backup.tar.gz"
這樣內容就完全聚焦在 Outline,且移除了 Wiki.js 的所有字眼。需要我幫你調整封面圖片命名或其他細節嗎?