Veritas InfoScale™ 7.2 Solutions Guide - Solaris
- Section I. Introducing Veritas InfoScale
- Section II. Solutions for Veritas InfoScale products
- Section III. Improving database performance- Overview of database accelerators
- Improving database performance with Veritas Quick I/O- About Quick I/O
- Tasks for setting up Quick I/O in a database environment
- Creating DB2 database containers as Quick I/O files using qiomkfile Creating Sybase files as Quick I/O files using qiomkfile
- Preallocating space for Quick I/O files using the setext command
- Accessing regular VxFS files as Quick I/O files
- Extending a Quick I/O file
- Disabling Quick I/O
 
- Improving database performance with Veritas Cached Quick I/O
- Improving database performance with Veritas Concurrent I/O
 
- Section IV. Using point-in-time copies- Understanding point-in-time copy methods
- Backing up and recovering- Storage Foundation and High Availability Solutions backup and recovery methods
- Preserving multiple point-in-time copies
- Online database backups
- Backing up on an off-host cluster file system
- Database recovery using Storage Checkpoints
 
- Backing up and recovering in a NetBackup environment
- Off-host processing
- Creating and refreshing test environments
- Creating point-in-time copies of files
 
- Section V. Maximizing storage utilization- Optimizing storage tiering with SmartTier- About SmartTier
- About VxFS multi-volume file systems
- About VxVM volume sets
- About volume tags
- SmartTier use cases for Sybase
- Setting up a filesystem for storage tiering with SmartTier
- Relocating old archive logs to tier two storage using SmartTier
- Relocating inactive tablespaces or segments to tier two storage
- Relocating active indexes to premium storage
- Relocating all indexes to premium storage
 
- Optimizing storage with Flexible Storage Sharing
 
- Optimizing storage tiering with SmartTier
- Section VI. Migrating data- Understanding data migration
- Offline migration from Solaris Volume Manager to Veritas Volume Manager- About migration from Solaris Volume Manager
- How Solaris Volume Manager objects are mapped to VxVM objects
- Overview of the conversion process
- Planning the conversion
- Preparing a Solaris Volume Manager configuration for conversion
- Setting up a Solaris Volume Manager configuration for conversion
- Converting from the Solaris Volume Manager software to VxVM
- Post conversion tasks
- Converting a root disk
 
- Online migration of a native file system to the VxFS file system- About online migration of a native file system to the VxFS file system
- Administrative interface for online migration of a native file system to the VxFS file system
- Migrating a native file system to the VxFS file system
- Migrating a source file system to the VxFS file system over NFS v3
- Backing out an online migration of a native file system to the VxFS file system
- VxFS features not available during online migration
 
- Migrating storage arrays
- Migrating data between platforms- Overview of the Cross-Platform Data Sharing (CDS) feature
- CDS disk format and disk groups
- Setting up your system to use Cross-platform Data Sharing (CDS)
- Maintaining your system- Disk tasks
- Disk group tasks- Changing the alignment of a disk group during disk encapsulation
- Changing the alignment of a non-CDS disk group
- Splitting a CDS disk group
- Moving objects between CDS disk groups and non-CDS disk groups
- Moving objects between CDS disk groups
- Joining disk groups
- Changing the default CDS setting for disk group creation
- Creating non-CDS disk groups
- Upgrading an older version non-CDS disk group
- Replacing a disk in a CDS disk group
- Setting the maximum number of devices for CDS disk groups
- Changing the DRL map and log size
- Creating a volume with a DRL log
- Setting the DRL map length
 
- Displaying information- Determining the setting of the CDS attribute on a disk group
- Displaying the maximum number of devices in a CDS disk group
- Displaying map length and map alignment of traditional DRL logs
- Displaying the disk group alignment
- Displaying the log map length and alignment
- Displaying offset and length information in units of 512 bytes
 
- Default activation mode of shared disk groups
- Additional considerations when importing CDS disk groups
 
- File system considerations- Considerations about data in the file system
- File system migration
- Specifying the migration target
- Using the fscdsadm command- Checking that the metadata limits are not exceeded
- Maintaining the list of target operating systems
- Enforcing the established CDS limits on a file system
- Ignoring the established CDS limits on a file system
- Validating the operating system targets for a file system
- Displaying the CDS status of a file system
 
