Wednesday, June 13, 2012

Part 41 of series - Re-define tables and create referecne partitions on child tables



With your tongue, chant the Name of the One Lord. In this world, it shall bring you peace, comfort and great joy; hereafter, it shall go with your soul, and shall be of use to you. Pause .The disease of your ego shall be eradicated. By Guru’s Grace, practice Raja Yoga, the Yoga of  meditation and success. Those who taste the sublime essence of the Lord have their thirst quenched. Those who have found the Lord, the Treasure of peace, shall not go anywhere else again. Those, unto whom the Guru has given the Lord's Name, Har, Har — O Nanak, their fears are removed.



Index to all the Posts of Gurpartap Singh's Blog




Part 1:

Lets create 3 tables one parent and two as its childern and they are not partitioned:

 -- Parent


CREATE TABLE GSINGH.TRANSACTION (

TRANSACTION_ID NUMBER PRIMARY KEY,

TRANSACTION_DATE DATE NOT NULL,

ACCOUNT_ID NUMBER NOT NULL,

DEVICE_ID NUMBER)

;





CREATE INDEX GSINGH.TRANSACTION_date_ind ON TRANSACTION(ACCOUNT_ID);



--============================================================



-- Child 1



--Create child table ORDERS with reference partitioning:

CREATE TABLE GSINGH.ORDERS (

TRANSACTION_ID NUMBER NOT NULL,

ORDER_ID NUMBER PRIMARY KEY,

PRICE NUMBER,

QUANTITY NUMBER,

CONSTRAINT orders_fk FOREIGN KEY (TRANSACTION_ID) REFERENCES TRANSACTION

);







--============================================================



-- Child 2



--Create child table LEDGER with reference partitioning:

CREATE TABLE GSINGH.LEDGER (

LEDGER_ID NUMBER PRIMARY KEY,

TRANSACTION_ID NUMBER NOT NULL,

CURRENCY_CODE varchar(3),

PAYMENT_TOTAL NUMBER,

BALANCE NUMBER,

CONSTRAINT LEDGER_fk FOREIGN KEY (TRANSACTION_ID) REFERENCES TRANSACTION

);

 
You can see that they are not partitioned and have been created using:
 
set feed on


select count(*) from user_tab_partitions;

select * from transaction;

select * from orders;

select * from ledger;

 
Now  lets insert data in them:
 
--============================================================


--Insert data to Transaction Table

INSERT INTO GSINGH.TRANSACTION VALUES (1,'01-JAN-05',10020,11);

INSERT INTO GSINGH.TRANSACTION VALUES (2,'01-JUL-05',10040,14);

INSERT INTO GSINGH.TRANSACTION VALUES (3,'01-JAN-06',10238,17);

INSERT INTO GSINGH.TRANSACTION VALUES (4,'01-JUL-06',10765,16);

INSERT INTO GSINGH.TRANSACTION VALUES (5,'01-JAN-07',10111,18);

INSERT INTO GSINGH.TRANSACTION VALUES (6,'01-JUL-07',10757,30);

INSERT INTO GSINGH.TRANSACTION VALUES (7,'01-JAN-08',10768,15);

INSERT INTO GSINGH.TRANSACTION VALUES (8,'01-JUL-08',10986,3);

INSERT INTO GSINGH.TRANSACTION VALUES (9,'01-JAN-09',19879,5);

INSERT INTO GSINGH.TRANSACTION VALUES (10,'01-JUL-09',15671,7);

INSERT INTO GSINGH.TRANSACTION VALUES (11,'01-JAN-10',16873,23);

INSERT INTO GSINGH.TRANSACTION VALUES (12,'01-JUL-10',98746,26);

INSERT INTO GSINGH.TRANSACTION VALUES (13,'01-JAN-11',24571,29);

INSERT INTO GSINGH.TRANSACTION VALUES (14,'01-JUL-11',87645,21);

INSERT INTO GSINGH.TRANSACTION VALUES (15,'01-JAN-12',45872,19);

INSERT INTO GSINGH.TRANSACTION VALUES (16,'01-JUL-12',34587,10);

INSERT INTO GSINGH.TRANSACTION VALUES (17,'01-JAN-13',12354,26);

INSERT INTO GSINGH.TRANSACTION VALUES (18,'01-JUL-13',87659,1);



commit;





--Insert data to ORDERS Table

INSERT INTO GSINGH.ORDERS VALUES (1,100,4.99,1);

INSERT INTO GSINGH.ORDERS VALUES (2,101,7.99,1);

INSERT INTO GSINGH.ORDERS VALUES (3,102,14.99,1);

INSERT INTO GSINGH.ORDERS VALUES (4,103,5.99,3);

INSERT INTO GSINGH.ORDERS VALUES (5,104,7.99,2);

INSERT INTO GSINGH.ORDERS VALUES (6,105,9.99,1);

INSERT INTO GSINGH.ORDERS VALUES (7,106,12.99,2);

INSERT INTO GSINGH.ORDERS VALUES (8,107,21.99,5);

INSERT INTO GSINGH.ORDERS VALUES (9,108,31.99,6);

INSERT INTO GSINGH.ORDERS VALUES (10,109,53.99,1);

INSERT INTO GSINGH.ORDERS VALUES (11,110,34.99,2);

INSERT INTO GSINGH.ORDERS VALUES (12,111,54.99,3);

INSERT INTO GSINGH.ORDERS VALUES (13,112,67.99,5);

INSERT INTO GSINGH.ORDERS VALUES (14,113,2.99,1);

INSERT INTO GSINGH.ORDERS VALUES (15,114,1.99,1);

INSERT INTO GSINGH.ORDERS VALUES (16,115,8.99,2);

INSERT INTO GSINGH.ORDERS VALUES (17,116,6.99,1);

INSERT INTO GSINGH.ORDERS VALUES (18,117,4.99,5);



commit;



--Insert data to LEDGER Table



INSERT INTO GSINGH.LEDGER VALUES (34561,1,'USA',7.00,3.99);

INSERT INTO GSINGH.LEDGER VALUES (34562,2,'USA',17.00,13.99);

INSERT INTO GSINGH.LEDGER VALUES (34563,3,'USA',70.00,43.99);

INSERT INTO GSINGH.LEDGER VALUES (34564,4,'USA',15.00,13.99);

INSERT INTO GSINGH.LEDGER VALUES (34565,5,'USA',16.00,12.99);

INSERT INTO GSINGH.LEDGER VALUES (34566,6,'USA',47.00,43.99);

INSERT INTO GSINGH.LEDGER VALUES (34567,7,'USA',67.00,45.99);

INSERT INTO GSINGH.LEDGER VALUES (34568,8,'USA',97.00,89.99);

INSERT INTO GSINGH.LEDGER VALUES (34569,9,'USA',87.00,71.99);

INSERT INTO GSINGH.LEDGER VALUES (34521,10,'USA',17.00,12.99);

INSERT INTO GSINGH.LEDGER VALUES (34567,11,'USA',17.00,11.99);

INSERT INTO GSINGH.LEDGER VALUES (34531,12,'USA',7.00,4.99);

INSERT INTO GSINGH.LEDGER VALUES (34532,13,'USA',7.00,2.99);

