Optimizar tu aplicación web PHP – Parte 1

Hace tiempo escribí un artículo sobre como hacer que el código javascript se cargue de forma más rápida, y también el uso de memcache para optimizar la petición de consultas a la base de datos y hoy quiero empezar la primera parte de dos o quizás tres secciones de un artículo con consejos para optimizar tu aplicación web hecha en PHP.

Cuando me refiero a optimizar significa a que nuestras aplicaciones básicamente sean más rápidas ya sean usando menos memoria o menos procesos, lo primero que quiero es desmentir el mito que dice «una aplicación es optima que otra si usa menos líneas de código», eso es falso… quizás en algunas ocasiones aplique pero no siempre es así.

Ahora, como decía antes, hay varios aspectos a optimizar en una aplicación, trataré de dar consejos para los siguientes 3 aspectos optimizables dentro de cualquier programa o fragmento de código:

  1. Cantidad de líneas de código
  2. Consumo de memoria
  3. La velocidad en que se ejecuta (uso de procesador)

A mi criterio, los dos últimos puntos son los más importantes, estos dos determinan si un algoritmo es optimo o no, pero la cantidad de líneas de código no determina que tan optimo es un algoritmo. Ahora, si ayuda a la optimización porque cada línea de código significa una instrucción o instrucciones más para el procesador.

Mis consejos son:

  1. Tratar de no usar variables globales a menos que sea necesario. PHP siempre tiene que comprobar que existen.
  2. Es mejor no introducir código html dentro de PHP.Es más rápido usar
    Texto aquí

    que usar

    echo "Texto aquí"
  3. No declares variables que no usarás, estoy utilizaría memoria innecesaria
  4. La función require_once es lenta, así que en lo posible no la uses
  5. Siempre que puedas declarar un método o variable como estática, hazlo!
  6. Si vas a escribir en disco duro, trata de no hacerlo fragmento por fragmento sino todo de un solo golpe, quizás sacrifiques un poco de memoria RAM pero ganas rendimiento en velocidad, esto debido a que es más rápido acceder a memoria RAM que al disco duro… es necesario analizar bien el caso para saber como aplicarlo.
  7. Los ciclos o bucles consumen gran cantidad de procesamiento en la CPU, así que si puedes aplicar un poco de matemáticas discretas seguramente el procesador te lo agradecerá.
  8. Hay que calcular el tamaño de un arreglo antes de un ciclo, sino cada vez que se ejecuta el ciclo se tendrá que calcular el tamaño del arregloMal:
    for($i=1;$i<=sizeof($arreglo);$i++)

    Bien:

    $tamano=sizeof($arreglo);
    for($i=1;$i<=$tamano;$i++)
  9. Esconder los errores con @ es muy lento
  10. Utiliza pocos accesos a la base de datos
  11. Cuando hagas una consulta a la base de datos, no traigas campos innecesarios. No utilices «SELECT * FROM tabla» si no lo necesitas, utiliza «SELECT campo, campo FROM tabla».
  12. La programación orientada a objetos es muy útil cuando nuestro programa es grande y nos permite reutilizar código, por tanto tener menos líneas de código fuente

Bueno, estos son apenas unos cuantos consejos que doy de mi experiencia, quizás aún tu aplicación no sea optima pero seguro que estos consejos ayudarán a que el rendimiento mejore mucho.

