01/09/2011

El hardware costoso en las PYMES y la mala Arquitectura de Software


Salvo rarisimas ocasiones la compra de hardware costoso en las PYMES (Pequeñas Y Mediamas Empresas) es justificable, esto pasa mas comunmente cuando se adquiere un software mal diseñado y peor programado. En estos casos son los propios desarrolladores del sistema quienes sugieren la compra de un hardware 'moderno' que sea compatible a su sistema.

A continuacion relatare algunas experiencias de campo:


CASO 1

- En alguna ocasion visite un supermercado que apenas tenia 4 cajas, y algunos usuarios administrativos, dando un total de 10 usuarios en la red. La queja era: "El sistema es muy lento, a pesar de seguir las indicaciones del fabricante del software, sigue siendo muy lento". A este negocio lo hicieron adquirir las computadoras mas rapidas del mercado en esa epoca (3.2 Ghz & 1 Gb RAM) para las cajas y un servidor de marca conocida con bastante memoria y un buen procesador. Los cajeros se quejaban que incluso al vender, en el momento de escanear un producto tardaba un par de segundos en traer el resultado; a veces mas. El area de soporte tuvo la idea de aumentar la memoria al servidor lo cual por supuesto no mejoro absolutamente nada la situacion.


¿Cual era el problema?

En realidad era un problema bastante comun y facil de detectar para cualquier arquitecto de software, su manejador de bases de datos estaba basado en archivos (punto a punto) lo cual hacia que la busqueda de informacion y en general todo el motor de la base de datos se encontrara del lado del cliente (en las cajas), esto hacia que se trasladaran grandes cantidades de datos y el cuello de botella fuera la red, basta recordar que el limite que imponen las redes de 100 mbps (12 mb por seg.aprox) se distribuian entre los 10 usuarios. Por esto el aumentar la memoria del Servidor no servia de nada, ya que este se limitaba a compartir la carpeta donde se localizaban los archivos de la base de datos, asi que lo unico que hacia era 'prestar' el disco duro. Todo esto, con el costo en velocidad y seguridad que representaba.

Las unica sugerencias que se podia dar era:
   1) Cambiar el sistema por uno con arquitectura cliente-servidor
   2) Aliviar la situacion agregando una tarjeta de red al servidor y distribuyendo los usuarios entre ellas, y; si habia la posiblidad agregar un arreglo de discos (raid 0)



CASO 2

Una PYME con 10 usuarios en la red, 7 usando un software empresarial el cual esta bastante lento. La excusa de los 'expertos' fue la misma de siempre: "la base de datos es muy grande y son muchos usuarios". El administrador del sistema me muestra un servidor muy robusto, de marca reconocida incluso con sistema redundate (doble fuente de poder y doble tarjeta madre). Tenian reportes que se obtenian en 20 mins. A mi parecer ese servidor debia ser suficiente para dar servicio agilmente a 100 usuarios (con el software correcto).

En este caso el software si era cliente-servidor pero hacian un uso muy pobre del lenguaje SQL; en donde en lugar de enviar una consulta que obtuviera los datos desde todas las tablas que se requerian, relacionandolas adecuadamente. Para un solo reporte se enviaban centenares de consultas con el resultado ya descrito.

La solucion logica era pedirles al equipo de desarrollo optimizar sus consultas adecuadamente.



CASO 3 (Mi cliente)

Una comercializadora mayoristas con una pequeña red de 12 usuarios, funcionando alrededor de 9 años con una base de datos de poco mas de 1 gb., un Servidor HT 3.2, con 2 gb de RAM, Disco SCSI 2, Red 100 mbps. Todo iba bien hasta que el servidor empezo a fallar al encenderlo (se apagaba al final del dia y se encendia a las 5 am aprox. al iniciar operaciones). Para la revision del servidor les prestamos un equipo bastante modesto, era un equipo sin marca de los conocidos como 'clone' de apenas 1.8 Ghz y 512 de RAM.

Revisamos el servidor y se determino que el problema era que se perdia la configuracion de los dispositivos en el 'bios'; entre ellos el disco duro y por eso no podia arrancar, se cambio la bateria y funciono sin problemas. Despues de algunos dias de pruebas se devolvio al cliente y se regreso la base de datos.

