基于Docker Compose部署Traccar容器與主機MySQL的完整指南

????????Traccar Docker鏡像內嵌了H2數據庫,該數據庫容量有限,當達到一定容量時,定位數據無法寫入會導致無法定位顯示。為此有必要為Traccar 配置外部數據庫。根據官網文檔和自身經驗我選擇了MySQL。

參考的官方文檔

? ? ? 軟件環境為ubuntu server 24.04版,Traccar 鏡像為最新版。Mysql非容器版為主機安裝版。硬件設備選用HP T530小主機,硬盤128GB,內存8GB.

? ? 如何拉取Traccar 鏡像本文不再說明。請讀者自行解決。

?1安裝MySQL

??查看版本.

mysql --version

如果沒有安裝會出現:

安裝

sudo apt update && apt install mysql-server

安裝后查看版本

安裝完成后,可以通過以下命令驗證 MySQL 是否正常運行 。 如果服務正常運行,你會看到類似“active (running)”的狀態。

sudo systemctl status mysql

2創建為Traccar?配套MySQL的數據庫

sudo mysql -u root -p

輸入 root 密碼后進入 MySQL 命令行。

?創建數據庫

CREATE DATABASE traccardb DEFAULT CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci;

創建用戶并設置密碼

CREATE USER 'traccardb'@'%' IDENTIFIED BY 'yourpassword';

yourpassword改成你自己的密碼,下文遇到有?yourpassword地方請使用你設置的密碼。

`'%'` 表示允許任意主機連接,也可以用 `'localhost'` 限制只允許本機連接。

授權用戶訪問數據庫

GRANT ALL PRIVILEGES ON traccardb.* TO 'traccardb'@'%';

這里用戶名和數據庫名都是traccardb,可以不一樣。

刷新權限

FLUSH PRIVILEGES;

3配置數據庫

sudo nano /etc/mysql/mysql.conf.d/mysqld.cnf

原有文件?

#
# The MySQL database server configuration file.
#
# One can use all long options that the program supports.
# Run program with --help to get a list of available options and with
# --print-defaults to see which it would actually understand and use.
#
# For explanations see
# http://dev.mysql.com/doc/mysql/en/server-system-variables.html# Here is entries for some specific programs
# The following values assume you have at least 32M ram[mysqld]
#
# * Basic Settings
#
user        = mysql
# pid-file    = /var/run/mysqld/mysqld.pid
# socket    = /var/run/mysqld/mysqld.sock
# port        = 3306
# datadir    = /var/lib/mysql# If MySQL is running as a replication slave, this should be
# changed. Ref https://dev.mysql.com/doc/refman/8.0/en/server-system-variables.html#sysvar_tmpdir
# tmpdir        = /tmp
#
# Instead of skip-networking the default is now to listen only on
# localhost which is more compatible and is not less secure.
bind-address        = 127.0.0.1
mysqlx-bind-address    = 127.0.0.1
#
# * Fine Tuning
#
key_buffer_size        = 16M
# max_allowed_packet    = 64M
# thread_stack        = 256K# thread_cache_size       = -1# This replaces the startup script and checks MyISAM tables if needed
# the first time they are touched
myisam-recover-options  = BACKUP# max_connections        = 151# table_open_cache       = 4000#
# * Logging and Replication
#
# Both location gets rotated by the cronjob.
#
# Log all queries
# Be aware that this log type is a performance killer.
# general_log_file        = /var/log/mysql/query.log
# general_log             = 1
#
# Error log - should be very few entries.
#
log_error = /var/log/mysql/error.log
#
# Here you can see queries with especially long duration
# slow_query_log        = 1
# slow_query_log_file    = /var/log/mysql/mysql-slow.log
# long_query_time = 2
# log-queries-not-using-indexes
#
# The following can be used as easy to replay backup logs or for replication.
# note: if you are setting up a replication slave, see README.Debian about
#       other settings you may need to change.
# server-id        = 1
# log_bin            = /var/log/mysql/mysql-bin.log
# binlog_expire_logs_seconds    = 2592000
max_binlog_size   = 100M
# binlog_do_db        = include_database_name
# binlog_ignore_db    = include_database_name

修改成:

