使用 Docker 部署 Label Studio 時本地文件無法顯示的排查與解決

目錄

使用 Docker 部署 Label Studio 時本地文件無法顯示的排查與解決

1. 背景

2. 問題現象

3. 排查步驟

3.1 確認文件是否存在

3.2 檢查環境變量配置

4. 解決方案

方法一:修改 Sync Storage 路徑(相對路徑)

方法二:修改環境變量為 /

5. 最終解決

6. 總結

7. 建議


使用 Docker 部署 Label Studio 時本地文件無法顯示的排查與解決

1. 背景

在生產環境中,我們常使用 Docker 部署 Label Studio 來進行數據標注。標注文件通常存儲在一個掛載目錄中,例如 /obs,并通過 同步存儲(Sync Storage) 功能導入到項目中。

但在配置過程中遇到一個常見問題:圖片無法顯示,日志中報 404 錯誤


2. 問題現象

啟動容器后訪問項目頁面,標注圖片無法正常加載,日志出現以下報錯:

[WARNING] Not Found: /data/local-files/
"GET /data/local-files/?d=obs/fish/%E5%9B%8A%E8%82%BF%E7%89%99%E9%B2%86%E9%B1%BC/img/1927190418391302144_20250527102953_1-1.jpg HTTP/1.1" 404 0

可以看到請求路徑是:

/data/local-files/?d=obs/fish/囊腫牙鲆魚/img/xxx.jpg

但返回了 404。


3. 排查步驟

3.1 確認文件是否存在

進入容器查看文件是否掛載成功:

docker exec -it label-studio bash
ls /obs/fish/囊腫牙鲆魚/img/

文件存在,說明掛載沒問題。

3.2 檢查環境變量配置

啟動腳本中配置了:

--env LABEL_STUDIO_LOCAL_FILES_DOCUMENT_ROOT=/obs

意味著 Label Studio 期望所有訪問路徑是相對于 /obs 的,例如:

/fish/囊腫牙鲆魚/img/xxx.jpg

但實際 Sync Storage 路徑是:

/obs/fish/囊腫牙鲆魚/img/xxx.jpg

導致系統拼接后路徑錯誤,變成:

/obs/obs/fish/囊腫牙鲆魚/img/xxx.jpg

自然找不到文件。


4. 解決方案

方法一:修改 Sync Storage 路徑(相對路徑)

保持 LABEL_STUDIO_LOCAL_FILES_DOCUMENT_ROOT=/obs 不變,將路徑改為相對路徑:

/fish/囊腫牙鲆魚/img/xxx.jpg

這樣拼接后路徑正確。

方法二:修改環境變量為 /

如果無法調整 Sync Storage 路徑格式,可以直接讓 Label Studio 以 / 作為本地文件根目錄:

--env LABEL_STUDIO_LOCAL_FILES_DOCUMENT_ROOT=/

這樣 d=obs/fish/... 會直接解析為 /obs/fish/...,無需改 Sync Storage 配置。


5. 最終解決

本案例中選擇了方法二,即將環境變量改為 /

docker run -d \--name label-studio \-p 9002:8080 \-v /data1/apps/label-studio/data:/label-studio/data \-v /data1/apps/label-studio/files:/label-studio/files \-v /obs:/obs \--env LABEL_STUDIO_LOCAL_FILES_SERVING_ENABLED=true \--env LABEL_STUDIO_LOCAL_FILES_DOCUMENT_ROOT=/ \heartexlabs/label-studio:latest

修改后,圖片路徑 /obs/fish/... 可直接訪問,標注頁面圖片正常顯示。


6. 總結

問題原因:

  • LABEL_STUDIO_LOCAL_FILES_DOCUMENT_ROOT 定義了 Label Studio 允許訪問的本地文件根目錄;

  • d= 參數必須是該根目錄下的相對路徑;

  • 配置不一致會導致訪問路徑錯誤,返回 404。