Mi primer pregunta al gerente general fue si notaron que el sistema se volvio mas lento, a lo cual respondio que no hubo diferencia; por demas sorprendido fui a las cajas y pregunte a los usuarios y algunos indicaron que ni siquiera sabian que nos habiamos llevado el servidor.

En realidad yo esperaba que la diferencia no fuera grande, pero nunca imagine que a ese nivel de uso (10 usuarios) no se notara diferencia alguna. A la fecha fue el ultimo soporte tecnico a casi 2 años de ocurrido y las visitas posteriores han sido para agregar usuarios y funcionalidad al sistema.



 Mi Oficina

- En mi propia empresa hasta hace dias contabamos con un 'servidor' que adquiri seminuevo con uno de mis proveedores hace alrededor de 4-5 años, era una PC Pentium a 2.4 Ghz, 512 RAM y 40 Gb en disco , el cual mejoramos a 2 Gb de RAM y 250 Gb de disco. Esto era suficiente para tener instalado Windows Server 2008, SQL Server 2008, Sharepoint y por supuesto manejar nuestra base de datos empresarial (ventas, compras, inventarios, facturacion). Ademas nuestro pequeño servidor tenia instalado un sistema de vigilancia con 4 camaras, guardando la grabacion las 24 hrs en el mismo disco duro.
Equipo exacto que teniamos como servidor

Solo fue hasta hace dias que cambiamos a un servidor de 2 nucleos, y esto no fue motivado por necesidades de procesamiento, ni almacenamiento. Mas bien, se determino que despues de cambiar impresora laser y adquirir una mas a color, el unico equipo antiguo era el servidor y se planeaba aumentar el uso de el, instalando aplicaciones como Visual Studio Team Server.



CONCLUSIONES

Desde una optica tecnica muy simple; si una consulta a mi base de datos para obtener las ventas del dia (folio, cliente, importe, impuestos, condiciones de pago) me toma 30 ms y procesar 2 peticiones simultaneas de este proceso aumenta un 50% (1) el tiempo de ambas consultas  a 45 ms c/u, dando un total de 90 ms, aumentando exponencialmente con cada consulta simultanea que se procesa, supondria que con una decena de usuarios lo maximo que puede ocurrir es que todos ellos requieran una consulta al mismo tiempo, justo en el mismo segundo. En donde para tal caso obtener el resultado tardaria un par de segundos o unos cuantos a lo maximo.

Parece que ultimamente hacen falta arquitectos, hay muchos programadores, pocos son buenos y menos son buenos arquitectos. Creo que la comprension del hardware es lo que permite optimizar y generar aplicaciones que sepan aprovecharlo. Por otro lado, la mayoria se arroja a aprender un lenguaje de programacion, sin haber entendido antes la plataforma y filosofia en la cual estan basados.

Hasta ahora en las PYMES con datos muy 'relevantes' o con mayor transacionalidad la solucion que adoptamos para asegurar sus datos ha sido agregar un disco duro, al cual se acumulan un par de respaldos por dia, con lo cual en caso de perdidad total del disco duro en produccion,  se volverian a capturar los registros de ventas, compras, inventarios, cobranza, bancos, de medio dia de operacion, lo cual dificilmente supera el medio millar de transacciones distribuidos entre una docena de usuarios.

Por supuesto que aqui nos referimos exclusivamente al procesamiento de datos empresariales, puede haber excepciones, donde una PYME requiere procesador video, renderizar, o diseños arquitectonicos que justifiquen tal gasto. Dicho esto, hoy en dia los equipos 'basicos' disponibles en el mercado tienen una capacidad de procesamiento muy por encima a los requerimientos de la mayoria de las PYMES.

Cuando me consultan sobre los requerimientos de equipo para algun sistema de mi autoria, la respuesta tipica es: "el equipo nuevo mas pequeño en capacidad esta sobrado para los requerimientos" o "cualquiera que tenga windows XP y 512 de RAM".

No existe una regla para indicar el gasto maximo en equipos para un sistema, pero siempre desconfie de alguien que de entrada pide renovar todo el equipo. Recuerde: "UN SISTEMA DESARROLLADO CORRECTAMENTE REQUIERE MENOS EQUIPO YA QUE TRASLADA LA MAYOR CARGA DE PROCESAMIENTO AL SERVIDOR".


