本地部署Graphhopper路径规划服务(graphhopper.sh启动版)

文章目录

  • 文章参考
  • 源码获取
  • 一、配置Java环境变量
  • 二、配置Maven环境变量
  • 三、构建graphhopper步骤
    • 1. 下载数据
    • 2. 配置graphhopper配置文件`config-example.yml`
    • 3. 在项目中启动命令行执行`./graphhopper.sh build`
      • 3.1|、遇到的问题
        • 3.1.1、pom.xml中front-maven-plugin-无法下载npm6.14.5
        • 3.1.2、无法抽取npm-6.14.5.tar.gz文件
    • 4. 启动服务./graphhopper.sh -a web -i ./china-latest.osm.pbf
      • 4.1、问题
        • 4.1.1、解析的地图数据过大导致内存溢出发生错误
      • 4.2、启动完成验证

文章参考

个人尝试本地部署Graphhopper路径规划引擎的过程基本参考本地部署Graphhopper实现离线地图路径规划功能(小白放心食用版)。
本文主要是对整个过程从环境配置到服务部署的过程以及遇到的问题进行了记录。有些问题在参考的博客中有记录,本文并未完全移植,而是根据部署过程中遇到的其他问题进行了记录和解决。
部署过程中遇到的问题可以参照本文和参考博文记录的问题进行解决,希望能起到作用,有不足的地方也请指出。

源码获取

特别说明:使用的是graphhopper的stable分支
获取方式

  • 方式1:使用git命令:git clone -b stable https://github.com/graphhopper/graphhopper.git
  • 方式2:直接下载zip文件,切换到stable分支,下载zip文件,graphhoper项目地址
    在这里插入图片描述

一、配置Java环境变量

  1. 下载Java Development Kit (JDK):
    访问Oracle官网或者OpenJDK官网,下载适合你操作系统的JDK版本。传送门:官网
    JDK1.8夸克网盘下载:
    链接:https://pan.quark.cn/s/be289bd5a448 提取码:1YRZ
  2. 安装JDK:
    下载完成后,运行安装程序,按照提示完成JDK的安装。安装完成后,JDK通常会默认安装到一个路径,在Windows上可能是 C:\Program Files\Java\jdk-xx
  3. 设置环境变量:
    配置JAVA_HOME环境变量:在系统环境变量中新增一个名为JAVA_HOME的变量,其值为你JDK的安装路径,比如 C:\Program Files\Java\jdk-xx。
    配置PATH环境变量:将JDK的bin目录添加到PATH变量中,这样系统就可以找到Java和Javac命令。例如,将 C:\Program Files\Java\jdk-xx\bin 添加到PATH中。
    配置CLASSPATH:在系统环境中新建变量名:CLASSPATH;变量值:.;%JAVA_HOME%\lib\dt.jar;%JAVA_HOME%\lib\tools.jar;
  4. 验证安装:
    cmd启动命令终端,输入 java -version 和 javac -version 来检查Java和编译器是否成功安装和配置。

二、配置Maven环境变量

大体步骤如下:

  1. 下载Maven:
  2. 设置环境变量
  • 系统变量中,新建一个名为 MAVEN_HOME 的变量,指向你解压缩Maven的目录
  • 编辑系统变量 Path,在末尾添加 %MAVEN_HOME%\bin
  1. 验证安装:
    打开命令行输入 mvn -v 命令,检查输出是否显示了Maven的版本信息,确认安装成功。
  2. 配置settings.xml(可选):
    Maven的全局配置文件位于 M2_HOME/conf/settings.xml,可以根据需要进行配置,例如设置镜像、代理等。需要修改maven目录中conf文件夹下的settings.xml文件
  • Maven配置JDK版本
 <profiles>.......<profile><id>JDK-1.8</id><activation><activeByDefault>true</activeByDefault><jdk>1.8</jdk></activation><properties><maven.compiler.source>1.8</maven.compiler.source><maven.compiler.target>1.8</maven.compiler.target><maven.compiler.compilerVersion>1.8</maven.compiler.compilerVersion></properties></profile>
