sábado, 27 de agosto de 2011

Usando la última versión de Oracle XE (11.2)

Oracle ofrece una edición gratiuta de la base de datos, llamada XE, que tiene algunos límites respecto a la versión comercial.

Desde Abril está disponible la última versión, 11.2 en beta y sólo para linux 64 bits o windows 32 bits.

En esta versión, los límites de recursos que puede utilizar son:
  • una sola instancia

  • una CPU

  • 11 GB de datos de usuario

  • 1 GB RAM



La instalación en Opensuse 11.4 es simple.


oraculo:/local/soft/oracle/oracle-xe # rpm -Uvh oracle-xe-11.2.0-0.5.x86_64.rpm
Preparing... ########################################### [100%]
1:oracle-xe ########################################### [100%]
Executing post-install steps...

You must run '/etc/init.d/oracle-xe configure' as the root user to configure the database.


En mi caso, ya tenía una instalación de oracle anterior y por lo tanto ya estaba creado el usuario oracle en el sistema operativo, instalados los paquetes necesarios y ajustados los parámetros del kernel.
En una instalación nueva sin estos, son unos pasos más siguiendo el manual, o usando el paquete orarun.

Hecha la introducción, me interesa comentar algo que encontré y no está tan claro: para bajar la base, el script provisto funciona sólo si está configurado el inicio autómatico. Sino, debe bajarse manualmente.

En mi instalación, respondí que no quería inicio automático de la base al momento de la configuración:


oraculo:/local/soft/oracle/oracle-xe # /etc/init.d/oracle-xe configure

Oracle Database 11g Express Edition Configuration
-------------------------------------------------
This will configure on-boot properties of Oracle Database 11g Express
Edition. The following questions will determine whether the database should
be starting upon system boot, the ports it will use, and the passwords that
will be used for database accounts. Press to accept the defaults.
Ctrl-C will abort.

Specify the HTTP port that will be used for Oracle Application Express [8080]:

Specify a port that will be used for the database listener [1521]:

Specify a password to be used for database accounts. Note that the same
password will be used for SYS and SYSTEM. Oracle recommends the use of
different passwords for each database account. This can be done after
initial configuration:
Confirm the password:

Do you want Oracle Database 11g Express Edition to be started on boot (y/n) [y]:n

Starting Oracle Net Listener...Done
Configuring database...Done
Starting Oracle Database 11g Express Edition instance...Done
Installation completed successfully.



Una vez que está funcionando..


oraculo:/local/soft/oracle/oracle-xe # ps -eaf | grep XE | grep pmon
oracle 7663 1 0 01:50 ? 00:00:09 xe_pmon_XE

oracle@oraculo:/u01/app/oracle/product/11.2.0/xe/bin> sqlplus / as sysdba

SQL*Plus: Release 11.2.0.2.0 Beta on Sun Aug 28 13:14:36 2011

Copyright (c) 1982, 2010, Oracle. All rights reserved.


Connected to:
Oracle Database 11g Express Edition Release 11.2.0.2.0 - 64bit Beta

SQL> select * from v$version;

BANNER
--------------------------------------------------------------------------------
Oracle Database 11g Express Edition Release 11.2.0.2.0 - 64bit Beta
PL/SQL Release 11.2.0.2.0 - Beta
CORE 11.2.0.2.0 Production
TNS for Linux: Version 11.2.0.2.0 - Beta
NLSRTL Version 11.2.0.2.0 - Production


..cuando intentamos bajarla, no lo hace:


oraculo:/local/soft/oracle/oracle-xe # service oracle-xe stop

oraculo:/local/soft/oracle/oracle-xe # ps -eaf | grep XE | grep pmon
oracle 7663 1 0 01:50 ? 00:00:09 xe_pmon_XE


Revisando el código de /etc/init.d/oracle-xe se puede ver a partir de la línea 644 que la bajada depende de la configuración escrita en /etc/sysconfig/oracle-xe ($CONFIGURATION):


stop)
if test -f "$CONFIGURATION"
then
if test "$ORACLE_DBENABLED" != "true"
then
exit 0
fi
else
echo "Oracle Database 11g Express Edition is not configured. You must run
'/etc/init.d/oracle-xe configure' as the root user to configure the database."
exit 0
fi
stop
;;


Comprobamos que entramos en el segundo if ($ORACLE_DBENABLED):


oraculo:> grep DBENABLED /etc/sysconfig/oracle-xe
# ORACLE_DBENABLED:'true' means to load the Database at system boot.
ORACLE_DBENABLED=false



La solución simple es bajarla manualmente, y no olvidarse de bajar el listener.

Sino, habilitar el inicio automático:


oraculo: # service oracle-xe enable

oraculo:> grep DBENABLED /etc/sysconfig/oracle-xe
# ORACLE_DBENABLED:'true' means to load the Database at system boot.
ORACLE_DBENABLED=true

oraculo: # service oracle-xe stop
Shutting down Oracle Database 11g Express Edition instance.
Stopping Oracle Net Listener.

oraculo: # ps -eaf | grep XE
root 22607 7011 0 13:00 pts/0 00:00:00 grep XE


miércoles, 24 de agosto de 2011

Variables de paquetes edicionados

¿Que ocurre con los valores de las variables públicas en paquetes que tienen varias ediciones?

Esta fue una pregunta del público (gracias Victoria!) al final de mi charla sobre 11gR2 en la JIAP, explorando las posibilidades de la nueva funcionalidad Edition-Based Redefinition (EBR).

Aprovecho a desarrollar un ejemplo simple que muestra este comportamiento, donde se comprueba que cada edición del paquete mantiene su estado. Está aclarado en el manual aquí.

