Blog

Blog

ORA-01654 sur SYSAUX

Je suis tombée sur une erreur ORA-01654 car le tablespace SYSAUX était plein. Je pense qu'il n'avait pas forcément été bien dimensionné au départ (il faut utiliser le script utlsyxsz pour estimer la taille nécessaire à SYSAUX).

Cependant, n'étant pas propriétaire de la base et n'ayant pas l'autorisation d'augmenter le-dit SYSAUX, j'ai du chercher à grappiller quelques Mo.

Utilisation de SYSAUX

Pour savoir ce qui utilise SYSAUX, il suffit de lancer cette requête :
SELECT  occupant_name "Coupable",
space_usage_kbytes/1048576 "Espace occupé (Go)",
schema_name "Schema"
FROM v$sysaux_occupants
ORDER BY 2 desc;
Dans mon cas, c'était AWR qui occupait plus de la moitié du SYSAUX.

AWR et droit d'utilisation

Pour ce client, AWR était d'autant plus inutile qu'il n'avait pas payé le tuning pack. Il n'avait donc pas le droit de générer et d'aller voir les rapports AWR. Il se trouve qu ele client ne savait même pas ce que c'était. j'ai donc eu l'autorisation de purger les snapshots.

Purge des snapshots

Pour purger les snapshots, il faut savoir quel est le plus ancien et quel est le plus récent. Cette requête donne ces infos.
SELECT snap_id, begin_interval_time, end_interval_time 
FROM SYS.WRM$_SNAPSHOT 
WHERE snap_id = ( SELECT MIN (snap_id) FROM SYS.WRM$_SNAPSHOT)
UNION 
SELECT snap_id, begin_interval_time, end_interval_time 
FROM SYS.WRM$_SNAPSHOT 
WHERE snap_id = ( SELECT MAX (snap_id) FROM SYS.WRM$_SNAPSHOT); 

Il faut ensuite réutiliser ces valeurs dans le bloc PL/SQL suivant :
BEGIN
  dbms_workload_repository.drop_snapshot_range(low_snap_id => 14241, high_snap_id=>14321);
END;

Récupérer la place libérée

Il faut ensuite shrinker la table pour pouvoir réellement récupérer la place (il faut être connecté en sys as sysdba).
alter table sys.WRH$_ACTIVE_SESSION_HISTORY shrink space cascade;

Et après ?

La procédure ci-dessus n'est qu'une procédure d'urgence. Il faudra prévoir rapidement d'envisager au moins une des actions suivantes :

  • Faire tourner le script utlsyxsz  pour évaluer le besoin réel d'espace de SYSAUX
  • Ajouter un datafile à SYSAUX (ou augmenter les datafiles existants)
  • Diminuer la fréquence et la rétention des snapshots d'AWR

ORA-19705 ou comment perdre le plus de temps possible

Je suis tombée par hasard sur une erreur ORA-19705 "tag value exceeds maximum length of 31 characters". J'ai donc appris à mes dépends qu'un tag de sauvegarde RMAN ne peut pas faire plus de 31 caractères.
Cela ne m'aurait pas posé de problème si RMAN me l'avait dit AU DEBUT de la sauvegarde, mais ce petit plaisantin a attendu d'avoir sauvegardé mes 100 Go de données pour planter tout à la fin!

La solution

Comme vous vous en doutez, la solution a été de réduire la taille de mon tag de sauvegarde, quitte à ce qu'il soit moins précis...
Tout ça pour ça!

D'un autre côté, si je n'avais pas perdu du temps aujourd'hui pour cette broutille, je n'aurai peut-être pas aussi bien retenu qu'un tag ne doit pas faire plus de 31 caractères!

Comment ne pas perdre le listener sous Windows 2012

Windows ne fonctionne pas comme Linux. Ce n'est pas une nouveauté. par contre, en arrêtant et redémarrant une base sous Windows, j'ai eu la surprise de perdre mon listener qui me découvrait 2 instances pour mon service alors qu'il n'y en avait qu'une :
Le service "rachel" comporte 2 instance(s).
L'instance "rachel", statut READY, comporte 1 gestionnaire(s) pour ce service.
L'instance "rachel", statut UNKNOWN, comporte 1 gestionnaire(s) pour ce service.
J'ai donc arrêté ma base et le listener ne retrouvait plus qu'une seule instance :
Le service "rachel" comporte 1 instance(s).
L'instance "rachel", statut UNKNOWN, comporte 1 gestionnaire(s) pour ce service.

Démarrage propre d'une instance sous Windows

