<?xml version="1.0" encoding="utf-8" ?>

<rss version="2.0" 
   xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
   xmlns:admin="http://webns.net/mvcb/"
   xmlns:dc="http://purl.org/dc/elements/1.1/"
   xmlns:slash="http://purl.org/rss/1.0/modules/slash/"
   xmlns:wfw="http://wellformedweb.org/CommentAPI/"
   xmlns:content="http://purl.org/rss/1.0/modules/content/"
   >
<channel>
    <title>Novanebula blog</title>
    <link>http://www.novanebula.net/blog/</link>
    <description>Noticias</description>
    <dc:language>es</dc:language>
    <generator>Serendipity 1.2.1 - http://www.s9y.org/</generator>
    <pubDate>Wed, 20 Aug 2008 19:43:38 GMT</pubDate>

    <image>
        <url>http://www.novanebula.net/blog/templates/default/img/s9y_banner_small.png</url>
        <title>RSS: Novanebula blog - Noticias</title>
        <link>http://www.novanebula.net/blog/</link>
        <width>100</width>
        <height>21</height>
    </image>

<item>
    <title>Losantos no tiene desperdicio con una camara delante</title>
    <link>http://www.novanebula.net/blog/archives/104-Losantos-no-tiene-desperdicio-con-una-camara-delante.html</link>
            <category>Política nacional</category>
    
    <comments>http://www.novanebula.net/blog/archives/104-Losantos-no-tiene-desperdicio-con-una-camara-delante.html#comments</comments>
    <wfw:comment>http://www.novanebula.net/blog/wfwcomment.php?cid=104</wfw:comment>

    <slash:comments>0</slash:comments>
    <wfw:commentRss>http://www.novanebula.net/blog/rss.php?version=2.0&amp;type=comments&amp;cid=104</wfw:commentRss>
    

    <author>nospam@example.com (Abraham Covelo)</author>
    <content:encoded>
    Losantos no tiene desperdicio con una camara delante y alguien que le ria las &quot;gracias&quot;.&lt;br /&gt;
 Sin lugar a dudas vomitivo... Habría que explicarle lo que es un dictador (FRANCISCO FRANCO) y lo que no (Evo Morales, Hugo Chavez, ...)&lt;br /&gt;
&lt;br /&gt;
&lt;object width=&quot;425&quot; height=&quot;344&quot;&gt;&lt;param name=&quot;movie&quot; value=&quot;http://www.youtube.com/v/UlU7Lefp9X4&amp;color1=11645361&amp;color2=13619151&amp;hl=en&amp;fs=1&quot;&gt;&lt;/param&gt;&lt;param name=&quot;wmode&quot; value=&quot;transparent&quot;&gt;&lt;/param&gt;&lt;param name=&quot;allowFullScreen&quot; value=&quot;true&quot;&gt;&lt;/param&gt;&lt;embed src=&quot;http://www.youtube.com/v/UlU7Lefp9X4&amp;color1=11645361&amp;color2=13619151&amp;hl=en&amp;fs=1&quot; type=&quot;application/x-shockwave-flash&quot; allowfullscreen=&quot;true&quot; wmode=&quot;transparent&quot; width=&quot;425&quot; height=&quot;344&quot;&gt;&lt;/embed&gt;&lt;/object&gt;&lt;br /&gt;
&lt;br /&gt;
Una persona que desea la enfermedad y la muerte a sus iguales creo que se define por sí misma.&lt;br /&gt;
 
    </content:encoded>

    <pubDate>Tue, 19 Aug 2008 23:48:38 +0200</pubDate>
    <guid isPermaLink="false">http://www.novanebula.net/blog/archives/104-guid.html</guid>
    
</item>
<item>
    <title>Comando linux: test</title>
    <link>http://www.novanebula.net/blog/archives/103-Comando-linux-test.html</link>
            <category>GNU/Linux</category>
    
    <comments>http://www.novanebula.net/blog/archives/103-Comando-linux-test.html#comments</comments>
    <wfw:comment>http://www.novanebula.net/blog/wfwcomment.php?cid=103</wfw:comment>

    <slash:comments>0</slash:comments>
    <wfw:commentRss>http://www.novanebula.net/blog/rss.php?version=2.0&amp;type=comments&amp;cid=103</wfw:commentRss>
    

    <author>nospam@example.com (Abraham Covelo)</author>
    <content:encoded>
    Este comando linux tiene ciertas peculiariedades que lo alejan de su utilización en consola y lo hacen realmente útil para el programación de scripts. Seguramente el hecho más relevante que reafirma lo que acabamos de decir en la manera en la que test devuelve la información; simplemente a través de su código de retorno. O sea que después de ejecutarlo por consola no veremos absolutamente nada sólo el prompt de nuestro terminal pidiendonos que introduzcamos la siguiente orden.&lt;br /&gt;
&lt;br /&gt;
Tes es un comando para evaluar expresiones devolviendo 0 (cómo código de retornos) en el caso de que la expresión evaluada sea verdadera o un valor distinto de 0 en el caso de ser falso. Esto es la manera habitual para la shell, completamente diferente a la programación en C donde 0 es evaluado como falso y diferente de 0 como verdadero (aunque C no tiene tipos booleanos). Bueno que me estoy liando.&lt;br /&gt;
&lt;br /&gt;
El caso es que test es capaz de analizar cadenas de texto, enteros y ficheros evaluando sus propiedades para analizar lo que más nos interese de estos elementos. Así por ejemplo para cadenas es capaz de determinar si estamos ante una cadana vacia o no (-n), si su longitud es cero (-z) si es igual a otro cadena (=). Para enteros puede determinar si son iguales, mayores o menores que otro dado y para ficheros que en mi modesta opinion es donde radica uno de sus puntos puede determinar un montón de cosas como:&lt;br /&gt;
&lt;br /&gt;
       FILE1 -ef FILE2&lt;br /&gt;
              FILE1 y FILE2 son el mismo fichero en realidad (mismo inodo y dispositivo)&lt;br /&gt;
&lt;br /&gt;
       FILE1 -nt FILE2&lt;br /&gt;
              FILE1 es más reciente que el FILE2 (por la fecha de modificación)&lt;br /&gt;
