Ejecutar aplicación local desde el navegador (Chrome en windows)

Este pequeño workaround nos permitirá ejecutar una aplicación local desde "el navegador" sin que al usuario le parezca que "sale" de él. Es útil si tenemos que lanzar algo en batch.

El truco está en salvar un marcador en la barra de marcadores cuya url es un ejecutable o un bat que está en el sistema local.

Para evitar que el navegador nos muestre el contenido del fichero en vez de ejecutarlo, tenemos que crear un nuevo "protocolo" que en realidad no es más que la ejecución de una shell para nuestro programa.

Para crear el protocolo, creamos una entrada de registro como, por ejemplo, appurl.reg

Windows Registry Editor Version 5.00

[HKEY_CLASSES_ROOT\appurl]
@="URL:AutoHotKey AppURL Protocol"
"URL Protocol"=""

[HKEY_CLASSES_ROOT\appurl\DefaultIcon]
@="appurl.exe,1"

[HKEY_CLASSES_ROOT\appurl\shell]

[HKEY_CLASSES_ROOT\appurl\shell\open]

[HKEY_CLASSES_ROOT\appurl\shell\open\command]
@="\"C:\\directorio\\programa.bat\" \"%1\""
y lo registramos (click derecho-> Combinar). Esto nos crea el "protocolo" appurl. Ahora creamos el fichero
c:\directorio\programa.bat
con nuestro código.

Finalmente, en el chrome vamos a Marcadores->Añadir página y en la url ponemos

appurl://lo-que-queramos-pasar-a-programaba.bat

Si queremos llamar al protocolo desde chrome, podemos usar

window.location.assign("appurl://algo");


Referencias:
http://www.autohotkey.com/board/topic/71831-application-url-launch-local-application-from-browser/
http://stackoverflow.com/questions/2330545/is-it-possible-to-open-custom-url-scheme-with-google-chrome

Linux networking (ubuntu)

Ver tarjetas de red instaladas en el equipo:

/proc/net/dev

Ver los interfaces up

sudo ifconfig -s

Configuración de los interfaces

/etc/network/interfaces

auto lo
iface lo inet loopback

auto eth1
iface eth1 inet static
  address 192.168.1.2
  netmask 255.255.255.0
  network 192.168.1.0
  broadcast 192.168.1.255
  gateway 192.168.1.1
  dns-nameservers 8.8.8.8

Habilitar/deshabititar interface

sudo ifup eth1
sudo ifdown eth1

Hacer cambios temporales

sudo ifconfig eth1 10.0.0.100 netmask 255.255.255.0
sudo route add default gw 10.0.0.1 eth1

para añadir servidor dns, poner ip en /etc/resolv.conf

para purgar esta config temporal 

ip addr flush eth1

Cambiar la configuración de hardware de la tarjeta

sudo apt-get install ethtool
sudo ethtool eth1

Si queremos fijar algún parámetro, editamos /etc/networking/interfaces y añadimos un pre-up:

auto eth1
iface eth1 inet static
pre-up /usr/bin/ethtool -s eth1 speed 1000 duplex full





Propietats emergents de sistemes complexes

Bona entrada de Carlos Gershenson sobre les propietats emergents dels sistemes complexes al blog de l'Investigación y Ciencia. Són emergents perquè les observam al sistema però no a cap de les seves parts. La propietat està causada per les interaccions entre els components més que per els components per si mateixos.

Generalment, no observam la propietat emergent a escales inferiors perquè les interaccions només són observables a escales superiors. El problema és que la metodologia reduccionista que tan bon servei ens presta a l'hora de simplificar l'anàlisi d'un sistema pot fer-nos perdre alguna d'aquestes característiques. Tendim a pensar que els components són reals peró les seves interaccions no.