(1) El aumento de un 50% por cada consulta simultanea que se suma a la ejecucion, es un dato hipotetico.
 * Se omiten acentos intencionalmente.

13/09/2010

Dia del Programador

Apenas hoy me entere que es dia del Programador, esto por ser el dia 256 del año, o lo que es lo mismo 2^8, y hasta sitio web existe: http://www.programmerday.info/

Por cierto tambien es mi cumpleaños.

25/05/2010

SQLBk

Hoy he terminado mi herramienta SQLBk, la cual se encarga de realizar respaldos de bases de datos SQL Server, comprimiendolos y enviandolos a un servidor FTP.

La version gratuita respaldar bases de datos de cualquier tamaño y las comprime en formato .gz (se abre con WinZip y Winrar) sin opcion de transferirla por FTP.



La funcionalidad es por demas sencilla, simplemente ejecutamos el archivo SQLBk.exe y se abre la ventana de la foto anterior, donde se configuran los parametros de conexion a la instancia de SQL Server, asi como el servidor FTP. En el boton aceptar se guardan los parametros y se cierra el programa.

Posteriormente se ejecuta SQLBk con el parametro /Respaldar para realizar un respaldo en modo oculto, comprimirlo y subirlo a un servidor FTP (version enterprise)

Una herramienta sencilla, ligera, que realiza una tarea repetitiva sin esfuerzo alguno.

Haz clic aquí para descargar la versión gratuita de SQLBk 1.0

05/04/2010

Lanzamiento de VS2010 & Azure

En esta ocasion estoy invitando a los desarrolladores, estudiantes y empresarios del software al evento de lanzamiento de Visual Studio 2010 y Azure, donde se mostraran las nuevas caracteristicas de VS2010 que permiten obtener mayor productividad y uso de caracteristicas especificas de Windows 7. Por otro lado se mostrara la plataforma de Microsoft para el modelo Software como Servicio (SAAS), la cual es una tendencia en el futuro que vendra a complementar el modelo de computacion actual.

El evento es en:
Universidad Autonoma de Nayarit
Auditorio de la Biblioteca Magna
Ciudad de la Cultura "Amado Nervo"
Tepic, Nayarit

Regístrate haciendo clic en el siguiente banner:



15/10/2009

Reunion de la comunidad .NET Tepic 15/oct/2009

Este jueves 15 de Octubre a las 7 pm, la comunidad .NET Tepic invita a su reunion, donde se mostraran caracteristicas de optimizacion en SQL Server 2008, la dinamica sera un poco diferente a otras reuniones, pues en esta ocasion se pretende ser un poco mas practica, es por eso que se realiza en las instalaciones de Quantum Soluciones.


La cita es en:
   Av. Sauces #10
   Frente al parque del Fracc. Castilla
   Col. 26 de Septiembre
   Tepic, Nayarit, Mexico

Registro al evento:
http://msevents.microsoft.com/CUI/EventDetail.aspx?EventID=1032429448&Culture=es-MX

Aqui el mapa de la ubicacion:
http://maps.google.com/maps?f=q&source=s_q&hl=es&geocode=&q=quantum+soluciones&sll=37.0625,-95.677068&sspn=54.269804,78.662109&ie=UTF8&hq=quantum+soluciones&hnear=&ll=21.470862,-104.882054&spn=0.015755,0.019205&z=16&iwloc=B

14/08/2009

Techdays 2009

Este jueves 13 de Agosto de 2009 asistí a Guadalajara al evento 'TechDays 2009', tenia dias registrado y esperaba ansioso la fecha, asi que hice preparativos y conduje por casi 3 hrs desde Tepic.

Antes de salir al evento converse por el mensajero con Jaime Sanchez, orador de Microsoft y Coordinador de comunidades Mexico, me comento que estaria presente en el Techdays en Guadalajara y platicariamos sobre su presencia en la ciudad de Tepic para algun evento de la comunidad .NET o algo especifico de Microsoft.

Asi pues, esperaba encontrarme con el, pero mi sorpresa fue mayor cuando me di cuenta que era uno de los 2 oradores del evento. En el cual dio informacion muy especifica de Windows 7, tanto para usuarios como desarrolladores, ademas mostro algunos tips y funcionalidad muy interesante respecto a desarrollar aplicaciones optimizadas para el ahorro de energia, respondiendo a eventos desde Servicios Windows.

