FTP | CCD | Buscar | Trucos | Trabajo | Foros |
|
Registrarse | FAQ | Miembros | Calendario | Guía de estilo | Temas de Hoy |
|
Herramientas | Buscar en Tema | Desplegado |
#1
|
||||
|
||||
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:
|
#2
|
||||
|
||||
Á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
__________________
La otra guía de estilo | Búsquedas avanzadas | Etiquetas para código | Colabora mediante Paypal |
#3
|
|||
|
|||
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. |
#4
|
||||
|
||||
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:
|
#5
|
||||
|
||||
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.
__________________
La otra guía de estilo | Búsquedas avanzadas | Etiquetas para código | Colabora mediante Paypal |
#6
|
||||
|
||||
Muchas gracias. Probaré y os diré como ha ido.
|
#7
|
||||
|
||||
Vengo ahora mismo de probarlo y sigue dando el mismo error.
|
#8
|
||||
|
||||
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.?
__________________
La otra guía de estilo | Búsquedas avanzadas | Etiquetas para código | Colabora mediante Paypal |
#9
|
||||
|
||||
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.
|
#10
|
||||
|
||||
Lo que no veas, no te lo creas.
Y de lo que veas, créete solamente la mitad.
__________________
La otra guía de estilo | Búsquedas avanzadas | Etiquetas para código | Colabora mediante Paypal |
#11
|
||||
|
||||
Totalmente de acuerdo
|
#12
|
|||
|
|||
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.
|
#13
|
||||
|
||||
Están en la misma red, seguro. Desde ambos puestos se tiene acceso, vía explorador, a la carpeta en la que está la base de datos.
|
#14
|
||||
|
||||
Cita:
__________________
La otra guía de estilo | Búsquedas avanzadas | Etiquetas para código | Colabora mediante Paypal |
#15
|
||||
|
||||
Pues efectivamente: Me he perdido. Yo entiendo que si desde los puestos puedo acceder a la carpeta en la que se encuentra la base de datos, el programa debería acceder suponiendo que como comentabas ayer esté bien instalado el cliente FB, abiertos los puertos, etc. Mi respuesta venía por el comentario de bitbow.
|
#16
|
||||
|
||||
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.
__________________
La otra guía de estilo | Búsquedas avanzadas | Etiquetas para código | Colabora mediante Paypal |
#17
|
||||
|
||||
Ok. Gracias.
|
#18
|
|||
|
|||
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. |
#19
|
||||
|
||||
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. |
|
|
Temas Similares | ||||
Tema | Autor | Foro | Respuestas | Último mensaje |
Conectar y re-conectar por TCP | jars | Varios | 0 | 10-08-2012 20:04:35 |
Conectar dos pc en red | Caral | Linux | 4 | 10-05-2010 01:20:36 |
Conectar Mi TV a mi PC | rgstuamigo | Varios | 18 | 16-10-2008 01:26:38 |
Conectar a DBF | jocey | Conexión con bases de datos | 3 | 28-02-2008 20:39:01 |
Conectar | trex2000 | Conexión con bases de datos | 1 | 04-10-2003 02:57:56 |
|