一、前言

任何程序开发,如果不能进入断点调试,是非常的痛苦的。

如果有过SOE开发经验的人都知道,SOE开发过程中调试是非常麻烦的。任何在SOE开发模板中的修改都需要重新编译工程,重新生成.soe 文件。并在站点中重新部署soe文件。但是重部署后,经常会出现没有办法进入断点调试(表现是断点是空心点,而不是实心点)模式。

由于调试的复杂性,建议大家在实际soe开发的过程中,先将整个核心的代码以ArcEngine的形式进行实现。然后再移植到soe模板中。

二、问题出现场景及原因分析

软件环境:visual studio 2010,2012, ArcObjects sdk for .net 10.1,10.2

soe开发不能进入断点调试的核心原因是:站点中部署的soe的版本和当前调试的版本不匹配。举个例子说明,你将vs中的soe进行了更改,但是并没有将更改的结果重新部署到站点中去,导致两者不匹配,无法调试。

但是有意思的是即使大家及时将更改的结果进行站点部署,保证两者版本进行匹配,发现任然不能进入到断点调试。当时这个问题困惑了笔者很久,但是一个偶然的机会发现,我重新建个soe模板,更换工程名字,将不能调试的代码粘贴进去,重新编译,部署,就可以调试。而对这个新建的工程进行更改,替换站点中的同名soe文件,又不能出现调试。根据这个现象我推测,是因为在站点中删除或者覆盖同名soe文件,在服务器端还是存在的,并没有删除。这样就导致了无论vs中怎么变化,但是服务器端还是提供前一次的soe文件,造成两者不匹配,无法进入调试模式。

为了验证我的推测,我进入到admin中,去查看我的服务器端,存在的soe文件。惊讶的发现,我每次在vs中对gounpSpatialIndex工程更新,并重新部署到站点中,其实上一次的并没有删除。如我这次vs中跟新到了红色3项,而实际上服务器端调试的soe工程1或者2。这就导致vs中一直无法进入断点模式。而新建vs工程,重新部署可以调试,就是因为两者对应的唯一性。

  

  图1 admin upload items

三、解决办法

遇到此类无法调试的问题,根本原理是保持调试的代码和服务端soe是一致的。

首先确定你的更新是否及时部署到服务器端,

然后在站点中重新部署的时候,请选择删除已有同名的soe,不要选择编辑。在非第一部署soe中,可以选择edit和delete,如图2红色方框部分。建议选择delete,如果是edit的话,就会出现服务器端多个同名soe文件的现象。

  

            图2 soe部署界面

但是经过我多次测试,发现即使用删除还是有可能出现不可能调试的原因,这时候就要上终极办法,把上一版本的soe从站点中取消注册,并删除。步骤如下:

1、进入admin

http://localhost:6080/arcgis/admin

2、unregister 站点中的soe

在Resource中,点击service。在servic页面的Resource点击types,进入types页面,在Resource中点击extension。然后unregister,如图3。(ps,为了写博客方便,图3和图1,2不是同一服务器上的截图)

3、删除站点中的soe

在admin的主页面中,找到uploads,把对应的soe删除。ps,直接删除不unregister是不行的,会出现错误,该soe已经在站点中注册。

4、部署新版本soe文件

四、总结

这个问题应该是产品的缺陷的地方,但是也没有和老美交流,确定为bug,但是确实存在这样的问题。