INSERT INTO GSINGH.LEDGER VALUES (34533,14,'USA',7.00,1.99);

INSERT INTO GSINGH.LEDGER VALUES (34534,15,'USA',6.00,3.99);

INSERT INTO GSINGH.LEDGER VALUES (34535,16,'USA',7.00,5.99);

INSERT INTO GSINGH.LEDGER VALUES (34536,17,'USA',8.00,6.99);

INSERT INTO GSINGH.LEDGER VALUES (34537,18,'USA',9.00,5.99);



commit;

 
 
Now collect stats on them:
 
 
EXEC DBMS_STATS.gather_table_stats(USER, 'TRANSACTION', cascade => TRUE);


EXEC DBMS_STATS.gather_table_stats(USER, 'ORDERS', cascade => TRUE);

EXEC DBMS_STATS.gather_table_stats(USER, 'LEDGER', cascade => TRUE);

 
 
Now lets see how they are partitioned:
 
set echo off




set pagesize 2000

set long 10000

set linesize 200

set feedback on

column partition_name format a25

column high_value format a85

set echo on





-- show how the partitions were created



col table_name format a20

col ref_ptn_constraint_name format a20

col format partitioning_type a20

col format REF_TABLE a20

select table_name, partitioning_type, ref_ptn_constraint_name

from user_part_tables

where table_name in ('TRANSACTION','ORDERS','LEDGER');



select table_name, partition_name, high_value

from user_tab_partitions

where table_name in ('TRANSACTION','ORDERS','LEDGER')

order by partition_position, table_name;



select up.table_name, up.partitioning_type, uc.table_name ref_table

from user_part_tables up,

(select r.table_name, r.constraint_name from user_constraints uc, user_constraints r

where uc.constraint_name=r.constraint_name and uc.owner=r.owner) uc

where up.ref_ptn_constraint_name = uc.constraint_name(+)

and up.table_name in ('TRANSACTION','ORDERS','LEDGER');



set echo on

select table_name, partition_name, high_value

from user_tab_partitions

where table_name in ('TRANSACTION')

order by partition_position, table_name

/



--============================================================


 
 
Part 2:
 
Now lets partition the parent table online with a range partition as:
 
 
-- Step 1 : Create interium table:




CREATE TABLE GSINGH.TRANSACTION_PAR (

TRANSACTION_ID NUMBER PRIMARY KEY,

TRANSACTION_DATE DATE NOT NULL,

ACCOUNT_ID NUMBER NOT NULL,

DEVICE_ID NUMBER)

PARTITION BY RANGE (TRANSACTION_DATE)

subpartition by hash(DEVICE_ID)

( PARTITION y1 VALUES LESS THAN (TO_DATE('01-JAN-2006', 'DD-MON-YYYY')),

PARTITION y2 VALUES LESS THAN (TO_DATE('01-JAN-2007', 'DD-MON-YYYY')),

PARTITION y3 VALUES LESS THAN (TO_DATE('01-JAN-2008', 'DD-MON-YYYY')),

PARTITION y4 VALUES LESS THAN (TO_DATE('01-JAN-2009', 'DD-MON-YYYY')),

PARTITION y5 VALUES LESS THAN (TO_DATE('01-JAN-2010', 'DD-MON-YYYY')),

PARTITION y6 VALUES LESS THAN (TO_DATE('01-JAN-2011', 'DD-MON-YYYY')),

PARTITION y7 VALUES LESS THAN (TO_DATE('01-JAN-2012', 'DD-MON-YYYY')),

PARTITION y8 VALUES LESS THAN (TO_DATE('01-JAN-2013', 'DD-MON-YYYY')));





-- Step 2. Check if table can be redefined:



EXEC dbms_redefinition.can_redef_table(USER, 'TRANSACTION');



--To get better performance use parallel operations as follows



alter session force parallel query parallel 60;

alter session force parallel query parallel 60;







-- Step 3. Start redefinition of the table, This may take long for big tables and for big tables we should use parallelism:



BEGIN

DBMS_REDEFINITION.start_redef_table(

uname => USER,

orig_table => 'TRANSACTION',

int_table => 'TRANSACTION_PAR');

END;

/



Step 4: Create the table constraints and indexes in this section



CREATE INDEX GSINGH.TRANSACTION_PAR_date_ind ON TRANSACTION_PAR(ACCOUNT_ID);



-- Step 5: Gather stats for this table.



EXEC DBMS_STATS.gather_table_stats(USER, 'TRANSACTION', cascade => TRUE);





-- Step 6: Now finish the process of redefinition.



BEGIN

dbms_redefinition.finish_redef_table(

uname => USER,

orig_table => 'TRANSACTION',

int_table => 'TRANSACTION_PAR');

END;

/





-- At this point the interim table has become the "real" table and their names have been switched in the name dictionary.



-- Step 7: Remove original table which now has the name of the interim table:



-- Check the constraints to be dropped

col owner format a20

col CONSTRAINT_NAME format a20

select owner,CONSTRAINT_NAME,CONSTRAINT_TYPE,TABLE_NAME,STATUS from dba_constraints where owner='GSINGH' and table_name in ('TRANSACTION','ORDERS','LEDGER','TRANSACTION_PAR');



--Drop constraints

alter table GSINGH.ORDERS drop CONSTRAINT ORDERS_FK;

alter table GSINGH.LEDGER drop CONSTRAINT LEDGER_FK;



-- Drop table

drop table GSINGH.TRANSACTION_PAR;



-- Add foreign Key constraints and other constraints again

alter table GSINGH.ORDERS add CONSTRAINT orders_fk FOREIGN KEY (TRANSACTION_ID) REFERENCES TRANSACTION;

alter table GSINGH.LEDGER add CONSTRAINT LEDGER_fk FOREIGN KEY (TRANSACTION_ID) REFERENCES TRANSACTION;



-- Rename the Index back to teh original name

ALTER INDEX GSINGH.TRANSACTION_PAR_date_ind RENAME TO TRANSACTION_date_ind;



-- Finally check for what we just did i.e. if the table has repartitioned or not.



SELECT partitioned FROM user_tables WHERE table_name = 'TRANSACTION';

SELECT partition_name FROM user_tab_partitions WHERE table_name = 'TRANSACTION';



--========================================================================================



-- Do the final checks now



set feed on

set pages 100

set line 300

set feed on

select count(*) from user_tab_partitions;

select * from transaction;

select * from orders;

select * from ledger;



select segment_name, partition_name, sum(bytes)/1024/1024 from dba_segments where owner='GSINGH'

and segment_name in ('TRANSACTION','ORDERS','LEDGER')

group by segment_name, partition_name

order by segment_name, partition_name;

set pages 100



-- ===============================================================================



set echo off



set pagesize 2000

set long 10000

set linesize 200

set feedback on

column partition_name format a25

column high_value format a85

set echo on





-- show how the partitions were created



col table_name format a20

col ref_ptn_constraint_name format a20

col format partitioning_type a20

col format REF_TABLE a20

select table_name, partitioning_type, ref_ptn_constraint_name

from user_part_tables

where table_name in ('TRANSACTION','ORDERS','LEDGER');



select table_name, partition_name, high_value

from user_tab_partitions

where table_name in ('TRANSACTION','ORDERS','LEDGER')