Pronto escribiré otra tanda de consejos para que tu aplicación en php sea mas optima.

    Redireccionar a www, un consejo SEO

    No se si habrán notado que al entrar a webs como

    http://bubok.es
    http://facebook.com
    http://google.com
    http://linkedin.com

    Automaticamente, siempre se agrega el prefijo www. a la web.

    Pues la razón es que es un punto a favor para lograr un buen posicionamiento de tu web, porque al final si no aplicas esta técnica para los buscadores www.bubok.es y bubok.es son dos dominios (webs) diferentes, en cambios si obligamos a que bubok.es vaya a www.bubok.es siempre lo tomará como un solo dominio y tendremos un mejor posicionamiento.

    Si tienen un servidor apache o similiar, podemos lograr esto mediante el archivo .htaccess en tu servidor y el siguiente fragmento de código:

    RewriteCond %{HTTP_HOST} ^[a-zA-Z]+\.info
    RewriteRule (.*) http://www.%{HTTP_HOST}/$1 [R=301,L]

    El anterior fragmento hace que al entrar en mi dominio http://rafaelvega.com redireccione se 301 a http://www.rafaelvega.com

    Escribir mensajes en twitter desde PHP

    Desde hace un tiempo atrás del cual no tengo idea cuanto fue, twitter cambió su API para conectarse a sus servicios, esto causó que todo mundo tuviera que actualizar sus códigos OBLIGATORIAMENTE para poder seguir haciendo lo que venían haciendo antes.

    Despues de varios intentos fallidos encontré una forma de hacer la autenticación, fue un aporte de Tijs Verkoyen.

    Lo unico que no hace Tijs es decir como utilizar su clase… aquí trataré de poner de la forma más fácil como twittear con la clase de Tijs, el resto de funciones las puede mirar en su web.

    1. Bajar el archivo .php de la clase, aquí.

    2. Crear una aplicación de twitter, rellenando todos los datos en: http://dev.twitter.com/apps/new

    3. Entramos a http://dev.twitter.com/apps e ingresamos a la aplicación que hemos creado, de aquí debemos tomar los valores de «Consumer key» y el «Consumer secret».

    4. Luego de copiar/anotar los valores, vamos al menú derecho y entramos a «My Access Token», de aquí copiaremos los valores de «Access Token» y «Access Token Secret»

    Ya tenemos casi listo todo 🙂 , ahora viene el código.

    $twi_user = new Twitter("Consumer key","Consumer secret"); 
    $twi_user->setOAuthToken("Access Token");  
    $twi_user->setOAuthTokenSecret("Access Token Secret");
    $twi_user->statusesUpdate("Este es mi primer mensaje en twitter con el nuevo método de autenticación"); 
    

    Eso es todo, más fácil de lo que parece

    Memcache + PHP

    ¿Por qué memcache?
    En muchos proyectos de software (incluyendo Web) se realizan consultas a la base de datos que un lapso de tiempo siempre arrojan el mismo resultado; pero como no teníamos con una forma de almacenar esa información para disponer de ella cada vez que la necesitamos sin tener que realizar la consulta en el motor de bases de datos nuevamente, entonces simplemente llamábamos un query X cantidad de veces sin importar los recursos que tomaba la ejecución de dicha consulta. Con el fin de evitar ese desperdicio de recursos es que ha nacido memcache.

    ¿Qué es memcache?
    Memcache es un servicio para almacenar objetos en memoria RAM y que pueden ser utilizados por múltiples procesos sin importar si se encuentran en la misma máquina o no. El objetivo principal por el que surgió memcache es el de evitar peticiones incesarías a la base de datos.

    ¿Cómo lo instalo y configuro?
    Para unix:
    $ sudo apt-get install memcached
    $ sudo /etc/init.d/memcached restart
    $ sudo apt-get install php5-memcache

    Activar la extensión editando el archivo /etc/php5/conf.d/memcache.ini y descomentando la línea extension.
    ; uncomment the next line to enable the module
    extension=memcache.so

    Por último reiniciar apache

    Para Windows:
    Bajar e instalar: http://allegiance.chi-town.com/MemCacheDManager.aspx

    Activar la extensión editando el archivo  G:\wamp\bin\php\php5.2.6\php.ini  y descomentando la línea extension.
    extension=php_memcache.dll

    Por último reiniciar apache

    Memcache es un servicio/daemon que se ejecuta por consola de la siguiente manera:

    /usr/bin/memcached -d -m 2048 -u root
    -d : corre como servicio.
    -m : limite de memoria en MB que le permitiremos usar a memecache
    -u : identidad de quien ejecuta el proceso
    -p : puerto (por default es 11211)
    -c : limite de conexiones simultaneas (default es 1024)
    -h : muestra ayudas y otros parámetros de uso

    ¿Cómo lo uso?

    function memcache_test(){
       $memcache = new Memcache();
       $memcache->connect("localhost",11211);
       $key = "todos_los_registros_de_tabla_datos";
       $datos = $memcache->get($key);
       if (!$datos){
          echo "No esta cachado... hitting db e insertando en  memcache. <br>";
          $result = mysql_query("SELECT * FROM datos");
          while( ($dato=mysql_fetch_assoc($result))!=null){
             $datos[]=$dato;
          }
          $memcache->set($key,$datos,false,60*60*24); //cachados  por 24 horas
          print_r($datos);
       }else{
          echo "Ya se encuentra en memoria:<br>";
          print_r($datos);
       }
    }

    Gracias luis por la info