Esta opción nos permite monitorizar las peticiones que Velneo vClient hace a Velneo vServer durante la ejecución de una aplicación. Informa sobre cada una de las conexiones (sockets) que realiza Velneo vClient con Velneo vServer por segundo, detallando la información de cada una de ellas.
Se trata de una extensión. Ver el capítulo dedicado a las extensiones para conocer cómo se instala.
Una vez instalada, ejecutaremos el monitor de vClient desde la opción monitor de vClient del menú ver de Velneo vDevelop.
Una vez abierto el monitor en vDevelop tendremos que ejecutar en modo depuración la solución a monitorizar , para ello, ejecutar la opción depurar solución actual del menú soluciones de Velneo vDevelop, o bien ejecutar Velneo vClient con el parámetro /debug y ya comenzaremos a ver la información:
En la parte superior se muestra en una gráfica en tiempo real el número de conexiones realizadas por segundo, lo que nos podrá ayudar a conocer la carga de conexiones en las partes de la aplicación por las que nos vayamos moviendo.
En la parte inferior del monitor de vClient de cada conexión se muestra lo siguiente:
La información del tiempo.
Tipo de operación (comando de protocolo VATPS).
Si la aplicación está esperando por algo, por ejemplo, durante la ejecución de un proceso en primer plano el usuario tiene que esperar a que termine para seguir interactuando con la aplicación (Gui = sí, está a la espera, Gui = no, no está a la espera).
Dependiendo del tipo de comando, información adicional sobre éste que, en la mayoría de los casos, será el testigo del enganche (un identificador de la conexión).
Recomendamos tener a la vista de forma simultanea el monitor de vClient y Velneo vClient, para poder ir viendo lo que se está ejecutando al mismo tiempo que se está viendo la monitorización.
Normalmente, en las aplicaciones cloud el cuello de botella suele estar en las comunicaciones, por ejemplo, procesos que requieren muchas peticiones al servidor; así que nos servirá para detectar en qué partes están esos cuellos de botella y que es recomendable mejorar para que nuestra aplicación se ejecute con más fluidez en cloud.
El monitor de vClient genera un log en disco en el directorio de la caché de Velneo vClient, en un fichero llamado msg_vclient.txt. Ese fichero podremos usarlo para exportar la información a una aplicación externa para analizar los datos.
Para que nuestras aplicaciones vayan muy bien en cloud, recomendamos que nuestras aplicaciones no necesiten más de cinco conexiones por segundo. Esto no quiere decir que no podamos requerir en momentos puntuales más de cinco conexiones, pero debemos saber que con más de 5 conexiones el rendimiento será inferior.
A continuación facilitamos una lista de algunos de los comandos de protocolo VATPS que podrán presentarse.
Comando
Descripción
Abortar transacción
Se aborta una operación de escritura en disco, por ejemplo, por el uso del comando de instrucción de proceso deshacer transacción.
Alta de ficha
Añadir una ficha a una tabla. Ejemplo: aceptar formulario de altas de una tabla.
Baja de ficha
Eliminar una ficha de una tabla. Ejemplo: botón eliminar de un formulario.
Bloquear una ficha
Bloquear un registro en modo lectura/escritura. Ejemplo: comando de botón aceptar en un formulario.
Bloquear y leer múltiples fichas
Bloquear y leer una lista de registros en modo lectura/escritura. Por ejemplo: comando de instrucción de proceso recorrer lista lectura/escritura.
Bloquear y leer una ficha
Bloquear y leer un registro en modo lectura/escritura. Ejemplo: comando modificar ficha seleccionada.
Buscar campo entre límites
Buscar por un índice entre límites.
Buscar campos iguales
Sobre una lista, se ha ejecutado la opción de listas campos duplicados.
Buscar entre límites
Ejecutar un componente búsqueda entre límites.
Buscar entre límites en una tabla
Ejecución de un componente de búsqueda entre límites.
Buscar entre límites por índice complejo
Ejecutar un componente de búsqueda por un índice complejo.
Buscar ficha por índice
Busca una ficha por índice, devolviendo la ficha.
Buscar ficha por índice complejo
Se realiza una búsqueda de un registro usando un índice complejo.
Buscar múltiples fichas por índice
Busca múltiples fichas por índice, devolviendo la lista.
Buscar por palabras
Ejecutar un componente búsqueda por palabras.
Buscar por palabras por índice complejo
Ejecutar un componente de búsqueda por palabras por un índice complejo
Buscar posición por índice
Busca una ficha por índice, devolviendo la posición de la misma, por ejemplo, calcular un enlace singular de plural por índice en un formulario.
Buscar por trozos
Ejecutar un componente búsqueda por trozos de palabras.
Buscar por trozos por índice complejo
Ejecutar un componente de búsqueda por trozos por un índice complejo
Buscar tabla completa
Carga todos los registros de una tabla. Este comando del protocolo VATP se usa cuando en un combobox editamos un campo enlazado a maestro.
Buscar y bloquear ficha por índice
Busca una ficha y además la bloquea para escribir.
Buscar y bloquear ficha por índice complejo
Busca una ficha por un un índice complejo y la bloquea.
Buscar y leer ficha por índice complejo
Busca una ficha por índice complejo y la lee.
Buscar y leer múltiples fichas
Busca múltiples fichas por posición obteniendo varias fichas.
Comprobar enganche activo
Comando auxiliar del Control de refresco para avisar al servidor de que determinado enganche está activo.
Comprobar índice de clave única
Al guardar o modificar una ficha, el sistema comprueba los índices de clave única. También se generará con el comando de instrucción de proceso ¿ya existe en el índice?
Conectar con instancia de aplicación/datos de un enganche previo sin instancia
Cuando nos conectamos a un Velneo vServer servidor con Velneo vClient, al seleccionar una instancia se ejecuta este comando del protocolo.
Conectar con servidor e instancia de aplicación
Conexión a una instancia de aplicación.
Conectar con servidor e instancia de datos
Conexión a una instancia de datos.
Conectar con servidor pendiente de conectar a instancia
Se ha conectado con el servidor y no se ha seleccionado aún ninguna instancia.
Controlar refresco del cliente
Ejecución del hilo de control de Velneo vClient.
Desconectar de instancia
Se cierra la aplicación.
Devolver información de la tabla
Información de la configuración de la tabla que necesita Velneo vClient.
Ejecutar búsqueda en el servidor
Se dispara en tercer plano una búsqueda con el comando de instrucción de proceso disparar objeto.
Ejecutar función remota
Se ejecuta una función remota.
Ejecutar proceso origen ficha en el servidor
Se ejecuta en tercer plano un proceso con origen ficha, o bien con el comando ejecutar proceso, o bien con el comando disparar objeto.
Ejecutar proceso origen lista en el servidor
Se ejecuta en tercer plano un proceso con origen lista, o bien con el comando ejecutar proceso, o bien con el comando disparar objeto.
Ejecutar proceso origen ficha en 4º plano en el servidor
Se ejecuta en el servidor en modo asíncrono un procesoorigen ficha, o bien con el comando ejecutar proceso, o bien con el comando disparar objeto.
Ejecutar proceso origen lista en 4º plano en el servidor
Se ejecuta en el servidor en modo asíncrono un proceso con origen lista, o bien con el comando ejecutar proceso, o bien con el comando disparar objeto.
Ejecutar proceso sin origen en 4º plano en el servidor
Se ejecuta en el servidor en modo asíncrono un proceso sin origen, o bien con el comando ejecutar proceso, o bien con el comando disparar objeto.
Ejecutar proceso sin origen en el servidor
Se ejecuta en tercer plano un proceso sin origen, o bien con el comando ejecutar proceso, o bien con el comando disparar objeto.
Establecer una variable global
Se cambia el valor de una variable global, por ejemplo, editándola directamente en un formulario.
Finalizar transacción
Finaliza una operación de escritura en disco. Ejemplo: finaliza la ejecución de un proceso que da de alta 1000 registros en una única transacción.
Incrementar una variable global
Este comando de protocolo se ejecutará cuando en una tabla se use una variable global para generar la clave del campo ID.
Iniciar transacción
Se inicia una operación de escritura en disco. Ejemplo: ejecución de un proceso que da de alta 1000 fichas en una única transacción.
Leer múltiples fichas
Lectura de una lista de registros. Ejemplo: comando recorrer lista sólo lectura.
Leer una ficha
Lectura de un registro. Ejemplo: comando leer ficha seleccionada.
Leer una variable global
Se solicita el valor de una variable global. Por ejemplo, usamos una variable global en una condición de activo de un control de un formulario.
Modificación de ficha bloqueada previamente
Modificar una ficha bloqueada previamente, por ejemplo, modificar una ficha en un formulario con bloqueo duro activado.
Modificación de ficha sin bloquear previamente
Modificar una ficha sin bloqueo previo, por ejemplo, aceptar un formulario de modificación (sin bloqueo duro activado).
Obtener información del usuario en curso
Obtiene la información del usuario que necesita el cliente. Por ejemplo, uso de la variable del sistema sysUserName.
Obtener lista de instancias de aplicación permitidas
Petición de lista de instancias de aplicación permitidas al usuario.
Obtener lista de instancias de datos permitidas
Petición de lista de instancias de datos permitidas al usuario.
Obtener múltiples objetos del contenedor
Busca paquetes de campos objeto de una tabla, por ejemplo, cargar una rejilla en la que en una columna se incluye un campo de tipo objeto.
Obtener objeto del contenedor
Solicitar un campo de tipo objeto. Por ejemplo, al abrir un formulario de un registro en el que se muestra un campo objeto.
Regenerar datos e índices de una tabla y su contenedor
Se regenera el área de datos, índices y contenedor de una tabla, por ejemplo, por un cambio en la estructura del fichero.
Regenerar índice complejo
Regeneración de un índice complejo, por ejemplo, al ejecutar la función regenComplexIndex de la API de Velneo para Javascrpt.
Una búsqueda con más de un componente o un comando cargar lista que resuelve más de un componente de un índice, generará un comando de tipo búsqueda por cada componente.