Ir al contenido principal

Haciendo respaldos automaticos

Buscando y buscando no entre ningun programa que pudiera generar respaldos automaticos en windows. en linux con la linea de comando seria bastante sencillo hacerlo.

Asi que me aburri de buscar y empeze a buscar y desarrollar en python, el resultado de esto fue bastante bueno. Aqui dejo el codigo


import os
import shutil
import datetime

date = datetime.date.today()
dateDelete = date - datetime.timedelta(weeks=4)

sourcePath = r'F:\develop\trunk'
destRootPath = r'U:\respaldoAutomaticos'
destPath = destRootPath + "\\" + str(date) + " _respaldo"

print ("find old Directories")
try:
for directory in os.listdir(destRootPath):
try:
array = directory.split(" ")[0].split("-")
dateDir = datetime.date(int(array[0]), int(array[1]), int(array[2]))
if dateDir < dateDelete:
print ("try drop Directory" + destRootPath + "\\" + directory)
shutil.rmtree(destRootPath + "\\" + directory)
print ('Directory "' + destRootPath + "\\" + directory + '" Deleted')
except Exception, e:
print e
except Exception, e:
print e

for root, dirs, files in os.walk(sourcePath):
dest = destPath + root.replace(sourcePath, '')

if not os.path.isdir(dest):
os.mkdir(dest)
print ('Directory created at: ' + dest)

for f in files:
oldLoc = root + '\\' + f
newLoc = dest + '\\' + f

if not os.path.isfile(newLoc):
try:
shutil.copy2(oldLoc, newLoc)
print ('File ' + f + ' copied.')
except IOError:
print ('file "' + f + '" already exists')

y para automatizar estos respaldos simplemento lo agregamos a las tareas programadas de windows y listo.

Como funciona: Toma una carpeta de origen y la deja en una de destino, en mi caso "U:\respaldoAutomaticos" es una unidad de red :D.

En el destino crea una carpeta con la fecha mas un texto, esto nos sirve para eliminar los respaldos antiguos.

cada vez que se ejecute el programa en dias distinto, genera un respaldo completo en una nueva carpeta.

Ademas borra los respaldos anteriores a 4 semanas. Asi no gastamos mucho espacio en respaldo.

Por Mejorar: Estoy pensando en implementar una variación, que deje en el destino solo un único respaldo, copiando solo los archivos modificados y nuevos, este vendría siendo otro programa, por que personalmente a mi me interesa tener varias respaldos.

En fin tenemos nuestro programa de respaldo automático o backup automáticos que funciona en windows.

por ultimo el tema del performance, anda super bien, por eso no comprimí el archivo, para que mientras respalde podemos seguir usando nuestra estación de trabajo sin problema.




--
Atte.
Victor Hugo Saavedra
http://vhspiceros.blogspot.com

Comentarios

Publicar un comentario

Entradas populares de este blog

buscar columnas en todas las tablas Sql Server

me vi en la necesidad de buscar en todas las tablas de una base de datos por un comodin ya que no conocia bien el modelo de la base de datos.
aqui les dejo el sql.
SELECT sysobjects.name AS table_name, syscolumns.name AS column_name, systypes.name AS datatype, syscolumns.LENGTH AS LENGTH FROM sysobjects INNER JOIN syscolumns ON sysobjects.id = syscolumns.id INNER JOIN systypes ON syscolumns.xtype = systypes.xtype WHERE (sysobjects.xtype = 'U') and (UPPER(syscolumns.name) like upper('%myFieldName%')) ORDER BY sysobjects.name, syscolumns.colid


Solo tienen que cambiar donde dice "myFieldName"por el nombre de la columna que desean buscar.

--
Atte.
Victor Hugo Saavedra
http://vhspiceros.blogspot.com

"is not null" o "<> Null" en Sql Server

Trabajando con NHinbernate. mapeando unas clases, guardaba unos datos y hacia esta consulta para ver si estaba bien:


select * from table where campo <> NULL;


pero no me arrojaba los datos que queria y luego darle y darle vueltas hice esta consulta.

select * from table where campo is not NULL;


y ahi me di cuenta que el mapeo de Hibernet, y los cambios que habia hecho estaban bien. perdi toda una mañana de trabajo por esto :(.


Asi no es lo mismo "is not null" o "<> Null", por lo menos en Sql Server

Entonces ahora cada vez que quiera preguntar si un capo no es Null, voy a preguntar por "IS NOT NULL".

En caso de que quiera saber si un campo es null "IS NULL".




--
Atte.
Victor Hugo Saavedra
http://vhspiceros.blogspot.com

Aplicación y Aplicativo

Cada dia es mas comun escuchar de aplicativo para referirse a un programa informatico,  esto puede sonar bastante cool, pero la verdad es que no lo es. El termino "aplicativo"  no existe en informatica, la palabra correcta para referirse a un programa informatica es "Aplicacion".

Las definiciones segun la real academedia española son;


Aplicación (informatica): Programa preparado para una utilización específica, como el pago de nóminas, formación de un banco de términos léxicos, etc.Aplicativo: Que sirve para aplicar algo.
y ustedes van a seguir usando aplicativo en vez de aplicación
Links:
http://buscon.rae.es/draeI/SrvltConsulta?TIPO_BUS=3&LEMA=aplicativo http://buscon.rae.es/draeI/SrvltConsulta?TIPO_BUS=3&LEMA=aplicaci%F3n


--
Atte.
Victor Hugo Saavedra
http://vhspiceros.blogspot.com