order by partition_position, table_name;



select up.table_name, up.partitioning_type, uc.table_name ref_table

from user_part_tables up,

(select r.table_name, r.constraint_name from user_constraints uc, user_constraints r

where uc.constraint_name=r.constraint_name and uc.owner=r.owner) uc

where up.ref_ptn_constraint_name = uc.constraint_name(+)

and up.table_name in ('TRANSACTION','ORDERS','LEDGER');



set echo on

select table_name, partition_name, high_value

from user_tab_partitions

where table_name in ('TRANSACTION')

order by partition_position, table_name

/



-- ===============================================================================


 
 
 
Part 3: Now lets partition Child table 1 as reference partition on Parent Table:
 
 
-- Reference Partitioning of the child table table




CREATE TABLE GSINGH.ORDERS_PAR (

TRANSACTION_ID NUMBER NOT NULL,

ORDER_ID NUMBER PRIMARY KEY,

PRICE NUMBER,

QUANTITY NUMBER,

CONSTRAINT orders_fk_par FOREIGN KEY (TRANSACTION_ID) REFERENCES TRANSACTION

)

PARTITION BY REFERENCE (orders_fk_par);





-- Check if it can be redefined

EXEC dbms_redefinition.can_redef_table(USER, 'ORDERS');



--To get better performance use parallel operations as follows



alter session force parallel query parallel 60;

alter session force parallel query parallel 60;





--Start redefinition of the table, This may take long for big tables and for big tables we should use parallelism:



BEGIN

DBMS_REDEFINITION.start_redef_table(

uname => USER,

orig_table => 'ORDERS',

int_table => 'ORDERS_PAR');

END;

/







-- Step 5: Gather stats for this table.



EXEC DBMS_STATS.gather_table_stats(USER, 'ORDERS_PAR', cascade => TRUE);





--Now finish the process of redefinition.



BEGIN

dbms_redefinition.finish_redef_table(

uname => USER,

orig_table => 'ORDERS',

int_table => 'ORDERS_PAR');

END;

/



-- At this point the interim table has become the "real" table and their names have been switched in the name dictionary.

-- Remove original table which now has the name of the interim table:

-- Drop table

drop table GSINGH.ORDERS_PAR;



-- Rename the constraint

select owner,CONSTRAINT_NAME,CONSTRAINT_TYPE,TABLE_NAME,STATUS from dba_constraints where owner='GSINGH' and table_name='ORDERS' and CONSTRAINT_TYPE='R';



begin

for r in (select CONSTRAINT_NAME,TABLE_NAME from dba_constraints where owner='GSINGH' and table_name='ORDERS' and CONSTRAINT_TYPE='R') loop

execute immediate 'alter table '

r.TABLE_NAME

' rename constraint '

r.CONSTRAINT_NAME

' to orders_fk';

end loop;

end;

/



select owner,CONSTRAINT_NAME,CONSTRAINT_TYPE,TABLE_NAME,STATUS from dba_constraints where owner='GSINGH' and table_name='ORDERS' and CONSTRAINT_TYPE='R';





set echo off



set pagesize 2000

set long 10000

set linesize 200

set feedback on

column partition_name format a25

column high_value format a85

set echo on





-- show how the partitions were created



col table_name format a20

col ref_ptn_constraint_name format a20

col format partitioning_type a20

col format REF_TABLE a20

select table_name, partitioning_type, ref_ptn_constraint_name

from user_part_tables

where table_name in ('TRANSACTION','ORDERS','LEDGER');



select table_name, partition_name, high_value

from user_tab_partitions

where table_name in ('TRANSACTION','ORDERS','LEDGER')

order by partition_position, table_name;



select up.table_name, up.partitioning_type, uc.table_name ref_table

from user_part_tables up,

(select r.table_name, r.constraint_name from user_constraints uc, user_constraints r

where uc.constraint_name=r.constraint_name and uc.owner=r.owner) uc

where up.ref_ptn_constraint_name = uc.constraint_name(+)

and up.table_name in ('TRANSACTION','ORDERS','LEDGER');



set echo on

select table_name, partition_name, high_value

from user_tab_partitions

where table_name in ('TRANSACTION')

order by partition_position, table_name

/



-- ===============================================================================

Now lets partition the second child table as reference partition of the parent table as:



-- Reference Partitioning of the second child table table




CREATE TABLE GSINGH.LEDGER_PAR (

LEDGER_ID NUMBER PRIMARY KEY,

TRANSACTION_ID NUMBER NOT NULL,

CURRENCY_CODE varchar(3),

PAYMENT_TOTAL NUMBER,

BALANCE NUMBER,

CONSTRAINT LEDGER_fk_par FOREIGN KEY (TRANSACTION_ID) REFERENCES TRANSACTION

)

PARTITION BY REFERENCE (LEDGER_fk_par);





-- Check if it can be redefined

EXEC dbms_redefinition.can_redef_table(USER, 'LEDGER');



--To get better performance use parallel operations as follows



alter session force parallel query parallel 60;

alter session force parallel query parallel 60;





--Start redefinition of the table, This may take long for big tables and for big tables we should use parallelism:



BEGIN

DBMS_REDEFINITION.start_redef_table(

uname => USER,

orig_table => 'LEDGER',

int_table => 'LEDGER_PAR');

END;

/







-- Step 5: Gather stats for this table.



EXEC DBMS_STATS.gather_table_stats(USER, 'LEDGER_PAR', cascade => TRUE);





--Now finish the process of redefinition.



BEGIN

dbms_redefinition.finish_redef_table(

uname => USER,

orig_table => 'LEDGER',

int_table => 'LEDGER_PAR');

END;

/



-- At this point the interim table has become the "real" table and their names have been switched in the name dictionary.

-- Remove original table which now has the name of the interim table:

-- Drop table

drop table GSINGH.LEDGER_PAR;



-- Rename the constraint

select owner,CONSTRAINT_NAME,CONSTRAINT_TYPE,TABLE_NAME,STATUS from dba_constraints where owner='GSINGH' and table_name='LEDGER' and CONSTRAINT_TYPE='R';



begin

for r in (select CONSTRAINT_NAME,TABLE_NAME from dba_constraints where owner='GSINGH' and table_name='LEDGER' and CONSTRAINT_TYPE='R') loop

execute immediate 'alter table '

r.TABLE_NAME

' rename constraint '

r.CONSTRAINT_NAME

' to ledger_fk';

end loop;

end;

/



select owner,CONSTRAINT_NAME,CONSTRAINT_TYPE,TABLE_NAME,STATUS from dba_constraints where owner='GSINGH' and table_name='LEDGER' and CONSTRAINT_TYPE='R';





set echo off



set pagesize 2000

set long 10000

set linesize 200

set feedback on

column partition_name format a25

column high_value format a85

set echo on





-- show how the partitions were created



col table_name format a20

col ref_ptn_constraint_name format a20

col format partitioning_type a20

col format REF_TABLE a20

select table_name, partitioning_type, ref_ptn_constraint_name

from user_part_tables

where table_name in ('TRANSACTION','ORDERS','LEDGER');



select table_name, partition_name, high_value

from user_tab_partitions

where table_name in ('TRANSACTION','ORDERS','LEDGER')

