Outils pour utilisateurs

Outils du site


environnements:oracle

Différences

Ci-dessous, les différences entre deux révisions de la page.

Lien vers cette vue comparative

Les deux révisions précédentes Révision précédente
Prochaine révision
Révision précédente
Prochaine révision Les deux révisions suivantes
environnements:oracle [2017/09/14 14:13]
magim >
environnements:oracle [2022/12/05 11:24]
boulayen [Se connecter à Oracle depuis une application 2021]
Ligne 1: Ligne 1:
-====== Le serveur de base de données Oracle ======+====== Le serveur de base de données Oracle ​- Modalités de connexion septembre 2022 ======
  
 +Suite à des changements sur notre infrastructure pour des raisons de sécurité, et de performance un nouveau serveur Oracle (19C) à été déployé, les modalités de connexion à la base Oracle restent similaires : 
  
-Les TP Oracle ​sont centralisés sur le serveur ​''​im2ag-oracle.e.ujf-grenoble.fr''​ , ce serveur ​est dédié à cet usage.+  * **<color #​ed1c24>​Le mot de passe Oracle ​n'​est ​pas celui de votre compte universitaire.</​color>​**
  
-Le nom de l'​instance (SID) qui héberge l'​ensemble des schémas est : ufrima 
  
-===== Accès aux bases =====+Voir le chapitre "​[[https://​im2ag-wiki.univ-grenoble-alpes.fr/​doku.php?​id=environnements:​oracle#​connexion_oracle_a_partir_de_septembre_2022|connexion à Oracle]]"​ ci-dessous pour plus de détails sur les nouvelles modalités de connexion. 
 +===== Les différentes instances  ​=====
  