#
# The MySQL database server configuration file.
#
# One can use all long options that the program supports.
# Run program with --help to get a list of available options and with
# --print-defaults to see which it would actually understand and use.
#
# For explanations see
# http://dev.mysql.com/doc/mysql/en/server-system-variables.html# Here is entries for some specific programs
# The following values assume you have at least 32M ram[mysqld]
#
# * Basic Settings
#
user        = mysql
pid-file    = /var/run/mysqld/mysqld.pid
socket    = /var/run/mysqld/mysqld.sock
port   = 3306   # 取消注釋以明確指定端口
datadir    = /var/lib/mysql  # 取消注釋# If MySQL is running as a replication slave, this should be
# changed. Ref https://dev.mysql.com/doc/refman/8.0/en/server-system-variables.html#sysvar_tmpdir
# tmpdir        = /tmp
#
# Instead of skip-networking the default is now to listen only on
# localhost which is more compatible and is not less secure.
bind-address        = 0.0.0.0   # 確保監聽所有網絡接口
mysqlx-bind-address    = 127.0.0.1
#
# * Fine Tuning
#
key_buffer_size        = 16M
max_allowed_packet    = 64M # 取消注釋并增大值
# thread_stack        = 256K# thread_cache_size       = -1# This replaces the startup script and checks MyISAM tables if needed
# the first time they are touched
myisam-recover-options  = BACKUPmax_connections        = 300  # 增加連接數# table_open_cache       = 4000#
# * Logging and Replication
#
# Both location gets rotated by the cronjob.
#
# Log all queries
# Be aware that this log type is a performance killer.
# general_log_file        = /var/log/mysql/query.log
# general_log             = 1
#
# Error log - should be very few entries.
#
log_error = /var/log/mysql/error.log
#
# Here you can see queries with especially long duration
slow_query_log        = 1
slow_query_log_file    = /var/log/mysql/mysql-slow.log
long_query_time = 2
# log-queries-not-using-indexes
#
# The following can be used as easy to replay backup logs or for replication.
# note: if you are setting up a replication slave, see README.Debian about
#       other settings you may need to change.
# server-id        = 1
# log_bin            = /var/log/mysql/mysql-bin.log
# binlog_expire_logs_seconds    = 2592000
max_binlog_size   = 100M
# binlog_do_db        = include_database_name
# binlog_ignore_db    = include_database_name

?nano CTRL+O 保存? ??CTRL+X退出。

4新建yml文件為Traccar配置數據庫

? ? ? ? 如果先前有Traccar容器運行,可以先使用如下命令,停止并刪除當前運行的容器。

docker stop traccar
docker rm traccar

重新運行容器,不使用 --restart 參數:

docker run -d --name traccar \-v /home/t503/traccar/to/data:/opt/traccar/data \-p 18082:8082 -p 15055:5055 \registry.cn-hangzhou.aliyuncs.com/armxu_docker/traccar

?上面命令請不要照搬,僅供參考。

運行以下命令查看容器的重啟策略:

docker inspect traccar --format '{{ .HostConfig.RestartPolicy.Name }}'

如果輸出為 no,則表示容器不會自動重啟

再次運行

docker stop traccar
docker rm traccar

ubuntu 查看IPV4地址

ifconfig

在服務器上創建項目目錄:

mkdir -p ~/traccar-docker
cd ~/traccar-docker

?創建 docker-compose.yml 文件:

nano docker-compose.yml

?復制下面內容:

services:traccar:image: registry.cn-hangzhou.aliyuncs.com/armxu_docker/traccarcontainer_name: traccarrestart: unless-stoppedenvironment:# 啟用環境變量配置CONFIG_USE_ENVIRONMENT_VARIABLES: "true"# MySQL 數據庫配置DATABASE_DRIVER: com.mysql.cj.jdbc.DriverDATABASE_URL: >-jdbc:mysql://192.168.9.105:3306/traccardb?zeroDateTimeBehavior=round&serverTimezone=Asia/Shanghai&allowPublicKeyRetrieval=true&useSSL=false&allowMultiQueries=true&autoReconnect=true&useUnicode=yes&characterEncoding=UTF-8&sessionVariables=sql_mode=''DATABASE_USER: traccardbDATABASE_PASSWORD: yourpassword# Traccar 核心配置WEB_PORT: 8082SERVER_PORT: 5055LOGGER_ENABLE: "true"LOGGER_LEVEL: "all"GEOCODER_ENABLE: "false"TZ: Asia/Shanghaiports:- "18082:8082"   # Web 界面- "15055:5055"   # 設備通信端口volumes:- ./logs:/opt/traccar/logs:rw  # 持久化日志- ./data:/opt/traccar/data:rw  # 持久化數據