order by partition_position, table_name;



select up.table_name, up.partitioning_type, uc.table_name ref_table

from user_part_tables up,

(select r.table_name, r.constraint_name from user_constraints uc, user_constraints r

where uc.constraint_name=r.constraint_name and uc.owner=r.owner) uc

where up.ref_ptn_constraint_name = uc.constraint_name(+)

and up.table_name in ('TRANSACTION','ORDERS','LEDGER');



set echo on

select table_name, partition_name, high_value

from user_tab_partitions

where table_name in ('TRANSACTION')

order by partition_position, table_name

/



-- ===============================================================================




Thats it ! Tables have been redefined as reference partition online. For this I used Oracle Note: 472449.1




In the dwelling of the womb, there is no ancestry or social status. All have originated from the Seed of God. 
Tell me, O Pandit, O religious scholar: since when have you been a Brahmin? Don’t waste your life by continually claiming to be a Brahmin. Pause . If you are indeed a Brahmin, born of a Brahmin mother, then why didn’t you come by some other way? How is it that you are a Brahmin, and I am of a low social status? How is it that I am formed of blood, and you are made of milk? Says Kabeer, one who contemplates God, is said to be a Brahmin among us.






 
 
 
 

Thursday, June 7, 2012

Part 40 of series - Upgrade Oracle Enterprise Manager 11g to Oracle Enterprise Manager 12c, Part - 2




ONE UNIVERSAL CREATOR GOD. BY THE GRACE OF THE TRUE GURU:



My sorrows are ended, and I am filled with peace. The fire of desire within me has been quenched. The True Guru has implanted the treasure of the Naam, the Name of the Lord, within me; it neither dies, nor goes anywhere. || 1 ||Meditating on the Lord, the bonds of Maya are cut away. When my God becomes kind and compassionate, one joins the Saadh Sangat, the Company of the Holy, and is emancipated.



Index of all the posts of Gurpartap Singh's Blog


Start OMS upgrade


Unzip zipped files like following and do chmod as well or installer can hang in between looking for some jar files.

jar -xvf em12_linux64_disk1of2.zip
jar -xvf em12_linux64_disk2of2.zip

21:41 : oracle : xxxxxxx : @NOSID : /m2/scratch/install/12c/software
$ chmod -R 777 12c_software










In end execute root:

[]$ sudo /opt/app/oracle/product/Middleware_12c/oms/allroot.sh

Starting to execute allroot.sh .........
Starting to execute /opt/app/oracle/product/Middleware_12c/oms/root.sh ......

Running Oracle 11g root.sh script...
The following environment variables are set as:

ORACLE_OWNER= oracle
ORACLE_HOME= /opt/app/oracle/product/Middleware_12c/oms
Enter the full pathname of the local bin directory: [/usr/local/bin]:

The file "dbhome" already exists in /usr/local/bin. Overwrite it? (y/n)
[n]:

The file "oraenv" already exists in /usr/local/bin. Overwrite it? (y/n)
[n]:

The file "coraenv" already exists in /usr/local/bin. Overwrite it? (y/n)
[n]:

Entries will be added to the /etc/oratab file as needed by
Database Configuration Assistant when a database is created

Finished running generic part of root.sh script.
Now product-specific root actions will be performed.

/etc exist
/opt/app/oracle/product/Middleware_12c/oms

Finished execution of /opt/app/oracle/product/Middleware_12c/oms/root.sh ......

Starting to execute /opt/app/oracle/product/Middleware_12c/agent/core/12.1.0.1.0/root.sh ......
Finished product-specific root actions.

/etc exist

/opt/app/oracle/product/Middleware_12c/agent/core/12.1.0.1.0
Finished execution of /opt/app/oracle/product/Middleware_12c/agent/core/12.1.0.1.0/root.sh ......
[]$



 
 
22:26 : oracle : xxxxxxxxxxxx : @OMS11G : /opt/app/oracle/product/Middleware_12c/oms/sysman/install


$ ./ConfigureGC.sh

Starting Oracle Universal Installer...

Checking Temp space: must be greater than 400 MB. Actual 2579 MB Passed
Checking swap space: must be greater than 150 MB. Actual 16404 MB Passed
Checking monitor: must be configured to display at least 256 colors. Actual 16777216 Passed








Click ok and cancel and bring plugins from ship home to installed oms home as follows:




22:31 : oracle : xxxxxxxxx : @NOSID : /opt/app/oracle/product/Middleware_12c/oms/sysman/install/undeployed_plugins

$ ls

12.1.0.1.0_oracle.em.sidb_2000_0.opar 12.1.0.1.0_oracle.sysman.emfa_2000_0.opar 12.1.0.1.0_oracle.sysman.vt_2000_0.opar
12.1.0.1.0_oracle.em.ssad_2000_0.opar 12.1.0.1.0_oracle.sysman.empa_2000_0.opar
12.1.0.1.0_oracle.sysman.emct_2000_0.opar 12.1.0.1.0_oracle.sysman.ssa_2000_0.opar



22:31 : oracle : xxxxxxxxx : @NOSID : /opt/app/oracle/product/Middleware_12c/oms/sysman/install/undeployed_plugins

$ mkdir /opt/app/oracle/product/tmp_support



22:33 : oracle : xxxxxxxxx : @NOSID : /opt/app/oracle/product/Middleware_12c/oms/sysman/install/undeployed_plugins

$ cp 12.1.0.1.0_oracle.sysman.vt_2000_0.opar /opt/app/oracle/product/tmp_support/.


22:33 : oracle : xxxxxxxxx : @NOSID : /opt/app/oracle/product/Middleware_12c/oms/sysman/install/undeployed_plugins

$ cp 12.1.0.1.0_oracle.em.ssad_2000_0.opar /opt/app/oracle/product/tmp_support/.

22:33 : oracle : xxxxxxxxx : @NOSID : /opt/app/oracle/product/Middleware_12c/oms/sysman/install/undeployed_plugins

$ cp 12.1.0.1.0_oracle.sysman.emfa_2000_0.opar /opt/app/oracle/product/tmp_support/.

22:34 : oracle : xxxxxxxxx : @NOSID : /opt/app/oracle/product/Middleware_12c/oms/sysman/install/undeployed_plugins

$ cp 12.1.0.1.0_oracle.sysman.empa_2000_0.opar /opt/app/oracle/product/tmp_support/.

22:34 : oracle : xxxxxxxxx : @NOSID : /opt/app/oracle/product/Middleware_12c/oms/sysman/install/undeployed_plugins

$ cp 12.1.0.1.0_oracle.em.sidb_2000_0.opar /opt/app/oracle/product/tmp_support/.

22:34 : oracle : xxxxxxxxx : @NOSID : /opt/app/oracle/product/Middleware_12c/oms/sysman/install/undeployed_plugins

$ cd /opt/app/oracle/product/tmp_support/.

22:34 : oracle : xxxxxxxxx : @NOSID : /opt/app/oracle/product/tmp_support

$ ls
12.1.0.1.0_oracle.em.sidb_2000_0.opar 12.1.0.1.0_oracle.sysman.emfa_2000_0.opar 12.1.0.1.0_oracle.sysman.vt_2000_0.opar
12.1.0.1.0_oracle.em.ssad_2000_0.opar 12.1.0.1.0_oracle.sysman.empa_2000_0.opar

