Depuración de la aplicación de Service Fabric para Java con Eclipse
Inicie un clúster de desarrollo local siguiendo los pasos descritos en Configurar el entorno de desarrollo de Service Fabric.
Actualice el archivo entryPoint.sh del servicio que desea depurar para que comience el proceso de Java con parámetros de depuración remota. Este archivo se puede encontrar en la ubicación siguiente:
ApplicationName\ServiceNamePkg\Code\entrypoint.sh
. En este ejemplo, el puerto 8001 está establecido para depuración.java -Xdebug -Xrunjdwp:transport=dt_socket,address=8001,server=y,suspend=n -Djava.library.path=$LD_LIBRARY_PATH -jar myapp.jar
Actualice el manifiesto de aplicación estableciendo el recuento de instancias o el recuento de réplicas para el servicio que está en depuración en 1. Esta configuración evita conflictos en el puerto que se usa para depuración. Por ejemplo, para servicios sin estado, establezca
InstanceCount="1"
y, para los servicios con estado, establezca los tamaños del conjunto de réplicas mínimo y de destino en 1 de la manera siguiente:TargetReplicaSetSize="1" MinReplicaSetSize="1"
.Implemente la aplicación.
En el IDE de Eclipse, seleccione Run -> Debug Configurations -> Remote Java Application and input connection properties (Ejecutar -> Configuraciones de depuración -> Aplicación Java remota y propiedades de conexión de entrada) y establezca las propiedades como se muestra a continuación:
Host: ipaddress Port: 8001
Establezca puntos de interrupción en los puntos deseados y depure la aplicación.
Si se bloquea la aplicación, puede que también desee habilitar los volcados de memoria. Ejecute ulimit -c
en un shell y, si devuelve el valor 0, los volcados de memoria no están habilitados. Para habilitar volcados de memoria ilimitados, ejecute el comando siguiente: ulimit -c unlimited
. También podemos comprobar el estado con el comando ulimit -a
. Si desea actualizar la ruta de acceso a la generación de volcado de memoria, ejecute echo '/tmp/core_%e.%p' | sudo tee /proc/sys/kernel/core_pattern
.