Bien entendu, si la base est arrêtée, il n'est pas possible d'ouvrir sqlplus avec un nom de service (@rachel).
Voici comment faire correctement sous Windows :
set oracle_sid=rachel
sqlplus sys/*** as sysdba
SQL>startup
...et mon listener était content!
Le service "rachel" comporte 1 instance(s).
L'instance "rachel", statut READY, comporte 1 gestionnaire(s) pour ce service.

Comment résoudre une erreur TNS-12560 sous Windows 2012 ?

Nous avons eu "la chance" avec un collègue de faire une installation sous Windows 2012... Ce n'est un secret pour personne, la plupart des DBAs préfèrent une installation sous Linux. Il y a certainement une part de résistance aux changements là-dedans (hé, oui, nous sommes humains, jetez-nous la première pierre!) et aussi une bonne dose de What The Fuck quand on tente d'administrer une base Oracle sous Windows.

Bref, nous avions installé Oracle et nous voulions configurer le listener pour pouvoir créer la base. netca se lance correctement, dit que tout va bien, mais le listener ne fonctionne pas... erreur TNS-12560.

Dieu sous Windows : Le mode administrateur

Après avoir cherché à droite à gauche, j'ai fini par comprendre que notre ami netca, même s'il disait que tout allait bien dans le meilleur des mondes, ne pouvait pas écrire dans le listener.ora... Parce qu'il n'avait pas les droits administrateurs. J'ai donc relancé netca en mode administrateur et tout baigne.

Dieu existe aussi en mode console

J'ai ensuite lancé un petit lsnrctl status et tout allait bien. Puis j'ai voulu arrêter le listener (pour le relancer et voir que tout allait bien) et là, le truc recommence à m'insulter... Pas moyen d'arrêter le listener! Après une petite pause relaxation, j'ai découvert que le menu Windows+X me donnait accès à "Invite de commandes en mode administrateur" après avoir lancé cette console, j'ai pu arrêter mon listener et même le redémarrer sans me faire insulter.

Donc voilà, même avec un compte admin, il faut lancer les différents utilitaires Oracle soit en mode admin soit depuis une console en mode admin. Il n'est pas possible de passer d'une console en mode à une console en mode admin avec une commande équivalente à su, ce serait bien trop simple!

Comment faire si on a un mot réservé dans un nom de colonne sous postgreSQL ?

PostgreSQL gère une liste de mots réservés et une liste de mot non réservés, mais un peu réservés quand même... Bref, il peut laisser un outil créer une table avec un mot réservé comme nom de colonne et à vous de galérer après pour la modifier!
J'ai connu l'expérience avec openstreetmap qui nomme un des attributs "natural". "natural" n'est pas u mot clé réservé de la norme SQL, par contre, il est réservé pour PostgreSQL... Je ne me suis rendue compte du problème qu'une fois l'import effectué avec shp2pgsql.

Le préfixe

Pour une requête de sélection, il suffit de préfixer le nom de colonne avec le nom de la table.
SELECT *
FROM maTable
WHERE maTable.natural="gnagnagna";
Et ça marche...

Et pour le DDL ?

PostgreSQL n'accepte pas d'alias dans le DDL, c'est d'ailleurs un des écueils de la migration Oracle vers PostgreSQL. Il faut donc arriver à lui dire que ce n'est qu'un identifiant. ça se fait tout bêtement en mettant des guillemets autour de l'identifiant.
ALTER maTable RENAME COLUMN "natural" TO naturelle;

Pour aller plus loin

Vous pouvez consulter la documentation PostgreSQL:

Quelle versions sous postgreSQL et postGIS ?

Il arrive parfois qu'on se pose des questions toutes bêtes... On veut consulter la documentation postGIS et là, trou de mémoire, sous quelle version de postGIS suis-je ?PostGIS l'a prévu!

La fonction PostGIS_full_version()

C'est tout simple! Une ptite requête et zou!
SELECT PostGIS_full_version();
Et la réponse arrive :
"POSTGIS="2.1.5 r13152" GEOS="3.4.2-CAPI-1.8.2 r3921" PROJ="Rel. 4.8.0, 6 March 2012" GDAL="GDAL 1.9.2, released 2012/10/08" LIBXML="2.7.6" LIBJSON="UNKNOWN" RASTER"
Pour une fois que c'est simple! Enjoy!

Et pour postgreSQL ?

C'est tout aussi simple!
SELECT version();

Pour aller plus loin

Vous pouvez consulter la documentation PostGIS et PostgreSQL: