2015/09/11

Copiar archivos con conexiones lentas (windows)

La alternativa libre y válida para GNU/Linux, Mac y Windows es sin duda usar RSync, pero si estás en un windows desde Windows Vista, microsoft incorporado robocopy.exe como parte de la instalación estándar. La herramienta robocopy de línea de comandos es realmente útil para la copia masiva de ficheros en entornos windows, pudiendo programar con muchas opciones las copias, sincronizar carpetas, etc...

Entre las virtudes de este programa frente a una simple copia de ficheros con la interfaz de usuario o el comando "copy" están:

  • Posee un indicador de progreso de la copia.
  • Es tolerante a interrupciones en la copia de archivos.
  • Realiza reintentos automáticos si no se puede acceder a un archivo.
  • Permite copiar grandes cantidades de archivos.
  • Duplica información como propiedades, atributos, datos del propietario, fechas, etc. así como los permisos del archivo.

  • Una de las características más interesantes es el parámetro /IPG o Inter Packet Gap, que permite definir un tiempo en milisegundos entre cada paquete enviado. Esto permite que optimizar mucho el uso del ancho de banda en redes lentas o con problemas de conexión para no interferir en otros procesos. Para calcular mejor cómo configurar este parámetros IPG puede ser de utilidad el artículo "Copy files on slow links" y sobre todo su calculadora que me he permitido incorporar aquí traducida al español:

    Calculadora Robocopy IPG
    Tamaño
    Velocidad
    Valor IPG
    Paquetes
    Retardo (hh:mm:ss)
    Tiempo de copia (hh:mm:ss)
    Tiempo Total (hh:mm:ss)


    Para ver todos los parámetros que la herramienta ofrece visitar la página de documentación de microsoft sobre robocopy.
           
       

    2015/07/22

    Tamaño usado y libre de una base de datos Oracle

    Si no eres DBA de una base de datos Oracle y necesitas obtener el tamaño actual de un tablespace puedes obtenerlo con la consulta SQL siguiente:
    SELECT TABLESPACE_NAME,TO_CHAR(SUM(NVL(BYTES,0))/1024/1024/1024, '99,999,990.99') AS "USED SPACE(IN GB)"
     FROM USER_SEGMENTS
     GROUP BY TABLESPACE_NAME
    El valor de espacio libre disponible se obtiene con (sustuir 'MyDbName' con lo que corresponda):
    SELECT TABLESPACE_NAME,SUM(BYTES)/1024/1024 "FREE SPACE(MB)"
     FROM USER_FREE_SPACE
     where TABLESPACE_NAME in ('MyDbName')
     GROUP BY TABLESPACE_NAME;
           
       

    2015/07/17

    Averiguar versión, distribución y kernel desde consola en sistema GNU/Linux

    Para averiguar rápidamente la información de una máquina Linux, lo más sencillo es desde una terminal ejecutar:

    cat /etc/*-release

    Para tener más información del kernel usado, ejecuta:

    uname -a
           
       

    2015/06/03

    Compilar automáticamente Vistas y procedimientos en Oracle

    En ocasiones en bases de datos Oracle donde se almacenan procedimientos y vistas (sobre todo cuando hay relaciones entre estos elementos) pueden producirse errores que provocan que una compilación defectuosa incluso con elementos que estaban correctos.

    En algunos casos estas "descompilaciones" de VIEWs y PROCEDUREs se dan con cierta frecuencia y generan el malfuncionamiento de la base de datos y las aplicaciones que la usan. No he conseguido determinar porqué se produce este fenómeno, pero al menos he visto el modo de poder detectarlo. Para los schemas de BD "MYSCHEMA1" y "MYSCHEMA2":

    
    -- CHECK invalid views 
    --  and 
    -- invalid procedures (MYSCHEMA1, MYSCHEMA2)
    
    
    SELECT OBJECT_NAME, OBJECT_TYPE, owner 
    FROM all_objects 
    WHERE object_type in ('PROCEDURE', 'VIEW') 
    AND owner in ('MYSCHEMA1' , 'MYSCHEMA2') 
    AND status = 'INVALID' 
    ; 
    
    exit;
    

    Una vez detectado los errores de compilación se puede forzar la ejecución de una compilación con la sentencia:

    
    -- Recompile invalid views
    --  and
    -- Recompile invalid procedures
    
    begin
      FOR cur IN (SELECT OBJECT_NAME, OBJECT_TYPE, owner
      FROM all_objects
      WHERE object_type in ('PROCEDURE', 'VIEW')
      AND owner in ('MYSCHEMA1', 'MYSCHEMA2')
      AND status = 'INVALID' ) LOOP
    BEGIN
      if cur.OBJECT_TYPE = 'PACKAGE BODY' then
        EXECUTE IMMEDIATE 'alter ' || cur.OBJECT_TYPE || ' "' || cur.owner || '"."' || cur.OBJECT_NAME || '" compile body';
      else
        EXECUTE IMMEDIATE 'alter ' || cur.OBJECT_TYPE || ' "' || cur.owner || '"."' || cur.OBJECT_NAME || '" compile';
      end if;
    EXCEPTION
      WHEN OTHERS THEN NULL;
    END;
    end loop;
    end;
    /
    exit;
    
    
    Uniendo estas 2 sentencias en un script y programando la tarea en CRON con cierta frecuencia, se puede actuar sin intervención humana sobre este problema automáticamente.
           
       

    2015/05/22

    Sin estilos en Django admin

    Si al subir una aplicación web a tu servidor, por ejemplo en Heroku, y no están accediendo a los estilos y otros ficheros estáticos, puede deberse a una mala configuración de las variables STATIC, STATIC_URL, etc. El tema de servir este tipo de ficheros está bastante bien recogido en la documentación oficial de Django, pero siempre pueden surgir problemas.

    Si la página de administración "/admin" está estilos seguramente aparecen errores tales como:

    static/admin/css/base.css 404 NOT FOUND
    en la consola de desarrollador del navegador.

    Si tienes acceso al servidor puedes probar a importar manualmente los ficheros estáticos con el comando:

    python manage.py collectstatic --noinput
    # En Heroku, algo como...
    heroku run -a MYAPP python manage.py collectstatic --noinput
    y podrás diagnósticar mejor el problema.

    El probable que el problema sea que no existe el directorio que esté definido en settings.py como STATIC, por lo que si en el momento actual no existe, una solución sería crearlo e incluirlo en el repositorio.

    mkdir static
    touch static/empty ## debido a que GIT no lleva cuenta de carpetas vacías
    git add static
    git push -am "Added empty static folder to collect files on the server"

    Más información sobre Heroku, Django y static files

           
       

    2015/05/11

    Eliminar texto en consola al ejecutar script en sqlplus (Oracle)

    Cuando lanzamos un script muy largo a través de sqlplus del modo:
    sqlplus user/pass@db < myscript.sql
    a veces este genera un gran volumen de mensajes en consola que hacen que se pueda ralentizar el proceso. Para evitarlo, se puede apagar esta salida de texto introduciendo al comienzo del script los comandos:
    set termout off
    set feedback off
           
       

    2015/04/25

    Problemas harddisk en Windows 8

    He tenido este problema en un portatil con Windows 8.1:
    KERNEL_DATA_INPAGE_ERROR
    Aquí va lo que he hecho, al volver a arrancar:

    1. Abrir CMD.exe como administrador
    2. Revisar los eventos de sistema con
      eventvwr
    3. Ejecutar:
      DISM /Online /Cleanup-Image /RestoreHealth
    4. Ejecutar y revisar el log de:
      sfc /scannow 
    5. Hacer un chequeo de disco (en el siguiente reinicio) con:
      chkdsk C: /f /r /x

           
       

    2015/01/26

    No cerrar consola de windows al ejecutar un script

    Si tienes un script, por ejemplo de python, que quieres ejecutar en Windows con un acceso directo (asociando la ejecución con "pythonw.exe" para que se lance la consola) vemos que al hacer click sobre él se ejecuta, pero no podemos ver el resultado ya que se cierra rápidamente la terminal de línea de comandos.

    Un truco sencillo es usar el comando "pause" como última línea del script.
    Veamos un ejemplo:

    C:\Python\pythonw.exe myscript.py
    pause
    Con eso antes, tras finalizar el script de python se detiene la ejecución hasta que el usuario pulse una tecla y se puede ver la salida del programa en la consola. Esto también funciona scripts en otros lenguajes MSDOS, los .cmd".