Conectar FB en red (2)
Después de la gran ayuda que me habéis prestado en otros dos hilos anteriores (Conectar Firebird en red y Conexión en red a FB) vuelvo a la carga porque me surgen nuevos problemas que por másvueltas que doy no soy capaz de solucionar.
1. Un puesto de la red no se conecta La aplicación está instalada en una red con tres puestos y un servidor dedicado. En éste última, además del motor y la base de datos, está instalado el programa más que nada por seguridad. Los parámetros para conectarse a la base dedatos están guardados en un fichero INI como este, idéntico para todos los puestos: Cita:
Código PHP:
Cita:
2. Guardar ficheros desde programa En prácticamente todos los listados que genera la aplicación doy diferentes posibilidades de salida: Pantalla, Impresora, Exportar a PDF, a Excel, a Word o a texto. Para las opciones que generan ficheros lo hago a través de esta función: Código PHP:
Cita:
Cita:
|
Ángel, para empezar te recomiendo lo mismo que te he indicado en otras ocasiones, porque es lo más directo, seguro y eficiente (IP, unidad física, ruta completa hasta la base de datos):
192.168.1.100:D:\datos\labasedatos.fdb Lo de compartir la unidad del servidor, no sirve para nada, cuando un cliente se conecta al servidor lo que hace es enviar peticiones por el puerto 3050 (o el que configures) y es el servidor de bases de datos el que está escuchando ese puerto para hacer lo que se le pida y devolver los datos por ese mismo puerto. NO interviene para nada unidades de red, carpetas compartidas ni nada de eso. A partir de ahí, para estar seguro, seguimos probando ;) |
Hola, como te comentan y es muy importante que se entienda como trabajan los motores y servidores de bases de datos:
Access, dbase, paradox, sqlite (los que conozco): estos se conectan al archivo directamente por lo que es necesario tener permisos de lectura escritura directa, en el caso del servidor es necesario configurar un directorio de red con todos los permisos. Firebird, MySQL, MsSql, posgresql, oracle (servidores de base de datos): estos son servidores como tal por lo que el acceso es directo y este lo proporcionan mediante un puerto, imagina que quieres compartir la conexion de mysql a nivel mundial (muy usado aunque no recomendado), en este caso no podrias compartir un directorio y en el caso no te serviria de nada, firebird al igual que los otros mencionados sirve desde un puerto y la ruta la utiliza para acceder localmente al archivo de base de datos (otros motores no requieren la ruta en el servidor), que quede claro que el servidor firebird toma la direccion o nombre del servidor (//servidor01 o //localhost o //192.168.1.25) y la ruta que pareciera local la ocupa internamente para acceder al archivo pero esto solo lo hace el servidor mas no el cliente. Como te menciona Casimiro es importante que pongan un direccion de red valida y visible desde los equipos de tu red, puedes validar si estan en dominio, si estan en el grupo de trabajo o si se encuentran en el mismo nodo de red, el punto es que el equipo sea visible (prueba haciendo ping o telnel al puerto). Otro punto importante es que debes tener la librerias correspondientes del cliente y algo que siempre recomiendo es que se tenga un cliente standar (heidisql, ems firebird, navicat) y recomiendo aunque no me pagan por ello el dbeaver (http://dbeaver.jkiss.org). Saludos. |
Gracias por vuestra ayuda. Mañana sin falta haré la prueba. Otra pregunta: Si empleo la sintaxis que me recomendáis (IP, unidad física, ruta completa hasta la base de datos), ¿es necesario incluir el puerto de conexión? Es decir, ¿quedaría así?
Cita:
|
Yo nunca pongo el puerto porque el 3050 es el predeterminado (está guardado en el fichero del sistema), así que nunca vas a necesitar indicarlo. Salvo que lo hayas cambiado, claro.
Además, según creo recordar, usas BCB, por lo que la sintaxis de las barras creo que era poniendolas dobles: 192.168.1.100:D:\\datos\\labasedatos.fdb Pero eso la sabrás tú mejor que yo. |
Cita:
|
Cita:
|
Si un equipo conecta y el otro no conecta, está claro que el problema es el equipo que no conecta, ¿firebird cliente instalado, antivirus, firewall, etc.?
|
El cleinte está instalado, aunque ya empiezo a dudar que lo haya hecho de forma correcta. El firewall tiene autorizado tanto al programa como a los puertos. El antivirus no me da ningún aviso pero no me he dado cuenta de comprobarlo; lo haré mañana. :(
|
Lo que no veas, no te lo creas.
Y de lo que veas, créete solamente la mitad. |
^\||/ Totalmente de acuerdo
|
El tema del telnet es probar la conectividad, si no hay respuesta de telnet o ping pues ese es el problema y deberias de revisar si los equipos se encuentran en la misma red, si tienen acceso o si hay algun problema de red.
|
Cita:
|
Cita:
|
Cita:
|
Cita:
CLIENTE: Los clientes únicamente hacen peticiones a una IP, por un puerto (predeterminado el 3050), se acabó, los clientes no necesitan saber más. (En todo caso la ruta a la base de datos, si no se usa alias). 192.168.1.100:c:\datos\basedatos.fdb SERVIDOR: El servidor está oyendo el puerto 3050, recibe una petición, la procesa y responde por el mismo puerto. Se acabó. Por lo tanto, los clientes no necesitan saber nada más. Por lo tanto, el servidor no tiene que compartir NADA. Eso es todo. Si no hay conexión con la base de datos, es por otro motivo: no está funcionando el servidor, no está funcionando el cliente, está el cable roto, está cortando la conexión el firewall, el antivirus, etc. |
Ok. Gracias.
|
Creo que al final estas quedando en las mismas, el acceso mediante red (TCP IP) no es lo mismo que el acceso a puerto 3050 en este caso, que es lo que te comentaba y para eso te indico que uses el telenet o el cliente alternativo como navicat, ems u otro mientras esto no te quede claro no vas a entender bien tu problema.
Puede que tengas acceso al directorio compartido y no tengas acceso al puerto 3050 (bloqueado por firewall, antivirus o cualquier cosa), al final al firebird le vale chetos si ves o no el directorio de red pues el no lo ocupa. Asi sencillo baja el dbeaver configura una conexion y si tienes un problema al configurar o conectar pues checa los puertos de entrada y salida en el cliente puesto que indicas que otros equipos si se pueden conectar al servidor (ahi no esta el problema). No te compliques tanto las pruebas son simples. Saludos. |
Gracias por la sugerencia. He descargado la aplicación que me indicas y veo que, básicamente, es similar a EMS SQL Manager. Sin embargo estoy teniendo un problema para utilizarla.
Al configurar la conexión me identifica correctamente la base de datos pero cuando trato de abrirla me sale este mensaje de error. Por más vueltas que he dado sólo encuentro un sitio en el que indicar el valor del charset, en esta pantalla de las propiedades de la conexión: Pero a pesar de todo no consigo conectar la base de datos. |
No se ven las imagenes, el charset iria por default a menos que tu configuraras algo distinto en tu base de datos.
Saludos. |
Vale. A ver si ahora se ven las imágenes.
El mensaje de error es este: Y la pantalla de configuración a la que hago referencia es esta: El charset de la BB.DD. es ISO8859_1. No obstante, y ya además de perplejo empiezo a estar harto, acabo estar comprobando al instalción y aparentemente los dos equipos están configurados igual; miedo me da cuando tenga que instalar la aplicación en un tercer equipo que hace falta. Tengo que hablar con la persona que les lleva el mantenimiento de la red para tratar de averiguar que demonios pasa. |
Y si sustituyes el charset que sale en la pantalla (utf-8) por el que tiene la base de datos (iso8859_1, según dices) ¿tampoco conecta?
|
Tampoco. Me da el mismo error.
|
Y siogo sin poder resolver el otro problema que planteaba al prinicpio, el de exportar los listados a la unidad de red.
|
Se supone que el cliente firebird es la misma versión que el servidor... y también se supone que la base de datos está creada con la versión de firebird instalada.
No sé, la cosa es demasiado simple y sencilla, ¿seguro que ese ordenador funciona y no tiene virus ni cosas raras? Cable de red tendrá, ya es por decir cualquier obviedad. |
Cita:
|
Cita:
Cita:
El equipo tiene instaldo antivirus y está actualizado. Y funciona a la perfección. La base de datos está creada en mi equipo (problemas de migración) pero con la misma versión del motor en ambos equipos. Acaso la única diferencia es que en el servidor está instalada la versión de 64 bits y en los puestos la de 32, pero vuelvo a lo de antes: desde uno de los equipos sí se conecta sin ningún problema y desde el otro no. Cable de red claro que sí; de otra forma no "vería" el servidor. Además la aplicación antigua, que corre con tablas Paradox, funciona a la perfección. :) |
En ese segundo punto, el de exportar los ficheros, modifiqué el código de forma que primero se crea el informe en la carpeta temporal y luego se debería copiar en la que se gaurdan todos los informes. He modificado el código dejándolo así:
El fichero en que inicialmente se guarda lo monto así: Código PHP:
Código PHP:
|
¿Y al final cómo quedó esto?
|
Cita:
|
La franja horaria es GMT +2. Ahora son las 02:59:10. |
Powered by vBulletin® Version 3.6.8
Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
Traducción al castellano por el equipo de moderadores del Club Delphi