?

創建數據目錄:

mkdir -p logs data

設置目錄權限:

chmod -R 775 logs data

運行

docker-compose up -d

如果想停止

docker-compose down

這是已經注冊好的賬戶。第一次運行到可以出現頁面需要等待一些時候。

進入后的頁面顯示?

調試

沒有硬件設備的情況下,可使用android 手機上的Traccar進行測試。細節自行研究。

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

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

相關文章

paddlehub環境搭建和測試

目錄1.環境搭建1.1 創建conda環境1.2 安裝paddlepaddle和paddlehub1.3 安裝依賴2. 移動端模型部署2.1 安裝移動端模型2.2 測試3. 服務部署3.1 啟動PaddleHub Serving3.2 發送預測請求1.環境搭建 1.1 創建conda環境 conda create --name paddlehub python3.8 conda activate p…

408第三季part2 - 計算機網絡 - ip地址II

理解路由聚合就是從第一個不一樣的往后全置為0題目這里一般來說會到達2個目的地址,但中間有個路由,所以路由聚合一下就行了聚合出來這個然后下一跳就是跳到下一個路由器d前面一樣的不動,不一樣的開始全置為0c再次理解題目這個先匹配169.96.40…

【Unity】MiniGame編輯器小游戲(十一)消消樂【Crush】

更新日期:2025年7月9日。 項目源碼:獲取項目源碼 索引 消消樂【Crush】一、游戲最終效果二、玩法簡介三、正式開始1.定義游戲窗口類2.規劃游戲窗口、視口區域3.方塊 Block①.定義方塊類②.生成方塊所有類型③.生成消消樂棋盤④.繪制收集欄⑤.繪制方塊陣列4.查看方塊擋住的其他…

RK3588 Android SDK 實戰全解析 —— 架構、原理與開發關鍵點

📖 推薦閱讀:《Yocto項目實戰教程:高效定制嵌入式Linux系統》 🎥 更多學習視頻請關注 B 站:嵌入式Jerry RK3588 Android SDK 實戰全解析 —— 架構、原理與開發關鍵點 作者:嵌入式 Jerry 一、前言 隨著 AIoT、工業智…

從救火到賦能:運維的職責演進與云原生時代的未來圖景

引言:刻板印象的瓦解 提起"運維工程師",許多人腦海中可能仍會浮現這樣的畫面:深夜里守著閃爍的監控屏幕、手忙腳亂地重啟服務器、在布滿網線的機房里穿梭…這曾是運維工作的真實片段,但絕非全貌,更非未來。 在云計算、DevOps、SRE理念和云原生技術棧的沖擊下,…

UDP的socket編程

socket接口int socket(int domain, int type, int protocol);參數說明??參數說明domain協議族(地址族),如 AF_INET(IPv4)、AF_INET6(IPv6)type套接字類型,UDP 使用 SOCK_DGRAM&…

基于SD-WAN的管件制造數字化產線系統集成方案

1. 背景與目標隨著制造業向智能化、數字化方向轉型,傳統產線面臨著數據割裂、協同效率低下等問題。管件制造作為典型場景,涉及多環節的設計、制造與質檢流程,亟需一套高效的系統集成方案,保障全流程數據貫通與實時協同。本方案基于…

學習open62541 --- [79] 在docker中運行open62541工程

docker是非常流行的容器技術,解決了部署環境不一致的問題,open62541的工程也可以在docker容器中運行,本文講述如何把open62541工程放到docker容器中運行。 本文使用WSL ubuntu 22.04作為宿主環境,其它linux也是一樣。一 拉取debia…

Spring Boot微服務中集成gRPC實踐經驗分享

Spring Boot微服務中集成gRPC實踐經驗分享 一、業務場景描述 在某電商系統中,推薦服務、庫存服務、訂單服務等微服務需要高效、雙向流式通信,RESTHTTP已無法滿足低延遲、高并發和嚴格類型安全的需求。為此,我們選擇在Spring Boot微服務中集成…

