Setup DBMarlin server
Prerequisitos
- Revisar plataformas soportadas Linux y Windows (https://docs.dbmarlin.com/docs/Getting-Started/supported-platforms)
- Para este laboratorio utilizaremos un servidor Ubuntu 22.04.3 LTS.
- Instalar net-tools para validar disponibilidad de puertos 9070, 9080 y 9090.
# Install if needed RHEL or Centos
sudo yum install net-tools
# Install if needed Ubuntu
sudo apt-get install net-tools
netstat -na | grep LISTEN | grep 9080
netstat -na | grep LISTEN | grep 9090
netstat -na | grep LISTEN | grep 9070
-
Crear usuario y grupo dbmarlin
useradd dbmarlin mkdir /opt/dbmarlin chown -R dbmarlin:dbmarlin /opt/dbmarlin
-
Descargar instalador desde la web https://download.dbmarlin.com
Instalación
-
Loguearse con el usurio dbmarlin para descomprimir e inciar la instalacion.
-
Descomprimir en la ruta /opt
dbmarlin-Linux-x64-[VERSION].tar.gz
cd /opt
tar -xzvf dbmarlin-Linux-x64-[VERSION].tar.gz
- Ingresar a la ruta donde se descomprimio el instalador e instalar de acuerdo a como se muestra.
cd /opt/dbmarlin
./configure.sh
Press Enter then space bar to scroll
...
Do you accept the agreement Y/N ? y
Done.
Set port for Nginx (current 9090): 9090
Set port for Tomcat (current 9080): 9080
Set port for PostgreSQL (current 9070): 9070
See https://docs.dbmarlin.com/docs/Getting-Started/server-installation/hardware-requirements for Profile sizes
1) XSmall
2) Small
3) Medium
4) Large
5) Xlarge
Choose the profile [1-5]: 2
Small profile selected
Recommended RAM is 4GB. You have 4G
Continue Y/N ? y
Configuring DBmarlin now...
Changing Nginx port from 9090 to 9090
Changing Tomcat port from 9080 to 9080
Using profile Small
All done!
Use ./start.sh to startup the DBmarlin services
- Iniciar servicios del DBMarlin server.
cd /opt/dbmarlin
./start.sh
- Verificar estado de servicios.
cd /opt/dbmarlin
./status.sh
nginx (Running)
tomcat (Running)
postgres (Running)
Componentes:
Azure Kubernetes service:
- Base de Datos Mysql contactos(tabla emails)
- Aplicacion Frontend en nodesjs para consulta y registro de contactos.
- DB Marlin agent desplegado en kubernetes.
Virtual Server:
- DB Marlin server implemementado en los pasos anteriores
Procedimiento:
-
Los recursos seran desplegados dentro del namespace default.
-
Aplicar la configuracion de base de datos.
kubectl apply -f database.yaml
-
Aplicar la configuracion del fontend.
kubectl apply -f frontend.yaml
-
Aplicar la configuracion del agente DB Marlin ( Reemplazar la ip publica del servidor DB Marlin y aplicar la configuracion, para este ejemplo es la ip 163.107.83.92 )
kubectl apply -f marlin-agent.yaml
-
Verificar recursos desplegados:
kubectl get all
-
Ejecutar la validacion para la ip publica del frontend, en el ejemplo 20.171.241.74
Operación GET para listar los contactos registrados
Operación POST para registrar nuevos contactos
-
Para realizar el monitoreo mediante el agente DB Marlin en la BD Mysql se requiere de la creacion de un usuario con los permisos de lectura sobre las bases de datos. Para ello ingresar al pod de la BD y ejecutar las siguientes sentencias. documentacion
*Colocar el nombre del pod mysql correspondiente en su ambiente. kubectl exec -it mysql-5b8854c844-74vrv -- bash mysql -u root -pP4ssw0rd CREATE USER dbmarlin IDENTIFIED BY 'securepassword'; GRANT SELECT,PROCESS,SHOW DATABASES on *.* to 'dbmarlin'@'%'; GRANT REPLICATION CLIENT ON *.* to 'dbmarlin'@'%'; FLUSH privileges;
-
Registrar la BD Mysql en la consola de DB Marlin y configurar el monitoreo mediante el agente DB Marlin previamente desplegado en el cluster AKS.
- Configurar la extension de DB Marlin en su navegador web Edge o Chrome. Colocar la url del servidor DB Marlin como se muestra en la imagen.
- Verificar las trazas capturadas en instana y ubicar las sentencias SQL donde se mostrara el icono que enlaza instana con DB Marlin para obtener mayor detalle a nivel de base de datos.