jeudi 19 décembre 2013

How to recover from : CRS-0184: Cannot communicate with the CRS daemon

Yesterday, i am facing an issue where all crs commands fail on a cluster with the following error :
“CRS-0184: Cannot communicate with the CRS daemon”

 I doesn't want to resintall a complete clusterware and loose all the clusterware configuration.

To solve the probleme, i use perl script defined in the  $ORAGRID_HOME./crs/install/ directory.
I found that the file crsconfig_params containes the global configuration of my cluster.
This file will be generated at the first installation.
This file in used as input by some perl scripts and especially by the roothas.pl and rootcrs.pl. 

so first, i try on each node of my cluster to reset the complete ocr/olr configuration files. 
To that i execute the following commands :
$ORAGRID_HOME./crs/install/roothas.pl  -deconfig  -force
and 
$ORAGRID_HOME./crs/install/rootcrs.pl  -deconfig  -force

This script remove all the configuration donne for the Oracle High Availability Services and also for the Cluster Ready Services.
The -force option is used to indicate to note use the clusterware services (cause not available)
The -deconfig option is used to remove content of the clusterware configuration files.

To recreate the cluster i use the following command that takes in input by default the crsconfig_params file :
$ORAGRID_HOME./crs/install/rootcrs.pl

The magic is done.
You can after restart your cluster using the following command :
$ORAGRID_HOME/bin/crsctl start crs
@see here under the content of the crsconfig_params file :
SILENT=false
ORACLE_OWNER=ora11grid
ORA_DBA_GROUP=dba
ORA_ASM_GROUP=dba
LANGUAGE_ID=AMERICAN_AMERICA.AL32UTF8
TZ=Europe/Paris
ISROLLING=true
REUSEDG=false
ASM_AU_SIZE=1
USER_IGNORED_PREREQ=true

ORACLE_HOME=/opt/ora11grid
ORACLE_BASE=/opt/oracle
OLD_CRS_HOME=
JREDIR=/opt/ora11grid/jdk/jre/
JLIBDIR=/opt/ora11grid/jlib

VNDR_CLUSTER=true
OCR_LOCATIONS=/ocr/ocr1/ocr1.data,/ocr/ocr2/ocr2.data,/ocr/ocr3/ocr3.data
CLUSTER_NAME=mycluster_1_2
HOST_NAME_LIST=node1,node2
NODE_NAME_LIST=node1,node2
PRIVATE_NAME_LIST=
VOTING_DISKS=/voting/vot1/vot1.data,/voting/vot2/vot2.data,/voting/vot3/vot3.data
#VF_DISCOVERY_STRING=%s_vfdiscoverystring%
ASM_UPGRADE=false
ASM_SPFILE=
ASM_DISK_GROUP=
ASM_DISCOVERY_STRING=
ASM_DISKS=
ASM_REDUNDANCY=
CRS_STORAGE_OPTION=2
CSS_LEASEDURATION=400
CRS_NODEVIPS='node1-vip/255.255.252.0/eth0,node2-vip/255.255.252.0/eth0'
NODELIST=node1,node2
NETWORKS="eth0"/10.10.xx.xx:public,"bond0"/192.168.164.0:cluster_interconnect
SCAN_NAME=mycluster_1_2-scan
SCAN_PORT=1521
GPNP_PA=
OCFS_CONFIG=

# GNS consts
GNS_CONF=false
GNS_ADDR_LIST=
GNS_DOMAIN_LIST=
GNS_ALLOW_NET_LIST=
GNS_DENY_NET_LIST=
GNS_DENY_ITF_LIST=

####
Required by OUI add node
NEW_HOST_NAME_LIST=
NEW_NODE_NAME_LIST=
NEW_PRIVATE_NAME_LIST=
NEW_NODEVIPS='node1-vip/255.255.252.0/eth0,node2-vip/255.255.252.0/eth0'

###############
# OCR constants
#GPNPCONFIGDIR is handled differently in dev (T_HAS_WORK for all)
#GPNPGCONFIGDIR in dev expands to T_HAS_WORK_GLOBAL
GPNPCONFIGDIR=$ORACLE_HOME
GPNPGCONFIGDIR=$ORACLE_HOME
OCRLOC=
OLRLOC=
OCRID=
CLUSTER_GUID=
CLSCFG_MISSCOUNT=

####IPD/OS
CRFHOME="/opt/ora11grid"

mardi 17 décembre 2013

How to ping an Oracle RAC intance through the RAC private interface with specific MTU

Some times it is interesting to check that the Oracle private network interface support a specific MTU.
Use the ping cmmand like following :
On Linux system :
/bin/ping -s <MTU> -c 2 -I <private_source_ip> <remote_nodename_priv> 
/bin/traceroute -s <private_source_ip> -r -F  <remote_nodename_priv> <MTU>
On Solaris system :
/usr/sbin/ping -i <private_source_ip> -s <remote_nodename_priv> <MTU>
/usr/sbin/traceroute -s <private_source_ip> -r -F <remote_nodename_priv> <MTU>

jeudi 28 novembre 2013

[Oracle] How to monitor real SGA memory usage

From something read on the net :
select name, round(sum(mb),1) mb, round(sum(inuse),1) inuse
from (
    select case when name = 'buffer_cache' then 'db_cache_size'
                when name = 'log_buffer' then 'log_buffer'
                else pool end name,
           bytes/1024/1024 mb,
           case when name = 'buffer_cache' then (bytes - (select count(*) from v$bh where status = 'free') *
                                                         (select value from v$parameter where name = 'db_block_size')
                                                 )/1024/1024
                when name <> 'free memory' then bytes/1024/1024
                end inuse
    from v$sgastat
)
group by name;

mercredi 27 novembre 2013

[ORACLE] Autoriser l'acces distant à la base en tant que sysdba


Verifier si :

  Le parametre remote_os_authent=TRUE
  Le parametre remote_login_passwordfile=EXCLUSIVE | SHARE
  Pour se connecter en tant que sys, verifier si l'utilisateur est declaré dans le fichier le mot de passe :
select * from v$pwfile_users;

Si c'est vide, verifier si le fichier password existe sous ORACLE_HOME/dbs.
S'il n'existe pas le créer:
 orapwd file=orapw<SID> password=<password> entries=5

si il n'apparait pas dans la liste l'ajouter avec
grant sysdba to <user>; 

[ORACLE] Pour connaître la liste des patch-set appliqués sur une base

select * from registry$history;