解決方法:

  • 要么保持環境變量為 /obs,路徑寫相對路徑;

  • 要么環境變量改為 /,路徑保持原始 /obs/... 格式。


7. 建議

  • 生產環境中推薦明確設置 LOCAL_FILES_DOCUMENT_ROOT,避免隨意改動文件路徑結構;

  • 如果存在多個文件根目錄,可統一掛載到 /label-studio/files 下,減少混亂;

  • 遇到 404 問題時,優先檢查:

    1. 容器內文件是否存在;

    2. 環境變量與路徑是否匹配;

    3. Sync Storage 配置是否多加或少加路徑前綴。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/bicheng/91645.shtml
繁體地址,請注明出處:http://hk.pswp.cn/bicheng/91645.shtml
英文地址,請注明出處:http://en.pswp.cn/bicheng/91645.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

ElasticJob怎么使用?

我們使用ElasticJob需要以下步驟: 1. 添加依賴 2. 配置任務(可以使用Spring命名空間配置或Java配置) 3. 實現任務邏輯(實現SimpleJob、DataflowJob等接口) 4. 啟動任務 下面是一個詳細的示例,包括Spring Bo…

TCP協議的特點和首部格式

文章目錄TCP協議是什么?TCP協議的主要特點1. 面向連接2. 可靠傳輸3. 流量控制4. 擁塞控制TCP首部格式源端口和目標端口(各16位)序列號(32位)確認號(32位)數據偏移(4位)保…

IO流-文件的常用方法