&lt;br /&gt;
       FILE1 -ot FILE2&lt;br /&gt;
              FILE1 es más antiguo que FILE2&lt;br /&gt;
&lt;br /&gt;
       -b FILE&lt;br /&gt;
              FILE existe y es un fichero de bloque especial (no un fichero regular, ver mknod)&lt;br /&gt;
&lt;br /&gt;
       -c FILE&lt;br /&gt;
              FILE existe y es un dispositivo de tipo caracter (ver mknod)&lt;br /&gt;
&lt;br /&gt;
       -d FILE&lt;br /&gt;
              FILE existe y es un directorio&lt;br /&gt;
&lt;br /&gt;
       -e FILE&lt;br /&gt;
              FILE exite (sin entrar en otras consideraciones como en el caso de los otros parámetros)&lt;br /&gt;
&lt;br /&gt;
       -f FILE&lt;br /&gt;
              FILE existe y es un fichero regular&lt;br /&gt;
&lt;br /&gt;
       -g FILE&lt;br /&gt;
              FILE existe y tiene marcado el bit de GUID (id de grupo)&lt;br /&gt;
&lt;br /&gt;
       -G FILE&lt;br /&gt;
              FILE existe y es poseido por el EGUID (id de grupo efectivo)&lt;br /&gt;
&lt;br /&gt;
       -h FILE&lt;br /&gt;
              FILE existe y es un enlace simbólico (igual que el modificador -L)&lt;br /&gt;
&lt;br /&gt;
       -k FILE&lt;br /&gt;
              FILE existe y tiene marcado el bit sticky&lt;br /&gt;
&lt;br /&gt;
       -L FILE&lt;br /&gt;
              FILE existe y es un enlace simbólico (igual que el modificador -h)&lt;br /&gt;
&lt;br /&gt;
       -O FILE&lt;br /&gt;
              FILE existe y es poseido por el EUID (id de usuario efectivo)&lt;br /&gt;
