miércoles, 24 de diciembre de 2014

Como programar backups con SQL Server 2012

Estos son los pasos para programar backups con Microsoft SQL Server 2012 :

1. Iniciar sesión en el Microsoft SQL Server Management Studio ( SSMS ) con las credenciales necesarias para hacer tareas de mantenimiento.

2. En el SSMS abrimos la opción de Management > Maintenance plan y marcamos la opción de New Maintenance Plan... 



3. Indicamos un nombre para el nuevo plan de mantenimiento:



4. En este momento esta creado el nuevo plan de mantenimiento:


5. En la barra de la izquierda, abrimos las herramienta de la Toolbox y clicamos para crear una nueva tarea de backup:


6. Se creara una nueva tarea de copia sobre la que tendremos que hacer doble clic para editar las propiedades.


7. En las propiedades de la tarea de backup podemos seleccionar:

  • Backup type: tipo de copia de seguridad Full, Diferential, Transactional Log 
  • Databases(s): Seleccionamos la bases o bases de datos para realizar backups. 
  • Backup to: Indicamos la ubicación donde queremos dejar las copias de seguridad.



8. Después de crear la tarea de backup, creamos la tarea de limpieza de los archivos: 


9. Hacemos doble clic sobre la tarea recién creada


10. En las propiedades de la tarea, indicamos el tipo de tarea de limpieza y el tiempo de vida de los backups, para poder eliminarlos cuando este haya expirado.


11. Una vez completado este formulario, podemos guardar el plan de mantenimiento.

12. Despues de salvar el Maintenance plan, veremos que se ha creado una nueva tareas en el SQL Server Agent -> Jobs . Para poder programar la tarea , abriremos las propiedades.


12. En las propiedades vamos a la página de Schedules y creamos una nueva programación.


13. En la nueva programación, solo tenemos que indicar cuando queremos que se ejecute el trabajo de backup según nuestras directivas de protección de datos.


14. Una vez completada la programación, podemos lanzar el trabajo de forma manual con la opción Start Job at Step... 


Y ya tenemos programada una tarea de backup, para ver el historial de la tarea tenemos que clicar sobre View History : 




jueves, 18 de diciembre de 2014

Problemas con las Transport Rules de Exchange 2010


Hoy, al hacer una prueba con un nuevo servicio de antispam externo me he encontrado con un error de estos que te tienen entretenido medio día.


Nuestro servicio de filtro de spam anterior marcava todos los emails que considerava como no desados con un header X-SPAM y un valor del 0 al 9.

 Si el valor era 9, el MS Exchange mediante una Transport Rule lo envía directamente a la Junk mail ( Carpeta de correo no deseado ) del usuario.


Al probar el nuevo servicio de filtro de SPAM externo, este también usa la cabecera X-Spam, pero usando otros valores:


Resulta que la transport rule que tenia configurada al comprobar la condición la resuelve como TRUE y enviava todos los emails a la carpeta de Junk email.

La única explicación que encuentro es que la regla esta mal enunciada (o mal programada) y no se trata de un matches si no de un contains y por eso el Exchange me marcaba todo como SPAM. 


Para que puedan convivir los dos servicios de filtrado de email en mi servidor de correo finalmente he tenido que usar otro método para marcar los emails, añadiendo una etiqueta SPAM en el asunto del mensaje.





martes, 16 de diciembre de 2014

Raw Device Mapping no esta disponible


Me he encontrado con que al intentar añadir un disco duro usando Raw Device Mapping presentada desde un dispositivo SAS ( HP P2000 G3 SAS ) la opción no se puede seleccionar en las Propiedades de la VM al agregar una nueva unidad de disco.



Esto ocurre porque vmware solo marca esta opción si encuentra unidades de disco disponibles para ser mapeadas. En este caso los discos SAS son detectados como discos locales y por diseño estos discos no aparecen disponibles para hacer RDM .

Para poder mapear estas LUNs hay que deshabilitar el filtro RdmFilter.HbaShared en los ESX . Para desactivar este filtro hay que ir a: Configuration > Software > Advanced Settings > RdmFilter y desactivar el filtro:


Y entonces las LUNs estarán accesibles para ser mapeadas usando RDM en las VMs.


Links:
https://communities.vmware.com/message/1668266
http://www.experts-exchange.com/Software/VMWare/Q_27837858.html

lunes, 16 de junio de 2014

Powershell Script para dar de alta mailbox de Exchange


Esta mañana tenia que crear varias cuentas de correo a partir de un listado de Excel, con usuarios en el que no sabia que usuarios estaban ya dados de alta, que usuarios tenian Mailbox y cuales eran usuarios nuevos.

Como eran un montón de usuarios me he dedicado ha hacer un script de Powershell que lea un CSV (creado a partir del Excel)  que comprueba si el usuario existe y crea el buzón con los parámetros deseados.

Lo primero es decir que el Excel tiene que tener un formato parecido a este:

Name;Alias;Username;Password
Hannibal Smith;asmith;asmith@ateam.local;password
M. A. Barracus;mabarracus;mabarracus@ateam.local;password
H. M. Murdock;murdock;murdock@ateam.local;password

Una vez tenemos el CSV con un formato parecido, el powershell script es el siguiente:


$listado = Import-Csv '.\<listado>.csv' -Delimiter ';'

$basededatos = "<base de datos>"
$unidadorganizativa = "<unidad organizativa>"
foreach ($user in $listado) {

$usuario = $user.Usernameecho "//////////////////////////////////"echo "## CREAR BUZON USUARIO $usuario ##"If (get-mailbox $user.username -ErrorACtion SilentlyContinue) {
echo "EL BUZON $usuario YA EXISTE"
}Else{
echo "El buzón de $usuario no existe" If (get-user $usuario -ErrorACtion SilentlyContinue) {
get-user -Identity $usuario echo "HABILITAR BUZON DEL USUARIO $usuario" enable-mailbox -identity $usuario -Database $basededatos -Alias $user.alias
}Else{
If (!(get-user $usuario -ErrorACtion SilentlyContinue)){ echo "CREAR USUARIO Y HABILITAR BUZON PARA $usuario" new-mailbox -UserprincipalName $usuario -Alias $user.alias -Name $user.name -Database $basededatos -OrganizationalUnit $unidadorganizativa -Password (ConvertTo-SecureString $user.Password –AsPlainText –force)}
}
}echo "\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\"
}