-Il existe ​plusieurs ​façons ​de se connecter ​à ''​im2ag-oracle''​selon +Le serveur Oracle héberge ​plusieurs ​instances : afin de cloisonner les TP, à la fois par rapport aux manipulations sensibles de certains d'entre euxmais aussi dans le but de mieux répartir ​les ressources du système. 
-les accès dont on dispose et les programmes auxquels on a accès.+   
 +Par défaut (si on ne change pas d'​instance),​ c'est l'​instance **IM2AG** qui est configurée dans l'​environnement.
  
-==== Connexion depuis un terminal ouvert sur le serveur ​ ====+Les instances accessible à tous sont:
  
-Il est possible ​de changer dinstance Oracle. +  * **IM2AG** : sur cette instance, les utilisateurs peuvent créer leur propre base de données, elle est donc particulièrement adaptée aux TP plus avancés où les étudiants doivent faire de telles manipulations.
-Pour cela, entrez la commande:+
  
-   ​source /​oracle/<​nom-instance>/​.cshrc +  ​* **UFRIMA** : cette instance ​est la plus utiliséeelle est dédiée aux TP qui font des requêtes d'interrogation des schémas publics (camions, repas, etc.). Attention, sur cette instance, il est impossible pour les utilisateurs de créer leur propre base de données.
-   ​ +
-Par defaut (si on ne change pas d'instance)c'est l'​instance ​UFRIMA qui est configuré dans l'​environnement.+
  
-Les instances ​accessible à tous sont:+Il y a aussi d'​autres ​instances ​qui sont réservées à des TP spécifiques,​ les enseignants s'​occupent de faire les demandes d'​accès au service info pour les étudiants concernés. Voici une liste des instances existantes ​:
  
-  * UFRIMA ​(Accessible en lecture uniquement) +  ​* **UFRIMA** 
-  * IM2AG (Accessible en lecture/​écriture)+  ​* **IM2AG** 
 +  * **M1MIAGE** 
 +  * **TPTOMCAT**
  
-Il y a aussi d'​autres instances qui sont réservées à des TP spécifiques,​ les enseignants s'​occupent de faire les demandes d'​accès pour les étudiants concernés : 
  
-  * M1MIAGE +===== Connexion Oracle à partir de septembre 2022 ===== 
-  TPTOMCAT +Il faut vous connecter en ssh sur le serveur ​**im2ag-oracle.univ-grenoble-alpes.fr** avec vos login et mot de passe universitaires :
-  ​INF245 +
-  ​M2CCI +
-  * TP_ADMIN_ORACLE_M2MIAGE +
-  * TP_ADMIN_ORACLE_M2PGI +
-  ​HIB+
  
-Exemple; pour se connecter à l'​instance M1MIAGE+<​code=bash>​ 
 +ssh login@im2ag-oracle.univ-grenoble-alpes.fr 
 +</​code>​
  
-   > source ​/oracle/M1MIAGE/.cshrc+Ensuite, prenez connaissance de votre mot de passe pour les bases de données Oracle. Il se trouve dans un fichier texte à la racine de votre HOME : **~/oracle.txt**. Votre HOME est monté sur le serveur Oracle, vous pouvez donc utiliser la commande suivante pour afficher votre mot de passe Oracle :
  
-On utilise l'​outil ''​sqlplus''​ pour se connecter à la base de donnée. +<​code=bash>​ 
-Il faut ensuite lancer''​sqlplus''​ depuis la console, ce qui vous donne un +cat ~/oracle.txt 
-accès instantané à la base hébergée localementSi tout fonctionne, +</​code>​
-vous devriez obtenir le résultat suivant :+
  
-   ... sur im2ag-oracle.e ... +L'​instance par defaut est precisée à la connexion, il s'agit de **IM2AG**, pour changer d'​instance il faudra modifier l'​environement avec la commande source 
-  sqlplus +Exemple pour l'​instance UFRIMA: 
-  ​SQL*Plus:​ Release 11.2.0.1.0 Production on Tue Oct 14 16:11:50 2014 +<​code=bash>​ 
-  ​Copyright (c) 1982, 2009, Oracle. ​ All rights reserved+source /oracle/UFRIMA/.cshrc 
-  Enter user-name: ​+</code
 +Exemple pour l'​instance M1MIAGE
 +<​code=bash>​ 
 +source /​oracle/​M1MIAG/​.cshrc 
 +</​code>​
  
-Si vous souhaitez vérifier ​sur quelle instance vous travaillez avant de lancer sqlplus, ​vous pouvez utiliser la commande ​suivant ​:+Pour visualiser ​sur quelle instance vous êtes actuellement positionné ​vous pouvez utiliser la commande: 
 +<​code=bash>​ 
 +echo $ORACLE_SID 
 +</​code>​
  
- env+Pour s'y connecter utilisez la commande :
  
-Le contenu de la variable "​ORACLE_SID"​ vous indique sur quelle instance vous allez travailler.+<​code=bash>​ 
 +sqlplus LOGIN 
 +</​code>​
  
-==== En cas d'​accès interdits depuis l'​extérieur ====+En remplaçant **LOGIN** par votre login universitaire.
  
-Si vous essayez ​de vous connecter ​de chez vous, ou depuis ​le VPN, et +Un prompt ​vous demandera ​de saisir le mot de passe qui se trouve dans le fichier ~/​oracle.txt.
-que vos tentatives de connexion sont bloquées, vous pouvez utiliser +
-une technique de tunnel SSH pour travailler envers et contre tout +
-obstacle.+
  
-Le principe est le suivant ​plutôt que d'​accèder directement au port Oracle sur le serveur, ​on peut feinter en passant par le port SSH quiluiest toujours ouvert, et en se connectant au port Oracle ​"de l'​intérieur"​Pour se faire, entrez la commande suivante ​+<​code=bash>​ 
 +[LOGIN@im2ag-oracle ~]$ sqlplus LOGIN 
 +SQL*PlusRelease 19.0.0.0.0 - Production ​on Thu Sep 15 09:42:00 2022 
 +Version 19.3.0.0.0 
 +Copyright (c) 19822019, Oracle. ​All rights reserved. 
 +Enter password: 
 +</​code>​
  
-  ssh -NL 21521:​localhost:​1521 im2ag-oracle.e.ujf-grenoble.fr 
  
-Cette commande ouvre le port 21521 sur votre machine ​et le lie au port +<color #​ff7b0a>​**Remarque : **</​color>​ Il est possible d'​utiliser **gqlplus** à la place de **sqlplus** il s'agit d'une alternative qui permet d'​avoir un historique des commandes SQL une édition de ligne fonctionnelle et de l'​autocompletion. 
-1521 (le fameux port Oracle) de "​localhost ​de im2ag-oracle.e", c'est à + 
-dire au port 1521 comme vu de im2ag-oracle lui-même.+===== Changement de mot de passe Oracle ===== 
 + 
 +**Avertissement** : vous êtes l'​unique détenteur de votre mot de passe Oracle. 
 + 
 +Si vous le souhaitez, vous pouvez modifier le mot de passe qui se trouve dans le fichier oracle.txt. Prenez garde à choisir un mot de passe ayant au minimum 8 caractères et au maximum 16, et faites attention à ne pas laisser de caractères spéciaux dans le fichier (sauts de lignes, espaces, etc.). Une fois le fichier modifié, le mot de passe sera mis à jour **dans les 12h suivantes** ​sur toutes les instances. En attendant, l'​ancien mot de passe est toujours valide, attention donc à le conserver le temps de la mise à jour. 
 + 
 +<color #​ed1c24>​**Attention :​**</​color>​ si vous supprimez ​votre fichier oracle.txt, un nouveau mot de passe sera généré dans les 12h suivantes pour toutes les instances ​et le fichier sera recréé. 
 +===== Les schémas publics ===== 
 + 
 +Pour les besoins des TP, certaines instances hébergent des schémas publics : tous les utilisateurs peuvent faire des requêtes d'​interrogation sur ces derniers. 
 + 
 +Lorsque l'on se trouve sur une instance, la requête SQL suivante permet de lister l'​ensemble des schémas et tables publics qui nous sont accessibles : 
 + 
 +<​code=sql>​ 
 +    SELECT owner, table_name FROM all_tables 
 +    WHERE owner NOT IN ('​SYS',​ '​SYSTEM',​ '​CTXSYS',​ '​MDSYS'​) 
 +    ORDER BY owner, table_name;​ 
 +</​code>​ 
 +La colonne owner correspond au nom des schémas, et la colonne table_name contient ​le nom des tables. Attention, cette requête liste également les schémas des éventuels utilisateurs qui ont défini un accès public sur leurs tables (et peut être certaines tables système dont il ne faut pas tenir compte)
 + 
 +La mise à disposition d'un schéma sur une ou des instances se fait à la demande des enseignants. 
 + 
 +===== Les schémas personnels ===== 
 + 
 +Chaque étudiant ou enseignant possède sa propre base (schéma) sur Oracle, sur lequel il a les droits ​de lecture et d'​écriture. 
 + 
 +Ce schéma est accessible ​de deux façons : 
 + 
 +  * Soit en préfixant le nom des tables par votrelogin 
 +  * Soit en changeant le schéma sur lequel on travaille avec la commande **ALTER SESSION SET CURRENT_SCHEMA = votrelogin**,​ les tables sont ensuite accessible directement par leur nom sans aucun préfixe 
 + 
 +Il est possible de créer des tables, des vues, des triggers, etc. 
 + 
 +===== Se connecter à Oracle depuis une application ===== 
 + 
 +Pour se connecter à Oracle depuis une application,​ vous aurez en général besoin des informations suivantes : 
 + 
 +**Nom d'hote :** im2ag-oracle.univ-grenoble-alpes.fr 
 + 
 +**Port :** 1521 
 + 
 +**Instance/​Servicename :** le nom de l'​instance sur laquelle vous travaillez (voir la liste des instances en haut de cette page) 
 + 
 +Pour se connecter depuis une application PHP hébergée sur Goedel (ou autre), vous avez un exemple de code ici : https://im2ag-wiki.univ-grenoble-alpes.fr/​doku.php?​id=environnements:​php#​procedure_pour_se_connecter_a_une_base_oracle 
 + 
 +À noter que si vous essayez d'​accéder au port 1521 en dehors des réseaux de l'UGA, vous devez utiliser le **VPN** \\ 
 +<color #​ff7b0a>​Fonctionnement et installation du VPN</​color>:​ [[ https://​nomadisme.grenet.fr/​ ]].
  
-Ensuite, tous vos accès à la base Oracle peuvent se faire sur 
-''​localhost:​21521'',​ qui sera automatiquement forwardé à ''​im2ag-oracle.e:​1521''​ 
  
 ===== Mise en garde ===== ===== Mise en garde =====
 +
 +Faites attention à bien fermer votre session (ou si vous écrivez des
 +scripts, à bien fermer la connexion à la base après avoir effectué vos
 +requêtes). Dans le cas contraire, les connexions mortes ainsi créées
 +attendent le timeout du serveur pour se fermer, ce qui entretemps peut
 +vous empêcher d'en ouvrir de nouvelles.
 +
 +
 +
 +
 +====== Le serveur de base de données Oracle - Modalités de connexion septembre 2021======
 +
 +
 +<color #​ff7b0a>​**Le serveur historique ORACLE (Sun) est toujours disponible**</​color>​
 +Suite à des changements sur notre système d'​authentification pour des raisons de sécurité, les modalités de connexion à la base Oracle ont changées : 
 +
 +  * **<color #​ed1c24>​Le serveur im2ag-oracle.e.ujf-grenoble.fr n'est plus accessible en ssh.</​color>​**
 +
 +
 +  * **<color #​ed1c24>​Le mot de passe Oracle n'est plus celui de votre compte universitaire.</​color>​**
 +
 +
 +Voir le chapitre "​[[https://​im2ag-wiki.univ-grenoble-alpes.fr/​doku.php?​id=environnements:​oracle#​connexion_oracle_septembre_2021|connexion à Oracle 2021]]"​ ci-dessous pour plus de détails sur les modalités de connexion.
 +===== Les différentes instances 2021 =====
 +
 +Le serveur Oracle héberge plusieurs instances : cela a pour but de cloisonner les TP, à la fois par rapport aux manipulations sensibles de certains d'​entre eux, mais cela a aussi pour but de mieux répartir les ressources du système.
 +  ​
 +Par défaut (si on ne change pas d'​instance),​ c'est l'​instance **UFRIMA** qui est configurée dans l'​environnement.
 +
 +Les instances accessible à tous sont:
 +
 +  * **UFRIMA** : cette instance est la plus utilisée, elle est dédiée aux TP qui font des requêtes d'​interrogation des schémas publics (camions, repas, etc.). Attention, sur cette instance, il est impossible pour les utilisateurs de créer leur propre base de données.
 +
 +
 +  * **IM2AG** : sur cette instance, les utilisateurs peuvent créer leur propre base de données, elle est donc particulièrement adaptée aux TP plus avancés où les étudiants doivent faire de telles manipulations.
 +
 +Il y a aussi d'​autres instances qui sont réservées à des TP spécifiques,​ les enseignants s'​occupent de faire les demandes d'​accès au service info pour les étudiants concernés. Voici une liste des instances existantes :
 +
 +  * **UFRIMA**
 +  * **IM2AG**
 +  * **M1MIAGE**
 +  * **TPTOMCAT**
 +
 +
 +===== Connexion Oracle septembre 2021 =====
 +Il faut premièrement vous connecter en ssh sur le serveur **im2ag-goedel.univ-grenoble-alpes.fr** avec vos login et mot de passe universitaires :
 +
 +<​code=bash>​
 +   ssh login@im2ag-goedel.univ-grenoble-alpes.fr
 +</​code>​
 +
 +Ensuite, prenez connaissance de votre mot de passe pour les bases de données Oracle. Il se trouve dans un fichier texte à la racine de votre HOME : **~/​oracle.txt**. Votre HOME est monté sur le serveur Goedel, donc vous pouvez simplement utiliser la commande suivante pour afficher votre mot de passe Oracle :
 +
 +<​code=bash>​
 +   cat ~/​oracle.txt
 +</​code>​
 +
 +Puis utilisez la commande :
 +
 +<​code=bash>​
 +   ​sqlplus login@INSTANCE
 +
 +</​code>​
 +En remplaçant **login** par votre login universitaire et **INSTANCE** par l'une des instances présentées plus haut.
 +
 +Un prompt vous demandera de saisir le mot de passe qui se trouve dans le fichier ~/​oracle.txt.
 +
 +
 +<​code=bash>​
 +    im2ag-goedel:​~
 +    [16:​22:​11]LOGIN$ sqlplus LOGIN@M1MIAGE
 +    SQL*Plus: Release 10.2.0.1.0 - Production on Mon Sep 20 16:22:19 2021
 +    Copyright (c) 1982, 2005, Oracle. ​ All rights reserved.
 +    Enter password:
 +</​code>​
 +
 +<color #​ed1c24>​**Attention : **</​color>​lorsque vous tapez la commande sqlplus présentée plus haut, si vous ne spécifiez aucune instance, ou une instance qui n'​existe pas, il vous sera quand même demandé de saisir un mot de passe, mais vous devriez ensuite obtenir une erreur **ORA-12154** et/ou **ORA-12545**.
 +===== Changement de mot de passe Oracle 2021 =====
 +
 +**Avertissement** : vous êtes l'​unique détenteur de votre mot de passe Oracle.
 +
 +Si vous le souhaitez, vous pouvez modifier le mot de passe qui se trouve dans le fichier oracle.txt. Prenez garde à choisir un mot de passe ayant au minimum 8 caractères et au maximum 16, et faites attention à ne pas laisser de caractères spéciaux dans le fichier (sauts de lignes, espaces, etc.). Une fois le fichier modifié, le mot de passe sera mis à jour **dans les 12h suivantes** sur toutes les instances. En attendant, l'​ancien mot de passe est toujours valide, attention donc à le conserver le temps de la mise à jour.
 +
 +<color #​ed1c24>​**Attention :​**</​color>​ si vous supprimez votre fichier oracle.txt, un nouveau mot de passe sera généré dans les 12h suivantes pour toutes les instances et le fichier sera recréé.
 +===== Les schémas publics 2021 =====
 +
 +Pour les besoins des TP, certaines instances hébergent des schémas publics : tous les utilisateurs peuvent faire des requêtes d'​interrogation sur ces derniers.
 +
 +Lorsque l'on se trouve sur une instance, la requête SQL suivante permet de lister l'​ensemble des schémas et tables publics qui nous sont accessibles :
 +
 +<​code=sql>​
 +    SELECT owner, table_name FROM all_tables
 +    WHERE owner NOT IN ('​SYS',​ '​SYSTEM',​ '​CTXSYS',​ '​MDSYS'​)
 +    ORDER BY owner, table_name;
 +</​code>​
 +La colonne owner correspond au nom des schémas, et la colonne table_name contient le nom des tables. Attention, cette requête liste également les schémas des éventuels utilisateurs qui ont défini un accès public sur leurs tables (et peut être certaines tables système dont il ne faut pas tenir compte).
 +
 +La mise à disposition d'un schéma sur une ou des instances se fait à la demande des enseignants.
 +
 +===== Les schémas personnels 2021 =====
 +
 +Chaque étudiant ou enseignant possède sa propre base (schéma) sur Oracle, sur lequel il a les droits de lecture et d'​écriture.
 +
 +Ce schéma est accessible de deux façons :
 +
 +  * Soit en préfixant le nom des tables par votrelogin
 +  * Soit en changeant le schéma sur lequel on travaille avec la commande **ALTER SESSION SET CURRENT_SCHEMA = votrelogin**,​ les tables sont ensuite accessible directement par leur nom sans aucun préfixe
 +
 +Il est possible de créer des tables, des vues, des triggers, etc.
 +
 +===== Se connecter à Oracle depuis une application 2021 =====
 +
 +Pour se connecter à Oracle depuis une application,​ vous aurez en général besoin des informations suivantes :
 +
 +**Nom d'hote :** im2ag-oracle.e.ujf-grenoble.fr
 +
 +**Port :** 1521
 +
 +**Instance/​Servicename :** le nom de l'​instance sur laquelle vous travaillez (voir la liste des instances en haut de cette page)
 +
 +Pour se connecter depuis une application PHP hébergée sur Goedel (ou autre), vous avez un exemple de code ici : https://​im2ag-wiki.univ-grenoble-alpes.fr/​doku.php?​id=environnements:​php#​procedure_pour_se_connecter_a_une_base_oracle
 +
 +A noter que si vous essayez d'​accéder au port 1521 en dehors des réseaux de l'UGA, vous devez utiliser le VPN.
 +
 +===== Mise en garde 2021 =====
  
 Faites attention à bien fermer votre session (ou si vous écrivez des Faites attention à bien fermer votre session (ou si vous écrivez des
environnements/oracle.txt · Dernière modification: 2023/11/16 10:54 par magim