&lt;br /&gt;
       -p FILE&lt;br /&gt;
              FILE existe y es una tuberia con nombre (ver &lt;a href=&quot;http://www.novanebula.net/blog/archives/2-FIFOs-en-linux.html&quot;&gt;FIFOs&lt;/a&gt;)&lt;br /&gt;
&lt;br /&gt;
       -r FILE&lt;br /&gt;
              FILE existe y el usuario actual tiene permiso de lectura sobre él&lt;br /&gt;
&lt;br /&gt;
       -s FILE&lt;br /&gt;
              FILE existe y tiene un tamaño mayor que cero&lt;br /&gt;
&lt;br /&gt;
       -S FILE&lt;br /&gt;
              FILE existe y es un fichero tipo socket&lt;br /&gt;
&lt;br /&gt;
       -t FD  &lt;br /&gt;
              el descriptor de fichero FD esta abierto en una terminal&lt;br /&gt;
&lt;br /&gt;
       -u FILE&lt;br /&gt;
              FILE exite y su SUID está marcado&lt;br /&gt;
&lt;br /&gt;
       -w FILE&lt;br /&gt;
              FILE existe y el usuario actual tiene permiso de escritura sobre él&lt;br /&gt;
&lt;br /&gt;
       -x FILE&lt;br /&gt;
              FILE existe y el usuario actual tiene permiso de ejecución (o busqueda) sobre él&lt;br /&gt;
&lt;br /&gt;
Además test es capaz de concatenar varias expresiones empleando AND o OR lógicos con los siguientes modificadores:&lt;br /&gt;
&lt;br /&gt;
EXPRESSION1 -a EXPRESSION2  (AND lógico)&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
EXPRESSION1 -o EXPRESSION2 (OR lógico)&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Como ya he comentado antes test se emplea sobre todo en programación bash en instrucciones condicionales por acabar el articulo con un par de ejemplos que ilustraran claramente su utilización:&lt;br /&gt;
&lt;br /&gt;
file=&quot;/tmp&quot;&lt;br /&gt;
if [ -k $file ]&lt;br /&gt;
then&lt;br /&gt;
   echo &quot;El directorio /tmp tiene el bit sticky marcado&quot;;&lt;br /&gt;
fi&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Otro ejemplo&lt;br /&gt;
&lt;br /&gt;
cadena=&quot;hola&quot;&lt;br /&gt;
if [ $cadena = &quot;hola&quot; ]&lt;br /&gt;
then&lt;br /&gt;
        echo &quot;Hola mundo!&quot;;&lt;br /&gt;
fi&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Observad que en los ejemplos no hemos puesto ningún test pero es que en programación en bash y en este tipo de construcciones el corchete abierto [ es sinónimo de test (y por razones de eficiencia en un builtin (bash lo tiene incluido internamente y no llama al comando test al que emula)&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
 
    </content:encoded>

    <pubDate>Fri, 08 Aug 2008 23:40:00 +0200</pubDate>
    <guid isPermaLink="false">http://www.novanebula.net/blog/archives/103-guid.html</guid>
    
</item>
<item>
    <title>XCache</title>
    <link>http://www.novanebula.net/blog/archives/102-XCache.html</link>
            <category>Programación</category>
    
    <comments>http://www.novanebula.net/blog/archives/102-XCache.html#comments</comments>
    <wfw:comment>http://www.novanebula.net/blog/wfwcomment.php?cid=102</wfw:comment>

    <slash:comments>0</slash:comments>
    <wfw:commentRss>http://www.novanebula.net/blog/rss.php?version=2.0&amp;type=comments&amp;cid=102</wfw:commentRss>
    

    <author>nospam@example.com (Abraham Covelo)</author>
    <content:encoded>
    Xcache es una librería que sirve para almacenar en cache los códigos de operación de nuestros scripts php. Aunque esta frase pueda parecer algo oscuro y difícil de entender sólo significa que tendremos pre-parseados e interpretados nuestros scripts por el core de php. De manera que en ejecuciones posterires no hará falta pasar por todas las fases de validación, análisis, tratamiento e interpretación del código. Nos encontramos pues ante una especie de compilación de código php. Lo mejor es que el código no está realmente compilado y podemos modificarlo de la forma habitual forzando que se recree el cache sólo para los scripts que hemos modificado.&lt;br /&gt;
&lt;br /&gt;
De esta manera se optimiza el rendimiento de las páginas php en los servidores. Almacenando en RAM (shm) de cache el estado compilado de los scripts php se ahorra tiempo de compilación. Según sus desarrolladores es posible obtener hasta 5 veces más de velocidad en la generación de páginas.&lt;br /&gt;
&lt;br /&gt;
La página oficial de Xcache es la siguiente: &lt;a onclick=&quot;javascript: pageTracker._trackPageview(&#039;/extlink/xcache.lighttpd.net/&#039;);&quot;  href=&quot;http://xcache.lighttpd.net/&quot;&gt;Xcache&lt;/a&gt;&lt;br /&gt;
&lt;br /&gt;
Actualmente se encuentra en versión estable y sólo disponible para linux. Soporta varias versiones de php desde la 4.3 hasta la 5.3 (e incluso para pre versiones de &lt;a href=&quot;http://www.novanebula.net/blog/archives/98-PHP-6.html&quot;&gt;php6&lt;/a&gt;). Extrañamente no es soportado para la versión 5.0. 
    </content:encoded>

    <pubDate>Fri, 08 Aug 2008 22:22:00 +0200</pubDate>
    <guid isPermaLink="false">http://www.novanebula.net/blog/archives/102-guid.html</guid>
    
</item>
<item>
    <title>Optimizando consultas Mysql</title>
    <link>http://www.novanebula.net/blog/archives/101-Optimizando-consultas-Mysql.html</link>
            <category>Programación</category>
    
    <comments>http://www.novanebula.net/blog/archives/101-Optimizando-consultas-Mysql.html#comments</comments>
    <wfw:comment>http://www.novanebula.net/blog/wfwcomment.php?cid=101</wfw:comment>

    <slash:comments>0</slash:comments>
    <wfw:commentRss>http://www.novanebula.net/blog/rss.php?version=2.0&amp;type=comments&amp;cid=101</wfw:commentRss>
    

    <author>nospam@example.com (Abraham Covelo)</author>
    <content:encoded>
    La optimización de las consultas a la base de datos de tus aplicaciones web es de vital importancia, no sólo ha la hora de medir el tiempo en el que una página se carga sino también cuando el tráfico de tu máquina se incrementa o cuando el hardware tiene trabajo extra debido a un mal diseño de esas consultas.&lt;br /&gt;
&lt;br /&gt;
Incluso aunque tengamos implementadas soluciones de caché (librerías de mysql con cache, &lt;a href=&quot;http://www.novanebula.net/blog/archives/94-Memcache.html&quot;&gt;memcache&lt;/a&gt; o similares) la optimización de las consultas sigue teniendo un relevancia plena. En este artículo resumiremos que herramientas podemos emplear para optimizar, detectar y solucionar problemas en las consultas a tu base de datos que lastran tu aplicación llegando ha hacerla inutilizable o requiriendo una inversión mayor en equipo cuando no debería.&lt;br /&gt;
&lt;br /&gt;
La primera de las herramientas, interna al propio servidor mysql es la sentencia explain, explain también es un alias del comando describe cuando se escribe a continuación un nombre de tabla. Explain o describe devolverá información sobre la estructura de la tabla. La otra sintaxis propia de explain, y la que nos interesa, es la que sirve para analizar como mysql ejecuta una sentencia select.&lt;br /&gt;
&lt;br /&gt;
EXPLAIN [EXTENDED] SELECT select_options&lt;br /&gt;
&lt;br /&gt;
Explain hará que el optimizar de mysql nos devuelva información sobre como se procesará la sentencia SELECT incluyendo información de que tablas usará como utilizará los joins, en que orden y en que modo utilizará los indices que haya definidos en las tablas. Todo esta información se conoce con el nombre de información sobre plan de ejecución de mysql.&lt;br /&gt;
&lt;br /&gt;
Esta información es muy valiosa y se puede emplear para optimizar nuestros selects. Con esta información podremos por ejemplo decidir añadir nuevos índices a nuestras tablas o modificar nuestros selects para que se fuerte un determinado orden para nuestros joins.&lt;br /&gt;
&lt;br /&gt;
Explain devuelve una fila de información por cada tabla empleada en la consulta. Las tablas son listadas en el orden en el que mysql las leerá a la hora de procesar la consulta. Si añadimos EXTENDED mysql nos dará información adicional en forma de warning, para poder verla debemos ejecutar un SHOW WARNINGS. La información extra contiene como el optimizador da &lt;br /&gt;
nombre cada una de las tablas y columnas de la sentencia select y puede que otras notas sobre el proceso de optimización.&lt;br /&gt;
&lt;br /&gt;
Veamoslo con un ejemplo bien simple:&lt;br /&gt;
&lt;br /&gt;
mysql&gt; select 1;&lt;br /&gt;
+---+&lt;br /&gt;
| 1 |&lt;br /&gt;
+---+&lt;br /&gt;
| 1 |&lt;br /&gt;
+---+&lt;br /&gt;
1 row in set (0.00 sec)&lt;br /&gt;
&lt;br /&gt;
mysql&gt; explain select 1;&lt;br /&gt;
+----+-------------+-------+------+---------------+------+---------+------+------+----------------+&lt;br /&gt;
| id | select_type | table | type | possible_keys | key  | key_len | ref  | rows | Extra          |&lt;br /&gt;
+----+-------------+-------+------+---------------+------+---------+------+------+----------------+&lt;br /&gt;
|  1 | SIMPLE      | NULL  | NULL | NULL          | NULL | NULL    | NULL | NULL | No tables used |&lt;br /&gt;
+----+-------------+-------+------+---------------+------+---------+------+------+----------------+&lt;br /&gt;
1 row in set (0.00 sec)&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Cada columna que devuelve EXPLAIN tiene el siguiente significado:&lt;br /&gt;
&lt;br /&gt;
id - identificador, es sólo una secuencia numérica autoincrementada para cada una de las filas del explain&lt;br /&gt;
select_type - Debe ser uno de los siguiente tipos&lt;br /&gt;
    SIMPLE - No usa subqueries ni UNION&lt;br /&gt;
    PRIMARY - Último SELECT&lt;br /&gt;
    UNION - Segunda o última sentencia SELECT en una UNION&lt;br /&gt;
    DEPENDENT UNION - Segunda o última sentencia SELECT en una UNION, dependiente de otra query&lt;br /&gt;
    SUBQUERY - Primera SELECT en una subquery&lt;br /&gt;
    DEPENDENT SUBQUERY - Primera SELECT en una subquery, dependiente de otra query&lt;br /&gt;
    DERIVED - Tabla SELECT derivada (subquery en una clausula FROM)&lt;br /&gt;
    UNCACHEABLE SUBQUERY - Una subquery cuyo resultado no puede ser cacheado y debe ser re-evaluado para cada file de la otra query.&lt;br /&gt;
&lt;br /&gt;
table - la tabla a la que se refiere la información&lt;br /&gt;
tipo - el tipo de unión empleado, que puede ser:&lt;br /&gt;
    sytem - SYSTEM SELECT sólo hay una fila en la tabla (tipo especial del tipo const)&lt;br /&gt;
    const - La tabla tiene como mucho un sola fila resultado, que es leída al principio de la operación convirtiéndose en una constante para el resto de las operaciones del select (operación muy rápida)&lt;br /&gt;
    eq_ref - Una fila es leída de la tabla por cada combinación de filas en las tablas previas.&lt;br /&gt;
    ref - Todas las filas con valores de índices validos son leídos de esta tabla por cada combinación de filas de las tablas previas.&lt;br /&gt;
    fulltext - El join se utiliza mediante un índice FULLTEXT&lt;br /&gt;
    ref_or_null - Este tipo de join es como el ref, pero además MySQL hace una busqueda extra por filas que contengan valores NULL&lt;br /&gt;
    index_merge - la columna key en la fila de salida contiene una lista de indices a utilizar, y key_len contiene una lista de las claves más largas para los índices utilizados.&lt;br /&gt;
    unique_subquery -  Este tipo sustituye al ref para algunas subqueries IN de el siguiente tipo de estructuras: value IN (SELECT primary_key FROM single_table WHERE some_expr)&lt;br /&gt;
    index_subquery - Este tipo join es similar al unique_subquery. Este sustituye subqueries IN, pero funciona para índices no únicos en subqueries del siguiente tipo: value IN (SELECT key_column FROM single_table WHERE some_expr)&lt;br /&gt;
    range - Solamente las columnas que están en un rango dado son retornadas, empleando un índice para seleccionar las columnas. La columna key indica que índice es utilizado. key_len contiene el índice más largo de la parte del índice más larga utilizada. ref es NULL para este tipo.&lt;br /&gt;
    index - Este ipo de join es el mismo que el de ALL, con la excepción de que sólo se realiza el escaneado a través de un índice. Esto es mas rápido que ALL ya que los ficheros índice son generalmente más pequeños que el fichero de datos.&lt;br /&gt;
    all - Se realiza un escaneado de toda la tabla por cada combinación de filas de las tablas anteriores.&lt;br /&gt;
&lt;br /&gt;
Estos tipos están ordenados en cuando a lo mejor o peor en cuanto a optimización. Así un tipo all sería lo peor y un tipo system sería lo mejor. Reducir de un tipo a otro, cambiando o creando índices para una determinada tabla o modificando la estrucutra misma de la petición es la tarea básica que debemos intentar para optimizar nuestra querys.&lt;br /&gt;
&lt;br /&gt;
possible_keys - La columna indica que índices se pueden seleccionar para ser usados a la hora de encontrar filas en la tabla.&lt;br /&gt;
key - Índica que índice es empleado finalmente (podría se uno que no estuviera listado en las possible_keys).&lt;br /&gt;
key_len - Longitud del índice empleado&lt;br /&gt;
ref - Muestra que columnas o constante son empleadas para comparar con el índice&lt;br /&gt;
rows - Número de filas que MySQL piensa que debe examinar al ejecutar la petición&lt;br /&gt;
extra - Información adicional sobre la consulta.&lt;br /&gt;
&lt;br /&gt;
Cuando modifiques la estructura de una tabla o añadas índices recuerda ejecutar un:&lt;br /&gt;
&lt;br /&gt;
ANALIZE TABLE nombre_tabla;&lt;br /&gt;
&lt;br /&gt;
Esto hará que el optimizador analize adecuadamente la tabla, los datos los usará para ayudarle a determinar la mejor estrategia en consultas posteriores. Tras modificar la tabla ejecuta ANALIZE y vuelve a ejecutar un EXPLAIN para observar las modificaciónes en el plan de ejecución de la consulta.&lt;br /&gt;
&lt;br /&gt;
 
    </content:encoded>

    <pubDate>Sun, 01 Jun 2008 17:00:43 +0200</pubDate>
    <guid isPermaLink="false">http://www.novanebula.net/blog/archives/101-guid.html</guid>
    
</item>
<item>
    <title>Firefox 3 rc1</title>
    <link>http://www.novanebula.net/blog/archives/100-Firefox-3-rc1.html</link>
            <category>Programación</category>
    
    <comments>http://www.novanebula.net/blog/archives/100-Firefox-3-rc1.html#comments</comments>
    <wfw:comment>http://www.novanebula.net/blog/wfwcomment.php?cid=100</wfw:comment>

    <slash:comments>0</slash:comments>
    <wfw:commentRss>http://www.novanebula.net/blog/rss.php?version=2.0&amp;type=comments&amp;cid=100</wfw:commentRss>
    

    <author>nospam@example.com (Abraham Covelo)</author>
    <content:encoded>
    Firefox, uno de los navegadores más empleados en la actualidad y el más importante de las alternativas &quot;open source&quot; acaba de anunciar la salida de la primera &quot;release candidate&quot;.&lt;br /&gt;
&lt;br /&gt;
Este navegador podría ser el primero en desbancar a internet explorer como &lt;a onclick=&quot;javascript: pageTracker._trackPageview(&#039;/extlink/www.w3schools.com/browsers/browsers_stats.asp&#039;);&quot;  href=&quot;http://www.w3schools.com/browsers/browsers_stats.asp&quot;&gt;navegador más empleado&lt;/a&gt;.&lt;br /&gt;
&lt;br /&gt;
La versión puede ser descargada directamente desde las páginas de &lt;a onclick=&quot;javascript: pageTracker._trackPageview(&#039;/extlink/www.mozilla.com/en-US/firefox/all-rc.html&#039;);&quot;  href=&quot;http://www.mozilla.com/en-US/firefox/all-rc.html&quot;&gt;mozilla&lt;/a&gt;. Pero se avisa que sólo es válido para realizar pruebas. No presenta muchas características nuevas respecto a las betas anteriores por lo que nos encontramos ante una versión más estable que sólo (esperemos) solucione bugs de las betas anteriores. 
    </content:encoded>

    <pubDate>Sat, 24 May 2008 15:56:01 +0200</pubDate>
    <guid isPermaLink="false">http://www.novanebula.net/blog/archives/100-guid.html</guid>
    
</item>
<item>
    <title>Unit testing (pruebas unitarias)</title>
    <link>http://www.novanebula.net/blog/archives/99-Unit-testing-pruebas-unitarias.html</link>
            <category>Programación</category>
    
    <comments>http://www.novanebula.net/blog/archives/99-Unit-testing-pruebas-unitarias.html#comments</comments>
    <wfw:comment>http://www.novanebula.net/blog/wfwcomment.php?cid=99</wfw:comment>

    <slash:comments>0</slash:comments>
    <wfw:commentRss>http://www.novanebula.net/blog/rss.php?version=2.0&amp;type=comments&amp;cid=99</wfw:commentRss>
    

    <author>nospam@example.com (Abraham Covelo)</author>
    <content:encoded>
    En el desarrollo de software la ausencia de errores es una autentica quimera. Tantos son los factores que finalmente pueden alterar el flujo que consideramos &quot;normal&quot; en el programa como los errores propios a cualquier actividad humana.&lt;br /&gt;
&lt;br /&gt;
&amp;#160;&amp;#160;&amp;#160;&amp;#160;Uno de los métodos más utilizados para realizar pruebas a nuestro software es el llamado de pruebas unitarias (unit testing). La base de este método es el hacer pruebas en pequeños fragmentos de nuestro programa. Estos fragmentos deben ser unidades estructurales de nuestro programa encargados de una tarea especifica, en programación procedural u orientada a objetos podemos afirmar que estas unidades son los métodos o las funciones que tenemos definidos.&lt;br /&gt;
&lt;br /&gt;
&amp;#160;&amp;#160;&amp;#160;&amp;#160;Tras realizar estas pruebas sobre los elementos unitarios de nuestro programa podremos eliminar gran parte de los errores de los que podría adolecer. Como ya sabemos cualquier prueba demuestra no la ausencia de errores sino que revela la presencia de ellos. Las pruebas unitarias no revelan errores en la integración de las partes unitarias ni tampoco otros problemas como el bajo rendimiento de las aplicaciones o problemas derivados del sistema sobre el que está ejecutándose nuestro programa.&lt;br /&gt;
&lt;br /&gt;
&amp;#160;&amp;#160;&amp;#160;&amp;#160;El objetivo de las pruebas unitarias es el aislamiento de partes del código y la demostración de que estas partes no contienen errores.&lt;br /&gt;
&lt;br /&gt;
&amp;#160;&amp;#160;&amp;#160;&amp;#160;Una vez creados el conjunto de pruebas unitarias sobre un fragmento de código los beneficios obtenidos, incluso antes de ejecutar ninguna prueba, son múltiples. Pasaré a enumerarlos:&lt;br /&gt;
&lt;br /&gt;
&lt;strong&gt;Simplificación de la integración&lt;/strong&gt;&lt;br /&gt;
&amp;#160;&amp;#160;&amp;#160;&amp;#160;Las pruebas unitarias eliminan las posibles incertidumbres y errores en lo que se espera de cada una de las unidades ayudando a entender la integración de cada una de las partes.&lt;br /&gt;
&lt;br /&gt;
&lt;strong&gt;Refactorización de código&lt;/strong&gt;&lt;br /&gt;
&amp;#160;&amp;#160;&amp;#160;&amp;#160;Una vez refactorizado el código; las mismas pruebas unitarias nos pueden servir para probar el nuevo código asegurándonos de que este sigue siendo válido bajo la nueva implementación.&lt;br /&gt;
&lt;br /&gt;
&lt;strong&gt;Documentación&lt;/strong&gt;&lt;br /&gt;
&amp;#160;&amp;#160;&amp;#160;&amp;#160;Las pruebas unitarias sirven como método de documentación mismo. Los desarrolladores pueden ver a través de las pruebas unitarias cual es el objetivo de las distintas partes del código de una manera básica.&lt;br /&gt;
&lt;br /&gt;
&lt;strong&gt;Diseño&lt;/strong&gt;&lt;br /&gt;
&amp;#160;&amp;#160;&amp;#160;&amp;#160;Cuando se desarrolla el software las pruebas unitarias pueden tomar el lugar del diseño formal. Cada prueba unitaria puede ser visto como un elemento de diseños que especifica las clases, los métodos y el comportamiento observable de la aplicación.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
 
    </content:encoded>

    <pubDate>Thu, 22 May 2008 21:42:56 +0200</pubDate>
    <guid isPermaLink="false">http://www.novanebula.net/blog/archives/99-guid.html</guid>
    
</item>
<item>
    <title>PHP 6</title>
    <link>http://www.novanebula.net/blog/archives/98-PHP-6.html</link>
            <category>Programación</category>
    
    <comments>http://www.novanebula.net/blog/archives/98-PHP-6.html#comments</comments>
    <wfw:comment>http://www.novanebula.net/blog/wfwcomment.php?cid=98</wfw:comment>

    <slash:comments>0</slash:comments>
    <wfw:commentRss>http://www.novanebula.net/blog/rss.php?version=2.0&amp;type=comments&amp;cid=98</wfw:commentRss>
    

    <author>nospam@example.com (Abraham Covelo)</author>
    <content:encoded>
    Dentro de muy poco tiempo tendremos entre nosotros la próxima versión de php, php6. Esta versión ya está disponible en php.net para su &lt;a onclick=&quot;javascript: pageTracker._trackPageview(&#039;/extlink/snaps.php.net/&#039;);&quot;  href=&quot;http://snaps.php.net/&quot;&gt;descargar&lt;/a&gt;. Aunque la adopción de php5 y desaparición de php4 fue un proceso algo más lento de lo esperado. PHP6 no supone un cambio tan radical como el que sucedió con la versión anterior por lo que es de esperar, si todo va bien, que la adopción de esta versión sea más rápida.&lt;br /&gt;
&lt;br /&gt;
&amp;#160;&amp;#160;&amp;#160;&amp;#160;&lt;strong&gt;PHP&lt;/strong&gt; sigue siendo el &lt;strong&gt;lenguaje script&lt;/strong&gt; para &lt;strong&gt;desarrollos web&lt;/strong&gt; &lt;a onclick=&quot;javascript: pageTracker._trackPageview(&#039;/extlink/www.php.net/usage.php&#039;);&quot;  href=&quot;http://www.php.net/usage.php&quot;&gt;más popular&lt;/a&gt; y la lista de  &lt;strong&gt;nuevas características&lt;/strong&gt; que vienen con esta nueva versión pueden situarle en posiciones todavía más destacadas.&lt;br /&gt;
&lt;br /&gt;
Estas son las novedades que incorporará el lenguaje:&lt;br /&gt;
&lt;br /&gt;
Soporte para &lt;strong&gt;Unicode&lt;/strong&gt;&lt;br /&gt;
&lt;br /&gt;
&amp;#160;&amp;#160;&amp;#160;&amp;#160;PHP6 soporta Unicode en la mayoría de sus funciones principales. Esta característica tendrá un fuerte impacto ya que permitirá una mayor capacidad de internazionalización al soportar un conjunto de caracteres mucho mayor mediante sus funciones nativas. &lt;br /&gt;
&lt;br /&gt;
Espacios de nombres (&lt;strong&gt;Namespaces&lt;/strong&gt;)&lt;br /&gt;
&lt;br /&gt;
&amp;#160;&amp;#160;&amp;#160;&amp;#160;PHP6 soporta namespaces. Una manera de evitar colisiones entre los nombres que asignemos a las diferentes clases sin tener que estar elaborando notaciones especificas para evitar este problema. De esta manera al crear tu propio espacio de nombres no tienes que preocuparte por si php tiene una clase con el mismo nombre o si una librería externa podría fallar debido a una colisión en los nombres de clase.&lt;br /&gt;
&lt;br /&gt;
&amp;#160;&amp;#160;&amp;#160;&amp;#160;No es obligatorio el uso de namespaces lo que permite que el código de la versión 5 sea compatible con esta nueva caracteristica. Los namespaces aparecen ya soportados en la version php 5.3&lt;br /&gt;
&lt;br /&gt;
Ejemplo:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;php&lt;br /&gt;
namespace ACC&lt;br /&gt;
class Dummy {}&lt;br /&gt;
$dummy = new ACC::Dummy();&lt;br /&gt;
?&amp;gt;&lt;br /&gt;
&lt;br /&gt;
&lt;strong&gt;SOAP&lt;/strong&gt;&lt;br /&gt;
&lt;br /&gt;
&amp;#160;&amp;#160;&amp;#160;&amp;#160;SOAP es uno de los protocolos empleados por los servicios web soportado en otros lenguajes como JAVA. SOAP permite la interoperativilidad entre diferentes plataformas.&lt;br /&gt;
&lt;br /&gt;
&amp;#160;&amp;#160;&amp;#160;&amp;#160;PHP6 tendra una extensión SOAP que nos permitirá una manera más sencilla de implementar tanto clientes como servidores SOAP&lt;br /&gt;
&lt;br /&gt;
&lt;strong&gt;XML&lt;/strong&gt;&lt;br /&gt;
&lt;br /&gt;
&amp;#160;&amp;#160;&amp;#160;&amp;#160;A partir de PHP5.1 XMLWriter y XMLReader han formado parte del núcleo de PHP lo que permite construir y leer mensajes XML sin tener que preocuparte de los detalles más complejos de este formato. PHP6 mejora esta funcionalidad&lt;br /&gt;
&lt;br /&gt;
Cosas que se han eliminado en PHP6&lt;br /&gt;
&lt;br /&gt;
&amp;#160;&amp;#160;&amp;#160;&amp;#160;Además de los nuevas características añadidas, PHP 6 no tendrá algunas de las funciones y características propias de versiones anteriores. La mayoría de estas características, como register_globlas y safe_mode, son consideradas negativamente en la versión actual. Los que se oponen ha estas modificaciones arguyen que estos cambios provocará el fallo en los scripts actuales en cuanto se actualize a la nueva versión.&lt;br /&gt;
&lt;br /&gt;
Estas con las características eliminadas en la próxima versión de PHP&lt;br /&gt;
&lt;br /&gt;
 &lt;a onclick=&quot;javascript: pageTracker._trackPageview(&#039;/extlink/es.php.net/magic_quotes/&#039;);&quot;  href=&quot;http://es.php.net/magic_quotes/&quot;&gt;magic_quotes&lt;/a&gt;&lt;br /&gt;
 &lt;a onclick=&quot;javascript: pageTracker._trackPageview(&#039;/extlink/es.php.net/register_globals&#039;);&quot;  href=&quot;http://es.php.net/register_globals&quot;&gt;register_globals&lt;/a&gt;&lt;br /&gt;
 &lt;a onclick=&quot;javascript: pageTracker._trackPageview(&#039;/extlink/es.php.net/manual/en/language.variables.predefined.php&#039;);&quot;  href=&quot;http://es.php.net/manual/en/language.variables.predefined.php&quot;&gt;register_long_arrays&lt;/a&gt;&lt;br /&gt;
 &lt;a onclick=&quot;javascript: pageTracker._trackPageview(&#039;/extlink/es.php.net/manual/en/features.safe-mode.php&#039;);&quot;  href=&quot;http://es.php.net/manual/en/features.safe-mode.php&quot;&gt;safe_mode&lt;/a&gt;&lt;br /&gt;
&lt;br /&gt;
&lt;strong&gt;Magic quotes&lt;/strong&gt;&lt;br /&gt;
&lt;br /&gt;
&amp;#160;&amp;#160;&amp;#160;&amp;#160;Por razones de portabilidad, rendimiento e inconveniencia se recomienda ya no utilizar esta característica. magic_quotes escapa cadenas que proceden de datos introducidos por el usuario $_POST, $_GET, $_REQUEST y que podrían ser empleados en una sentencia SQL originando fallos en la seguridad de la aplicación si se introducen determinadas secuencias de caracteres. Cuando se elimine esto de PHP también desaparecerá la función get_magic_quotes_gpc(). En su lugar para eliminar este riesgo de seguridad debemos recurrir a funciones del estilo mysql_escape_string para mysql y pg_escape_string para PostgreSQL.&lt;br /&gt;
&lt;br /&gt;
&lt;strong&gt;Register globals&lt;/strong&gt;&lt;br /&gt;
&lt;br /&gt;
&amp;#160;&amp;#160;&amp;#160;&amp;#160;Register globals permitía inicializar variables a partir de datos externos ($_GET,$_POST,$_REQUEST) lo que potencialmente podría producir importantes errores en la aplicación y su seguridad. Register globals paso de estar activo a desactivo por defecto a partir de la versión 4.2&lt;br /&gt;
&lt;br /&gt;
&lt;strong&gt;Register long arrays&lt;/strong&gt;&lt;br /&gt;
&lt;br /&gt;
&amp;#160;&amp;#160;&amp;#160;&amp;#160;Se eliminan los variables superglobales $HTTP_*_VARS se ha mantenido por razones de compatibilidad, aunque se aconsejaba dejar esta característica deshabilitada para mejorar el rendimiento de los scripts.&lt;br /&gt;
&lt;br /&gt;
&lt;strong&gt;Safe mode&lt;/strong&gt;&lt;br /&gt;
&lt;br /&gt;
&amp;#160;&amp;#160;&amp;#160;&amp;#160;Cuando esta habilitada safe mode se aseguraba de que el propietario del fichero que se está ejecutando coincida con el propietario del fichero que se está empleando. Originariamente fue un intento para securizar determinadas operaciones en un entorno en el que el servidor estaba compartido.&lt;br /&gt;
&lt;br /&gt;
&lt;strong&gt;Etiquetas PHP&lt;/strong&gt;&lt;br /&gt;
&lt;br /&gt;
&amp;#160;&amp;#160;&amp;#160;&amp;#160;Ya no se permiten ni etiquetas cortas &lt;? ?&gt; ni el formato ASP &lt;% %&gt; para encerrar fragmentos de código php&lt;br /&gt;
&lt;br /&gt;
&lt;strong&gt;FreeType 1 y GD1&lt;/strong&gt;&lt;br /&gt;
&lt;br /&gt;
&amp;#160;&amp;#160;&amp;#160;&amp;#160;El soporte para FreeType 1 y GD 1 será eliminado completamente de PHP debido a que ambas librería ya no son mantenidas desde hace bastante tiempo. Las nuevas versiones de ambas librerías si que seguirán en PHP ya que proporcionan mejor funcionalidad.&lt;br /&gt;
&lt;br /&gt;
&lt;strong&gt;Ereg&lt;/strong&gt;&lt;br /&gt;
&lt;br /&gt;
&amp;#160;&amp;#160;&amp;#160;&amp;#160;La extensión ereg también desaparecerá. En su lugar ya tenemos las expresiones regulares compatibles Perl (PCRE - Perl-Compatible Regular Expressions). De esta manera ereg() y eregi() pueden ser sustituidas por preg_match() y ereg_replace() y ereg_replacei() por preg_replace.&lt;br /&gt;
&lt;br /&gt;
&lt;strong&gt;PHP 5.3&lt;/strong&gt;&lt;br /&gt;
&lt;br /&gt;
&amp;#160;&amp;#160;&amp;#160;&amp;#160;Algunas de las características mencionadas previamente para la nueva versión ya han sido portadas a la versión 5.3 de PHP para que el cambio de versión no sea tan violento como son los Namespaces y la inclusión en el núcleo de PHP de XMLReader y XMLWriter.&lt;br /&gt;
 
    </content:encoded>

    <pubDate>Fri, 09 May 2008 22:13:19 +0200</pubDate>
    <guid isPermaLink="false">http://www.novanebula.net/blog/archives/98-guid.html</guid>
    
</item>
<item>
    <title>Temas piramidales (SEO)</title>
    <link>http://www.novanebula.net/blog/archives/97-Temas-piramidales-SEO.html</link>
            <category>Ocio</category>
    
    <comments>http://www.novanebula.net/blog/archives/97-Temas-piramidales-SEO.html#comments</comments>
    <wfw:comment>http://www.novanebula.net/blog/wfwcomment.php?cid=97</wfw:comment>

    <slash:comments>0</slash:comments>
    <wfw:commentRss>http://www.novanebula.net/blog/rss.php?version=2.0&amp;type=comments&amp;cid=97</wfw:commentRss>
    

    <author>nospam@example.com (Abraham Covelo)</author>
    <content:encoded>
    Una de las estrategias SEO que se emplean para diseñar desde cero un sitio web es el de los temas piramidales. Los estructuración del un sitio web en temas piramidales presenta ventajas no sólo desde el mundo &lt;strong&gt;SEO&lt;/strong&gt; sino también a nivel organizativo y de usabilidad del sitio. Muchos sitios presente una estructura cercana a esta en mayor o menor medida pero al no comprender en profundidad las ventajas de este tipo de estructuración finalmente el sitio pierde estas ventajas a medida que el sitio crece en tamaño.&lt;br /&gt;
&lt;br /&gt;
Los &lt;strong&gt;temas piramidales&lt;/strong&gt; no son algo nuevo que haya surgido hace poco tiempo sino que ya han sido utilizados desde hace años.&lt;br /&gt;
&lt;br /&gt;
Los sitios basados en temas piramidales son más sencillos de mantener, organizativamente facilitan la tarea de encontrar los contenidos que buscas y de optimizan sus el futuras mejoras y mantenimiento debido a su clara organización. Los temas piramidales se basan en &lt;strong&gt;concepto de tema&lt;/strong&gt;.&lt;br /&gt;
&lt;br /&gt;
¿Que es un tema?&lt;br /&gt;
&lt;br /&gt;
Es la base, la idea común, a partir de la cual desarrollamos nuestro sitio. Es el termino unificador que reune todas las partes de nuestro sitio y que puede englobar todo el contenido de nuestro sitio bajo este concepto.  Es el &lt;strong&gt;keyword&lt;/strong&gt; que define  todo nuestro conjunto de páginas.&lt;br /&gt;
&lt;br /&gt;
Construcción de temas piramidales&lt;br /&gt;
&lt;br /&gt;
La palabra/keyword principal que define el tema principal de tu sitio será la empleada en la página inicial, y todas los niveles debajo de la página principal contendrán variaciones de esta keywords de una manera jerarquizada. Es decir cada keyword debajo de la principal  tendrá a su vez otras keywords (niveles) y actuará como englobador o tema común de todas las que se encuentren por debajo y así sucesivamente. De manera que cuanto más profundizaremos en la estructura del sitio encontraremos keywords cada vez más específicas.&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Este tema principal estará recogido en nuestra página principal soportado por varios subtemas muy relacionados. Para soportar estos subtemas cada uno de ellos tiene otros temas fuertemente relacionados con este subtema y así seguiríamos a través de varios niveles.&lt;br /&gt;
&lt;br /&gt;
Valor SEO&lt;br /&gt;
Sin valor                    Home page (tema principal)&lt;br /&gt;
bajo valor       SubtemaA      SubtemaB     SubtemaC     SubtemaD&lt;br /&gt;
medio valor   kw a1    kw a2   kw b1  kw b2  kw c1  kw c2   kw d1 kw d2&lt;br /&gt;
alto valor  ka1a ka1b ka2a ka2b ..........&lt;br /&gt;
Dinero      $ $ $ $ $ $ $ $ $ $ .....&lt;br /&gt;
&lt;br /&gt;
La teoría de los temas piramidales implica ver al sitio como un todo compartimentado. Comenzado por un contenedor que englobe a todo el sitio tema principal y diseñando subtemas nivel tras nivel para abarcar todo el contenido del sitio. Enlazar cada tema arriba y abajo pero no a través de los temas con diferentes temas padres (esto reforzara las páginas y la popularidad del enlace). &lt;strong&gt;Estructura vertical&lt;/strong&gt; de enlaces NO HORIZONTAL.&lt;br /&gt;
&lt;br /&gt;
Cosas importantes en el diseño de un sitio estructurado en temas piramidales, en cada nivel:&lt;br /&gt;
&lt;br /&gt;
1. La pagina principal APENAS tiene valor SEO. Raramente ranquea bien y tampoco es algo que nos deba preocupar demasiado. Una página principal bien ranqueada con una estructura de este tipo es la excepción y no la regla. Si ranquea bien es generalmente debido a factores externos (off-the-page). Sus únicas funciones es ser usable para los visitantes y servir de alimento(enlaces a los niveles inferiores) a los buscadores que visitan tu sitio web. Intenta también colocar enlaces tan profundos como puedas a los buscadores les gusta el contenido de primer nivel sobre todo en keywords que te interesan especialmente.&lt;br /&gt;
&lt;br /&gt;
2. Para el segundo nivel el valor SEO es más importante pero lo más importante aquí, es también colocar enlaces a los niveles más profundos de tu sitio web y no sólo al siguiente. Enlaces verticales dentro de este subtema arriba y abajo. No horizontales.&lt;br /&gt;
&lt;br /&gt;
3. Valor SEO importante la distinción entre los niveles 4 y 5 puede ser confusa. Suele contener términos muy competitivos y de posicionamiento difícil. Algunos de los enlaces entrantes deberían proceder de la home page.&lt;br /&gt;
&lt;br /&gt;
4. Suele tener el contenido básico de calidad del sitio. Enlázalo verticalmente. Si enlazas con sitios externos procura que sea también contenido muy relacionado.&lt;br /&gt;
&lt;br /&gt;
5. Habitualmente las páginas que traen el dinero. Enlázalo con todas las páginas de sus niveles superiores&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Con toda esa pirámide de keywords el impacto en el posicionamiento de estas keywords será muy importante pues cada una de ellos reforzará a cada una de las demás.&lt;br /&gt;
&lt;br /&gt;
Ventajas temas piramidales:&lt;br /&gt;
1.-Es sencillo tener un sitio web organizado y centrado en el tema principal, a veces cuando un sitio web crece esto se vuelve algo complicado.&lt;br /&gt;
2.-Una correcta organización en temas te permite obtener una diferenciación clara entre las distintas partes de tu web y abarcar keywords especificas y sus variaciones en diferentes secciones.&lt;br /&gt;
3.-Una buena organización en temas tiene un impacto positivo en la selección, fuerza y posicionamiento de tus keywords.&lt;br /&gt;
4.-Una web estructurada en temas piramidales está preparada para el futuro. Los buscadores tienen un estructura organizada, limpia y con términos relevantes que no van a eliminar de sus bases de datos.&lt;br /&gt;
5.-Un web estructura así te permitirá ahorrar tiempo en el futuro&lt;br /&gt;
6.-Muchos de los buscadores actuales usan temas para sus algoritmos de posicionamiento&lt;br /&gt;
&lt;br /&gt;
Buscadores basados en temas, ¿como funcionan?&lt;br /&gt;
&lt;br /&gt;
La diferencia principal es que un buscador basado en temas visita las páginas de tu sitio web y las indexa en conjunto no una a una a media que las va visitando. El buscador basado en temas examina y pondera tu sitio web como un todo en lugar de hacerlo en cada página individualmente. Con este tipo de indexación es más difícil que una página aislada en una web no estructurada en temas obtenga un buen posicionamiento para una keyword que un sitio entero que hable de esta keyword y que reciba y tenga enlaces de keywords muy relacionadas. 
    </content:encoded>

    <pubDate>Thu, 08 May 2008 23:26:11 +0200</pubDate>
    <guid isPermaLink="false">http://www.novanebula.net/blog/archives/97-guid.html</guid>
    
</item>

</channel>
</rss>