........
</profiles>
  • 配置国内镜像
<mirrors>......<mirror>  <id>alimaven</id>  <name>aliyun maven</name>  <url>http://maven.aliyun.com/nexus/content/groups/public/</url>  <mirrorOf>central</mirrorOf>          </mirror>.......</mirrors>
  • 配置Maven本地仓库地址
<settings xmlns="http://maven.apache.org/SETTINGS/1.2.0"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="http://maven.apache.org/SETTINGS/1.2.0 https://maven.apache.org/xsd/settings-1.2.0.xsd">......<localRepository>D:\Program Files\Java\mvn-repository</localRepository>......
</settings>

三、构建graphhopper步骤

1. 下载数据

地图数据下载地址,可以根据根据需要下载,我下载的中国的数据,有1g过,后面构建运行的时候还挺耗时的。
我将china-latest.osm.pbf放在了源码项目的根目录了
pbf地图数据下载页面截图

2. 配置graphhopper配置文件config-example.yml

  datareader.file: "./china-latest.osm.pbf"# Local folder used by graphhopper to store its datagraphhopper.flag_encoders: cargraph.location: graph-cachehttp.port: 8989

3. 在项目中启动命令行执行./graphhopper.sh build

3.1|、遇到的问题

3.1.1、pom.xml中front-maven-plugin-无法下载npm6.14.5
[ERROR] Failed to execute goal com.github.eirslett:frontend-maven-plugin:1.10.0:install-node-and-npm (install node and npm) on project graphhopper-web: Could not download npm: Could not download https://registry.npmjs.org/npm/-/npm-6.14.5.tgz: Read timed out -> [Help 1]

无法下载错误截图
解决办法:打开graphhoper项目文件夹下的pom.xml文件,在plugins标签内添加如下配置,就是更改了npm源为淘宝最新的npm源,如果不行的话尝试一下科学上网

 <plugin><groupId>com.github.eirslett</groupId><artifactId>frontend-maven-plugin</artifactId><version>1.6</version><executions><execution><id>install node and npm</id><goals><goal>install-node-and-npm</goal></goals><configuration><nodeDownloadRoot>http://nodejs.org/dist/</nodeDownloadRoot><npmDownloadRoot>https://registry.npmmirror.com</npmDownloadRoot><!-- <nodeVersion>v9.11.1</nodeVersion> --></configuration></execution></executions>
</plugin>
3.1.2、无法抽取npm-6.14.5.tar.gz文件

[ERROR] Failed to execute goal com.github.eirslett:frontend-maven-plugin:1.10.0:install-node-and-npm (install node and npm) on project graphhopper-web: Could not extract the npm archive: Could not extract archive: 'D:\Program Files\Java\mvn-repository\com\github\eirslett\npm\6.14.5\npm-6.14.5.tar.gz': EOFException -> [Help 1]
无法抽取文件错误截图

解决办法:删除...\com\github\eirslett\目录下的eirslett文件夹,然后执行mvn clean install
参考文章Could not extract the npm archive (using frontend-maven-plugin 1.3) #545

4. 启动服务./graphhopper.sh -a web -i ./china-latest.osm.pbf

执行命令:./graphhopper.sh -a web -i ./china-latest.osm.pbf

4.1、问题

4.1.1、解析的地图数据过大导致内存溢出发生错误

解决办法export JAVA_OPTS="-Xmx4g -Xms4g"#加大至4G内存

4.2、启动完成验证

因为要解析地图数据,会耗费大概15分钟左右,很多人在浏览器输入http://127.0.0.1:8989,网页一直打转,没有立马加载出来,是因为服务还没有完全启动,很多博客忽略这个环节,启动成功的标志是
服务完全启动截图

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/bicheng/50664.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

使用 nmcli 管理网络连接

