Page 1 of 3
Programa muy lento en red
Posted: Thu Jul 26, 2007 2:15 pm
by Rafael Clemente
Estoy utilizando FWH 2.6 para hacer una aplicación cuya pantalla principal básicamente contiene un TxBrowse() de una tabla de Clientes con unos 4000 registros. Para ver solamente un subset de los clientes, aplico un simple filtro por ejemplo: SET FILTER TO Poblacion="B" (Ya sé que podría utilizar Scopes, pero por otras razones, he de emplear SET FILTER)
Mi sistema incluye dos PCs conectados en red local de 100 Mb. Los datos de clientes se encuentran en uno de los dos PCs, pero pueden ser accedidos desde cualquiera de los ordenadores. Como veis, un montaje de lo más simple.
Y ahora viene mi pregunta: Cuando aplico un filtro desde el PC que contiene los datos, la respuesta es casi instantánea; pero cuando lo hago desde el otro PC, el filtro es lentísimo (hasta 5 segundos o más). Recuendo hace años, cuando una aplicación similar escrita en DOS/Clipper respondía con toda rapidez desde cualquier PC.
¿Qué puedo estar olvidando? ¿Alguna variable de entorno? ¿Algún Set en mi programa? ¿Tendré que compilar con algún switch en especial?
Alguien puede darme alguna idea al respecto? Gracias
Rafael
Posted: Thu Jul 26, 2007 2:49 pm
by Adolfo
Rafeal.
Revisa todo lo concerniente a velocidad de tu red, firewall, antivirus
Existen algunos antivirus que revisan TODO lo que sale o entra por la red, deshabilita los archivos DBF, CDX, o NTX y los FPT en el scaneo que hace el antivirus.
Pon a tu servidor como Pc de confianza en el Firewall de tu Pc cliente, no habilites DHCP, usa IP's fijas, que ambos esten en el mismo Grupo de trabajo, usa Switch en vz de Hubs, revisa _ de red y si es posible midelos.
bueno esas recomendaciones te puedo dar, lo ideal es tener un servidor de archivos para compartir tus dbf's, yo uso varios Linux con Samba y tengo hasta 37 Pc's accesando dbf's y cdx's en una lan y la velocidad es buenisima.
Eso nada mas, espero te sirva
Posted: Thu Jul 26, 2007 3:08 pm
by Rafael Clemente
Adolfo:
Muchas gracias por tu respuesta. A ese respecto:
a) Efectivamente, uso IP fijas, no DHCP
b) Utilizo un Switch
c) Ambos PCs están en el mismo grupo de trabajo
d) _ de red parecen en buen estado y como los dos PCs están uno junto a otro, no tienen más de medio metro cada uno.
Lo que me queda por revisar es lo del antivirus (Norton) y el firewall (el del Windows Xp SP2), que están instalados con los ajustes por defecto. Lo pruebo y te digo algo en este mismo foro.
Saludos,
Rafael
Posted: Thu Jul 26, 2007 3:30 pm
by R.F.
Rafael:
Recuerda que xHarbour copia los datos del ordenador donde los estas usando al ordenador remoto de la red, si a esto le metes un SET FILTER entoces eso es mas lento que el caballo del malo.
Recomendacion: si es forzoso que utilices SET FILTER, y solo tienes 2 usuarios conectados a los datos, utiliza el servidor LOCAL de ADS, hace un filtrado extremadamente rapido (con dbsetfilter) y es gratuito.
Posted: Thu Jul 26, 2007 3:32 pm
by Rafael Clemente
Adolfo:
He desactivado el antivirus y no he notadoninguna mejora en la velocidad de acceso.
He desactivado el Firewall de Windows y ahí sí que he creido aprecia una ligeríiiiisima mejora pero nada sustancial.
Me prefunto si el problema no estará en´la asignación de buffers o alguna variable interna o quizás en los switches de compilación.
Yo uso:
.prg.c:
c:\harbour\bin\harbour $< /O$@ /n/i..include;c:\harbour\include;c:\fwh\include;c:\fwh\include /p /gc
.c.obj:
c:\bcc55\bin\bcc32 -M -c -Ic:\harbour\include $<
Posted: Thu Jul 26, 2007 4:12 pm
by Rafael Clemente
René:
Ajá! Eso de usar un servidor local ya me suena mejor. Por favor:
a) Dónde me puedo bajar el servidor local de ADS (aunque sea de pago, si funciona, no me importaría comprar una licencia)?
b) Me podrías dar una idea de cómo usarlo? (He de modificar mi programa o simplemente instalar el servidor local. Y si he de modificar mi programa, en qué sentido?)
Muchas gracias
Rafael
Posted: Thu Jul 26, 2007 4:19 pm
by JoseLuis
Hola Rafael
Por ir delimitando.
Yo tengo los datos en un servidor, en una carpeta compartida que pertenece a un grupo de trabajo.
A mi se me vuelve extremadamente lento cuando tengo que buscar una cadena dentro de un campo por lo que, como tu dices, no hay mas remedio que utilizar set filter. Pero sólo en el caso de que desde cualquier pc se haya conectado a la misma dbf. Si hay un solo usuario conectado, el filtro va cien.
Esto no me pasaba en FW, luego tiene que ser por xHarbour.
He revisado todo lo anteriormente dicho y nada, sigue igual.
Saludos
Jose Luis
Posted: Thu Jul 26, 2007 5:08 pm
by Rafael Clemente
José Luis:
Efectivamente, cuando intento acceder a la misma tabla desde los dos PCs a la vez (por ejemplo, aplicando un filtro distinto desde cada uno)la cosa va lentísima.
También va muy lento aunque no haya filtro aplicado.
Y si sólo accedo desde un PC, el resultado es el que ya dije al principio: Desde el PC "servidor" va perfecto pero desde el otro, va bastante "pastoso". Si eso ocurre co una red cableada a 100 Mb, prefiero no pensar qué pasará si el enlace es inalámbrico...
Hasta ahora, la sugerencia de René parece la más sólida. Me estoy mirando
http://www.google.com/ads.htm, donde viene la cosa explicada en bastante detalle
No sé si encontraremos una solución pero por lo menos tranquiliza ver que no es sólo un problema mío...
Saludos
Rafael
Posted: Thu Jul 26, 2007 7:51 pm
by Antonio Linares
Rafael,
SET FILTER es muy lento. Usa un índice temporal creado con una condición, ó usa scopes
Posted: Thu Jul 26, 2007 9:54 pm
by Rafael Clemente
Antonio:
Efectivamente, SET FILTER es muy lento pero a veces no queda otro remedio. Creo que el problema no es el SET FILTER sino la "pastosidad" general en el acceso a tablas por red. Con el Set FILTER es muy evidente, pero también se nota esa lentitud al cargar el browse inicialmente o moverse de registro en registro.
Quizás la explicación de René es la que parece más lógica, pero antes de empezar a experimentar con ADS (o algo similar, si existe) quería saber si el problema se debía a algún fallo mío más básico: Algo que tuviera que ver con número de buffers, etc...
Si se te ocurre alguna otra idea para probar, me gustaría intentarlo, porque parece que este es un problema que afecta a más de uno en el foro.
Saludos,
Rafael
Posted: Thu Jul 26, 2007 9:54 pm
by JoseLuis
Hola Antonio
No encuentro otra forma de hacer lo siguiente mas que con set filter
Code: Select all
(aAlias[21])->( dbSetfILTER( {|| (ALLTRIM(Upper(@codibus)) $ Upper((aAlias[21])->Nombre))},'(ALLTRIM(Upper(@codibus)) $ Upper((aAlias[21])->Nombre))') )
Donde codibus es la cadena que debo buscar dentro del campo Nombre.
Saludos
Jose Luis
Posted: Fri Jul 27, 2007 6:23 am
by Biel EA6DD
Mi experiencia con Harbour en Red, sin usar ADS ni otra tecnologia C/S, es que funciona bastante bien(manejando tablas de mas de 500.000 registros,lineas de albaranes a fecha de hoy 1.759.700). Una solucion como ADS, tiene que ser mejor, pero entiendo que no necesaria para la mayoria de Pimes.
Yo tengo desterrados los Set Filter, casi siempre se puede encontrar una alternativa mas rapida.
En el ejemplo que pone Jose Luis, incluso una lectura completa del fichero DBF con memoread, puede que sea mas rapido que set Filter(En este foro, en el de ingles se ha comentado el tema hace tiempo, lo siento pero no tengo el link). Y para optimizarlo tener un indice sobre el campo que quieres realizar la comparacion, y hacer la bussqueda sobre dicho fichero, siempre mas pequeño que el DBF. Para hacerlo hace falta disponer de la estructura del tipo de indice usado, NTX o CDX. Por la red circula una funcion para NTX, WildSrch.
Posted: Fri Jul 27, 2007 7:21 am
by Loren
Rafael,
Por tus explicaciones, deduzco que el PC Cliente accede al PC Servidor mediante una "Unidad de Red" en el Acceso Directo en Windows. Si es así yo te recomiendo que conectes los usuarios directamente al servidor, por codigo fuente, osea que enrutes tus bases de datos directamente desde el programa. De esta manera tendras tantos EXEs como PC en tu RED, evitando saturar de memoria al Servidor y por consiguiente ganando velocidad.
Un saludo.
LORENZO Fdez.
Posted: Fri Jul 27, 2007 7:39 am
by Rafael Clemente
Biel:
El Set Filter es donde más se nota la lentitud (lógicamente!) pero no es el único sitio. EN general, todo el acceso es "pastoso", en especial al arrancar el programa, cuando parece que el TxBrowse se baja los 4000 registros antes de presentarlos. En todo caso, voy a buscar una alternativa al Filter a través de Scopes, que esos sí, funcionan razonablemente bien.
Loren:
Yo siempre instalo una copia del Exe en cada Pc y abro las bases de datos mediante un Use ("\\Servidor\Datos\MyDbf"). No suelo utilizar asignación de nuevas unidades de red como Z:, Y: etc. No sé si es a esto a lo que te referias...
Gracias a los dos
Rafael
Posted: Fri Jul 27, 2007 7:43 am
by pymsoft
Tengo el mismo problema que Rafael Clemente, (lo dije en un post hace algunos dias).
En varios clientes, o sea, varias redes con linux como servidor. Todas a 100 megabit, sin usar ningun set filter, y el problema es como los describe Rafael, si accedo desde un pc, no hay problema, pero si accedo desde 2 o mas pc's, se enlentece todo... Al moverse de registro en registro queda "pastoso", esa es la palabra. Supongo que tiene que ver con algo del DBFCDX, porque con clipper FW y la misma red, no sucede.
O sea, el mismo programa, con las mismas bases de datos con los mismos indices solo que compilado a 16 bits funciona mas rapido.
He cambiado de twbrowse, dejé de usar (despues de 6 años) el twbrowse de Hernán por el de FW porque es un 20% más rapido, lastima que le falten los footers al de FW y que la clase de pintado sea en prg en ves de C.
O sea, no es un problema de la twbrowse, pero es un problema cuando se visualizan los datos, porque verás que si te toca recorrer la base de datos, con indices y set filters y todo lo que sea, lo hace muy rapidamente.
Saludos.