- Migrating a file system one time
- Migrating a file system on an ongoing basis
- When to convert a file system
- Converting the byte order of a file system
 
- Alignment value and block size
- Disk group alignment and encapsulated disks
- Disk group import between Linux and non-Linux machines
- Migrating a snapshot volume
 
 
- Section VII. Veritas InfoScale 4K sector device support solution
Setting up a replica database for off-host decision support
To set up a replica database for off-host decision support
- If you have not already done so, prepare the off-host processing host to use the snapshot volume that contains the copy of the database tables. Set up any new database logs and configuration files that are required to initialize the database.
- On the primary host, use the following command to make a full-sized snapshot, snapvol, of the tablespace volume by breaking off plexes from the original volume:# vxsnap -g database_dg make \ source=volume/newvol=snapvol/nmirror=N The nmirror attribute specifies the number of mirrors, N, in the snapshot volume. If the volume does not have any available plexes, or its layout does not support plex break-off, prepare an empty volume for the snapshot. Then use the following command to create the snapshot: # vxsnap -g database_dg make source=volume/snapvol=snapvol If a database spans more than one volume, specify all the volumes and their snapshot volumes as separate tuples on the same line, for example: # vxsnap -g database_dg make source=vol1/snapvol=svol1 \ source=vol2/snapvol=svol2 source=vol3/snapvol=svol3 Note: This step sets up the snapshot volumes, and starts tracking changes to the original volumes. When you are ready to create the replica database, proceed to step 3. 
- If the volumes to be backed up contain database tables in file systems, suspend updates to the volumes:DB2 provides the write suspend command to temporarily suspend I/O activity for a database. As the DB2 database administrator, use a script such as that shown in the example. Note that if the replica database must be able to be rolled forward (for example, if it is to be used as a standby database), the primary database must be in LOGRETAIN RECOVERY mode. #!/bin/ksh # # script: backup_start.sh # # Sample script to suspend I/O for a DB2 database. # # Note: To recover a database using backups of snapshots, the database # must be in LOGRETAIN mode. db2 <<! connect to database set write suspend for database quit ! Sybase ASE from version 12.0 onward provides the Quiesce feature to allow temporary suspension of writes to a database. As the Sybase database administrator, put the database in quiesce mode by using a script such as that shown in the example. #!/bin/ksh # # script: backup_start.sh # # Sample script to quiesce example Sybase ASE database. # # Note: The "for external dump" clause was introduced in Sybase # ASE 12.5 to allow a snapshot database to be rolled forward. # See the Sybase ASE 12.5 documentation for more information. isql -Usa -Ppassword -SFMR <<! quiesce database tag hold database1[, database2]... [for external dump] go quit ! If you are using Sybase ASE 12.5, you can specify the for external dump clause to the quiesce command. This warm standby method allows you to update a replica database using transaction logs dumped from the primary database. 
- On the primary host, refresh the contents of the snapshot volumes from the original volume using the following command:# vxsnap -g database_dg refresh snapvol source=vol \ [snapvol2 source=vol2]... syncing=yes The syncing=yes attribute starts a synchronization of the snapshot in the background. For example, to refresh the snapshots svol1, svol2 and svol3: # vxsnap -g database_dg refresh svol1 source=vol1 \ svol2 source=vol2 svol3 source=vol3 
- If you temporarily suspended updates to volumes in step 3 , release all the tablespaces or databases from suspend, hot backup or quiesce mode:As the DB2 database administrator, use a script such as that shown in the example. #!/bin/ksh # # script: backup_end.sh # # Sample script to resume I/O for a DB2 database. # db2 <<! connect to database set write resume for database quit ! As the Sybase database administrator, release the database from quiesce mode using a script such as that shown in the example. #!/bin/ksh # # script: backup_end.sh # # Sample script to release example Sybase ASE database from quiesce mode. isql -Usa -Ppassword -SFMR <<! quiesce database tag release go quit ! 
- Use the following command to wait for the contents of the snapshot to be fully synchronous with the contents of the original volume:# vxsnap -g database_dg syncwait snapvol For example, to wait for synchronization to finish for all the snapshots svol1, svol2 and svol3, you would issue three separate commands: # vxsnap -g database_dg syncwait svol1 # vxsnap -g database_dg syncwait svol2 # vxsnap -g database_dg syncwait svol3 Note: You cannot move a snapshot volume into a different disk group until synchronization of its contents is complete. You can use the vxsnap print command to check on the progress of synchronization. 
- On the primary host, use the following command to split the disks containing the snapshot volumes into a separate disk group, snapvoldg, from the original disk group, database_dg:# vxdg split database_dg snapvoldg snapvol ... For example to split the snap volumes from database_dg: # vxdg split database_dg snapvoldg svol1 svol2 svol3 
- On the primary host, deport the snapshot volume's disk group using the following command:# vxdg deport snapvoldg 
- On the off-host processing host where the replica database is to be set up, use the following command to import the snapshot volume's disk group:# vxdg import snapvoldg 
- VxVM will recover the volumes automatically after the disk group import unless it is set to not recover automatically. Check if the snapshot volume is initially disabled and not recovered following the split.If a volume is in the DISABLED state, use the following command on the off-host processing host to recover and restart the snapshot volume: # vxrecover -g snapvoldg -m snapvol ... 
- On the off-host processing host, for each snapshot volume containing tablespaces, check the file system that it contains, and mount the volume using the following commands:# fsck -F vxfs /dev/vx/rdsk/diskgroup/snapvol # mount -F vxfs /dev/vx/dsk/diskgroup/snapvol mount_point For example, to check the file system in the snapshot volume snap1_dbase_vol, and mount it on /rep/dbase_vol: # fsck -F vxfs /dev/vx/rdsk/snapvoldg/snap1_dbase_vol # mount -F vxfs /dev/vx/dsk/snapvoldg/snap1_dbase_vol \ /rep/dbase_vol Note: For a replica DB2 database, the database volume must be mounted in the same location as on the primary host. 
- Copy any required log files from the primary host to the off-host processing host.For a Sybase ASE database on the primary host, if you specified the for external dump clause when you quiesced the database, use the following isql command as the database administrator to dump the transaction log for the database: dump transaction to dump_device with standby_access Then copy the dumped transaction log to the appropriate database directory on the off-host processing host. 
- As the database administrator, start the new database:If the replica DB2 database is not to be rolled forward, use the following commands to start and recover it: db2start db2inidb database as snapshot If the replica DB2 database is to be rolled forward (the primary must have been placed in LOGRETAIN RECOVERY mode before the snapshot was taken), use the following commands to start it, and put it in roll-forward pending state: db2start db2inidb database as standby Obtain the latest log files from the primary database, and use the following command to roll the replica database forward to the end of the logs: db2 rollforward db database to end of logs For a Sybase ASE database, use a script such as that shown in the example. #!/bin/ksh # # script: startdb.sh <list_of_database_volumes> # # Sample script to recover and start replica Sybase ASE # database. # Import the snapshot volume disk group. vxdg import $snapvoldg # Mount the snapshot volumes (the mount points must already # exist). for i in $* do fsck -F vxfs /dev/vx/rdsk/$snapvoldg/snap_$i mount -F vxfs /dev/vx/dsk/$snapvoldg/snap_$i \ ${rep_mnt_point}/$i done # Start the replica database. # Specify the -q option if you specified the "for external # dump" clause when you quiesced the primary database. # See the Sybase ASE 12.5 documentation for more information. /sybase/ASE-12_5/bin/dataserver \ [-q] \ -sdatabase_name \ -d /sybevm/master \ -e /sybase/ASE-12_5/install/dbasename.log \ -M /sybase # Online the database. Load the transaction log dump and # specify "for standby_access" if you used the -q option # with the dataserver command. isql -Usa -Ppassword -SFMR <<! [load transaction from dump_device with standby_access go] online database database_name [for standby_access] go quit !If you are using the warm standby method, specify the -q option to the dataserver command. Use the following isql commands to load the dump of the transaction log and put the database online: load transaction from dump_device with standby_access online database database_name for standby_access If you are not using the warm standby method, use the following isql command to recover the database, roll back any uncommitted transactions to the time that the quiesce command was issued, and put the database online: online database database_name 
More Information