nmcli 是 NetworkManager 的命令行工具&#xff0c;它提供了一种方便的方式来管理网络连接、查看网络状态以及进行网络配置。无论你是在服务器环境中&#xff0c;还是在没有图形界面的桌面系统中&#xff0c;nmcli 都是一个强大的网络管理工具。本文将介绍 nmcli 的基础用法及一…

【python代码不需要额外的操作就能交换两个变量的值】

看到一个案例&#xff0c;想着用Python代码实现一下&#xff0c;不需要额外的操作就能交换两个变量的值 def swap(a, b):return b, a a, b -1, 14 swap(a, b) # (14, -1) spread([1,2,3,[4,5,6],[7],8,9]) # [1,2,3,4,5,6,7,8,9]在Python中&#xff0c;确实存在一种非常简洁的…

JavaScript 的奇技淫巧

JavaScript 作为一门动态语言&#xff0c;拥有丰富的特性和灵活性。这使得开发者们能够编写出既强大又高效的代码。然而&#xff0c;在某些情况下&#xff0c;为了追求代码的精简或性能优化&#xff0c;开发者可能会采用一些非传统的技巧。接下来&#xff0c;我们一起探索一些这…

土耳其云手机提升TikTok电商效率

在数字化飞速发展的今天&#xff0c;TikTok不仅是一个社交平台&#xff0c;更是一个巨大的电商市场。随着TikTok电商功能在全球范围内的扩展&#xff0c;土耳其的商家和内容创作者正面临着前所未有的机遇。本文将详细介绍土耳其云手机怎样帮助商家抓住机遇&#xff0c;实现业务…

项目都做完了,领导要求国际化????--JAVA后端篇

springboot项目国际化相信各位小伙伴都会&#xff0c;很简单&#xff0c;但是怎么项目都做完了&#xff0c;领导却要求国际化文件就很头疼了 国际化的SpringBoot代码&#xff1a; 第一步&#xff1a;创建工具类 /*** 获取i18n资源文件** author bims*/ public class Message…

MATLAB怎么实现多条曲线共用一个图例

y1 sin(x); y2 3*sin(x); y3 cos(x); y4 3*cos(x); 例子&#xff1a;如果我们有4条曲线&#xff0c;分布是cos类和sin类&#xff0c;我们的图例就想区分是cos类还是sin类。 第一步&#xff08;关键步骤&#xff09; 我们要把我们所需要的类别曲线先画一遍&#xff0c; …

实现文档的自动化发布与跨平台阅读

在当今的软件开发领域&#xff0c;文档作为代码之外的重要资产&#xff0c;其管理和发布同样需要高效和自动化。 利用Git进行版本控制&#xff0c;通过GitBook和Typora发布文档&#xff0c;并与GitLab CI/CD工具集成&#xff0c;以实现文档在多种设备上的流畅阅读体验。 一、…

《Programming from the Ground Up》阅读笔记:p75-p87

《Programming from the Ground Up》学习第4天&#xff0c;p75-p87总结&#xff0c;总计13页。 一、技术总结 1.persistent data p75, Data which is stored in files is called persistent data, because it persists in files that remain on disk even when the program …

用 apifox cli 命令行运行本地接口出现TypeError:Invalid IP address: undefined

用 apifox cli 命令行运行本地接口出现TypeError:Invalid IP address: undefined&#xff0c;客户端运行是通过的但命令行运行会报错 修改端口也是一样报错&#xff0c;地址修改为127.0.0.1会报错connect ECONNREFUSED 127.0.0.1:8080 解决方法&#xff1a;不用localhost&…

智能合约在能源行业中的应用:促进可再生能源的发展与利用

随着全球能源需求的增长和环境保护意识的提升&#xff0c;可再生能源作为替代传统能源的重要选择&#xff0c;正逐步成为能源供应的主流。本文将探讨智能合约在能源行业中的应用&#xff0c;特别是如何通过智能合约促进可再生能源的发展与利用。 可再生能源的重要性与挑战 可再…

react中使用forwardRef获取子组件中的节点以及子组件的方法(useImperativeHandle的使用)

