Add

Tuesday, 11 March 2014

Grub2 Fedora 17 : Changing Background - Default - Timeout settings

Today GRUB2 ships out with most of the Linux Distribution as a default Boot loader. Let’s take some time to do customization.

Topics covered: 
               Changing your “DEFAULT OPTION” from Linux to Windows.
                Changing your “TIMEOUT OPTION” from default 5 sec.
               Changing GRUB2 background Wallpaper “SPLASHIMAGES” of your own.


Remember these configuration three files:
·         /etc/default/grub
·         /boot/grub2/grub.cfg
·         /etc/grub.d/<<Scripts>>

PART I
Whenever you install Linux above Windows(i.e Installing Windows OS at first and later installing Linux) “DEFAULT OPTION”  in boot loader will be set to Linux by default. Timeout is a delay waiting for user inputs before selecting default option. It’s necessary to change the DEFAULT and TIMEOUT Option for our choice.


Step 1) Identify the TITLE of Operating system which has to be loaded default.
NOTE: If you install windows first and above it Linux, Grub2 Boot loader will take care of identifying already residing OS’s. Grep 'Windows' or 'Fedora' or 'Ubuntu' keywords from the greub2.cfg file.

 #cat /boot/grub2/grub.cfg | egrep -i 'Windows|Fedora|Ubuntu'
 or 
 #cat /etc/grub.cfg | egrep -i 'Windows|Fedora|Ubuntu'


Step 2) Use #grub2-set-default command to set the new value of your choice. You can check the default entry using #grub2-editenv list to see the changes.
 #grub2-set-default='Windows 7 (loader) (on /dev/sda2)'   




Step 3) Update #grub2-mkconfig to update the grub.cfg file.

# grub2-mkconfig -o /etc/grub2.cfg
# grub2-mkconfig -o /boot/grub2/grub.cfg


Step 4) Update value “GRUB_TIMEOUT” in file /etc/default/grub
GRUB_TIMEOUT=20 [Value in seconds] 


Step 5) Update #grub2-mkconfig to update the grub.cfg file.

# grub2-mkconfig -o  /etc/grub2.cfg
# grub2-mkconfig -o  /boot/grub2/grub.cfg



Part II

However it isn't compulsory to change the default background wallpaper, but something of your own will always add attitude of you, I’m just touching background and font part in theme.


Step 1) Remove comment for GRUB_THEME line in /etc/default/grub
GRUB_THEME="/boot/grub2/themes/system/theme.txt"

    
Step 2) Download / Copy files to /boot/grub2/themes/system/{default theme parent directory}


Step 3) Edit theme.txt file in boot/grub2/themes/system/ with desktop-image=”value to latest background filename”.
    
desktop-image: "amithbackground.jpg"


Step 4) Update #grub-mkconfig to update the grub.cfg file
# grub2-mkconfig -o  /etc/grub2.cfg
# grub2-mkconfig -o  /boot/grub2/grub.cfg



Step 5)Reboot to see changes :)  .



Reference : theme.txt 
######################################################################## 
#general settings
message-font: "DejaVu Serif Regular 12"
message-color: "#fff"
message-bg-color: "#000"
terminal-box: "terminal_box_*.png"
terminal-font: "DejaVu Serif Regular 12"
desktop-image: "amithbackground.jpg"

#help bar at the bottom
+ label {
        top = 100%-25
        left = 0
        width = 100%
        height = 20
        text = "@KEYMAP_MIDDLE@"
        align = "center"
        font = "DejaVu Serif Regular 10"
        color = "#FFF"
}

#boot menu
+ boot_menu {
        left = 10%
        width = 80%
        top = 20%
        height = 50%
        item_font = "DejaVu Serif Regular 12"
        item_color = "#3c6eb4"
        selected_item_font = "DejaVu Serif Bold 14"
        selected_item_color= "#fff"
        selected_item_pixmap_style = "blob_*.png"
        icon_height = 25
        icon_width = 25
        item_height = 26
        item_padding = 0
        item_icon_space = 0
        item_spacing = 1
        scrollbar = true
        scrollbar_width = 20
        scrollbar_thumb = "slider_*.png"
        menu_pixmap_style = "boot_menu_*.png"
}

#progress bar
+ progress_bar {
        id = "__timeout__"
        left = 15%
        top = 80%
        height = 20
        width = 70%
        font = "DejaVu Serif Regular 12"
        text_color = "#fff"
        fg_color = "#3c6eb4"
        bg_color = "#294172"
        border_color = "#fff"
        text = "@TIMEOUT_NOTIFICATION_LONG@"
}


Thursday, 6 March 2014

DATA migration : Using expdp/impdp for Data Transfer between Oracle Databases.

DATA migration : Using expdp/impdp for Data Transfer between Oracle Databases.
 
Unless Databases are in some version.release it won’t make an issue, But for example if you have Oracle 11.1.0.7 as source and wish to import it in 10.2.0.3.0 you should use version parameter along with expdp/impdp.
 
STEP 1: Sqlplus to source and target databases as sys : 
      # sqlplus / as sysdba

STEP 2: Specifying export/import dump directory:
 
      # CREATE DIRECTORY expdpump_dir AS /home/oracle[version]g/datapump and  exit.
 
NOTE: Exporting and importing can be done the using expdp/impdp in fallowing modes. 
 
Full Mode   : FULL=y
           Schema Mode : SCHEMAS=name1,name2,name3
           TABLES Mode : TABLES=Table1,Table2,Table3
          
Step 3: RUN export at Source:
 