22:34 : oracle : xxxxxxxxx : @NOSID : /opt/app/oracle/product/tmp_support

$

22:36 : oracle : xxxxxxxxx : @NOSID : /m2/scratch/install/12c/software/12c_software

$ ./runInstaller -plugininstall -pluginLocation /opt/app/oracle/product/tmp_support -mwHome /opt/app/oracle/product/Middleware_12c

22:41 : oracle : xxxxxxxxx : @OMS11G : /m2/scratch/install/12c/software/12c_software

$ ./runInstaller -plugininstall -pluginLocation /opt/app/oracle/product/tmp_support -mwHome /opt/app/oracle/product/Middleware_12c

Starting Oracle Universal Installer...
Checking Temp space: must be greater than 400 MB. Actual 2579 MB Passed
Checking swap space: must be greater than 150 MB. Actual 16404 MB Passed
Checking monitor: must be configured to display at least 256 colors. Actual 16777216 Passed
Preparing to launch Oracle Universal Installer from /tmp/OraInstall2012-03-15_10-42-02PM. Please wait ...

22:42 : oracle : xxxxxxxxx : @OMS11G : /m2/scratch/install/12c/software/12c_software

$ Unzipping operation is succeed..

the location is : /opt/app/oracle/product/Middleware_12c/oms/install/tmp_installer/oracle.sysman.empa/12.1.0.1.0

Installing plugin /opt/app/oracle/product/Middleware_12c/oms/install/tmp_installer/oracle.sysman.empa/12.1.0.1.0/12.1.0.1.0_OMS_2000_0.zip

You can find the log of this install session at:
/opt/app/oracle/product/oraInventory/logs/cloneActions2012-03-15_10-42-16-PM.log

Installing ORACLE_HOME /opt/app/oracle/product/Middleware_12c/plugins/oracle.sysman.empa.oms.plugin_12.1.0.1.0

Installation in progress
Install successful
Linking in progress
Link successful
Setup in progress
Setup successful
Unzipping operation is succeed..

the location is : /opt/app/oracle/product/Middleware_12c/oms/install/tmp_installer/oracle.em.ssad/12.1.0.1.0

Installing plugin /opt/app/oracle/product/Middleware_12c/oms/install/tmp_installer/oracle.em.ssad/12.1.0.1.0/12.1.0.1.0_OMS_2000_0.zip

You can find the log of this install session at:

/opt/app/oracle/product/oraInventory/logs/cloneActions2012-03-15_10-42-39-PM.log



Installing ORACLE_HOME /opt/app/oracle/product/Middleware_12c/plugins/oracle.em.ssad.oms.plugin_12.1.0.1.0

Installation in progress
Install successful
Linking in progress
Link successful
Setup in progress
Setup successful
Unzipping operation is succeed..

the location is : /opt/app/oracle/product/Middleware_12c/oms/install/tmp_installer/oracle.sysman.emfa/12.1.0.1.0

Installing plugin /opt/app/oracle/product/Middleware_12c/oms/install/tmp_installer/oracle.sysman.emfa/12.1.0.1.0/12.1.0.1.0_OMS_2000_0.zip

You can find the log of this install session at:

/opt/app/oracle/product/oraInventory/logs/cloneActions2012-03-15_10-43-01-PM.log



Installing ORACLE_HOME /opt/app/oracle/product/Middleware_12c/plugins/oracle.sysman.emfa.oms.plugin_12.1.0.1.0

Installation in progress
Install successful
Linking in progress
Link successful
Setup in progress
Setup successful
Unzipping operation is succeed..

the location is : /opt/app/oracle/product/Middleware_12c/oms/install/tmp_installer/oracle.em.sidb/12.1.0.1.0

Installing plugin /opt/app/oracle/product/Middleware_12c/oms/install/tmp_installer/oracle.em.sidb/12.1.0.1.0/12.1.0.1.0_OMS_2000_0.zip

You can find the log of this install session at:

/opt/app/oracle/product/oraInventory/logs/cloneActions2012-03-15_10-43-24-PM.log



Installing
ORACLE_HOME /opt/app/oracle/product/Middleware_12c/plugins/oracle.em.sidb.oms.plugin_12.1.0.1.0

Installation in progress
Install successful
Linking in progress
Link successful
Setup in progress



Setup successful
Unzipping operation is succeed..

the location is : /opt/app/oracle/product/Middleware_12c/oms/install/tmp_installer/oracle.sysman.vt/12.1.0.1.0

Installing plugin /opt/app/oracle/product/Middleware_12c/oms/install/tmp_installer/oracle.sysman.vt/12.1.0.1.0/12.1.0.1.0_OMS_2000_0.zip

You can find the log of this install session at:

/opt/app/oracle/product/oraInventory/logs/cloneActions2012-03-15_10-43-47-PM.log

Installing ORACLE_HOME /opt/app/oracle/product/Middleware_12c/plugins/oracle.sysman.vt.oms.plugin_12.1.0.1.0

Installation in progress
Install successful
Linking in progress
Link successful
Setup in progress
Setup successful
Plug-Ins installation is completed.


22:44 : oracle : xxxxxxxxx : @OMS11G : /m2/scratch/install/12c/software/12c_software

$


==========

22:45 : oracle : : @OMS11G : /opt/app/oracle/product/Middleware_12c/oms/sysman/install

$ ./ConfigureGC.sh

Starting Oracle Universal Installer...

Checking Temp space: must be greater than 400 MB. Actual 2380 MB Passed
Checking swap space: must be greater than 150 MB. Actual 16404 MB Passed
Checking monitor: must be configured to display at least 256 colors. Actual 16777216 Passed









 
 



 

















SQL> show parameter job_que




NAME TYPE
------------------------------------ ---------------------------------

VALUE
------------------------------

job_queue_processes integer
0

SQL> alter system set job_queue_processes=100;

System altered.

SQL> show parameter job_que


NAME TYPE
------------------------------------ ---------------------------------

VALUE
------------------------------
job_queue_processes integer

100
SQL>




Login as sysman:








Thats it !


He is the Creator of all, He is the Enjoyer of all. || 1 || Pause  || The Creator listens, and the Creator sees. The Creator is unseen, and the Creator is seen. The Creator forms, and the Creator destroys. The Creator touches, and the Creator is detached. || 1 ||The Creator is the One who speaks, and the Creator is the One who understands. The Creator comes, and the Creator also goes. The Creator is absolute and without qualities; the Creator is related, with the most excellent qualities. By Guru's Grace, Nanak looks upon all the same.
 

Tuesday, June 5, 2012

Part 39 of series - Upgrade Oracle Enterprise Manager 11g to Oracle Enterprise Manager 12c, Part - 1


When You are on my side, Lord, what do I need to worry about? You entrusted everything to me, when I became Your slave. My wealth is inexhaustible, no matter how much I spend and consume. The 8.4 million species of beings all work to serve me. All these enemies have become my friends, and no one wishes me ill. No one calls me to account, since God is my forgiver. I have become blissful, and I have found peace, meeting with the Guru, the Lord of the Universe. All my affairs have been resolved, since You are pleased with me.


