![]() |
![]() |
![]() |
![]() |
![]() |
FTP | ![]() |
![]() |
CCD | ![]() |
![]() |
Buscar | ![]() |
![]() |
Trucos | ![]() |
![]() |
Trabajo | ![]() |
![]() |
Foros | ![]() |
|
Registrarse | FAQ | Miembros | Calendario | Guía de estilo | Temas de Hoy |
![]() |
|
Herramientas | Buscar en Tema | Desplegado |
|
#1
|
|||
|
|||
Ver si proceso en ejecución en máquina remota
Buenas a todos!
En mi empresa tenemos múltiples sistemas de facturación ya que programamos a medida para nuestros clientes. Es por ello que la adaptación a Veri*Factu la haremos haciendo uso de un subprograma que mostrará el registro de facturación asociado a una factura, gestionará los envíos y respuestas, las firmas, los registros de eventos, etc. Como la mayoría de nuestras instalaciones son de tipo cliente-servidor, el subprograma en cuestión se ejecutará en el servidor y estará siempre disponible, y se mantendrá a la escucha para enviar los registros cada 60 segundos. Lo que pasa es que este subprograma, por razones diversas, podría ocurrir que de repente se cuelgue y deje de estar disponible para el envío de las facturas. Por tanto, cada uno de nuestros SIF debería detectar antes o después de generar el registro de una factura si dicho subprograma está en ejecución en la máquina remota para, en caso contrario, ejecutarlo o que nos avise por mail de que no está ejecutándose, pues de lo contrario no se podrían remitir los registros de facturación a la AEAT. ¿Alguno de ustedes sabe cómo puede consultarse desde un equipo si en otro equipo de la red existe un proceso en ejecución? Tras algunas consultas a Google y otras a Copilot, he estado probando la api de WMI pero hasta ahora no consigo que funcione. Mi código es el siguiente: Código:
var SWbemLocator: OLEVariant; SWbemServices: OLEVariant; SWbemObjectSet: OLEVariant; SWbemObject: OLEVariant; Enum: IEnumVariant; Value: Cardinal; begin Result := False; SWERROR := 0; try CoInitialize(nil); try SWbemLocator := CreateOleObject('WbemScripting.SWbemLocator'); If CBCredenciales.Checked Then // Si la máquina remota tiene autenticación SWbemServices := SWbemLocator.ConnectServer(RemoteMachine, 'root\CIMV2', Usuario.Text, Password.Text) Else SWbemServices := SWbemLocator.ConnectServer(RemoteMachine, 'root\CIMV2', '', ''); SWbemObjectSet := SWbemServices.ExecQuery(Format('SELECT * FROM Win32_Process WHERE Name = "%s"', [ProcessName])); Enum := IUnknown(SWbemObjectSet._NewEnum) as IEnumVariant; while Enum.Next(1, SWbemObject, Value) = S_OK do begin Result := True; SWbemObject := Unassigned; end; finally CoUninitialize; end; except on E: EOleException do begin SWERROR := 1; Memo1.Lines.Add(Format('Error %d : ($%x) Mensaje : %s', [E.ErrorCode, E.ErrorCode, E.Message])); end; on E: Exception do begin SWERROR := 1; Memo1.Lines.Add('Error ' + E.Classname + ': ' + E.Message); end; end; end; |
#2
|
|||
|
|||
Cita:
Última edición por ermendalenda fecha: 09-12-2024 a las 12:25:45. |
#3
|
||||
|
||||
Cita:
Yo creo que sería lo adecuado para este escenario. Para consultar si un servicio está en marcha, se podría utilizar WMI.
__________________
Germán Estévez => Web/Blog Guía de estilo, Guía alternativa Utiliza TAG's en tus mensajes. Contactar con el Clubdelphi ![]() P.D: Más tiempo dedicado a la pregunta=Mejores respuestas. |
#4
|
|||
|
|||
Cita:
Pero si ese programa remoto fuera ejecutado como un servicio, creo que mucho mejor. ¿Podrías orientarnos un poco el como hacer un programa que funcione como un servicio? |
#5
|
||||
|
||||
Cita:
Si es posible, lo más sencillo (creo yo) es que tantos los programas cliente (ERP) como el servicio (o la app. que habías pensado) estén conectados a la Base de Datos. Los ERP van colocando ficheros en la cola (es una o varias tablas dependiendo del diseño) y el servicio los va procesando y en la misma Base de Datos va generando las respuestas. La lógica de envío sólo está en el servicio. Cita:
Nosotros diseñamos el servicio en 2 piezas (EXE + DLL). En realidad para facilitar debug y pruebas, se diseña un servicio y una aplicación. Para no "repetir" código, toda la lógica se encuentra en la DLL y esa DLL se llama desde una APP y desde un SERVICIO. Como he dicho la APP y el SERVICIO sólo tienen una llamada al método de "procesar" de la DLL (que tiene toda la lógica). ¿Porqué se hace esto? Porque los servicios no pueden tener parte visual y los LOGs para debug se envían al registro de eventos de Windows, en el caso de la APP sí puede tener parte visual y los LOGs para debug se envían a un fichero. Para todo el proceso de desarrollo se usa la APP+DLL y para el cliente final SERVICIO+DLL. Si buscas por los foros encontrarás muchos hilos al respecto y posiblemente en el FTP encontrarás algún ejemplo: https://www.clubdelphi.com/foros/showthread.php?t=89341 https://www.clubdelphi.com/foros/showthread.php?t=48843 https://www.clubdelphi.com/foros/showthread.php?t=12776 https://www.clubdelphi.com/foros/showthread.php?t=20913 https://www.intitec.com/varios/delph...io_windows.pdf
__________________
Germán Estévez => Web/Blog Guía de estilo, Guía alternativa Utiliza TAG's en tus mensajes. Contactar con el Clubdelphi ![]() P.D: Más tiempo dedicado a la pregunta=Mejores respuestas. |
#6
|
|||
|
|||
Cita:
|
#7
|
|||
|
|||
Cita:
Los servicios se atienden a quien los pide, no se entremezclan y además puedes mandarles parámetros para identificar desde donde lo envías para que se registre. Última edición por ermendalenda fecha: 11-12-2024 a las 21:33:24. |
#8
|
||||
|
||||
Cita:
Es cuestión de buscar soluciones a los problemas. En nuestro caso hay un único Servidor de Base de Datos, pero puede haber varias Bases de Datos dentro de ese servidor. Cada base de datos es una empresa/obligado diferente (no se si es también tu caso); El servicio hace y una rueda y se va conectando a las diferentes Bases de Datos para enviar los datos de esa empresa. Una vez acabado se apunta en tiempo de espera (o el tiempo hasta el siguiente envío) para esa empresa. Es decir, en nuestro caso, un único servicio se encarga de todos los envíos de las diferentes empresas/obligados tributarios. Por ahora en el Thread principal, porque no contemplamos que la "rueda de envío" pueda tardar más de 60 sg. Actualmente se hace muy rápido. Si en su día esa "rueda de envíos" empezara a tardar mucho, nos planteamos crear Threads (ya lo tenemos pensado).
__________________
Germán Estévez => Web/Blog Guía de estilo, Guía alternativa Utiliza TAG's en tus mensajes. Contactar con el Clubdelphi ![]() P.D: Más tiempo dedicado a la pregunta=Mejores respuestas. |
#9
|
|||
|
|||
Cita:
Buenos días. A ver si alguien me puede dar alguna pista sobre el error que estoy teniendo. Yo hasta ahora tenía una dll que se encargaba de todo, el envío a la aeat, la respuesta, etc.... funcionando correctamente. Cuando he decidido crear un servicio que aproveche esta dll, mi sorpresa ha sido que no funciona correctamente, me da el siguiente error "Received content of invalid Content-Type setting: text/html - SOAP expects "text/xml". ¿ Alguien sabe algo de este error o me puede decir si se puede depurar un servicio en funcionamiento, para ver qué está pasando. ? Muchas gracias. |
#10
|
||||
|
||||
¿Estás llamado a la URL correcta?
Deberás añadir log, para ver más o menos dónde está fallando. CXreo que suele ser lo habitual, cuando el componente de envío no recibe una respuesta correcta al realizar la llamada, por ejemplo cuando la URL es incorrecta, pero sin saber algo más concreto es difícil.
__________________
Germán Estévez => Web/Blog Guía de estilo, Guía alternativa Utiliza TAG's en tus mensajes. Contactar con el Clubdelphi ![]() P.D: Más tiempo dedicado a la pregunta=Mejores respuestas. |
#11
|
|||
|
|||
Cita:
En nuestro caso, ISCOPYME, nos salía ese error cuando no se enviaba correctamente el certificado electrónico. Si abres el navegador web, pegas esa URL y no seleccionas el certificado, la AEAT devuelve un HTML indicando el error 403. En nuestro caso, si el Delphi no encontraba el certificado, cuando hacía la petición al WebService sin él, también devolvía un HTML. ¡Espero que te sirva! Última edición por aleixep fecha: Hace 2 Semanas a las 08:31:32. Razón: Añadí un emoticono pero no se veía |
![]() |
|
|
![]() |
||||
Tema | Autor | Foro | Respuestas | Último mensaje |
Capturar id de maquina remota | mediaplanet | API de Windows | 3 | 18-05-2010 10:46:09 |
Instalar un proceso de forma remota | fide_32 | API de Windows | 1 | 26-09-2008 10:08:42 |
Ejecutar programa desde una maquina remota | rjsitruiz | Varios | 0 | 12-01-2005 16:55:19 |
abrir un documento en una maquina remota | CarlosHernandez | API de Windows | 2 | 10-03-2004 21:47:14 |
Nuevo Contacto en máquina remota | Igna | Servers | 1 | 21-01-2004 18:47:24 |
![]() |
|