一步步DIY: OSM-Web服务器(三) OpenLays 与 SlippyMap

实现SlippyMap与OpenLayers集成教程
本文详细介绍了如何使用OpenLayers实现SlippyMap,包括下载并配置OpenLayers、引入OpenStreetMap.js、编写HTML代码以展示地图瓦片服务器的地图。

(-:<转载时请注明本文由goldenhawking在 CSDN blog 撰写  http://blog.csdn.net/goldenhawking/article/details/7955441

 上一步,我们已经有了自己的地图瓦片服务器,现在,开始实现SlippyMap啦!

<1>下载释放OpenLayers到 www文件夹

SlippyMap 利用 OpenLays 的AJax实现,直接从Openlays官网下载最新版文件

http://www.openlayers.org/

这里是2.12 版本。

http://www.openlayers.org/download/OpenLayers-2.12.tar.gz

释放到 /var/www/openlayes下,并为www-data 设置可读权限,就完成了!

<2>下载OpenStreetMap.js

对OSM的数据,下载这个文件,放在上面第一步创建的文件夹里。

http://www.openstreetmap.org/openlayers/OpenStreetMap.js

 

于是,目录看起来如下:

1347005857_8019.png

 

接着,我们来写网页

<2> 编写第一个网页,实现SlippyMap

我们编写第一个网页, 参考图书  OpenLayers 2.10 Beginner's Guide,该图书在 http://download.csdn.net/detail/zyk0511/3473416

代码

 

<html>
<head>
    <title>OSM Local Tiles</title>
    <link rel="stylesheet" href="/openlayers/theme/default/style.css" type="text/css" />
    <!-- bring in the OpenLayers javascript library
         (here we bring it from the remote site, but you could
         easily serve up this javascript yourself) -->

    <script src="/openlayers/OpenLayers.js"></script>

    <!-- bring in the OpenStreetMap OpenLayers layers.
         Using this hosted file will make sure we are kept up
         to date with any necessary changes -->

    <script src="/openlayers/OpenStreetMap.js"></script>

    <script type="text/javascript">
// Start position for the map (hardcoded here for simplicity)
        var lat=31.27386;
        var lon=121.48132;
        var zoom=7;
 
        var map; //complex object of type OpenLayers.Map
 
        //Initialise the 'map' object
        function init() {
 
            map = new OpenLayers.Map ("map", {
                controls:[
                     new OpenLayers.Control.Navigation(),
                    new OpenLayers.Control.PanZoomBar(),
                    //new OpenLayers.Control.PanZoom(),
                    new OpenLayers.Control.Permalink(),
                    new OpenLayers.Control.ScaleLine({geodesic: true}),
                    new OpenLayers.Control.Permalink('permalink'),
                    new OpenLayers.Control.KeyboardDefaults(),
                    new OpenLayers.Control.NavToolbar(),
                     new OpenLayers.Control.Attribution()],
                maxExtent: new OpenLayers.Bounds(-20037508.34,-20037508.34,20037508.34,20037508.34),
                maxResolution: 156543.0339,
                numZoomLevels: 19,
                units: 'm',
                projection: new OpenLayers.Projection("EPSG:900913"),
                displayProjection: new OpenLayers.Projection("EPSG:4326")
            } );
 
            // This is the layer that uses the locally stored tiles
            var newLayer = new OpenLayers.Layer.OSM("Local Tiles", "/osm_tiles2/${z}/${x}/${y}.png", {numZoomLevels: 19, transitionEffect: "resize"});
            map.addLayer(newLayer);

            var switcherControl = new OpenLayers.Control.LayerSwitcher();
            map.addControl(switcherControl);
            var vector_layer = new OpenLayers.Layer.Vector('Editable Vectors');
            map.addControl(new OpenLayers.Control.EditingToolbar(vector_layer));
            map.addLayer(vector_layer);

            map.addControl(new OpenLayers.Control.Graticule({visible: false}));
            var mousepos = new OpenLayers.Control.MousePosition({div: document.getElementById('mousepos_div')});
            map.addControl(mousepos);
            //mousepos.moveTo(new OpenLayers.Pixel(64,0));
            
            map.addControl(new OpenLayers.Control.OverviewMap());
             /*
            var navigationT =    new OpenLayers.Control.TouchNavigation({
                dragPanOptions:{
                    enableKinetic: true
                }
            });
            map.addControl(navigationT);
            */
            if( ! map.getCenter() ){
                var lonLat = new OpenLayers.LonLat(lon, lat).transform(new OpenLayers.Projection("EPSG:4326"), map.getProjectionObject());
                map.setCenter (lonLat, zoom);
            }
        }
 
    </script>

</head>
<!-- body.onload is called once the page is loaded (call the 'init' function) -->
<body onload="init();">
    <!-- define a DIV into which the map will appear. Make it take up the whole window -->
    <div style="width: 100%; height: 93%" id="map">
    </div>
    <P><a href='/index.html'>start screen</a></P>
    <div style="width: 100%; height: 5%" id="mousepos_div">
    
    
    
    </div>
</body>
</html>

 

访问网页,OK拉

 

1347006621_1637.png

 

 

下一篇,我们来导入全球的数据,并进行地名翻译。

 

<think>首先,用户的问题是:解决 'No such container: osm-docker-p25-dp-1' 错误的方法。用户提到了一个引用,但指出这个引用仅供参考,不是用户真正的需求。用户还说“参考用户上一次的问题和你的回答”,但在这个对话中,这是第一次互动,所以我需要回想是否有之前的上下文。用户提到“用户上一次的问题”,可能意味着在之前的对话中,但在这个线程中,这是第一条消息。所以,我应该专注于当前问题。 用户提供的引用是关于Docker的命令,特别是运行一个PostGIS容器,但这似乎不直接相关,因为用户说“上述引用仅供参考,并不是用户真正的需求”。用户真正的需求是解决 'No such container: osm-docker-p25-dp-1' 错误。 错误信息是:'No such container: osm-docker-p25-dp-1'。这看起来像是一个Docker错误,表示Docker尝试访问名为“osm-docker-p25-dp-1”的容器,但该容器不存在。 作为AI,我需要提供解决这个错误的方法。常见的解决方案包括: 1. **检查容器是否存在**:使用命令 docker ps -a 来列出所有容器,查看名为“osm-docker-p25-dp-1”的容器是否在列表中。 2. **确保容器名称正确**:确认容器名称拼写正确。在Docker中,容器名称是区分大小写的。 3. **启动容器**:如果容器存在但未运行,使用 docker start 命令启动它。例如:docker start osm-docker-p25-dp-1。 4. **创建容器**:如果容器不存在,用户可能需要创建它。这可能涉及到使用 docker run 命令来启动一个新的容器。用户需要知道容器的镜像和配置。 5. **检查Docker Compose**:如果用户使用的是Docker Compose,错误可能是由于服务未启动或配置错误。命令如 docker-compose up -d 或指定服务名称。 用户提到了“osm-docker-p25-dp-1”,这看起来像是一个Docker Compose项目中的服务名称,因为“osm-docker”可能表示OpenStreetMap相关的容器,“p25-dp-1”像是服务实例。 在Docker Compose中,容器名称通常格式为 <project_name>_<service_name>_<index>。假设项目目录是“osm-docker”,服务是“p25-dp”,索引是1,那么容器名称可能是“osm-docker_p25-dp_1”。但在错误中是“osm-docker-p25-dp-1”,使用了连字符而不是下划线,所以这可能是一个自定义名称或错误。 可能的解决方法: - 使用 docker-compose ps 来查看服务状态。 - 如果使用Docker Compose,运行 docker-compose up -d 来启动服务。 - 如果容器不存在,重新创建它。 用户引用的文本提到了下载geoserver插件和运行PostGIS容器,这可能OpenStreetMap相关,所以我需要将建议GIS上下文联系起来。 结构化回答: 1. **诊断错误**:解释错误的原因——容器不存在或未运行。 2. **第一步:检查容器状态**:建议运行 docker ps -a 或 docker container ls -a。 3. **第二步:启动或创建容器**:如果容器存在但停止,启动它;如果不存在,创建它。 4. **考虑Docker Compose**:如果使用Docker Compose,提供相关命令。 5. **常见原因**:列出可能导致错误的原因,如拼写错误、容器从未创建等。 根据系统指令: - 使用中文回答。 - 生成相关问题。 - 引用处理:用户提供了一个引用 [^1],但在回答中,我应该只在必要时引用。用户说“上述引用仅供参考”,所以我可能不需要引用它,除非相关。 用户说“参考站内引用:引用[1]:...”,但在回答中,我应该自然地添加引用标识如果需要。在这个情况下,引用可能问题相关,但用户说它不是真正的需求,所以我应该专注于错误解决方法。 最后,生成相关问题作为响应的一部分。 回答结构: - 清晰解释错误。 - 提供解决方案步骤。 - 以相关问题结束。 相关问题:基于这个错误,可能的问题包括: 1. 如何创建Docker容器? 2. Docker Compose的基本用法? 3. 如何解决Docker容器启动失败? 4. 常见Docker错误及其解决方法。 确保响应真实可靠:基于Docker文档和常见做法。 </think>### 解决 'No such container: osm-docker-p25-dp-1' 错误的方法 在Docker使用过程中出现 `No such container: osm-docker-p25-dp-1` 错误,通常表示您尝试操作(如启动、停止或访问)一个名为 "osm-docker-p25-dp-1" 的容器,但该容器在系统中不存在或未被正确识别。这种错误可能由多种原因引起,包括容器从未创建、名称拼写错误、容器被删除或系统未正确初始化。下面我将逐步指导您诊断和解决此问题。整个过程基于Docker的标准操作流程,确保安全可靠[^1]。 #### 步骤1: 确认容器是否存在 首先,检查容器是否存在于您的Docker环境中。容器可能未被创建、已被删除或处于停止状态。 - **列出所有容器**:运行以下命令,查看容器列表中是否包含 "osm-docker-p25-dp-1"。这将显示所有容器(包括运行中和已停止的)。 ```bash docker ps -a ``` - **结果分析**: - 如果能找到类似名称的容器(如 `osm-docker-p25-dp-1` 或变体),请记下其状态(如 `Exited` 表示停止)。 - 如果列表为空或没有匹配项,说明容器可能从未创建或被移除。 - **备注**:Docker容器名称区分大小写并严格匹配。确认您输入的容器名称完全正确(包括连字符和大小写)。常见错误是拼写不一致(例如,实际容器名可能是 `osm_docker_p25_dp_1` 或其他格式)。 #### 步骤2: 启动或创建容器 根据步骤1的结果,采取相应措施: - **情况A: 容器存在但未运行**(状态为 `Exited`) 启动容器: ```bash docker start osm-docker-p25-dp-1 ``` - 如果启动成功,运行 `docker ps` 验证状态变为 `Up`。 - 如果启动失败(如容器损坏),尝试重启或重新创建容器。 - **情况B: 容器不存在**(未在列表中找到) 您需要重新创建容器。这可能涉及: - **基于Docker Compose**(推荐):如果容器是Docker Compose项目的一部分(名称格式如 `osm-docker-p25-dp-1` 提示项目名 "osm-docker"),确保在项目目录下运行: ```bash docker-compose up -d ``` 这将启动所有服务(包括 "p25-dp-1"),并自动创建容器。检查服务状态: ```bash docker-compose ps ``` - **直接使用 docker run**:如果未使用Docker Compose,运行一个新容器。假设您有相关镜像(如PostGIS或OSM-related镜像),参考您的配置: ```bash docker run --name osm-docker-p25-dp-1 -d your_image_name ``` 替换 `your_image_name` 为实际镜像(例如 `postgis/postgis`)。如果您不记得镜像,检查历史命令或文档[^1]。 #### 步骤3: 检查常见原因和预防措施 - **常见原因**: - **容器未创建**:初始运行命令(如 `docker run`)未执行或失败。 - **名称冲突**:容器被重命名或删除(使用 `docker rm` 后需重新创建)。 - **Docker Compose项目未初始化**:如果使用Compose,确保 `docker-compose.yml` 文件存在且配置正确。 - **权限问题**:在Linux系统中,确保用户有Docker权限(运行 `sudo docker ...` 或添加用户到docker组)。 - **预防建议**: - 使用 `docker-compose` 管理服务以避免名称错误。 - 给容器添加唯一标签(如 `--label` 参数)。 - 定期备份容器状态(使用 `docker commit` 或卷挂载)。 #### 步骤4: 进阶诊断 如果上述步骤无效,深入诊断系统问题: - **检查Docker日志**:运行 `docker logs container_name`(替换为实际容器名)查看错误详情。 - **系统资源检查**:确保Docker守护进程运行正常: ```bash systemctl status docker # Linux系统 ``` - **重建项目**:如果是OpenStreetMapOSM)相关项目(如用户引用中的GIS上下文[^1]),确认镜像和插件已正确下载(例如geoserver插件)。 如果问题持续,提供更多上下文(如完整错误日志或您的 `docker-compose.yml`),我可进一步协助。 ### 相关问题 1. 如何使用Docker Compose管理多个容器服务? 2. Docker容器无法启动时的通用故障排除技巧有哪些? 3. 在GIS项目中(如OpenStreetMap),如何优化Docker容器的性能和稳定性? 4. 如何备份和恢复Docker容器以防止数据丢失?
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

丁劲犇

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值