SOE不能进入断点调试的更多相关文章

  1. PhpStorm集成xdebug进行断点调试

    本文介绍如何使用PhpStorm集成xdebug在本地开发环境进行断点调试的技巧. 我配置的环境是:Windows10 + PhpStorm10.0.1 + PHP5.6. 1. 下载xdebug的扩 ...

  2. PyCharm断点调试django

    我在用PyCharm开发django程序的时候,对于打印日志调试程序的方式感觉还是有点麻烦和不直观,所以研究了一下断点调试的方法如下: 1.打开你的工程,在菜单栏里找到Run-->Edit Co ...

  3. netbeans-xdebug 断点调试php

    来自NetBeans官网的帮助文档: https://netbeans.org/kb/docs/php/debugging_zh_CN.html 但具体问题,我们还是要说下 准备工作 本地部署的ser ...

  4. Drools mvel方言drl断点调试方法

    开发环境:myeclipse2014,  jdk1.8.0.91,drools6.4.0.Final, drools-eclipse-plugin,mvel2-2.2.6.Final问题描述:drl使 ...

  5. Eclipse断点调试

    转自:http://blog.csdn.net/maritimesun/article/details/7815903 作为开发人员,掌握开发环境下的调试技巧十分有必要.去年就想把关于Eclipse断 ...

  6. js断点调试心得

    虽然网上已经有多的数不清的调试教程了,但仍然没有发现哪篇文章写的通俗易懂,索性自己尝试写写自己的一些使用习惯或者说是心得,希望对那些还不是很懂得使用断点调试的孩子有一些帮助(大神请无视~). 1.断点 ...

  7. chrome developer tool—— 断点调试篇

    断点,调试器的功能之一,可以让程序中断在需要的地方,从而方便其分析.也可以在一次调试中设置断点,下一次只需让程序自动运行到设置断点位置,便可在上次设置断点的位置中断下来,极大的方便了操作,同时节省了时 ...

  8. .NET C#微信公众号开发远程断点调试(本地远程调试生产环境代码)

    最近在做微信公众号开发,由于之前没有接触过,突然发现调试不方便,不方便进行断点跟踪调试.因为微信那边绑定的服务器地址必须是公网地址,但是还是想进行断点调试(毕竟这样太方便了,程序有Bug,一步步断点跟 ...

  9. chrome断点调试

    chrome断点调试 在编写JavaScript代码时,如果出现了bug,就要不断的去找错误,如果console控制台中提示还好说,可是没有提示恐怕就要费一番周折了.但是有了chrome这个浏览器,我 ...

随机推荐

  1. Linux I/O复用中select poll epoll模型的介绍及其优缺点的比較

    关于I/O多路复用: I/O多路复用(又被称为"事件驱动"),首先要理解的是.操作系统为你提供了一个功能.当你的某个socket可读或者可写的时候.它能够给你一个通知.这样当配合非 ...

  2. PHPCMS V9数据库表结构分析

    PHPCMS V9可以轻松承载百万级的访问数据,最大的功臣就是PHPCMS良好的数据库结构,在数据库的设计方面,一定是下足了功夫.   一般网站的信息量离这个级别相差甚远,但是了解学习一下PHPCMS ...

  3. JAVA设计模式之 命令模式【Command Pattern】

    一.概述 命令模式能够将请求发送者和接收者全然解耦.发送者与接收者之间没有直接引用关系,发送请求的对象仅仅须要知道怎样发送请求,而不必知道怎样完毕请求.核心在于引入了命令类,通过命令类来减少发送者和接 ...

  4. 李洪强总结KVC用法

  5. PHP特性整合(PHP5.X到PHP7.1.x)

    Buid-in web server内置了一个简单的Web服务器 把当前目录作为Root Document只需要这条命令即可: php -S localhost:3300 也可以指定其它路径 php ...

  6. linux学习笔记18---目录结构

    对于每一个Linux学习者来说,了解Linux文件系统的目录结构,是学好Linux的至关重要的一步.,深入了解linux文件目录结构的标准和每个目录的详细功能,对于我们用好linux系统至关重要,下面 ...

  7. love2d教程34--thread模块

    love的thread是一个单独的lua运行环境,与主线程平行.因此可以用线程来处理 处理复杂的计算,不过由于隔离,线程不能访问主线程的变量和方法,而且进程 间通信也受限.   可以在线程里共享lov ...

  8. 如何编写Makefile?

    //swap.c #include<stdio.h> int swap(int *x,int *y) {printf("a=%d b=%d\n",*x,*y); int ...

  9. 截图工具gsnap

    嵌入式linux截图工具的基本原理就是通过读取Framebuffer,把LCD上显示的内容转换成图片格式文件(jpeg.bmp.png). gsnap.bin 1.jpg  /dev/fb0 gsna ...

  10. nginx php-fpm启用慢日志slowlog

    php-fpm慢日志slowlog设置可以让我们很好的看见哪些php进程速度太慢而导致的网站问题. 可以让我们方便的找到问题的所在.  代码如下 1 vi /data1/server/php-cgi/ ...