miércoles, 6 de marzo de 2019

tunel via ssh usando putty

El protocolo de ssh permite generar túneles sobre las conexiones que se abren a un servidor. Esto permite que un puerto local sea re-enviado a un puerto en el servidor remoto o un puerto en el servidor remoto, sea reenviado a un puerto local. Con esta característica se puede implementar vpn simples, por ejemplo, acceder a un sitio web o consola remota desde la conexión local.

La aplicación putty permite configurar esto en forma online en una conexión, sin desconectarse.

Ejemplo de re-envio de puerto local 8888 al puerto remoto 80
Con esta configuración si localmente desde un browser se conecta a la url http://127.0.0.1:8888/ este es re-enviado al 127.0.0.1 puerto 80, la ip remota puede ser cualquier ip que el servidor remoto pueda alcanzar












Ejemplo de re-envio de puerto remoto 9999 al puerto local 80
Con esta configuración si alguien se conecta en el lado remoto al puerto 9999 sera reenviado al puerto local 80.



Espero que esto les sea útil

lunes, 4 de marzo de 2019

Ejecutar una copia scp desde el "task manager" de windows

En linux es relativamente simple programar una copia automática entre dos servidores via scp y crontab.
Pero hacer la copia desde un windows a un linux es algo mas complejo, pero igual de posible.
  • Primero, se necesita instalar winscp, el cual se puede bajar desde aqui.
  • Obtener la key publica del servidor linux al cual se debe copiar los archivos, para esto usar uno de los siguientes comandos según al tipo de key en el servidor linux

ssh-keygen -l -f /etc/ssh/ssh_host_rsa_key
ssh-keygen -l -f /etc/ssh/ssh_host_dsa_key
ssh-keygen -l -f /etc/ssh/ssh_host_ecdsa_key

  • Generar un script indicando que ejecutara el winscp:
    • primero abrir la conexión, esto puede ser con usuario y contraseña o certificado digitan, se debe agregar el hostkey del destino para seguridad.
    • ejecutar el comando de copia o sincronización, en el ejemplo se sincroniza la carpeta de windows al servidor linux.
Ejemplo del script 
open sftp://usuario:contraseña@192.168.20.16/ -hostkey="ssh-rsa 2048 25:d8:94:4b:a2:38:ff:2c:49:3d:79:e2:a0:18:55:f6"
synchronize remote C:\origen /destino
exit

  • Programar en el "task manager" de windows la ejecución del comando siguiente:
Programa: "C:\Program Files (x86)\WinSCP\WinSCP.exe"
Argumentos: /script="c:\path_al_script\script.txt"  /ini=nul

Espero que les sea util, para mas detalles de los comando en winscp ver aqui.
 

domingo, 3 de marzo de 2019

¿Como crear y modificar un pdf desde .net C# ?

Un cliente tiene una aplicación web que generaba un certificado en pdf para sus empleados pero sin código de verificación o de autenticación. El proveedor de la aplicación no tenia entre sus planes agregar este código a los certificados, así que me solicitaron agregar un código a estos pdf.
La aplicación original estaba generada en .net con C#, así que debía generar el pdf original, capturarlo, modificarlo agregando el código de autenticación y a url de verificación.
Revisando en internet por librerías que modificaran los pdf, me encontré con
Spire.PDF for .NET , esta librería permitía crea, modificar archivos pdf y tiene una versión gratis que permite crear pdf de hasta 10 hojas y como solo necesita modificar 1, fue perfecta para  mi caso.

Tiene buenos tutoriales para usar esta librería, ejemplos en C#. Todas mis dudas las pude resolver con el soporte web.

Al final genere una nueva pagina para mi cliente, que tenias solo 30 lineas de código, agregando la información que solicitada:
  • Generar un pie de pagina donde apareciera el código de verificación.
  • Agregar la url de verificación
  • Colocar una linea recta que destacara el contenido

sábado, 2 de marzo de 2019

Habilitar ping en windows server 2016

Para habilitar el ping en windows server 2016, se debe ir a "Herramientas Administrativas de Windows", seleccionar "Firewall de windows con seguridad avanzada".
Seleccionar "Reglas de entrada"






Buscar la regla "Supervisión de máquina virtual (Solicitud de eco - ICMPv4 de entrada)" y habilitarla haciendo click con el botón derecho.



debe quedar así:


Ya tienes ping al servidor sin bajar el firewall

Que versiones son compatibles de MSSql con windows server 2016

Al realizar la migración de bases de datos para un cliente, el cual había adquirido Windows Server 2016, debí revisar la matriz de compatibilidad con mssql, la cual arrojo la siguiente información

Windows Server 2016 es compatible con:
  • Microsoft SQL Server 2012
  • Microsoft SQL Server 2014
  • Microsoft SQL Server 2016
  • Microsoft SQL Server 2017
  • Microsoft SQL Server 2016
  • Microsoft SQL Server 2019

La mitad de las bases de datos del cliente son Microsoft SQL Server 2008, las cuales solo están soportadas hasta Windows 2012.

fuentes:
https://docs.microsoft.com/en-us/windows-server/get-started/server-application-compatibility
 https://docs.microsoft.com/en-us/sql/sql-server/install/hardware-and-software-requirements-for-installing-sql-server?view=sql-server-ver15

Instalación rapida de kvm manager de oracle

 Para instalar kvm manager de oracle se deben seguir los siguientes pasos: Instalar Oracle Linux 7 configurar el fqdn en el archivo /etc/hos...