1.關于java.io.File類- File類只能表示計算機中的文件或目錄而不能獲取或操作文件- 通過File類獲得到文件的基本信息,如文件名、大小等,但不能獲取文件內容- java中表示文件路徑分隔符使用"/"或"\\"- File類中的構造方法- File(&quo…

AUTOSAR進階圖解==>AUTOSAR_SRS_E2E

AUTOSAR E2E通信保護解析 AUTOSAR End-to-End通信保護機制詳解與應用目錄 概述 1.1. AUTOSAR E2E通信保護的作用 1.2. E2E通信保護的應用場景AUTOSAR E2E架構 2.1. E2E組件層次結構 2.2. E2E庫和E2E轉換器E2E監控狀態機 3.1. 狀態定義與轉換 3.2. 狀態機實現E2E保護數據交換流…

鏡像快速部署ollama+python+ai

算力租賃入口:https://www.jygpu.com為大家提供以上鏡像快速部署方式,節約大家環境部署時間一鍵部署的便捷性傳統自建GPU服務器需要經歷復雜的硬件采購、驅動安裝、環境配置等繁瑣步驟,而現代??GPU租賃價格對比??顯示,容器化平…

使用Gemini API開發領域智能聊天機器人的思路

以下是使用 Gemini API 開發軟件自動化測試專家領域專屬智能聊天機器人的詳細思路及具體實現過程: 階段一:基礎準備與規劃 (Foundation & Planning) 這個階段的目標是明確方向、準備好所有必要的工具和憑證。 步驟 1:明確聊天機器人的目…

第13屆藍橋杯Python青少組_省賽_中/高級組_2022年4月17日真題

更多內容請查看網站:【試卷中心 -----> 藍橋杯----> Python----> 省賽】 網站鏈接 青少年軟件編程歷年真題模擬題實時更新 第13屆藍橋杯Python青少組_省賽_中/高級組_2022年4月17日真題 一、選擇題 第 1 題 下列二進制數中最大的是( &a…

sqli-labs:Less-17關卡詳細解析

1. 思路🚀 本關的SQL語句為: $sql"SELECT username, password FROM users WHERE username $uname LIMIT 0,1"; $update"UPDATE users SET password $passwd WHERE username$row1";注入類型:字符串型(單引號…

文心一言:推動 AIGC 領域進步

文心一言:推動AIGC領域進步 關鍵詞:文心一言、AIGC、自然語言處理、多模態生成、大模型、技術架構、應用場景 摘要:本文深入剖析百度文心一言在AIGC(人工智能生成內容)領域的技術創新與實踐成果。通過解析其核心技術架構、多模態生成原理、工程化落地策略及行業應用案例,…

第15講——微分方程

文章目錄思維導圖基本概念微分方程及其階思維導圖 基本概念 微分方程及其階

RAGFlow Agent 知識檢索節點源碼解析:從粗排到精排的完整流程

RAGFlow Agent 知識檢索節點深度解析:從查詢到重排序的完整流程 1. 總體架構概覽 RAGFlow Agent 中的知識檢索(Retrieval)節點是整個RAG系統的核心組件,負責從知識庫中找到與用戶查詢最相關的文檔片段。檢索流程可以分為以下幾個…

Python算法實戰:從排序到B+樹全解析

Python中常見的算法示例 以下是Python中常見的算法示例,涵蓋基礎算法和經典問題解決方案,代碼可直接運行: 排序算法 冒泡排序 def bubble_sort(arr):n = len(arr)for i in range(n):for j in range(0, n-i-1):if arr[j] > arr[j+1]:arr[j], arr[j+1] = arr[j+1], arr…

【C++算法】85.BFS解決最短路徑問題_最小基因變化

文章目錄題目鏈接:題目描述:解法C 算法代碼:題目鏈接: 433. 最小基因變化 題目描述: 解法 先看懂題目 先把這個問題轉化:圖論問題 邊權為1的最短路問題。 為什么可以這么想?! 因為每…

基于單片機汽車少兒安全預警系統

文章目錄一、前言1.1 項目介紹【1】項目開發背景【2】設計實現的功能【3】項目硬件模塊組成【4】設計意義【5】市面上同類產品研究現狀【6】摘要1.2 設計思路1.3 系統功能總結1.4 開發工具的選擇【1】設備端開發【2】上位機開發1.5 模塊的技術詳情介紹1.6 框架圖框架圖說明&…

Mac 上配置jdk 環境變量

核心步驟是設置 JAVA_HOME 變量,并將其 bin 目錄添加到系統的 PATH 變量中。 macOS 從 Catalina (10.15) 版本開始,默認的終端 Shell 從 bash 切換到了 zsh。因此,你需要先確定你正在使用的 Shell,然后編輯對應的配置文件。步驟一…

硬件-音頻學習DAY1——音箱材料選擇:密度板為何完勝實木

每日更新教程,評論區答疑解惑,小白也能變大神!" 目錄 一.音箱材料選擇的關鍵因素 二.密度板的聲學優勢 三.材料穩定性的對比 四.生產工藝的適應性 五.成本與環保的平衡 六.特殊場景的例外情況 七.消費者選購指南 八.行業發展趨勢…

微波(Microwave)與毫米波(Millimeter wave)簡介

一、電磁波頻段劃分,微波與毫米波所屬 二、微波 可以看出UHF及以上的頻段都可以統稱為微波。記得之前上微波技術實驗課的時候會接觸比巴掌還大的金屬波導,后來每次看到微波技術的時候都還是感到陌生。今天突然想到,不像在手機里就能完成的5G頻…

ObjectMapper教程

ObjectMapper 簡介ObjectMapper 是 Jackson 庫的核心類,用于 Java 對象與 JSON 數據之間的相互轉換。它支持序列化(對象轉 JSON)和反序列化(JSON 轉對象),廣泛應用于 REST API、數據存儲和配置處理等場景。…

【Node.js安裝注意事項】-安裝路徑不能有空格

問題描述:在項目中使用 nodemon時,出現了nodemon 啟動問題:nodemon : 無法將“nodemon”項識別為 cmdlet、函數、腳本文件或可運行程序的名稱。解決辦法:在網上找了很多教程,試了很多辦法,什么重新配置環境…

Shader開發(六)什么是著色器

在前面的章節中,我們簡要提到了著色器的概念,現在有了渲染管線的基礎知識,我們可以更深入地理解著色器的真正含義。著色器(Shader)是運行在圖形處理單元(GPU)上的專用程序,這與我們日…