Esto es algo más a considerar si pensamos usar EBR para hacer actualización de versiones de aplicativos y minimizar el tiempo en que la aplicación está fuera de línea.

Este ejemplo es usando 11.2.0.2 enterprise:

1) Levantamos la base:


oracle@oraculo:~> sqlplus / as sysdba

SQL*Plus: Release 11.2.0.2.0 Production on Wed Aug 24 00:02:33 2011

Copyright (c) 1982, 2010, Oracle. All rights reserved.


Connected to an idle instance.

SQL> startup

ORACLE instance started.

Total System Global Area 1043886080 bytes
Fixed Size 2233088 bytes
Variable Size 645926144 bytes
Database Buffers 390070272 bytes
Redo Buffers 5656576 bytes
Database mounted.
Database opened.

SQL> select * from v$version;

BANNER
--------------------------------------------------------------------------------
Oracle Database 11g Enterprise Edition Release 11.2.0.2.0 - 64bit Production
PL/SQL Release 11.2.0.2.0 - Production
CORE 11.2.0.2.0 Production
TNS for Linux: Version 11.2.0.2.0 - Production
NLSRTL Version 11.2.0.2.0 - Production


Creamos usuario para hacer la prueba

SQL> create user pru identified by pru;

User created.

SQL> grant dba to pru;

Grant succeeded.


Habilitamos EBR:

SQL> ALTER USER pru ENABLE EDITIONS;

User altered.

SQL> conn pru/pru
Connected.


Creamos el paquete PP con la variable VN y un par de procedimientos para incrementar y mostrar su valor:

SQL> create or replace package pp as
-- variable pública
vn number;
--procedimientos que usan la variable
procedure muestro;
procedure suma (n in number);
end;
/

Package created.

SQL> create or replace package body pp as
procedure muestro is
begin
dbms_output.put_line('vn vale: '||pp.vn);
end;
procedure suma (n in number) is
begin
pp.vn := nvl(pp.vn,0) + n;
end;
end;
/

Package body created.


Vemos en que edición quedó creado:

SQL> select edition_name, name, max(line)
from DBA_SOURCE_AE
where name = 'PP'
group by edition_name, name;

EDITION_NAME NAME MAX(LINE)
------------------------------ ------------------------------ ----------
ORA$BASE PP 13


Cargamos el valor 5 en la variable:

SQL> set serveroutput on;
SQL> exec pp.suma(5);

PL/SQL procedure successfully completed.

SQL> exec pp.muestro;
vn vale: 5

PL/SQL procedure successfully completed.


Ahora creamos una nueva edición y trabajamos en ella:

SQL> create edition e0;

Edition created.

SQL> ALTER SESSION SET EDITION = e0;

Session altered.


No creamos nada todavía, así que el paquete sigue siendo el original.
¿Cuanto vale la variable?. Sumamos uno y vemos:

SQL> exec pp.suma(1);

PL/SQL procedure successfully completed.

SQL> exec pp.muestro;
vn vale: 1

PL/SQL procedure successfully completed.


No se mantiene el valor que cargamos en la edición anterior (5), sino que se inicializó en esta edición.

Validamos en qué edición estamos trabajando:

SQL> SELECT SYS_CONTEXT('USERENV', 'CURRENT_EDITION_NAME'),
SYS_CONTEXT('USERENV', 'SESSION_EDITION_NAME')
FROM DUAL;

SYS_CONTEXT('USERENV','CURRENT_EDITION_NAME')
--------------------------------------------------------------------------------
SYS_CONTEXT('USERENV','SESSION_EDITION_NAME')
--------------------------------------------------------------------------------
E0
E0


Ahora cambiamos el código del paquete en esta edición, para poder diferenciarlo del anterior.

El texto desplegado incluye "2.0" y suma el doble de lo que se pide.
SQL> create or replace package pp as
vn number := 0;
procedure muestro;
procedure suma (n in number);
end;
/

Package created.

SQL> create or replace package body pp as
procedure muestro is
begin
dbms_output.put_line('vn 2.0 vale: '||pp.vn);
end;

procedure suma (n in number) is
begin
pp.vn := nvl(pp.vn,0) + n*2;
end;
end;
/

Package body created.



Comprobamos las versiones existentes del paquete

SQL> select edition_name, name, max(line)
from DBA_SOURCE_AE
where name = 'PP'
group by edition_name, name;

EDITION_NAME NAME MAX(LINE)
------------------------------ ------------------------------ ----------
ORA$BASE PP 13
E0 PP 13


Nuevamente incrementamos la variable global del paquete en esta edición

SQL> exec pp.suma(1);

PL/SQL procedure successfully completed.

SQL> exec pp.muestro;
vn 2.0 vale: 2

PL/SQL procedure successfully completed.


En resumen:
  • valía 5 en la edición ORA$BASE.
  • 1 en E0 cuando no se había cambiado.
  • luego de crear la nueva versión en E0 las variables se inicializan, y ahora vale 2.
Vuelvo a la edición original e incremento de nuevo para confirmar que mantiene su valor

SQL> ALTER SESSION SET EDITION = ORA$BASE;

Session altered.

SQL> exec pp.suma(1);

PL/SQL procedure successfully completed.

SQL> exec pp.muestro;
vn vale: 6

PL/SQL procedure successfully completed.


jueves, 18 de agosto de 2011

Presentación sobre 11gR2

Ayer comenzaron las jornadas anuales de la Asociación de Informáticos de la Administración Pública (AsIAP) en Montevideo, evento más conocido como la JIAP.

Propuse una charla sobre 11gR2 en nombre del UYOUG, que fue aceptada y presenté ayer.

Les dejo la presentación.


Saludos.