Skip To Content

Depurar una extensión

Depurar una extensión (SOE o SOI) plantea algunos retos, ya que debe entrar en un proceso de servicio en ejecución. ArcGIS Server Manager ofrece algunas configuraciones que pueden ayudarle a depurar extensiones de Java. Estas configuraciones se describen con más detalle a continuación. El proceso para depurar extensiones es el mismo independientemente del SDK que se utilice para desarrollar su SOE o SOI.

Flujo de trabajo de depuración

Para depurar su extensión, debe hacer lo siguiente:

  1. Utilizar ArcGIS Server Manager para implementar la extensión.
  2. Utilizar ArcGIS Server Manager para habilitar la depuración de la extensión y configurar la depuración. Estas acciones se describen en detalle a continuación.
  3. Establecer puntos de corte en las ubicaciones deseadas en el código de extensión.
  4. Detenga y vuelva a iniciar el servicio.
  5. Adjunte inmediatamente el depurador al proceso del sistema operativo que ejecuta el servicio. Si el punto de corte está en el código de inicialización de la extensión, el punto de corte se verá afectado a medida que el servicio se inicie. De lo contrario, el punto de corte se verá afectado cuando utilice la extensión.
  6. Utilice ArcGIS Server Manager para deshabilitar la depuración.

Configurar la depuración en el Administrador

Para facilitar la depuración, ArcGIS Server Manager le permite alterar el comportamiento de la extensión. Puede suspender el inicio del servicio para que pueda adjuntar su depurador al proceso del servicio antes de llamar a los métodos de inicialización de la extensión. También puede especificar un rango de puertos que utilizará cuando depure el servicio.

Para acceder a estas opciones de configuración de depuración en ArcGIS Server Manager, siga estos pasos:

  1. Inicie sesión en el ArcGIS Server Manager y haga clic en Sitio.
  2. Haga clic en Servidor SIG > Extensiones.
  3. Haga clic en Configuraciones de depuración y marque la opción Habilitar la depuración de extensiones. Esto habilita las demás opciones en el cuadro de diálogo.
  4. De manera opcional, marque Suspender el inicio del servicio e introduzca el número de segundos que debería retrasarse el inicio del servicio.

    El código de algunas extensiones solo se ejecuta una sola vez, cuando se inicia el servicio. Este código se colocan generalmente en el método Construir de la interfaz IObjectConstruct. Suspender el inicio del servicio le da tiempo para adjuntar su depurador al proceso del servicio antes de que el método Construir se ejecute, permitiendo así alcanzar cualquier punto de corte que haya establecido en el código de ese método.

  5. De manera opcional, puede especificar un rango de puertos que se va a utilizar durante la depuración.
  6. Haga clic en Save (Guardar).

Ahora puede depurar la extensión deteniendo y después iniciando de nuevo el servicio, y adjuntar su depurador al proceso del sistema operativo que ejecuta el servicio. Si configura una ventana de tiempo para la suspensión del inicio del servicio, debe adjuntar su depurador al proceso de servicio antes de que alcance esta ventana; de lo contrario, no alcanzará los puntos de corte en el método Construir de la extensión.

Puede detener e iniciar el servicio tantas veces como sea necesario durante el proceso de depuración.

Precaución:

Cuando haya terminado de depurar la extensión, vuelva a la configuración de depuración y desactive Habilitar depuración de extensiones. Si no lo hace y configuró la opción de suspender el inicio del servicio, experimentará un retraso cada vez que intente iniciar el servicio.