Este proyecto está basado en una actividad laboral 100% real ya que se requirió realizar una conexión a de base de datos con informix desde php. Para esto se tomó la decisión de usar pdo por lo que informix tiene una forma bastante sutil (fea 🤯 🤯 ) de crear un pdo_informix.so.
Con este contenedor se pueden realizar conexiones a bases de datos de tipo informix y hasta este momento (19-septiembre-2020)
funciona de forma correcta. Lamentablemente por cuestiones de tiempo se creó una imagen algo pesada(monstruo)
, que espero poder mejorar si el tiempo me lo permite.
La imagen es pesa 1.33GB
😱_ aproximadamente ya que se crea con una imagen de ubuntu18.04 y dentro de esa imagen se realizan todas las instalaciones requeridas:
- Actualizaciones de ubuntu
- Instalación de Apache
- Instalación de php7.2
- Instalación de diferentes módulos de php7.2
- Instalación de CSDK-informix (Client sdk de informix)
- Instalacion y creacion de pdo_informix.so
Al parecer la mejor forma de realizar esta conexión es usando Apache
ya que intentamos con Nginx
y no lo logramos esto puede ser a un desconocimiento del uso de Nginx (perdón😥 😓).
Si tienes alguna duda o mejora que quieras compartir no dudes en contactar.
Para la generación del paquete se requieren los siguientes paquetes:
- ibm.csdk.4.50.FC1.LNX.tar Para este paquete toma en cuenta el apartado de abajo.
- PDO_INFORMIX-1.3.3.tgz
Los links son drive espero nunca se borren esos paquetes en caso de que eso pase los podras descargar de la página de IBM 🧟 🧟♂️ 🧟♀️.
Lamentablemente el paquete ibm.csdk.4.50.FC1.LNX.tar
pesa casi 200 MEGAS, por este motivo si buscas en la carpeta ibm solo veras un info.txt que te explica lo mismo que aquí 🤪.
Usa el link de descarga del paquete de ibm.csdk.4.50.FC1.LNX.tar, en cuanto descargues coloca ese paquete en la carpeta ibm. Recuerda no cambiar el nombre o la extensión ya que la instalación se hace con ese mismo archivo.
En tu terminal dirígete a la raíz de este proyecto donde debes ver el archivo Dockerfile y docker-compose.yml, si no estás en esa carpeta ya te pasaste y debes dar vuelta en el siguiente retorno 😅.
Si ya descargaste e csdk ya solo tienes que iniciar la creación de la imagen:
docker-compose up -d
El proceso de la creación es muy tardado si gustas ve por un café ☕️ y convive con las personas que dicen ser tu familia 👨👩👧👦, espero que te caigan bien.
Si todo resulta correcto verás una respuesta como esta:
Si revisas el docker-compose.yml verás en la parte final un apartado llamado ports donde le decimos a docker que las personas normales acceden desde el puerto 9001 y los redirige al puerto 80 de docker.
Tambien puedes ver esto si ejecutas un:
docker ps
En mi caso particular trabajo con una máquina virtual de virtualbox que está en otra máquina. Lejos de mi pero en la misma red.
Por lo que tengo que configurar el reenvío de puertos como NAT en la máquina virtual.
Si estás ejecutando el docker desde tu misma máquina seguramente tendrías que acceder desde tu misma tu_ip:9001 o localhost:9001.
En caso de que también uses una maquina virtual te dejo unas imagenes de como tengo configurada mi maquina virtual.
Por lo tanto para acceder lo hago con esta ruta en mi navegador:
Al acceder vere lo siguiente:
Hay 3 archivos:
- info.php (Solo es la pagina de informacion de php para ver sus paquetes)
- informix.php (Solo es un ejemplo de conexión si la conexión es correcta solo lo dice)
- informix1.php (Es una consulta que imprime el objeto de la consulta)
Por lógica tienes que cambiar los datos de conexión ya que en el repositorio solo dejare textos de ejemplo.
En el info.php solo debes buscar todo lo que dice informix que es lo que básicamente debe cumplir para poder realizar conexiones.
Espero que todo esto te ayude y de verdad espero actualizar este repo.
Larga vida y prosperidad 🖖 🙂