springboot項目編寫測試類,亂碼問題解決

?MockMvc 的默認行為? MockMvc ?默認使用 ISO-8859-1 解碼響應,而服務端實際返回 UTF-8 編碼數據 。 Postman 無亂碼是因瀏覽器自動識別編碼,但 MockMvc 需顯式配置。 ?過濾器失效場景? Spring 的 CharacterEncodingFilter ?默認只對 POST 請求生效…

打破傳統,開啟 AR 智慧課堂?

在教育領域,AR 智慧課堂宛如一場及時雨,為傳統教育模式帶來了革命性的變革,讓學習變得更加生動有趣、高效互動。通過 AR 技術,抽象的知識瞬間變得鮮活起來,學生們可以在虛擬與現實交織的世界中,探索歷史的長…

熱烈祝賀 Flink 2.0 存算分離入選 VLDB 2025

VLDB 2025 論文熱烈祝賀 Apache Flink 2.0 的重磅研究成果《Disaggregated State Management in Apache Flink 2.0 》被數據庫領域頂級會議 VLDB 2025 正式接收!這項工作由 Apache Flink 社區 聯合 阿里巴巴實時計算 Flink 團隊 以及多位學術界研究人員共同完成&…

蓄電池能量管理matlab的simulink仿真

蓄電池能量管理matlab的simulink仿真模型 AlternatorTableData.mat , 7395 Battery_Management_Lib.mdl , 577258 Readme.txt , 1293 license.txt , 1551 ssc_battery_management.mdl , 221248 ssc_lead_acid_battery_50Ah_ini.m , 1760 ssc_lead_acid_battery_80Ah_ini.m , 1…

MyBatisPlus-03-擴展功能

文章目錄【README】【1】基于MyBatisPlus的代碼生成器【2】MyBatisPlus-DB靜態工具【2.1】使用MyBatisPlus的DB靜態工具查詢單個及多個用戶地址【查詢單個用戶的訪問效果】【查詢多個用戶的訪問效果】【3】邏輯刪除【3.1】代碼實現【4】枚舉處理器【4.1】代碼實現【5】JSON處理…

初識Neo4j之Cypher(三)

目錄 一、介紹 二、語法 1、節點 2、關系 3、屬性 4、模式 一、介紹 Cypher 是 Neo4j 的聲明式查詢語言,兼容 GQL 標準。通過 openCypher 項目,Cypher 以開源方式提供。它類似于 SQL,但專為圖數據優化。 Cypher 直觀且接近自然語言&…

19-C#靜態方法與靜態類

C#靜態方法與靜態類 1.static-靜態方法animal.eat();//直接調用 public class animal {public static void eat()//定義靜態方法{messagebox.show("animal eat");} }2.static-靜態類animal.eat();//直接調用public stat…

基于YOLO的足球檢測Web應用:從訓練到部署的完整實戰

用Python和深度學習技術打造一個完整的足球檢測系統,支持圖片檢測、視頻分析和實時監控。本文帶你從零開始構建一個專業的Web應用。🎯 項目背景 在體育賽事分析和足球訓練中,準確識別和定位足球是一個重要需求。本項目利用YOLO深度學習算法&a…

npm 切換 node 版本 和npm的源

在開發過程中,不同項目可能需要不同版本的 Node.js,同時 于由XX原因,我們需要切換npm的源。這時如果需要切換node版本或者npm的源,我們可以使用以下方法。 使用 nvm 切換 Node 版本 1、安裝 npm install nvm -g2、使用 # 列出所有…

Java學習第二十部分——EasyMock

目錄 一.概述 二.作用 三.工作原理 四.使用示例 五.主要特點 六.適用場景 七.其他模擬框架比較 八.idea簡單項目實戰 1.打開idea創建Java項目,注意構建系統選“Maven” 2.為pom.xml文件添加如下依賴,并重新加載Maven依賴,直至不報錯…

機器學習模型在C++平臺的部署

一、概述機器學習模型的訓練通常在Python環境下完成,而現實生產環境的復雜性和多樣性使得模型的部署成為一個值得關注的重點。不同應用場景下有不同適應的實現方式,這里主要介紹通過一種通用中間格式——ONNX(Open Neural Network Exchange&a…