#  expdp system/[PASSWORD]@[SID] schemas=[SCHEMA] DIRECTORY=expdpump_dir JOB_NAME=test DUMPFILE=[SCHEMA]_[SID]_[date]_%u.dmp logfile=EXP_[SCHEMA]_[SID]_date.log PARALLEL=4 VERSION=10.2.0.3.0
 
     Successful export output from log file : /home/oracle11g/datapump/exp_[SCHEMA]_[SID]_date.log
 
Dump file set for "SYS"."SYS_EXPORT_SCHEMA_01" is:
/home/oracle11g/datapump/[SCHEMA]_[SID]_[date]_1.dmp
/home/oracle11g/datapump/[SCHEMA]_[SID]_[date]_2.dmp
/home/oracle11g/datapump/[SCHEMA]_[SID]_[date]_3.dmp
/home/oracle11g/datapump/[SCHEMA]_[SID]_[date]_4.dmp
Job "SYS"."SYS_EXPORT_SCHEMA_01" successfully completed at 01:35:45
 
 
 
NOTE : Use  PARALLEL parameter depending on the number of CPUs(some says twice of CPUs cores, don’t try too much) on your server, %u in DUMPFILE implies that multiple files may be generated
 
NOTE : We should give the version parameter value as target database (Wherever we import) compatible parameter value.In my case impdp for : 10.2.0.3.0
 
 
STEP 4 : Transfer the Datapump to Destination dump dir’ “/home/oracle[version]g/datapump” use ftp or scp.
 
STEP 5 : RUN import at Destination :
 
#  impdp system/[PASSWORD]@[SID] schemas=[SCHEMA] DIRECTORY=dpump_dir1 JOB_NAME=test DUMPFILE=[SCHEMA]_[SID]_[date]%u.dmp logfile=IMP_[SCHEMA]_[SID]_date.log  PARALLEL=4 VERSION=10.2.0.3.0
    
Successful export output from log file : /home/oracle10g/datapump/IMP_[SCHEMA]_[SID]_date.log
 
imported "SYS"."SYS_OBJECTS"                           9.956 MB  101933 rows
Job "SYS"."SYS_IMPORT_SCHEMA_01" completed without any error(s) at 01:54:57
 
 
STEP 6 : Final but I always find very helpful – MONITORING the export/import job STATUS.I understand the pain of waiting for log file to be written, but understand this log file will be optionally written and you often suspect JOB may be NOT RUNNING. All I say is KEEP THE FAITH in expdp/impdp.
 
 
  >   SELECT owner_name, job_name, operation, state FROM dba_datapump_jobs;
 
OWNER_NAME JOB_NAME             OPERATION   STATE     
---------- -------------------- ---------- ------------
SYSTEM     TEST                  EXPORT     NOT RUNNING
 
Oh! Yes TEST EXPORT is NOT RUNNING.
 
STEP 7: KILL || STOP || RESUME || RESTART Datapump Jobs.
When exporting (or importing), press Ctrl-c to show the datapump prompt
 
     KILL_JOB  : Is something you cannot retriew the Job later, usually done when Job is in hung state.
    
           Processing object type DATABASE_EXPORT/SCHEMA/TABLE/TABLE_DATA
[Ctrl-c]
Export> KILL_JOB
 
     STOP_JOB : Can be reusmed later [STOP_JOB=IMMEDIATE] where you like to pause the datatpump job for some reason.
          
Processing object type DATABASE_EXPORT/SCHEMA/TABLE/TABLE_DATA
[Ctrl-c]
Export> STOP_JOB=IMMEDIATE
Are you sure you wish to stop this job ([yes]/no): yes

ATTACH  : Resume the Stopped JOB 

           # expdp system/[PASSWORD]@[SID ATTACH=[JOB_NAME]
 
 
     START_JOB: Restart the current job Use [=SKIP_CURRENT] and CONTINUE_CLIENT.
 
Processing object type DATABASE_EXPORT/SCHEMA/TABLE/TABLE_DATA
[Ctrl-c]
Export> START_JOB=SKIP_CURRENT
Export> CONTINUE_CLIENT
Job EXP_FULL has been reopened at Thursday, 09 June, 2011 10:26
Restarting "SYSTEM"."TEST":  expdp system*******@[SID] schemas=[SCHEMA] DIRECTORY=expdpump_dir JOB_NAME=test DUMPFILE=[SCHEMA]_[SID]_[date]_%u.dmp logfile=EXP_[SCHEMA]_[SID]_date.log PARALLEL=4 VERSION=10.2.0.3.0
 
Processing object type DATABASE_EXPORT/TABLESPACE

Wednesday, 5 March 2014

Reset ROOT password in MySQL

Using init file while starting the mysql daemon to reset the password of root user in MySQL
 
Step 1) Prepare the init file at : /home/<<location>>/mysql-init - content as fallows
    
        UPDATE mysql.user SET Password=PASSWORD('MyNewPass') WHERE User='root'; FLUSH PRIVILEGES;

NOTE: 
You don't need the old password to reset for new, its like something when you forgot/don't know the root password 
 
Step 2)

    i)if you are starting first time after fresh installation

            ## /etc/init.d/mysqld start --init-file=/home/<<location>>/mysql-init & 
 
    ii)if your myslqd already running,     

         a. Kill or stop mysql daemon
            # /etc/init.d/mysqld stop
                or
            # kill -9 <<PID's of all mysqld process>>
         

         b. Start in safe mode

            # mysqld_safe --init-file=/home/<<location>>/mysql-init &
    

    iii)Stop and restart in normal mode to make effect.

             # /etc/init.d/mysqld stop

             # /etc/init.d/mysqld start