1.forwardRef的使用 import { forwardRef, useRef } from "react"const Son forwardRef((props, ref)> {return (<input type"text" ref{ref} id"kannoId"/>) })function ForwardRef() {const sonRef useRef(null)const showRef ()…

Javascript前端面试基础5【每日更10】

let与var的区别 let命令不存在变量提升&#xff0c;如果在let前使用&#xff0c;会导致报错&#xff08;var存在变量提升&#xff09;如果块区中存在let和const命令&#xff0c;就会形成封闭作用域不允许重复声明&#xff0c;因此&#xff0c;不能在函数内部重新声明参数 m…

React如何用一个变量接收所有axios接口内的数据渲染dom

在React中&#xff0c;使用axios进行HTTP请求并接收数据以渲染DOM是常见的操作。你提到的“用一个变量接收所有axios接口内的数据”这个概念&#xff0c;实际上取决于你的应用结构和数据管理的需求。这里有几种常见的方式来处理这种情况&#xff1a; 1. 使用React状态&#xf…

基于Qt的视频剪辑

在Qt中进行视频剪辑可以通过多种方式实现&#xff0c;但通常需要使用一些额外的库来处理视频数据。以下是一些常见的方法和步骤&#xff1a; 使用FFmpeg FFmpeg是一个非常强大的多媒体框架&#xff0c;可以用来处理视频和音频数据。你可以使用FFmpeg的命令行工具或者其库来实现…

YOLOv8魔改核心-模型yaml文件解析与网络结构打印

前言 本篇文章主要用于记录学习YOLOv8中网络模型yaml文件&#xff0c;我们一般只知道如何去训练模型&#xff0c;和配置yaml文件&#xff0c;但是对于yaml文件是如何输入到模型里&#xff0c;模型如何将yaml文件解析出来的确是不知道的&#xff0c;下面我们从yaml文件来讲解&a…

python+vue3+onlyoffice在线文档系统实战20240726笔记,左侧菜单实现和最近文档基本实现

解决右侧高度过高的问题 解决方案&#xff1a;去掉右侧顶部和底部。 实现左侧菜单 最近文档&#xff0c;纯粹文档 我的文档&#xff0c;既包括文件夹也包括文件 共享文档&#xff0c;别人分享给我的 基本实现代码&#xff1a; 渲染效果&#xff1a; 简单优化 设置默认菜…

基于上云api前端开发经验教训(loading...)

问题一&#xff1a;部署前端代码时npm报错 由于npm源在国外&#xff0c;出现安装异常或比较慢的情况&#xff0c;使用cnpm(淘宝镜像)来解决。 安装cnpm npm install -g cnpm --registryhttp://registry.npmmirror.com使用cnpm(同npm一样) cnpm install

RT-Thread Studio搭建 Renesa Version Board开发环境

目录 概述 1 认识Version Board 1.1 Vision-Board简介 1.2 Vision-Board的资源 2 搭建Version Board开发环境 2.1 RT Thread Studio 2.2 安装SDK 3 开发环境验证 3.1 创建项目 3.2 编译和下载 概述 本文主要介绍使用RT-Thread Studio搭建 Renesa Version Board开发环…

c语言第四天笔记

关于 混合操作&#xff0c;不同计算结果推理 第一种编译结果&#xff1a; int i 5; int sum (i) (i) 6 7 13 第二种编译结果&#xff1a; int i 5; int sum (i) (i) 6 7 7 7 前面的7是因为后面i的变化被影响后&#xff0c;重新赋值 14 第一种编译结果&#xff…

Html+Css网页开发之动态登录页面(默认Chrome)

>>效果展示图<< 一、需求分析与设计要求 实现了一个动态背景图案的效果&#xff0c;包括一个白色的容器&#xff0c;内部有一个标题、一个输入框、一个按钮和一些文本。 背景是一个渐变色的线性渐变&#xff0c;而在容器的周围&#xff0c;有一些随机的方形和圆形图…