Index of all the posts of Gurpartap Singh's Blog



Purpose
This document will provide step by step document to upgrade 11g Enterprise Manager Grid Control 11g to Enterprise Manager Grid Contrlol 12c with 1- system upgrade approach. The audience of this

document should understand the install and working of the Enterprise Manager 11g as well as 12c and at least should know the high level overview of 1-System upgrade.

Documentation
For this upgrade I am following upgrade guide located at the following link:

http://docs.oracle.com/cd/E24628_01/upgrade.121/e22625.pdf

Please note due to our security compliance we cannot use these steps as it is and we have to do some teaks and played around with sudos and credential setup and went through series of notes on metalink. All is documented here.

Glossary
The following is a list of terms and abbreviations that will be used throughout this document:

OMS – Oracle Management Service
Agent – Oracle Management Agent

Also instead of user gnepal you can use any user who is part of the “dba” group on all the servers.

Overview
In 1 – System upgrade we have an outage from the point we switch agents to the time we upgrade Oracle Management Service to 12c.

The 12.1.0.1 Enterprise Manager uses the 10.3.5 WebLogic Server environment for Grid Control web application deployment instead of the 10.3.2 WLS deployment environment utilized with version 11.1, so the existing Weblogic Server domain will be extended in the process of the upgrade from 11.1.0.1 to 12.1.0.1. The installer will place an 10.3.5 WLS installation with the requisite jdk1.6.0_24 in the 1-System Upgrade method from version 11.1.0.1.

Additionally, in Enterprise Manager 12.1.0.1, there is no backwards agent version compatibility (the 12.1.0.1 agent is java-based) so all agents of interest must be converted to 12.1.0.1 to work with the 12.1.0.1 Enterprise Manager console. Likewise, versions of the OMS prior to 12.1.0.1 will not be able to work with the 12.1.0.1 agent.

Summay of the upgrade process


The typical upgrade from 11.1.0.1 with the 1-System Method is this sequence of steps:

1. The 11.1.0.1 Enterprise Manager console is patched with the capability to manage the pre-upgrade actions for the OMS and all agents intended for upgrade in the monitored enterprise.

2. In 12.1.0.1, the agent has been defined as an agent core, which represents only the agent and host targets, and plug-ins, which add the ability to monitor all other targets types, including databases, application servers, etc. For any target host, the agent core is required as a minimum agent configuration for agent and host monitoring, but it will require additional plug-ins for any other hosted targets. This 12.1.0.1 agent core and plug-in software must be obtained and staged for deployment through the upgrade-patched 11.1.0.1 OMS.

3. In the 1-System upgrade method from version 11.1.0.1, 12.1.0.1 agents and the associated plug-in software must be pre-deployed to all target hosts of interest through the Upgrade Console in 11.1.0.1 Enterprise Manager using the Enterprise Manager job system. Any agents required after OMS upgrade will necessarily be introduced as new installations, without prior monitoring history.

4. The pre-deployed agents are evaluated and a Health Report is generated in a second job action initiated from the 11.1.0.1 Upgrade Console. The Health report requires user verification in order to proceed.

5. At a time close to the planned OMS/repository upgrade, the pre-deployed and verified 12.1.0.1 agents are switched over in still another job initiated form the 11.1.0.1 Upgrade Console. In switch over, the 12.1.0.1 agents are activated, ready to report into the 12.1.0.1 OMS when it is available, and the original, pre-12c agents are disabled..

6. The OMS and repository are upgraded to 12.1.0.1 in the final step of the 1-System upgrade. This upgrade consists of a 12.1.0.1 OMS installation on the same host as the original OMS, using different Middleware and Oracle Home directories. The 12.1.0.1 OMS points to the same repository as the original OMS, and the installer will upgrade the repository for 12.1.0.1 compatibility. This action disables the 11.1.0.1 OMS for further use, and it may be decommissioned once it is disabled

In the transition from 11.1.0.1 to 12.1.0.1, the deployment environment changes from the 10.3.2 WebLogic Server to the 10.3.5 WebLogic Server. The 10.3.5 WebLogic Server requires a platform-compatible jdk in version 1.6.0_24 for installation. The upgrade installer will install both the 1.6.0_24 jdk and the 10.3.5 WLS in the Linux versions in a new Middleware directory location determined by the user, and an additional Oracle Home directory for the 12.1.0.1 OMS will be placed in that location. The 12.1.0.1 agent location was independently was already determined by the user in the deployment action executed in the 11.1.0.1 Upgrade Console.

7. As the 12.1.0.1 OMS is started up during configuration in the upgrade installation, the pre-deployed 12.1.0.1 agents begin reporting automatically as the OMS begins to ping them, initiating monitoring/management in the 12.1.0.1 environment.

Required Software
The required Enterprise Manager software components for upgrade to 12.1.0.1:
- Upgrade Console patch (13503844) for the 11.1.0.1 OMS
- 12.1.0.1 agent base product installation source that can be deployed
- Plug-in files

The above three can be downloaded form:
http://www.oracle.com/technetwork/oem/grid-control/downloads/oem-upgrade-console-502238.html

- 12.1.0.1 Enterprise Manager base product installer
OEM12c software mentioned above can be downloaded from:

http://www.oracle.com/technetwork/oem/grid-control/downloads/linuxx8664soft-085949.html

Patch OEM11g OMS to create Upgrade Console
You need to apply patch 13503844 to all 11.1.0.1 Oracle Management Services in your environment. We had two and I applied this patch. To apply this patch just follow the readme accompanies with this patch.

Once the patch application and post-installation scripts have been completed successfully, start the OMS and view the Deployments page by accessing its tab. Note the presence of a new feature, the Enterprise Manager 12c Upgrade Console at the top of the feature stack under the Upgrade heading.

Note the state of the OMS installation prior to patching shows no evidence of the upgrade console in the Deployments page.

As described in the README.txt file, for upgrade from version 11.1.0.1, run the first two post-patch rcuJDBCEngine scripts with sys credentials and the third with sysman credentials.

These scripts are required so the Upgrade Console will be functional. If these scripts are not run, the link to the Upgrade Console will be available in the Deployments main page, but an error will be returned when it is accessed.



Once the patch was applied our lsinventory will look like following:

17:20 : oracle : xxxxxx : @OMS11G : /opt/app/oracle/product/Middleware/oms11g/OPatch



$ ./opatch lsinventory
Oracle Interim Patch Installer version 11.1.0.9.4
Copyright (c) 2011, Oracle Corporation. All rights reserved.
Oracle Home : /opt/app/oracle/product/Middleware/oms11g
Central Inventory : /opt/app/oracle/product/oraInventory
from : /opt/app/oracle/product/Middleware/oms11g/oraInst.loc
OPatch version : 11.1.0.9.4
OUI version : 11.1.0.8.0
Log file location : /opt/app/oracle/product/Middleware/oms11g/cfgtoollogs/opatch/opatch2012-02-15_17-20-43PM_1.log
OPatch detects the Middleware Home as "/opt/app/oracle/product/Middleware"
Lsinventory Output file location : /opt/app/oracle/product/Middleware/oms11g/cfgtoollogs/opatch/lsinv/lsinventory2012-02-15_17-20-43PM.txt


