差異處

這裏顯示兩個版本的差異處。

連向這個比對檢視

兩邊的前次修訂版 前次修改
下次修改
前次修改
tech:owntrack [2025/05/26 16:52] – [架構圖] jonathantech:owntrack [2026/03/03 14:26] (目前版本) – 3. 匯出特定 user 或 device 在特定日期區間的軌跡資料作法 jonathan
行 81: 行 81:
 ├── auth ├── auth
 │   └── users.auth │   └── users.auth
-├── config 
-│   └── config.js 
 ├── docker-compose.yml ├── docker-compose.yml
 ├── .env ├── .env
行 107: 行 105:
 </cli> </cli>
     * {{repo>https://raw.githubusercontent.com/tryweb/docker-compose/refs/heads/main/owntracks/auth/users.auth | auth/users.auth}}      * {{repo>https://raw.githubusercontent.com/tryweb/docker-compose/refs/heads/main/owntracks/auth/users.auth | auth/users.auth}} 
-  - 設定 OwnTracks-Frontend 的設定檔 config/config.js (可以設定使用的帳號密碼) <cli> 
-mkdir -p config 
-vi config/config.js 
-</cli> 
-    * {{repo>https://raw.githubusercontent.com/tryweb/docker-compose/refs/heads/main/owntracks/config/config.js | config/config.js}}  
   - 第一次啟動服務 <cli>   - 第一次啟動服務 <cli>
 docker compose pull docker compose pull
行 119: 行 112:
     * docker compose 紀錄 <cli>docker compose logs -f</cli>     * docker compose 紀錄 <cli>docker compose logs -f</cli>
     * MQTT 紀錄 <cli>tail -f mosquitto/log/mosquitto.log</cli>     * MQTT 紀錄 <cli>tail -f mosquitto/log/mosquitto.log</cli>
 +  - 建立 Recoder 存取 MQTT 的帳號密碼(定義在 .env 內) Exp. recorder / recorderpass<cli>
 +docker compose exec mosquitto chown root:root /mosquitto/config/passwd
 +docker compose exec mosquitto mosquitto_passwd /mosquitto/config/passwd recorder
 +</cli>輸入兩次密碼 recorderpass 即可 
 +  - 建立 jonathan 存取 MQTT 的帳號密碼 Exp. jonathan / mypassword<cli>
 +docker compose exec mosquitto mosquitto_passwd /mosquitto/config/passwd jonathan
 +</cli>輸入兩次密碼 mypassword 即可 
  
 ==== 手機端 ==== ==== 手機端 ====
-  * Connection 要選 HTTP \\ {{:tech:screenshot_20250408-090124.jpg?400|}}+=== 直接連 OTRecoder === 
 +  * Connection 要選 HTTP  
 +    * ++看畫面|{{:tech:screenshot_20250408-090124.jpg?400|}}++
   * 設定 Endpoint 的 URL Exp. http://192.168.11.200:8083**/pub** **一定要加上 /pub 才可以**   * 設定 Endpoint 的 URL Exp. http://192.168.11.200:8083**/pub** **一定要加上 /pub 才可以**
-  * 設定 Credentials 的 Username 與 Password **要和 .env 內設定的相同** \\ {{:tech:screenshot_20250408-090134.jpg?400|}}+  * 設定 Credentials 的 Username 與 Password **要和 auth/users.auth 內設定的相同**  
 +    * ++看畫面|{{:tech:screenshot_20250408-090134.jpg?400|}}++
  
-===== 透過 Cloudflare Tunnel 設定對外服務 =====+=== 連 MQTT (才可看到 Friends) === 
 +  * Connection 要選 MQTT  
 +    * ++看畫面|{{:tech:screenshot_20250526-170934.png?400|}}++ 
 +  * 設定 Endpoint  
 +    * Host/Port Exp. 192.168.11.200 / 9001 (WebSocket) 
 +    * Client ID Exp. jonathan (建議和 Credentials 的 Username 相同  
 +    * Use WebSockets : 啟用 
 +    * ++看畫面|{{:tech:screenshot_20250526-180420.png?400|}}++ 
 +  * 設定 Identification 
 +    * Device ID Exp. pixel9 
 +    * Tracker ID Exp. jt (會顯示在 Android 的地圖上) 
 +      * ++看畫面|{{:tech:screenshot_20250526-172824.png?400|}}++ 
 +  * 設定 Credentials (設定在 mosquitto/config/passwd) 
 +    * Username Exp. jonathan 
 +    * Password Exp. mypassword 
 +  * TLS 關閉 
 +  * Parameters 
 +    * Keepalive : 3600 
 +    * Clean Session : 啟動 
 +  * ++看設定畫面|{{:tech:screenshot_20250526-171046.png?400|}}++ 
 + 
 +===== 管理端可以看到畫面 ===== 
 +  * Frontend - http://192.168.11.200 \\ {{:tech:螢幕擷取畫面_2025-05-26_181739.png|}} 
 +  * OTRecorder - http://192.168.11.200:8083 \\ {{:tech:螢幕擷取畫面_2025-05-26_183252.png|}} 
 + 
 +===== 設定 Reverse Proxy 方式 =====
   * 這樣的設定好處是, 手機連上哪個網路都可以立即回報, 不用等回到可連上內網的網路才統一回報   * 這樣的設定好處是, 手機連上哪個網路都可以立即回報, 不用等回到可連上內網的網路才統一回報
 +
 +==== 透過 Cloudflare Tunnel 設定 OTRecorder 對外服務 ====
 +<note>目前 MQTT + WebSocket 服務還無法成功透過 Cloudflare Tunnel 設定方式提供對外服務</note>
   * 以 Endpoint 的 URL Exp. http://192.168.11.200:8083/pub 為例, 預計對應成 https://rec-track.ichiayi.com \\ {{:tech:螢幕擷取畫面_2025-04-08_134422.png?800|}}   * 以 Endpoint 的 URL Exp. http://192.168.11.200:8083/pub 為例, 預計對應成 https://rec-track.ichiayi.com \\ {{:tech:螢幕擷取畫面_2025-04-08_134422.png?800|}}
  
-===== 管理端可以看到畫面 ===== +==== 透過 Nginx Proxy Manager 設定 MQTT + WebSocket 對外服務 ==== 
-  * Frontend - http://192.168.11.200 \\ {{:tech:螢幕擷取畫面_2025-04-08_134912.png|}} +  * 以 Endpoint 的 Host: mqtt.ichiayi.com Port:80 為例, 預計對應成 http://192.168.11.200:9001 \\ {{:tech:螢幕擷取畫面_2025-05-26_182730.png?800|}}  
-  * OTRecorder - http://192.168.11.200:8083 \\ {{:tech:螢幕擷取畫面_2025-04-08_135120.png|}} \\ + 
 + 
 + 
 +===== 常見問題 ===== 
 +==== 1. 合併兩個 rec 作法 ==== 
 +  * 因為在相同裝置 Exp. Android, 修改設定中的 Device ID, Username 就會在主機端自動建立不同的目錄 Exp. Device ID : pixel9 , Username jonathan 就會在 store/rec 與 store/last 都會建立出 jonathan/pixel9 的目錄 
 +  * 如果想要將 store/rec 內的紀錄檔 Exp2025-05.rec 進行合併 Expjonathan/jonathan/2025-05.rec -> jonathan/pixel9/2025-05.rec  
 +    - 備份與合併 2025-05.rec <cli> 
 +cd store/rec/jonathan/pixel9 
 +cp 2025-05.rec 2025-05.rec.bak 
 +cat ../jonathan/2025-05.rec >> 2025-05.rec 
 +</cli> 
 +    - 將合併後的檔案依照資料時間進行排序 <cli> 
 +sort -s -k 1 2025-05.rec -o 2025-05.rec 
 +</cli> 
 +    - 刪除 data.mdb 資料檔<cli> 
 +cd 
 +rm -f store/ghash/data.mdb 
 +</cli> 
 +    - 重起 otrecorder 服務<cli> 
 +docker compose restart otrecorder 
 +docker compose logs -f otrecorder 
 +</cli> 
 + 
 +==== 2. 刪除特定 user 或 device 作法 ==== 
 +  * 因為在相同裝置 Exp. Android, 修改設定中的 Device ID, Username 就會在主機端自動建立不同的目錄 Exp. Device ID jonathan , Username : jonathan 就會在 store/rec 與 store/last 都會建立出 jonathan/jonathan 的目錄 
 +  - 針對這檔案型的作法就是直接刪除檔案 Exp. 刪除 jonathan/jonathan <cli> 
 +cd 
 +rm -rf store/rec/jonathan/jonathan/ 
 +rm -rf store/last/jonathan/jonathan/ 
 +rm -f store/ghash/data.mdb 
 +</cli> 
 +  - 重起 otrecorder 服務<cli> 
 +docker compose restart otrecorder 
 +</cli> 
 +  - 刪除 MQTT 的資料後, 重起服務<cli> 
 +rm mosquitto/data/mosquitto.db 
 +docker compose restart mosquitto 
 +</cli> 
 +  - 在 Android 需要進入 Friends-> 點選要刪除的項目 Exp. jt -> 將畫面底下訊息上拉 -> 點選 CLEAR  
 +    * ++看畫面|{{:tech:screenshot_20250526-191959.png?400|}}++ 
 + 
 +==== 3. 匯出特定 user 或 device 在特定日期區間的軌跡資料作法 ==== 
 +  * 語法 : <code>http://{your-recorder-ip}:8083/api/0/locations?user={user}&device={device}&from={start_dt}&to={end_dt}&format=[geojson|gpx]</code> 
 +  * Exp. Device ID : pixel9 , Username : jonathan 在 2026-02-05 ~ 2026-02-23 的 gpx 軌跡資料<cli> 
 +curl -o mytrack_20260205-0223.gpx "http://owntracks-api.my.ichiayi.com/api/0/locations?user=jonathan&device=pixel9&from=2026-02-05T00:00:00Z&to=2026-02-23T23:59:59Z&format=gpx" 
 +</cli>
  
 ===== 參考網址 ===== ===== 參考網址 =====
  • tech/owntrack.1748249553.txt.gz
  • 上一次變更: 2025/05/26 16:52
  • jonathan