SOE不能进入断点调试
一、前言
任何程序开发,如果不能进入断点调试,是非常的痛苦的。
如果有过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不能进入断点调试的更多相关文章
- PhpStorm集成xdebug进行断点调试
本文介绍如何使用PhpStorm集成xdebug在本地开发环境进行断点调试的技巧. 我配置的环境是:Windows10 + PhpStorm10.0.1 + PHP5.6. 1. 下载xdebug的扩 ...
- PyCharm断点调试django
我在用PyCharm开发django程序的时候,对于打印日志调试程序的方式感觉还是有点麻烦和不直观,所以研究了一下断点调试的方法如下: 1.打开你的工程,在菜单栏里找到Run-->Edit Co ...
- netbeans-xdebug 断点调试php
来自NetBeans官网的帮助文档: https://netbeans.org/kb/docs/php/debugging_zh_CN.html 但具体问题,我们还是要说下 准备工作 本地部署的ser ...
- Drools mvel方言drl断点调试方法
开发环境:myeclipse2014, jdk1.8.0.91,drools6.4.0.Final, drools-eclipse-plugin,mvel2-2.2.6.Final问题描述:drl使 ...
- Eclipse断点调试
转自:http://blog.csdn.net/maritimesun/article/details/7815903 作为开发人员,掌握开发环境下的调试技巧十分有必要.去年就想把关于Eclipse断 ...
- js断点调试心得
虽然网上已经有多的数不清的调试教程了,但仍然没有发现哪篇文章写的通俗易懂,索性自己尝试写写自己的一些使用习惯或者说是心得,希望对那些还不是很懂得使用断点调试的孩子有一些帮助(大神请无视~). 1.断点 ...
- chrome developer tool—— 断点调试篇
断点,调试器的功能之一,可以让程序中断在需要的地方,从而方便其分析.也可以在一次调试中设置断点,下一次只需让程序自动运行到设置断点位置,便可在上次设置断点的位置中断下来,极大的方便了操作,同时节省了时 ...
- .NET C#微信公众号开发远程断点调试(本地远程调试生产环境代码)
最近在做微信公众号开发,由于之前没有接触过,突然发现调试不方便,不方便进行断点跟踪调试.因为微信那边绑定的服务器地址必须是公网地址,但是还是想进行断点调试(毕竟这样太方便了,程序有Bug,一步步断点跟 ...
- chrome断点调试
chrome断点调试 在编写JavaScript代码时,如果出现了bug,就要不断的去找错误,如果console控制台中提示还好说,可是没有提示恐怕就要费一番周折了.但是有了chrome这个浏览器,我 ...
随机推荐
- Linux I/O复用中select poll epoll模型的介绍及其优缺点的比較
关于I/O多路复用: I/O多路复用(又被称为"事件驱动"),首先要理解的是.操作系统为你提供了一个功能.当你的某个socket可读或者可写的时候.它能够给你一个通知.这样当配合非 ...
- 点滴积累【JS】---JS小功能(offsetLeft实现图片滚动效果)
效果: 代码: <head runat="server"> <title></title> <style type="text/ ...
- 通道符和xargs命令
通道符“|“:是将前一个命令的输出做为后一个命令的标准输入.注意:这里的标准输入指的是:通道符右侧命令的处理内容,也就是说左侧的标准输出不能作为右侧命令的参数,只能作为命令的处理对象. 简单讲:只有通 ...
- Atitit.设计模式-----触发器模式 trigger 详解
Atitit.设计模式-----触发器模式 trigger 详解 1. 触发器概念1 1.1. 触发器位置 after|before|instead of1 2. 数据库里面的触发器1 2.1. o ...
- Atitit.获取主板与bios序列号获取硬件设备信息 Wmi wmic 的作用
Atitit.获取主板与bios序列号获取硬件设备信息 Wmi wmic 的作用 1 获取硬件核心基础核心基础Wmi1 2 其他资料2 3 Wmic WMI 命令行接口2 4 Atitit.获取主板 ...
- Atitit.软件开发的几大规则,法则,与原则p821.doc
Atitit.软件开发的几大规则,法则,与原则p821.doc 1. 设计模式六大原则2 1.1. 设计模式六大原则(1):单一职责原则2 1.2. 设计模式六大原则(2):里氏替换原则2 1.3. ...
- Java创建多线程的三种方法
Java多线程实现方式主要有三种:继承Thread类.实现Runnable接口.使用ExecutorService.Callable.Future实现有返回结果的多线程.其中前两种方式线程执行完后都没 ...
- 关于Tensorflow 的数据读取环节
Tensorflow读取数据的一般方式有下面3种: preloaded直接创建变量:在tensorflow定义图的过程中,创建常量或变量来存储数据 feed:在运行程序时,通过feed_dict传入数 ...
- CentOS6.2下安装Qt5.1.0
因为要将程序实现跨平台,所以只能在CentOS6.2上再安装一次Qt,为了保证一致性,我使用了和windows下版本一样的Qt5.1.0,可以到此处下载. 下载好,复制到虚拟机上后,直接双击运行,一切 ...
- 初识layer遮罩层
背景:楼主做了一个先删除数据再插入的功能,但是狂点菜单的时候会有重复数据插入进来,设置字段unique之后,再狂点,控制台也会报错. 为了防止这种问题出现,我采取了制止”狂点“这种行为出现的做法,所以 ...