--------------------------------------------------------------------------------


Installed Top-level Products (1):
Oracle Enterprise Manager Grid Console 11.1.0.1.0
There are 1 products installed in this Oracle Home.
Interim patches (4) :
Patch 13503844 : applied on Fri Jan 27 14:31:15 PST 2012
Unique Patch ID: 14378035
Created on 16 Dec 2011, 02:16:47 hrs PST8PDT
Bugs fixed:
10044087, 13503844
Patch 11727299 : applied on Thu May 05 17:09:58 PDT 2011
Unique Patch ID: 13669556
Created on 11 Mar 2011, 08:29:30 hrs PST8PDT

Bugs fixed:
9804442, 10122270, 9930146, 9576468, 10108019, 9535382, 9928480, 9543582
9276193, 10278756, 9892455, 9476313, 9911851, 9506062, 9876632, 9386076
9803798, 10043790, 9646681, 9965939, 9500255, 9390531, 9662869, 9462098
9544428, 9747671, 9489355, 9706552, 9562462, 9570911, 10638043, 9937784
7340407, 9723689, 9575427, 10204587, 9935898, 9734399, 9504581, 9558551
9446422, 9874327, 9586285, 9548105, 9313608, 9534200, 9684768, 9341486
10122223, 10307544, 9849222, 9537948, 10118817, 9919614, 9903280, 9888852
9342290, 10410743, 9151748, 9221090, 10213026, 9952713, 9491872, 9559264
10015330, 10036568, 10042225

Patch 9367763 : applied on Wed Oct 27 20:33:08 PDT 2010
Unique Patch ID: 12255254
Created on 1 Mar 2010, 22:34:50 hrs PST8PDT


Bugs fixed:
9367763


Patch 9207217 : applied on Wed Oct 27 20:33:01 PDT 2010
Unique Patch ID: 12151251
Created on 27 Jan 2010, 15:49:36 hrs US/Pacific
Bugs fixed:
9207217

--------------------------------------------------------------------------------
OPatch succeeded.


17:20 : oracle : xxxxx0 : @OMS11G : /opt/app/oracle/product/Middlewa







OMS/Repository Upgrade Preparation: Managing Agent Software


8.1 Accessing the Upgrade Console

The view from the Upgrade Console allows access to the Overview link, which takes the user to a description of the upgrade process for reference, the Agent Upgrade Status view, which summarizes the state of the agent deployment and preparation activity and the Manage Software view, which allows association of agent core product and plug-in install stages with the console for deployment purposes.

Note that the steps involved in the upgrade will change with the upgrade type selection that must be made before continuing. Described here is the 1-System upgrade (same host).

Note also the presence of the Refresh Agent List button which will allow recognition of any agents discovered

After the Upgrade Console patch was applied. The list is not automatically updated, so refreshing from the Upgrade Console will be required in the event of new agent additions.

When you click on the upgrade console you will see the following screen:




8.2 Manage Software to Get an Appraisal of the Enterprise Targets




The task sequence in the conversion to 12.1.0.1 Enterprise Manager monitoring in the 1-System method is to deploy and configure 12.1.0.1 agents to all monitored hosts, evaluate the health of the monitoring environment and switch over to the newly deployed 12.1.0.1 agents. To prepare for the deployment of 12.1.0.1 agents, staged agent software must be recognized by the Upgrade Console.



8.2.1 Download and Deploy Agent Core and required Plugins
On the OMS server download and deploy the plugins and agent core software at the same location.
Download them from following location:

http://www.oracle.com/technetwork/oem/grid-control/downloads/oem-upgrade-console-502238.html

and deploy on both nodes at this location, please note that zip file of agent core is not unzipped:

/m2/scratch/install/12c/software/AgentCore_226

Here is ls –lart looks like in this directory on both servers:

18:41 : oracle : xxxx : @OMS11G : /m2/scratch/install/12c/software/AgentCore_226



$ ls -lart


total 1433092


-rw-r--r-- 1 oracle oinstall 8980435 Feb 9 15:42 12.1.0.1.0_oracle.sysman.mos_2000_0.opar


-rw-r--r-- 1 oracle oinstall 297231 Feb 9 15:42 12.1.0.1.0_oracle.sysman.emrep_2000_0.opar


-rw-r--r-- 1 oracle oinstall 3925371 Feb 9 15:42 12.1.0.1.0_oracle.em.soee_2000_0.opar


-rw-r--r-- 1 oracle oinstall 3505186 Feb 9 15:43 12.1.0.1.0_oracle.sysman.xa_2000_0.opar


-rw-r--r-- 1 oracle oinstall 621251038 Feb 9 15:43 12.1.0.1.0_oracle.sysman.db_2000_0.opar


-rw-r--r-- 1 oracle oinstall 8780464 Feb 9 15:43 12.1.0.1.0_oracle.sysman.vt_2000_0.opar


-rw-r--r-- 1 oracle oinstall 580159 Feb 9 15:43 12.1.0.1.0_oracle.em.sidb_2000_0.opar


-rw-r--r-- 1 oracle oinstall 28076693 Feb 9 15:43 12.1.0.1.0_oracle.sysman.emfa_2000_0.opar


-rw-r--r-- 1 oracle oinstall 2246995 Feb 9 15:43 12.1.0.1.0_oracle.sysman.ssa_2000_0.opar


-rw-r--r-- 1 oracle oinstall 495016 Feb 9 15:43 12.1.0.1.0_oracle.sysman.oh_2000_0.opar


-rw-r--r-- 1 oracle oinstall 6555873 Feb 9 15:43 12.1.0.1.0_oracle.sysman.empa_2000_0.opar


-rw-r--r-- 1 oracle oinstall 2775862 Feb 9 15:43 12.1.0.1.0_oracle.sysman.emct_2000_0.opar


-rw-r--r-- 1 oracle oinstall 440206388 Feb 9 15:43 12.1.0.1.0_oracle.sysman.emas_2000_0.opar


-rw-r--r-- 1 oracle oinstall 499849 Feb 9 15:43 12.1.0.1.0_oracle.sysman.csa_2000_0.opar


-rw-r--r-- 1 oracle oinstall 106452968 Feb 9 15:43 12.1.0.1.0_oracle.sysman.beacon_2000_0.opar


-rw-r--r-- 1 oracle oinstall 607976 Feb 9 15:43 12.1.0.1.0_oracle.em.ssad_2000_0.opar


-rwxr-xr-x 1 oracle oinstall 230699506 Feb 9 15:43 12.1.0.1.0_AgentCore_226.zip


drwxr-xr-x 3 oracle oinstall 4096 Feb 9 15:43 .


drwxr-xr-x 8 oracle oinstall 4096 Feb 10 11:18 ..


drwxr----- 18 oracle oinstall 4096 Feb 10 16:15 plugin_bin






18:41 : oracle : xxxx : @OMS11G : /m2/scratch/install/12c/software/AgentCore_226


$


Recognizing the agent upgrade software


To associate the 12.1.0.1 agent software with the Upgrade Console, select the Manage Software link in the Upgrade Console. On initial access, without any software association, the Manage Software view will only show that agents are not upgradeable. This status should change as valid staged agent deployment software is recognized by the Upgrade Console. Note the status of the agent and plug-in software in the Agent Software and Plug-in Software tables near the bottom of the page.