Exemples de propietats emergents serien la vida (observant una molècula d'una cèl.lula, no podem dir que és viva) o la nostra ment (observant una neurona no podem afirmar l'existència de la ment, la propietat sorgeix per les interaccions de milions d'elles).

Instalación de Oracle Database 12 en Oracle Linux 6

Instalación del entorno gráfico
Bajar el Oracle Linux 6 de oracle.com y arrancar. Como el instalador es gráfico, tenemos que instalar un escritorio obligatoriamente. Puede ser gnome o KDE.

Si estas instalando en entorno virtual, puedes usar dos CDs, uno con el disco de boot y otro con el sistema completo.

Cuando nos pida seleccionar elementos, escojemos Internet->Navegador web y  en Escritorio tenemos que seleccionar X Windows, Escritorio y todo lo relacionado con gnome.

Nombre de máquina y configuración de red
Una posibilidad es dbserver.nombre_empresa.com
En configuración de red sólo tenemos que activar la opción "Conectar la tarjeta al inicio del sistema".

Espacio en disco y creación de particiones
Dejar un mínimo de 40Gb de disco y 2Gb de RAM.

En el asistente debemos seleccionar "Crear las particiones manualmente". Creamos una partición primaria en ext4 y otra de swap. Seleccionar en cada caso las opciones. Primero creamos la partición primaria, le ponemos el tamaño y la damos como activa. Seguidamente creamos la partición de swap con el File System "Swap" y le damos "ocupar todo el espacio disponible".

Tener en cuenta que el espacio de swap debe ser 1,5 veces el de la memoria RAM. Por lo tanto, nos quedará

partición primaria: Tamaño_disco - (1,5 * RAM)
swap: todo lo que quede

Para crear la partición primaria: Crear->Partición estándar
Punto de montaje: /
Sistema de archivos ext4
Tamaño: (mínimo 40000MB)
Tamaño fijo
Forzar partición primaria


Para el área de swap:
Crear->Partición estándar
Sistema de archivos sqap
Completar hasta el máximo aceptable


Usuario
Cuando nos pida el nombre de usuario darle el nombre "oracle".

Terminar el asistente y hacer reboot.

Entrar en el entorno gráfico como usuario oracle.


Primero tenemos que configurar el entorno para que cumpla con las especificaciones de oracle, tenemos que buscar el fichero de preinstalación adecuado a nuestra versión, en este momento es

oracle-rdbms-server-12cR1-preinstall

Abrir terminal y hacer

su
cd /etc/yum.repos.d/
wget http://public-yum.oracle.com/public-yum-ol6.repo
yum install oracle-rdbms-server-12cR1-preinstall
yum update

[ --- Snapshot --- ]
Hacer reboot

Cuando volvamos a abrir sesión, editar el la configuración de selinux para bajar la protección

su
vi /etc/selinux/config
cambiar la linea SELINUX=enforcing por SELINUX=permissive


Con el firefox, entrar en la página web de Oracle y bajar los dos ficheros zip de Oracle Database 12c


Crear la estructura de directorios

su
cd /
mkdir -p /u01/app/oracle/product/12c/db_1

Donde "oracle" es el nombre de usuario y por tanto será el oracle path de este usuario.

Damos propiedad al grupo oinstall.

chown -R oracle:oinstall /u01
chmod -R 775 /u01

Salimos de su

exit

Editamos el profile del usuario oracle para que incluya el path

cd /home/oracle
vi .bash_profile

Y añadimos:

ORACLE_HOSTNAME=dbserver.empresa.com; export ORACLE_HOSTNAME
ORACLE_UNQNAME=orcl; export ORACLE_UNQNAME
ORACLE_BASE=/u01/app/oracle; export ORACLE_BASE
ORACLE_HOME=$ORACLE_BASE/product/12c/db_1; export ORACLE_HOME
ORACLE_SID=orcl; export ORACLE_SID

PATH=$ORACLE_HOME/bin:$PATH; export PATH

LD_LIBRARY=$ORACLE_HOME/lib:/lib:/usr/lib; export LD_LIBRARY
CLASSPATH=$ORACLE_HOME/jlib:$ORACLE_HOME/rdbms/jlib; export CLASSPATH

Guardamos y recargamos

. .bash_profile

Vamos al directorio de descargas y unzipeamos

cd Descargas
unzip *.zip

Vamos al directorio database y arrancamos la instalación (sin ser root)

cd database
./runInstaller

Se arranca el instalador gráfico Oracle Universal Installer. Introducimos los datos.


Antes de instalar podemos guardar el archivo de respuesta, que nos puede servir en el futuro como referencia de la instalación.

Cuando el instalador termine nos pedirá que ejecutemos unos scripts como root.

Para comprobar la instalación abrimos una terminal y hacemos

sqlplus / as sysdba
startup;
select sysdate from dual;


probar el manager accediendo a 

https://localhost:1158/em

Logear como SYS y connect as SYSDBA, comprobar que la instancia esté levantada.

Si tenemos problemas con el listener.ora o el tnsnames.ora, estos apuntes pueden ayudar:

1) Comprobar el nombre de la base de datos

select name, value from v$parameter where name='db_name';

2) comprobar el nombre de la instancia

select instance_name, host_name from v$instance;

Con estos datos, en el tnsnames.ora, comprobamos el nombre del servicio:

=
(DESCRIPTION =
  (ADDRESS=
    (PROTOCOL = TCP)
    (HOST = )
   (PORT = 1521))
)
 (CONNECT_DATA =
   (SERVICE_NAME=)
 )
)

Y en el listener.ora:

SID_LIST_LISTENER = 
  (SID_LIST = 
    (SID_DESC =
      (SID_NAME = )
      (ORACLE_HOME = /u01/app/oracle/product/XXX/db_1)
   )
 )
)


Para hacer las comprobaciones, podemos usar los comandos:

lsnrctl stat
lsnrctl start

lsnrctl stop


Finalmente, para hacer el startup automático, editamos /etc/oratab y ponemos Y en el último caracter.  Seguir este tutorial, o este para terminar de configurar el auto start/stop.

Para crear el primer usuario y otorgarle permisos podemos usar algo parecido a esto.

En caso necesario, abrir el puerto 1521 en el cortafuegos.

[ --- Snapshot --- ]

Referencias:
Series de DBASoup http://www.youtube.com/watch?v=enzODUcYERI