Por otro lado la otra conferencia fue de Azure, para mi fue muy familiar pues ya habia asistido con anterioridad a un evento en linea de Microsoft, pero aun asi, se mostraron demos donde vi funcionalidad especifica y como utilizar los templetes de Azure en VS 2008.

Me retire de Guadalajara por la noche, finalizando este evento, llevandome la satisfaccion de presenciar 2 temas de mucho interes y que en los proximos dias marcaran el rumbo de la tecnologia. Ademas del compromiso por parte de Jaime para visitarnos a Tepic en los proximos meses.

03/08/2009

El baul de Visual Basic 6.0

Suguiendo en la revision de archivos viejos, encontre el instructivo del curso Visual Basic 6 que imparti hace ya algunos lustros. Al igual que el de Access, deseo ponerlo a la disposicion de cualquier persona que pueda serle de alguna utilidad.

Aqui el link de descarga:

http://ds.aortiz.net/descarga/manvb6.pdf

31/07/2009

El baul de Access

Ya son cerca de 14 años que inicie a desarrollar aplicaciones en Microsoft Access, por alla en 1995 conoci Access 2.0 y me agrado su interfase agil para creacion de aplicaciones, tuve una gran ventaja incluso sobre otras personas que ya lo utilizaban y quienes me apoyaron al inicio, gracias a mis conocimientos de Visual Basic 2.0, en especifico en la parte de codificacion. Eso, y que ademas yo venia de programar en lenguaje C, lo cual era un poco mas complejo.


Recordando esto, saque del baul de los recuerdos una guia que inicie poco despues de esa fecha, cuando inicie a impartir cursos a programadores que deseaban aprender a programar en Access. Al final la guia se quedo en Access 2000.

Así pues, aqui queda disponible esta guia para cualquier interesado en ella.
http://ds.aortiz.net/descarga/Manual%20Access%202000.pdf

Reproduzco el indice de esta guia:

Introduccion
I. Tablas
II. Consultas
III. Formularios
IV. Reportes
V. Macros
VI. DAO: Objeto de Acceso a Datos
VII. Distribucion de la Aplicacion
Temas Avanzados: API, DCOM, Cliente-Servidor


En mi trabajo profesional Access me ha dado muchas satisfacciones, y he logrado instalar miles de aplicaciones comerciales, la mayoria utilizando SQL Server como Back End, ahora que estoy cambiando totalmente de plataforma de desarrollo empezare a comentar mi experiencias y si encuetro cualquier recurso lo compartire con gusto.

15/05/2009

Festival de Instalacion Internet Explorer 8



Nuestro proximo evento es el festival de instalacion de Internet Explorer 8, el cual es coordinado a nivel mundial por Microsoft y será replicado en Tepic.

- Fecha: 16/Junio/2009
- Lugar: Laboratorio 1 de la Facultad de Economia, UNIVERSIDAD AUTONOMA DE NAYARIT


Para asistir al evento puedes registrarte (sin costo) e imprimir tu pase en esta direccion: http://www.microsoft.com/mexico/festivalie8/

El evento es gratuito y se regalaran souvenirs y discos donados por Microsoft para este evento

03/02/2009

Evento Silverlight


Ya paso bastante tiempo desde este evento y no habia tenido tiempo de subir informacion sobre el. En esta ocasión tuvimos la fortuna de contar con Rodrigo Diaz, uno de los mejores expertos en latinoamerica en el tema de Silverlight.

Una platica interesante donde explicó la arquitectura de silverlight asi como las posibilidades que nos brinda como desarrolladores y mejora de experiencia.

Las demostraciones y prácticas fueron muy completas, realmente despejo cualquier duda al respecto y nos motivo a emprender el camino para adoptar esta tecnología.

Por otro lado los profesores y directivos de la Universidad Autonoma de Nayarit, se vieron complacidos de contar con este tipo de eventos en sus instalaciones y le extendieron un reconocimiento a nuestro amigo Rodrigo, invitandolo a estar presente en un evento proximo de la UAN.

Los miembros de la comunidad .NET Tepic quedamos muy convencidos que Silverlight es una gran propuesta por su arquitectura multiplataforma y experiencia de usuario que brinda. Ahora estamos trabajando para llevar a la practica nuevos proyectos en esta plataforma.