In the Software Location field, enter the file path of the directory containing the agent core (i.e., 12.1.0.0.0_AgentCore_226.zip for the Linux x86_64 agent) and the plug-in files (i.e. 12.1.0.0.0_oracle.sysman.db_2000_0.opar for the generic db plug-in) on the OMS.

The screen will look like this:





Validating the Agent Software Location


Select Validate on the Manage Software page when the file path has been entered and the Upgrade Console will recognize a properly staged file set, associate this file set with the appropriate agents and update the view of the agent status to show ability to upgrade.

Click Validate and you will see the screen below, make sure that you check “Click if the software location is shared across all OMSes”






This should how 100% green but if not we can continue with upgrade with agents that are ok with plugins but which need plugins we have to install and deploy them. We had problem with exadata plugins and Oracle thinks it’s a bug and they are working on it.


Validation Results

Note the change in agent and target status shown in the pie charts and the tables on the Manage Software page. Review the results, especially the agents or targets in not upgradeable status, and correct any reported shortcomings, if the agent or target is one that must be monitored in Enterprise Manager 12.1.0.1. Validate once more, once the corrections have been made to accumulate the corrected agents and targets in the upgradeable category. Any change to the staged software will require re-validation.

The file location of the designated agent software will have added a /plugin_bin directory at the same level as the agent file, housing the plug-in software extracted in the validation step.

Note that an agent core .zip file is required for every agent platform represented in the current monitoring arrangement.

Push and configure Oracle Management Agent Software to Targets

Pre-step is to do host credentials test. As here in Sony we don’t have Oracle user password so, I had to work with security team to get the push of agents working for me.

There are 5 pre-steps and 3 of them are for SA.

1. Make sure we have package param_devel installed on the target server - SA

2. Take the backup of existing file /etc/pam.d/emagent if it exists and replace it with the contents of /etc/pam.d/sshd. If file /etc/pam.d/emagent doesn’t exist just create a new one as a copy of /etc/pam.d/sshd - SA

3. Update sudoers file as given in Apendix

4. Update .profile under home directory of user ORACLE and add following entry - DBA

export LD_LIBRARY_PATH=/usr/lib64:$LD_LIBRARY_PATH

5. Edit file commonenv in directory $AGENT_HOME/bin and in the end of that file add following text in blue

if [ "$LD_LIBRARY_PATH" = "" ] ; then
LD_LIBRARY_PATH=/usr/lib64/libpamc.so
else
LD_LIBRARY_PATH=/usr/lib64/libpamc.so:$LD_LIBRARY_PATH
fi

Set Manage Privilege Delegation Setting Templates

Go to Preferences -> Preferred Credentials (left part of Screen) -> Clcik Set Crendentials blue icon in front of Host -> In search bar find the target server

Now you will see the following screen as:





Here click url “Manage Privilege Delegation Settings” and search for your target host again and you will see the following screen:





Click on the pen on most right of the line to edit the privileges as and then on next scren click in a radio button in front of “Sudo” and then clcik update and you will see the following screen.




Here in “Sudo Command” box copy paste the following line in blue:


/usr/bin/sudo -u %RUNAS% %COMMAND%

Note – Here /usr/bin/sudo is the location of sudo binaries on your Operating system
And your screen now looks like following:



Click update now and on next screen click “Yes” and you will see the following, i.e. under type it will say “Sudo::


9.2 Set Prefered Credentials of the server


Go to Preferences -> Preferred Credentials (left part of Screen) -> Clcik Set Crendentials blue icon in front of Host -> In search bar find the target server

Now you will see the following screen as:




Fill the form as:



Normal Username – gnepal
Normal Password –
Run as - oracle
Privileged User - gnepal
Privileged Password -
Run as - root

Now your screen looks like following screen:


Now click test and check the result as “Credentials successfully verified for xxxxxxx:



Push the Agent from Upgrade console


Click Deployments ->


Click “Enterprise Manager 12c Upgrade Console” under heading upgrade and click “Target Upgradability Status” under heading “Other Links”


And you will see following and search for host “lv-dnp-db106.sonynei.net” or where you want to push the software:




You will see the following, i.e. target is upgradable:




Now on the home screen of Upgrade console under Deploymets -> Enterprise Manager 12c Upgrade Console,  Click “Deploy and Configure Agents” under “Agent Upgrade Steps” you will see the following screen:



Add agent that you want to upgrade by clicking add:


Type host name of the target server and in our case its “xxxxx” and click go.




Check the box in front of the agent name and click select and on your orignal screen you will that the agent has been select, just click the check box in front of it.


Under “Agent Base Directory” and “Agent Instance Name” make sure the path is:

/opt/app/oracle/product/agent12c/root.sh – Sony Standards

and not

/opt/app/oracle/product/agent12g/root.sh

and you will have the following screen:




Under “Agent Credentials” click “Override Oracle Home Preferred Credentials” and the page will refresh and you will again have to do the check mark in front of agent name. Now fill in the “User Name” as gnepal and also enter its password twice and check “SUDO” under “Run Privilege” and in “Run as” fill “oracle” . The screen will look like following, just match your screen.



Click “NEXT” and you will see the following screen , just fill in “User Name”  gnepal and enter the password twice. Make sure radio button in front of SUDO is checked and “Run As” is greyed out and is “root”




Now click Submit and you will get the follwoing screen :
 
 

Click on the job and you will see the following:





Just keep refreshing the page and see the progress:





Just keep watching it till the status changes from “Running” to “Succeeded”.


Make sure the status of all the componenets is also “Succeeded” and if any is failed please fix it and then proceed from this point onwards.







 
 









Click on “Sign off health Report of Deployed Agents” and you will see the following screen:




Select one agent at a time and click view detailed report and then on the same page go through the report. If there are ptroblems it will show warnings in red. If there are warnings just fix them and comeback and view detailed report again and if all is well just click “Verify and Sing Off Report”.



Report in beginning looks like:







And  in end looks like:





Once all have been verified you will see something like following:




Switch agents


Outage for the agent will start here. Just click and select the agent and fill the form as shown below and submit the job.












Click submit and you will get the following:
 

and
 


OMS upgraded is continued in next part.



Why, O mind, do you plot and plan, when the Dear Lord Himself provides for your care?
From rocks and stones He created living beings; He places their nourishment before them.  O my Dear Lord of souls, one who joins the Sat Sangat, the True Congregation, is saved. By Guru's Grace, the supreme status is obtained, and the dry wood blossoms forth again in lush greenery.  Pause Mothers, fathers, friends, children and spouses no one is the support of anyone else. For each and every person, our Lord and Master provides sustenance. Why are you so afraid, O mind?  The flamingoes fly hundreds of miles, leaving their young ones behind. Who feeds them, and who teaches them to feed themselves? Have you ever thought of this in your mind?  All the nine treasures, and the eighteen supernatural powers are held by our Lord and Master in the Palm of His Hand. Servant Nanak is devoted, dedicated, forever a sacrifice to You, Lord. Your Expanse has no limit, no boundary. 





Click on the job name and then you will get the following page:


Once all Switchover is done we will have a following screens: