IBM DS3300 - Command Line Scripting
IBM DS3300 - Command Line Scripting
GA32-0961-03
Note
Before using this information and the product it supports, read the information in Notices on page B-1.
iv IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Set iSCSI Initiator . . . . . . . . . . . 3-188 Show Storage Subsystem LUN Mappings . . . 3-244
Set iSCSI Target Properties . . . . . . . . 3-189 Show Storage Subsystem Negotiation Defaults 3-244
Set Logical Drive Attributes . . . . . . . . 3-190 Show Storage Subsystem Unreadable Sectors 3-245
Set Logical Drive Attributes . . . . . . . . 3-195 Show String . . . . . . . . . . . . . 3-245
Set Logical Drive Attributes for a Disk Pool . . 3-200 Show Thin Logical Drive . . . . . . . . . 3-245
Set Logical Drive Mapping . . . . . . . . 3-204 Show Storage Subsystem Unconfigured iSCSI
Set Read Only Enhanced FlashCopy Logical Initiators . . . . . . . . . . . . . . 3-246
Drive to a Read/Write Logical Drive . . . . . 3-205 Show VolumeCopy . . . . . . . . . . . 3-247
Set Remote Mirror . . . . . . . . . . . 3-206 Show VolumeCopy Source Candidates . . . . 3-247
Set Session . . . . . . . . . . . . . 3-207 Show VolumeCopy Target Candidates . . . . 3-248
Set Storage Subsystem . . . . . . . . . . 3-208 Start Array Defragment . . . . . . . . . 3-248
Set Storage Subsystem Enclosure Positions . . . 3-211 Start Array Export . . . . . . . . . . . 3-248
Set Storage Subsystem ICMP Response . . . . 3-212 Start Array Import . . . . . . . . . . . 3-249
Set Storage Subsystem iSNS Server IPv4 Address 3-213 Start Array Locate . . . . . . . . . . . 3-250
Set Storage Subsystem iSNS Server IPv6 Address 3-213 Start Cache Backup Device Diagnostic . . . . 3-250
Set Storage Subsystem iSNS Server Listening Port 3-214 Start Cache Memory Diagnostic . . . . . . 3-252
Set Storage Subsystem iSNS Server Refresh . . . 3-214 Start Disk Pool Locate . . . . . . . . . . 3-253
Set Storage Subsystem Learn Cycle . . . . . 3-215 Start Consistency Group Enhanced FlashCopy
Set Storage Subsystem Redundancy Mode . . . 3-215 Rollback . . . . . . . . . . . . . . 3-253
Set Storage Subsystem Security Key . . . . . 3-216 Start Controller Diagnostic . . . . . . . . 3-254
Set Storage Subsystem Time . . . . . . . . 3-216 Start Controller Trace . . . . . . . . . . 3-256
Set Thin Logical Drive Attributes . . . . . . 3-216 Start Drive Channel Fault Isolation Diagnostics 3-257
Set Storage Subsystem Unnamed Discovery Start Drive Channel Locate . . . . . . . . 3-258
Session . . . . . . . . . . . . . . . 3-217 Start Disk Drive Initialize. . . . . . . . . 3-258
Set VolumeCopy. . . . . . . . . . . . 3-218 Start Drive Locate . . . . . . . . . . . 3-259
Show Array . . . . . . . . . . . . . 3-219 Start Disk Drive Reconstruction . . . . . . 3-260
Show Array Export Dependencies . . . . . . 3-219 Start Enclosure Locate . . . . . . . . . . 3-260
Show Array Import Dependencies . . . . . . 3-219 Start Enhanced FlashCopy Image Rollback . . . 3-261
Show Cache Backup Device Diagnostic Status 3-220 Start Enhanced Remote Mirroring
Show Cache Memory Diagnostic Status . . . . 3-220 Synchronization . . . . . . . . . . . . 3-262
Show Consistency Group Enhanced FlashCopy Start FlashCopy Rollback . . . . . . . . . 3-262
Image . . . . . . . . . . . . . . . 3-221 Start Host Interface Card Diagnostic . . . . . 3-262
Show Controller . . . . . . . . . . . . 3-223 Start iSCSI DHCP Refresh . . . . . . . . 3-264
Show Controller Diagnostic Status . . . . . . 3-223 Start Logical Drive Initialization . . . . . . 3-265
Show Controller NVSRAM . . . . . . . . 3-224 Start Secure Disk Drive Erase . . . . . . . 3-265
Show Current iSCSI Sessions . . . . . . . 3-224 Start Storage Subsystem Locate . . . . . . . 3-266
Show Disk Pool . . . . . . . . . . . . 3-225 Start Storage Subsystem Configuration Database
Show Disk Drive . . . . . . . . . . . 3-226 Diagnostic . . . . . . . . . . . . . . 3-266
Show Drive Channel Statistics . . . . . . . 3-227 Start Storage Subsystem Diagnostic Data Capture 3-267
Show Drive Download Progress . . . . . . 3-228 Start Storage Subsystem iSNS Server Refresh 3-268
Show Enhanced FlashCopy Group. . . . . . 3-228 Stop Array Locate . . . . . . . . . . . 3-268
Show Enhanced FlashCopy Image . . . . . . 3-230 Stop Cache Backup Device Diagnostic . . . . 3-268
Show Enhanced FlashCopy Logical Drives . . . 3-231 Stop Cache Memory Diagnostic. . . . . . . 3-269
Show Enhanced Remote Mirroring Logical Drive Stop Consistency Group Enhanced FlashCopy
Candidates . . . . . . . . . . . . . 3-232 Rollback . . . . . . . . . . . . . . 3-269
Show Enhanced Remote Mirroring Logical Drive Stop Consistency Group Enhanced FlashCopy
Synchronization Progress . . . . . . . . . 3-232 Logical Drive . . . . . . . . . . . . . 3-270
Show Host Interface Card Diagnostic Status 3-233 Stop Controller Diagnostic . . . . . . . . 3-270
Show Host Ports. . . . . . . . . . . . 3-233 Stop Disk Pool Locate . . . . . . . . . . 3-271
Show Logical Drive. . . . . . . . . . . 3-234 Stop Drive Channel Fault Isolation Diagnostics 3-271
Show Logical Drive Action Progress . . . . . 3-235 Stop Drive Channel Locate . . . . . . . . 3-271
Show Logical Drive Performance Statistics . . . 3-235 Stop Drive Locate . . . . . . . . . . . 3-272
Show Logical Drive Reservations . . . . . . 3-236 Stop Enclosure Locate . . . . . . . . . . 3-272
Show Storage Subsystem . . . . . . . . . 3-236 Stop Enhanced FlashCopy Group Pending
Show Storage Subsystem Auto Configure . . . 3-239 Enhanced FlashCopy Images . . . . . . . 3-272
Show Storage Subsystem DBM Database . . . 3-242 Stop Enhanced FlashCopy Image . . . . . . 3-273
Show Storage Subsystem Diagnostic Data Stop Enhanced FlashCopy Image Rollback . . . 3-273
Capture . . . . . . . . . . . . . . 3-242 Stop Enhanced FlashCopy Logical Drive. . . . 3-274
Show Storage Subsystem Features . . . . . . 3-243 Stop FlashCopy . . . . . . . . . . . . 3-275
Show Storage Subsystem Host Topology. . . . 3-243 Stop FlashCopy Rollback . . . . . . . . . 3-275
Show Storage Subsystem Profile . . . . . . 3-243 Stop Host Interface Card Diagnostic . . . . . 3-276
Contents v
Stop Storage Subsystem iSCSI Session . . . . 3-276 Creating Logical Drives with User-Assigned
Stop Pending Enhanced FlashCopy Images on Disk Drives . . . . . . . . . . . . 4-34
Consistency Group . . . . . . . . . . . 3-276 Creating Logical Drives with
Stop Storage Subsystem Configuration Database Software-Assigned Disk Drives . . . . . 4-36
Diagnostic . . . . . . . . . . . . . . 3-277 Creating Logical Drives in an Existing Array 4-36
Stop Storage Subsystem Drive Firmware Enclosure Loss Protection . . . . . . . 4-37
Download . . . . . . . . . . . . . . 3-277 Configuring a storage subsystem with disk pools 4-37
Stop Storage Subsystem Locate . . . . . . . 3-278 Modifying Your Configuration . . . . . . . 4-44
Stop VolumeCopy . . . . . . . . . . . 3-278 Setting the Controller Clocks . . . . . . . 4-44
Suspend Remote Mirror . . . . . . . . . 3-278 Setting the Storage Subsystem Password . . . 4-44
Validate Storage Subsystem Security Key . . . 3-279 Setting the Storage Subsystem Host Type . . . 4-44
Script Commands Listed by Function. . . . . 3-280 Setting the Storage Subsystem Cache . . . . 4-45
Array Commands . . . . . . . . . . 3-280 Setting the Modification Priority . . . . . . 4-48
Controller Commands . . . . . . . . . 3-280 Assigning Global Hot Spares . . . . . . . 4-49
Database Commands . . . . . . . . . 3-281 Saving a Configuration to a File . . . . . . 4-49
Diagnostic Data Capture Commands . . . . 3-282
Disk Pool Commands . . . . . . . . . 3-282 Chapter 5. Using the FlashCopy
Disk Drive Commands . . . . . . . . 3-282 Premium Feature . . . . . . . . . . 5-1
Enclosure Commands . . . . . . . . . 3-283
How FlashCopy Works . . . . . . . . . . 5-1
Enhanced FlashCopy Commands . . . . . 3-283
Creating a FlashCopy Logical Drive . . . . . . 5-2
Enhanced FlashCopy Group Commands 3-283
Creating a FlashCopy Logical Drive with
Enhanced FlashCopy Image Commands 3-284
User-Assigned Disk Drives . . . . . . . . 5-3
Enhanced FlashCopy Logical Drive
Creating a FlashCopy Logical Drive with
Commands . . . . . . . . . . . 3-284
Software-Assigned Disk Drives . . . . . . 5-3
Consistency Group Commands . . . . . 3-285
Creating a FlashCopy Logical Drive by
Enhanced Remote Mirroring Commands . . 3-285
Specifying a Number of Disk Drives . . . . . 5-4
Feature Management Commands . . . . . 3-286
User-Defined Parameters . . . . . . . . 5-5
FlashCopy Commands. . . . . . . . . 3-286
FlashCopy Logical Drive Names and FlashCopy
Host Topology Commands . . . . . . . 3-286
Repository Logical Drive Names . . . . . . 5-6
iSCSI Commands . . . . . . . . . . 3-287
Changing FlashCopy Logical Drive Settings . . . 5-7
Logical Drive Commands (For Standard and
Stopping, Restarting, and Deleting a FlashCopy
Thin Logical Drives and Logical Drives in a
Logical Drive . . . . . . . . . . . . . 5-7
Disk pool) . . . . . . . . . . . . . 3-287
Repository Logical Drive Analysis Commands 3-288
Session Command . . . . . . . . . . 3-288 Chapter 6. Using the Enhanced
Storage Subsystem Commands . . . . . . 3-288 FlashCopy Images Premium Feature . 6-1
String Commands . . . . . . . . . . 3-291 About Enhanced FlashCopy Images Premium
Support Bundle Collection Commands . . . 3-291 Feature . . . . . . . . . . . . . . . 6-2
VolumeCopy Commands . . . . . . . . 3-291 Working With Enhanced FlashCopy Images
Premium Feature . . . . . . . . . . . . 6-7
Chapter 4. Configuring a Storage Creating an Enhanced FlashCopy Image Group 6-7
Deleting an Enhanced FlashCopy Image Group 6-8
Subsystem. . . . . . . . . . . . . 4-1
Creating an Enhanced FlashCopy Image . . . 6-8
Configuration Concepts . . . . . . . . . .4-2
Canceling a Pending Enhanced FlashCopy
Controllers . . . . . . . . . . . . .4-2
Image . . . . . . . . . . . . . . . 6-8
Disk Drives . . . . . . . . . . . . .4-7
Creating an Enhanced FlashCopy Image
Hot Spares . . . . . . . . . . . . .4-8
Schedule . . . . . . . . . . . . . . 6-9
Arrays . . . . . . . . . . . . . . .4-9
Deleting an Enhanced FlashCopy Image Group
Disk Pools . . . . . . . . . . . . .4-9
(with options) . . . . . . . . . . . . 6-11
Logical Drives . . . . . . . . . . . . 4-11
Creating a Consistency Group Enhanced
RAID Levels . . . . . . . . . . . . 4-12
FlashCopy logical drives . . . . . . . . 6-12
Hosts . . . . . . . . . . . . . . . 4-14
Deleting a Consistency Group Enhanced
Host Groups . . . . . . . . . . . . 4-15
FlashCopy Image . . . . . . . . . . . 6-14
Host Bus Adapter Host Ports . . . . . . . 4-15
Creating an Enhanced FlashCopy Image
Logical Unit Numbers . . . . . . . . . 4-16
Logical drive . . . . . . . . . . . . 6-14
Configuring a Storage Subsystem . . . . . . 4-16
Restarting a Consistency Group Enhanced
Determining What Is on Your Storage
FlashCopy Image Logical drive . . . . . . 6-15
Subsystem . . . . . . . . . . . . . 4-16
Deleting an Enhanced FlashCopy Image Logical
Clearing the Configuration . . . . . . . 4-31
drive . . . . . . . . . . . . . . . 6-16
Using the Auto Configure Command . . . . 4-31
Changing the Size of a Repository Logical drive 6-16
Using the Create LogicalDrive Command. . . 4-34
vi IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Starting, Stopping, and Resuming an Enhanced Removing Copy Pairs. . . . . . . . . . . 8-8
FlashCopy Image Rollback. . . . . . . . 6-18 Interaction with Other Features . . . . . . . 8-9
Storage Partitioning . . . . . . . . . . 8-9
Chapter 7. Using the Enhanced FlashCopy Logical Drives . . . . . . . . 8-9
Remote Mirroring Premium Feature . . 7-1 Enhanced Remote Mirroring . . . . . . . 8-10
Role Reversals . . . . . . . . . . . 8-10
How Enhanced Remote Mirroring Works . . . . 7-1
Mirror Repository Logical Drives . . . . . . 7-2
Mirror Relationships . . . . . . . . . . 7-2 Chapter 9. Maintaining a Storage
Data Replication . . . . . . . . . . . 7-3 System . . . . . . . . . . . . . . 9-1
Link Interruptions or Secondary Logical Drive Routine Maintenance . . . . . . . . . . . 9-1
Errors . . . . . . . . . . . . . . . 7-4 Running a Media Scan . . . . . . . . . 9-1
Resynchronization . . . . . . . . . . . 7-4 Running a Redundancy Check . . . . . . . 9-2
Creating a Remote Mirror Pair . . . . . . . . 7-5 Resetting a Controller. . . . . . . . . . 9-2
Performance Considerations . . . . . . . 7-5 Enabling a Controller Data Transfer . . . . . 9-2
Enabling the Enhanced Remote Mirroring Resetting the Battery Age . . . . . . . . 9-3
Feature . . . . . . . . . . . . . . 7-5 Removing Persistent Reservations. . . . . . 9-3
Activating the Enhanced Remote Mirroring Synchronizing the Controller Clocks . . . . . 9-3
Feature . . . . . . . . . . . . . . 7-6 Locating Disk Drives . . . . . . . . . . 9-3
Determining Candidates for a Remote-Mirror Relocating an Array . . . . . . . . . . 9-3
Pair . . . . . . . . . . . . . . . . 7-8 Performance Tuning . . . . . . . . . . . 9-5
Creating a Remote Mirror Pair . . . . . . . 7-8 Monitoring the Performance . . . . . . . 9-5
Changing Enhanced Remote Mirroring Settings . . 7-9 Changing the RAID Levels . . . . . . . . 9-6
Suspending and Resuming a Mirror Relationship 7-9 Changing the Segment Size . . . . . . . . 9-6
Removing a Mirror Relationship . . . . . . . 7-10 Changing the Cache Parameters . . . . . . 9-6
Deleting a Primary Logical Drive or a Secondary Defragmenting an Array . . . . . . . . . 9-7
Logical Drive . . . . . . . . . . . . . 7-11 Troubleshooting and Diagnostics . . . . . . . 9-7
Disabling the Enhanced Remote Mirroring Feature 7-11 Collecting All Support Data. . . . . . . . 9-7
Deactivating the Enhanced Remote Mirroring Collecting Drive Data . . . . . . . . . . 9-9
Feature . . . . . . . . . . . . . . . 7-11 Diagnosing a Controller . . . . . . . . . 9-9
Interaction with Other Features . . . . . . . 7-11 Running Read Link Status Diagnostics. . . . 9-10
Storage Partitioning . . . . . . . . . . 7-11 Collecting Switch-on-a-Chip Error Statistics 9-13
FlashCopy Logical Drives . . . . . . . . 7-12 Recovery Operations. . . . . . . . . . . 9-13
VolumeCopy . . . . . . . . . . . . 7-12 Setting the Controller Operational Mode . . . 9-14
Dynamic Logical Drive Expansion (DVE) . . . 7-12 Changing the Controller Ownership . . . . 9-14
Asynchronous Enhanced Remote Mirroring Utility 7-13 Initializing a Drive . . . . . . . . . . 9-14
Description of the Asynchronous Enhanced Reconstructing a Drive . . . . . . . . . 9-15
Remote Mirroring Utility . . . . . . . . 7-13 Initializing a Logical Drive. . . . . . . . 9-15
Operation of the Asynchronous Enhanced Redistributing Logical Drives . . . . . . . 9-15
Remote Mirroring Utility . . . . . . . . 7-13 Replacing CRUs . . . . . . . . . . . 9-16
Running the Asynchronous Enhanced Remote
Mirroring Utility . . . . . . . . . . . 7-14 Chapter 10. Examples of Information
Configuration Utility . . . . . . . . . 7-14 Returned by the Show Commands . . 10-1
Show Storage Subsystem Command . . . . . 10-1
Chapter 8. Using the VolumeCopy Show Controller NVSRAM . . . . . . . . 10-41
Premium Feature . . . . . . . . . . 8-1 Show Drive . . . . . . . . . . . . . 10-45
How VolumeCopy Works . . . . . . . . . 8-1 Show Drive Channel Status . . . . . . . . 10-49
Source Logical Drive . . . . . . . . . . 8-1 Show Logical Drives . . . . . . . . . . 10-54
Target Logical Drive . . . . . . . . . . 8-2
VolumeCopy and Persistent Reservations . . . 8-2 Chapter 11. Example Script Files . . . 11-1
Storage Subsystem Performance . . . . . . 8-3 Configuration Script Example 1 . . . . . . . 11-1
Restrictions . . . . . . . . . . . . . 8-3 Configuration Script Example 2 . . . . . . . 11-2
VolumeCopy Commands . . . . . . . . 8-3
Creating a VolumeCopy . . . . . . . . . . 8-4
Chapter 12. Deprecated Commands
Enabling the VolumeCopy Feature . . . . . 8-4
Determining VolumeCopy Candidates . . . . 8-4 and Parameters . . . . . . . . . . 12-1
Creating a VolumeCopy . . . . . . . . . 8-5 Deprecated Commands . . . . . . . . . . 12-1
Viewing VolumeCopy Properties . . . . . . . 8-6 Deprecated Parameters . . . . . . . . . . 12-9
Changing VolumeCopy Settings . . . . . . . 8-6
Recopying a Logical Drive . . . . . . . . . 8-7 Appendix. Additional Documentation A-1
Stopping a VolumeCopy . . . . . . . . . . 8-8
Contents vii
Notices . . . . . . . . . . . . . . B-1 Documentation format . . . . . . . . . . B-3
Trademarks . . . . . . . . . . . . . . B-2
Important notes . . . . . . . . . . . . B-2 Index . . . . . . . . . . . . . . . X-1
viii IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Figures
4-1. Host and Storage Relationship . . . . . 4-2 4-6. DS4200 and DS4700 Host Ports . . . . . 4-5
4-2. DS3200 Host Ports . . . . . . . . . 4-4 4-7. DS4800 Host Ports . . . . . . . . . 4-6
4-3. DS3400 Host Ports . . . . . . . . . 4-4 4-8. DS3950 and DS5020 Host Ports . . . . . 4-6
4-4. DS3500 Series Host Ports . . . . . . . 4-4 4-9. DS5300 / DS5100 Host Ports . . . . . . 4-7
4-5. DCS3700 Series Host Ports . . . . . . 4-5
For instructions to install the DS Storage Manager V10.77 or earlier, see the IBM System Storage DS Storage
Manager Version 10 Installation and Host Support Guide.
For instructions to install the DS Storage Manager V10.83 or later, see the IBM System Storage DS Storage
Manager Version 10.8 Installation and Host Support Guide.
This document does not cover hardware installation or integration. For information about these topics,
see the Installation and Support Guide that is appropriate for your storage subsystem. See Additional
Documentation, on page A-1 for a list of these documents.
Check the DS3000, DS4000, or DS5000 readme files for the most up-to-date information regarding
hardware, software, or firmware products that might not be described in this document.
xiv IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Set Storage Subsystem iSNS Server Listening Port
Set Storage Subsystem Remote Status Notification
Set Storage Subsystem Security Key
Set VolumeCopy
Show Array
Show Array Export Dependencies
Show Array Import Dependencies
Show Controller
Show Controller NVSRAM
Show Drive
Show Host Ports
Show Logical Drive
Show Logical Drive Action Progress
Show Logical Drive Performance Statistics
Show Storage Subsystem
Show Storage Subsystem Auto Configure
Show Storage Subsystem Host Topology
Show Storage Subsystem LUN Mappings
Show VolumeCopy Source Candidates
Start Array Defragment
Start Array Export
Start Array Import
Start Array Locate
Start Drive Initialize
Start Drive Locate
Start Drive Reconstruction
Start Host Interface Card Diagnostic
Start iSCSI DHCP Refresh
Start Secure Drive Erase
Stop Drive Channel Fault Isolation Diagnostics
v Commands deprecated in this release:
Diagnose Controller iSCSI Host Cable
Disable Storage Subsystem Remote Status Notification
Download Power Supply Firmware
Enable Storage Subsystem Feature Key
Enable Storage Subsystem Remote Status Notification
Import Storage Subsystem Security Key
Set Storage Subsystem Remote Status Notification
Show Storage Subsystem Remote Status Notification
Start Configuration Database Diagnostic
Stop Configuration Database Diagnostic
Note: Some of the script commands are also supported in earlier versions of DS4000 controller
firmware. Please see DS3000, DS4000, and DS5000 commands with minimum firmware levels on
page 3-3 for the minimum controller firmware that is required to support each script command. This
table also shows which commands are supported with the DS3000, DS4000, or DS5000 products only,
two of the three, or all three.
v DS5000: DS5000 Storage Manager Version 10.50 and later software in conjunction with the DS5000
controller firmware version 07.50 and later.
This document is intended for system operators, system administrators, and service personnel who are
responsible for operating, maintaining, troubleshooting, and servicing a DS3000, DS4000, or DS5000
storage subsystem. Users must be familiar with computer system operation, maintenance, and repair. In
addition, they should understand disk storage technology, Redundant Array of Independent Disks
(RAID) concepts, networking, and Fibre Channel and iSCSI technologies. The reader must have a basic
knowledge of SAN hardware functionality (controllers, drives, and hosts) and SAN cabling.
xvi IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
You can solve many problems without outside assistance by following the troubleshooting procedures
that IBM provides in the Storage Manager online help or in the documents that are provided with your
system and software. The information that comes with your system also describes the diagnostic tests
that you can perform. Most subsystems, operating systems, and programs come with information that
contains troubleshooting procedures and explanations of error messages and error codes. If you suspect a
software problem, see the information for the operating system or program.
Important: Before you install Storage Manager software, consult the readme file for your host operating
system. Updated readme files contain the latest device driver versions, firmware levels, limitations, and
other information not found in this document.
1. Go to the following website:
www.ibm.com/servers/storage/support/disk/
2. Click the link for your storage subsystem (for example, DS3400 or DS4800).
3. When the support page for your storage subsystem opens, click the Download link in the Support &
Downloads box. The Software and device drivers page opens.
4. In the Storage Manager section of the table, locate your operating system and version level, and click
on the version link in the right hand column. The specific page for your storage subsystem and
operating system version opens.
5. In the table under File details, click on the *.txt file link, and the README will open in your Web
browser.
www.ibm.com/services/sl/products
For more information about the IBM Support Line and other IBM services, go to the following websites:
v www.ibm.com/services
v www.ibm.com/planetwide
www.ibm.com/planetwide
xviii IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
In the U.S. and Canada, hardware service and support is available 24 hours a day, 7 days a week. In the
U.K., these services are available Monday through Friday, from 9 a.m. to 6 p.m.
f2c00790
The command-line interface (CLI) is a software tool that lets storage subsystem installers, developers, and
engineers configure and monitor storage subsystems using script commands. Using the CLI, you can run
commands from an operating system prompt, such as the Windows command prompt, a Linux operating
system console, or a Solaris operating system console. You have to install the IBM DS Storage Manager
client in order to run the script commands either through the script window, which is invoked from the
IBM DS Storage Manager client Enterprise window, or through the command line interface using the
SMcli program. The script command engine is automatically installed as part of the IBM DS Storage
Manager client installation.
Each command performs a specific action for managing a storage subsystem or returning information
about the status of a storage subsystem. You can enter individual commands, or you can run script files
when you need to perform operations more than once. For example, you can run script files when you
want to install the same configuration on several storage subsystems. The CLI lets you load a script file
from a disk and run the script file. The CLI provides a way to run storage management commands on
more than one network storage subsystem. You can use the CLI both in installation sites and in
development environments.
Note: If you issue the command from the directory or folder that does not contain the SMcli.exe
program, you need to include the appropriate path: directoryName/SMcli.
v storageSubsystem is the name or the IP address of the storage subsystem.
v parameters are CLI parameters that define the environment and the purpose for the command.
v script-commands are one or more script commands or the name of a script file that contains script
commands. (The script commands are the storage subsystem configuration commands.)
To end an interactive mode session, type the operating system-specific command for terminating a
program (such as Control-C on the UNIX operating system or the Windows operating system). Typing
the termination command (Control-C) while in interactive mode turns off interactive mode and returns
operation of the command prompt to an input mode that requires you to type the complete SMcli string.
If you enter an incomplete or inaccurate SMcli string that does not have the correct syntax, parameter
names, options, or terminals, the script engine returns usage information.
CLI Commands
The following table lists the conventions used in the command statement syntax to manage the storage
subsystem.
Table 1-1. Command Name Syntax Conventions
Convention Definition
(a | b | c) Alternative (a or b or c)
A terminal that needs user input to fulfill a
italicized-words parameter (a response to a variable)
[ ... ] (square brackets) Zero or one occurrence (square brackets are also
used as a delimiter for some command parameters)
{ ... } (curly braces) Zero or more occurrences
bold A terminal that needs a command parameter entered
to start an action
General forms of the CLI commands follow, which show the terminals and the parameters that are used
in each command.
SMcli DNS-network-name-or-IP-address [DNS-network-name-or-IP-address]
[-c command; {command2};]
[-n storage-system-name | -w wwID]
[-o outputfile] [-p password] [-e] [-S] [-quick]
SMcli DNS-network-name-or-IP-address[DNS-network-name-or-IP-address]
[-f scriptfile]
[-n storage-system-name | -w wwID]
[-o outputfile] [-p password] [-e] [-S] [-quick]
SMcli (-n storage-system-name | -w wwID)
[-c command; {command2};]
[-o outputfile] [-p password] [-e] [-S] [-quick]
SMcli (-n storage-system-name -w wwID)
[-f scriptfile]
[-o outputfile] [-p password] [-e] [-S] [-quick]
SMcli -a email: email-address [host-name-or-IP-address1
[host-name-or-IP-address2]]
[-n storage-system-name | -w wwID | -h host-name | -r (host_sa | direct_sa)]
[-I information-to-include] [-q frequency] [-S]
SMcli -x email: email-address [host-name-or-IP-address1
[host-name-or-IP-address2]]
[-n storage-system-name | -w wwID | -h host-name | -r (host_sa | direct_sa)] [-S]
1-2 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
SMcli (-a | -x) trap: community, host-name-or-IP-address
[host-name-or-IP-address1 [host-name-or-IP-address2]]
[-n storage-system-name | -w wwID | -h host-name | -r (host_sa | direct_sa)] [-S]
SMcli -d [-w] [-i] [-s] [-v] [-S]
SMcli -m host-name-or-IP-address -F email-address
[-g contactInfoFile] [-S]
SMcli -A [host-name-or-IP-address [host-name-or-IP-address]] [-S]
SMcli -X (-n storage-system-name | -w wwID | -h host-name)
SMcli -?
host-name-or-IP-address Specifies either the host name or the Internet Protocol (IP)
address (xxx.xxx.xxx.xxx) of an in-band managed storage
subsystem or an out-of-band managed storage subsystem.
v If you are managing a storage subsystem by using a host
through in-band storage management, you must use the -n
terminal or the -w terminal if more than one storage
subsystem is connected to the host.
v If you are managing a storage subsystem by using
out-of-band storage management through the Ethernet
connection on each controller, you must specify the
host-name-or-IP-address of the controllers.
v If you have previously configured a storage subsystem in
the Enterprise Management Window, you can specify the
storage subsystem by its user-supplied name by using the
-n terminal.
v If you have previously configured a storage subsystem in
the Enterprise Management Window, you can specify the
storage subsystem by its World-Wide Identifier (WWID) by
using the -w terminal.
-A
Adds a storage subsystem to the configuration file. If you do
not follow the -A terminal with a host-name-or-IP-address,
auto-discovery scans the local subnet for storage subsystems.
-a Adds a Simple Network Management Protocol (SNMP) trap
destination or an email address alert destination.
v When you add an SNMP trap destination, the SNMP
community is automatically defined as the community
name for the trap, and the host is the IP address or Domain
Name Server (DNS) host name of the system to which the
trap should be sent.
v When you add an email address for an alert destination, the
email-address is the email address to which you want the
alert message to be sent.
-c Indicates that you are entering one or more script commands
to run on the specified storage subsystem. End each command
with a semicolon (;). You cannot place more than one -c
terminal on the same command line. You can include more
than one script command after the -c terminal.
1-4 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Table 1-2. Command Line Terminals (continued)
Terminal Definition
-o Specifies a file name for all output text that is a result of
running the script commands when you use this terminal
with the -c terminal or the -f terminal. If you do not specify
an output file, the output text goes to standard output
(stdout). All output from commands that are not script
commands is sent to stdout, regardless of whether this
terminal is set.
-p Specifies the password for the storage subsystem on which
you want to run commands. A password is not necessary
under these conditions:
v A password has not been set on the storage subsystem.
v The password is specified in a script file that you are
running.
v You specify the password by using the -c terminal and the
set session password= password command.
-q Specifies the frequency that you want to include additional
profile or support bundle information in the email alert
notifications. An email alert notification containing at least the
basic event information is always generated for every critical
event. If you set the -I terminal to eventOnly, the only valid
value for the -q terminal is everyEvent. If you set the -I
terminal to either the profile value or the supportBundle
value, this information is included with the emails with the
frequency specified by the -q terminal. These values are valid
frequency values:
v everyEvent Information is returned with every email
alert notification.
v 2 Information is returned no more than once every two
hours.
v 4 Information is returned no more than once every four
hours.
v 8 Information is returned no more than once every eight
hours.
v 12 Information is returned no more than once every 12
hours.
v 24 Information is returned no more than once every 24
hours.
-quick
Reduces the amount of time that is required to run a
single-line operation. An example of a single-line operation is
the recreate FlashCopy LogicalDrive command. This
terminal reduces time by not running background processes
for the duration of the command.
Do not use this terminal for operations that involve more than
one single-line operation. Extensive use of this command can
overrun the controller with more commands than the
controller can process, which causes operational failure. Also,
status updates and configuration updates that are collected
usually from background processes will not be available to the
CLI. This terminal causes operations that depend on
background information to fail.
Formatting Considerations
Double quotation marks ( ) that are used as part of a name or label require special consideration when
you run the CLI commands and the script commands on a Microsoft Windows operating system. This
section describes how to use double quotation marks in names while running CLI commands and script
commands on a Windows operating system.
When double quotation marks ( ) are part of a name or value, you must insert a backslash (\) before
each double quotation mark character. For example:
-c set storageSubsystem userLabel=\Engineering\;
1-6 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
You cannot use double quotation marks ( ) as part of a character string (also called string literal) within
a script command. For example, you cannot enter the following string to set the storage subsystem name
to Finance Subsystem":
-c set storageSubsystem userLabel=\\Finance\Subsystem\;
In the Linux operating system and the Solaris operating system, the delimiters around names or labels
are single quotation marks ( ). The UNIX versions of the previous examples are as follows:
-c 'set storageSubsystem userLabel=Engineering;'
-n My_StorageSubsystem
In a Windows operating system, if you do not use double quotation marks ( ) around a name, you
must insert a caret ( ^ ) before each special script character. Special characters are ^, |, <, and >.
Insert a caret before each special script character when used with the terminals -n, -o, -f, and -p. For
example, to specify storage subsystem CLI>CLIENT, enter this string:
-n CLI^>CLIENT
Insert one caret (^) before each special script character when used within a string literal in a script
command. For example, to change the name of a storage subsystem to FINANCE_|_PAYROLL, enter the
following string:
-c set storageSubsystem userLabel=\FINANCE_^|_PAYROLL\;
When the CLI encounters either type of error, the CLI writes information that describes the error directly
to the command line and sets a return code. Depending on the return code, the CLI also might write
additional information about which terminal caused the error. The CLI also writes information about
what it was expecting in the command syntax to help you identify any syntax errors that you might have
entered.
When an exception occurs while a command is running, the CLI captures the error. At the end of
processing the command (after the command processing information has been written to the command
line), the CLI automatically saves the error information to a file.
The name of the file to which error information is saved is excprpt.txt. The CLI tries to place the
excprpt.txt file in the directory that is specified by the system property devmgr.datadir. If for any
reason the CLI cannot place the file in the directory specified by devmgr.datadir, the CLI saves the
excprpt.txt file in the same directory from which the CLI is running. You cannot change the file name or
HKLM\SOFTWARE\storage\SMclient\SunJVMOption1
In a typical installation with no changes in the default installation directory, the location is:
v Windows operating systems: c:\Program Files\IBM_DS....\client\data
v UNIX-based operating systems: /var/opt/SM
Trace Facility
The SMcli program has a trace facility. The purpose of the trace facility is to collect the SMcli information
during the command execution to assist IBM Technical Support in troubleshooting SMcli problems. The
trace facility is enabled by entering -trace on the command line followed by a list of trace options
separated by colons, and optionally a -tracefile command, followed by a filename you designate for the
trace file. To get the list of options for a release, you can use the command SMcli -trace, as noted in the
example section.
The most common options for debugging interaction with the storage subsystem are:
v 0 - JAL
v 1 - JAL Detail
v 79 - All Errors and Exceptions
Note: Any time tracing is enabled, 79 - All Errors and Exceptions is also enabled.
If the storage subsystem is being managed through the Storage Manager host agent, these options would
be helpful to use:
v 2 - RPC-UTM Agent
v 3 - RPC-UTM Agent Detail
Example
The examples listed below show the profile using SMcli with tracing enabled. The tracing information is
being written to a local file for a storage subsystem named ArrayName. The storage subsystem was
previously added to the Enterprise Management window of your Storage Manager client program.
SMcli -n ArrayName -c "show storageSubsystem profile;"
-trace 0:1:79 -tracefile trace_file.txt
SMcli -n ArrayName -c " clear storageSubsystem configuration;"
-trace 0:1:2:3:79 -tracefile trace_file.txt
Trace options available with SMcli with Storage Manager version 10.77
The following table provides a list of trace options that are available with SMcli in Storage Manager
version 10.77. The available trace options can also be displayed by running the SMcli command with the
-trace parameter.
1-8 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Table 1-3. Valid Trace Constants (continued)
Trace Options Trace Constant Description
2 Agent RPC-UTM Agent
3 Agent RPC-UTM Agent Detail
4 JRPC JRPC
5 JRPC-In JRPC Raw Data In
6 JRPC-Out JRPC Raw Data Out
7 DMV Errors DMV Errors and Exceptions
8 SAM Main SAM Main
9 SAM Physical SAM Main Physical View
10 CreateVol Create Logical drive
11 EventViewer Event Viewer
12 PerfMon Performance Monitor
13 PerfMon Performance Monitor Detail
14 RecGuru Recovery Guru
15 ScriptEngine Script Engine
16 Download Download
17 StoragePools Storage Pools
18 StoragePools Storage Pools Detail
19 NodeProvider DMV Internal: General
20 NP-LM DMV Internal: Link Monitor
21 NP-Device DMV Internal: Device Interaction
22 DataStore DMV Internal: Data Store
23 SADeviceCoupler SADeviceCoupler
24 SAStatusMonitor SAStatusMonitor
25 DMV Node State DMV Events: Node State
26 DMV Edge State DMV Events: Edge State
27 DMV Domain Change DMV Events: Domain Changes
28 DMV Progress Evt DMV Events: Progress
29 DMV Alert Evt DMV Events: Alerts
30 DMV Menus DMV Display: Toolbar and Menus
31 DMV Tree DMV Display: Tree
32 DMV Table DMV Display: Table
33 DMV Health DMV Display: Overall Health
34 DMV Progress DMV Display: Progress Label/Bar
35 DMV Add DMV Op: Add Device
36 DMV Remove DMV Op: Remove Device
37 DMV Comment DMV Op: Edit Comment
38 DMV AutoDisc DMV op: Automatic Discovery
39 DMV Rescan DMV Op: Rescan Server
40 DMV Manage DMV Op: Manage Device
41 DMV Script DMV Op: Script Launch
1-10 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Table 1-3. Valid Trace Constants (continued)
Trace Options Trace Constant Description
81 Menu Errors Menu System Errors
82 Auto Config Wizard Auto Config Wizard
83 Engine General Engine General
84 Engine Discovery Engine Discovery
85 Engine Bundle Aggregation Engine Bundle Aggregation
86 Engine Change State Engine Change State
87 Engine Backend Communication Engine Backend Communication
88 Diagnostics Report Diagnostics Report
89 Wizard Wizard
90 DDC Diagnostic Data Capture
91 Set Tray Tags Set Tray Tags
92 Drive Channel Diagnostics Drive Channel Diagnostics
93 View ISCSI Sessions Connections View ISCSI Sessions Connections
94 View ISCSI Statistics View ISCSI Statistics
95 Import Array Import Array
96 Export Array Export Array
97 Factory Factory
98 Dynamic Capacity Expansion Dynamic Capacity Expansion
99 Replace Drive Replace Drive
100 Rename Logical drive And Array Rename Logical drive And Array
101 Delete Logical drive And Array Delete Logical drive And Array
102 Pre-Read Redundancy Check Pre-Read Redundancy Check
103 Dynamic RAID Migration Dynamic RAID Migration
104 Lock Key Management Lock Key Management
105 Drive Icon Factory Drive Icon Factory
106 Media Scan Media Scan
107 Trace errors Trace errors and exceptions
108 Task Task
109 Fru Diagnostics Fru Diagnostics
110 Logical drive Operations Logical drive Operations
111 Phonehome Phonehome
112 DQ Trace Retrieval DQ Trace Retrieval
113 DBM Validation DBM Validation
114 DBM Data Collection DBM Data Collection
115 Mapping Mapping
116 HistoricalPerfMonitor HistoricalPerfMonitor SMcli failed.
1-12 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Usage Examples
The following examples show how to enter CLI commands on a command line. The examples show the
syntax, the form, and, in some examples, script commands. Examples are shown for both the Windows
operating system and the UNIX operating system. Note that the usage for the -c terminal varies
depending on your operating system. On Windows operating systems, enclose the script command
following the -c terminal in double quotation marks (" "). On UNIX operating systems, enclose the script
command following the -c terminal in single quotation marks (' '). (For descriptions of the script
commands used in these examples, see Chapter 3, Script Commands, on page 3-1.
This example shows how to change the name of a storage subsystem. The original name of the storage
subsystem is Payroll_Subsystem. The new name is Finance_Subsystem. The storage subsystem is
managed in-band through the host name ICTSANT.
v Windows operating system:
SMcli ICTSANT -n "Payroll_Subsystem"
-c "set storageSubsystem userLabel=\"Finance_Subsystem\";"
v UNIX operating system:
SMcli ICTSANT -n Payroll_Subsystem
-c set storageSubsystem userLabel="Finance_Subsystem";
This example shows how to delete an existing logical drive and create a new logical drive on a storage
subsystem. The existing logical drive name is Stocks_<_Bonds. The new logical drive name is Finance.
The controller host names are finance1 and finance2. The storage subsystem is protected, requiring the
password TestSubsystem.
v Windows operating system:
SMcli finance1 finance2
-c set session password=\"TestSubsystem\"; delete logicalDrive
[\"Stocks_<Bonds\"];
create logicalDrive driveCount[3] RAIDLEVEL=3 capacity=10GB userLabel=\
"Finance\";
show storageSubsystem healthStatus;"
v UNIX operating system:
SMcli finance1 finance2 -c set session password="TestSubsystem";
delete logicalDrive ["Stocks_<Bonds"];
create logicalDrive driveCount[3] RAIDLEVEL=3 capacity=10GB userLabel=
"Finance";
show storageSubsystem healthStatus;
This example shows how to run commands in a script file named scriptfile.scr on a storage subsystem
named Example. The -e terminal causes the file to run without checking the syntax. Running a script file
without checking the syntax lets the file run more quickly; however, the file might not run correctly
because the syntax for a command might be incorrect.
SMcli -n Example -f scriptfile.scr -e
This example shows how to run commands in a script file named scriptfile.scr on a storage subsystem
named Example. In this example, the storage subsystem is protected by the password MySubsystem.
Output, as a result of commands in the script file, goes to file output.txt.
v Windows operating system:
SMcli -n Example -f scriptfile.scr -p "My_Subsystem" -o output.txt
v UNIX operating system:
SMcli -n Example -f scriptfile.scr -p My_Subsystem -o output.txt
This example shows how to show all of the storage subsystems in the current configuration. The
command in this example returns the host name of each storage subsystem.
SMcli -d
1-14 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Chapter 2. About the Script Commands
You can use the script commands to configure and manage a storage subsystem. You can enter individual
script commands, or you can run a file of script commands.
To invoke the Storage Manager Command-Line Interface (SMcli), use the SMcli command.
Note: When you enter an individual script command, you include it as part of a SMcli command. When
you run a file of script commands, you include the file name as part of a SMcli command.
The script commands are processed by a script engine that performs the following functions:
v Verifies the command syntax
v Interprets the commands
v Converts the commands to the appropriate protocol-compliant commands
v Passes the commands to the storage subsystem
At the storage subsystem level, the storage subsystem controllers run script commands.
The script engine and the script commands support the storage subsystem configuration and
management operations that are listed in the following table:
Table 2-1. Configuration and Management Operations
Operation Activities
where command identifies the action to be performed, operand-data represents the objects associated with a
storage subsystem that you want to configure or manage, and statement-data provides the information
needed to perform the command.
An object can be identified four ways: object type, all parameter prefix, square brackets, or a list of
identifiers. Use an object type when the command is not referencing a specific object. The all parameter
prefix means all objects of the specified type in the storage subsystem (for example, allLogicalDrives).
To perform a command on a specific object, use square brackets to identify the object (for example,
logicalDrive [engineering]). Specify a subset of objects with a list of identifiers in square brackets (for
example, logicalDrives [sales engineering marketing]). A qualifier is required if you want to include
additional information to describe the objects.
The following table lists the object type and the identifiers that are associated with each object type.
Table 2-2. Object Types and Identifiers
Object Type Identifier
controller a or b
drive Enclosure ID and slot ID only, or enclosure ID,
drawer ID, and slot ID, depending on the type of
storage enclosure
replacementDrive Enclosure ID and slot ID only, or enclosure ID,
drawer ID, and slot ID, depending on the type of
storage enclosure
drivechannel Drive channel identifier
host User label
hostchannel Host channel identifier
hostgroup User label
hostport User label
iscsiInitiator Logical drive user label or iSCSI Qualified Name
(IQN)
iscsiTarget Logical drive user label or IQN
remote mirror Primary logical drive user label
flashcopy Logical drive user label
storagesubsystem Not applicable
enclosure Enclosure ID
logicalDrive Logical drive user label or logical drive World-Wide
Identifier (WWID) (set command only)
volumecopy Target logical drive user label and, optionally, the
source logical drive user label
2-2 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Table 2-2. Object Types and Identifiers (continued)
Object Type Identifier
A user-defined entry (such as a user label) is called a variable. In the syntax, it is shown in italic (such as
enclosureD or arrayName).
2-4 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Recurring Syntax Elements
Recurring syntax elements are a general category of variables and options that you can use in one or
more script commands. The recurring syntax is used in the general definitions of the script commands
that are listed in Chapter 3, Script Commands, on page 3-1
The following table lists the recurring syntax and the syntax values that you can use with the syntax.
Note: A command statement appears in a monospace font. The statement variables are in a monospace
italic font. Options are described separately, and usually the choices are shown as TRUE or FALSE, as a
letter (a), a number (42), or a number-range (0-99) selection.
Table 2-4. Recurring Syntax Elements
Recurring Syntax Syntax Value
(0 | 1 | 3 | 5 | 6)
raid-level
(1 | 3 | 5 | 6)
repository-raid-level
integer-literal[KB | MB | GB | TB | Bytes]
capacity-spec
integer-literal
segment-size-spec
(TRUE | FALSE)
boolean
string-literal
user-label {user-label}
user-label-list
create-raid-logicalDrive-attribute-value-
create-raid-logicalDrive-attr-value-
pair {create-raid-logicalDrive-attribute-
list
value-pair}
capacity=capacity-spec | owner=(a | b) |
create-raid-logicalDrive-attribute- cacheReadPrefetch=(TRUE | FALSE) |
value-pair segmentSize=integer-literal
usageHint=usage-hint-spec
(0-99)
noncontroller-enclosureID
(1-32)
slotID
(0-127)
portID
enclosureID,slotID or enclosureID,
drawerID,slotID, depending on the type
of storage enclosure
drive-spec {drive-spec}
drive-spec-list
enclosureID {enclosureID}
enclosureID-list
esm-spec {esm-spec}
esm-spec-list
enclosureID, (left|right)
esm-spec
0xhexadecimal-literal
hex-literal
integer-literal
array-number
string-literal
filename
(stop | continue)
error-action
(1 | 2 | 3 | 4 | 5 | 6 |7 | 8)
drive-channel-identifier
drive-channel-identifier-list {drive-channel-identifier}
(a1 | a2 | a3 | a4 | a5 | a6 | a7 | a8
|b1 | b2 | b3 | b4 | b5 | b6 | b7 | b8)
host-channel-identifier
Note: You might not be able to use all the
supported values, depending on your storage
subsystem model.
volumeCopy | mixedDriveTypes |
highPerformanceTier | SSDSupport |
storagePartition | flashcopy |
enhancedFlashCopyImage | driveSlotLimit |
FullDiskEncryption | ExternalKeyManager |
T10PI)
8 To use the High Performance Tier premium
feature-identifier
feature, you must configure a storage subsystem
as one of these:
v SHIPPED_ENABLED
v SHIPPED_ENABLED=FALSE;
KEY_ENABLED=TRUE
2-6 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Table 2-4. Recurring Syntax Elements (continued)
Recurring Syntax Syntax Value
instance-based-repository-spec |
repository-spec
count-based-repository-spec
repositoryRAIDLevel=repository-raid-level
repositoryDrives=(drive-spec-list)
[enclosureLossProtect=boolean1]
[drawerLossProtect=(TRUE | FALSE)2]) |
repositoryArray=array-number
instance-based-repository-spec
freeCapacityArea=integer-literal3
repositoryRAIDLevel=repository-raid-level
repositoryDriveCount=integer-literal
[repositoryArrayUserLabel=user-label]
[driveType=drive-type4]
count-based-repository-spec
[enclosureLossProtect=boolean2]
[drawerLossProtect=(TRUE | FALSE)2] |
[T10PI=(none | enabled)5] |
host-card-identifier (1 | 2 | 3 | 4)
(1 | n | all)
hex-literal
nvsram-offset
nvsram-value-> 0xhexadecimal |
nvsram-byte-setting
integer-literal
autoconfigure-logicaldrive-attr- autoconfigure-logicaldrive-attr-value-pair
value-list {autoconfigure-logicaldrive-attr-value-pair}
driveType=drive-type | raidLevel=raid-level
| arrayWidth=integer-literal |
arrayCount=integer-literal |
logicalDrivesPerArrayCount=integer-literal 6
autoconfigure-logicaldrive-attr-
| hotSpareCount=integer-literal |
value-pair
segmentSize=segment-size-spec |
cacheReadPrefetch=(TRUE | FALSE) |
securityType=(none | capable | enabled)7 |
T10PI=(none | enabled)5
create-volume-copy-attr-value-pair
create-volume-copy-attr-value-list
{create-volume-copy-attr-value-pair}
recover-raid-logicalDrive-attr- recover-raid-logicalDrive-attr-value-pair
value-list {recover-raid-logicalDrive-attr-value-pair}
serial-number string-literal
usageHint=(multiMedia | database |
usage-hint-spec
fileSystem)
[session-identifier]
iscsi-host-port (1 | 2 | 3 | 4)
2-8 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Table 2-4. Recurring Syntax Elements (continued)
Recurring Syntax Syntax Value
IPv4Address=ip-address |
IPv6LocalAddress=ipv6-address |
IPv6RoutableAddress=ipv6-address |
IPv6RouterAddress=ipv6-address | enableIPv4=
(TRUE | FALSE) | enableIPv6= (TRUE | FALSE)
| enableIPv4Priority= (TRUE | FALSE) |
enableIPv6Priority= (TRUE | FALSE) |
IPv4ConfigurationMethod= (static | dhcp) |
IPv6ConfigurationMethod= (static | auto) |
IPv4GatewayIP=ip-address |
iscsi-host-port-options IPv6HopLimit=integer |
IPv6NdDetectDuplicateAddress=integer |
IPv6NdReachableTime=time-interval |
IPv6NdRetransmitTime=time-interval |
IPv6NdTimeOut=time-interval |
IPv4Priority=integer | IPv6Priority=integer
| IPv4SubnetMask=ip-address |
IPv4VlanId=integer | IPv6VlanId=integer |
maxFramePayload=integer |
tcpListeningPort=tcp-port-id |
portSpeed=(autoNegotiate | 1 | 10)
controller=(a | b) |
test-devices-list esms=(esm-speclist) |
drives=(drive-spec-list)
controller=(a | b)esms=(esm-spec-
test-devices
list)drives=(drive-spec-list)
flashcopy-schedule-attribute-valuepair
flashcopy-schedule-attribute-value- {flashcopy-schedule-attribute-valuepair}
list
(GMT+HH:MM | GMTHH:MM)
time-zone-spec [dayLightSaving=HH:MM]
startDate=MM:DD:YY
scheduleDay=(dayOfWeek|all)startTime=HH:MM
flashcopy-schedule-attribute-value- scheduleInterval=integer
pair endDate=(MM:DD:YY|noEndDate)
timesPerDay=integer
1
For enclosure loss protection to work, each disk drive in an array must be in a separate enclosure. If you
set the enclosureLossProtect parameter to TRUE and you have selected more than one disk drive from
If you set the enclosureLossProtect parameter to TRUE, the storage subsystem returns an error if the
controller firmware cannot find drives that will enable the new array to have enclosure loss protection. If
you set the enclosureLossProtect parameter to FALSE, the storage subsystem performs the operation
even if it means that the array might not have enclosure loss protection.
2
In the enclosures that have drawers for holding the drives, such as EXP5060 and DCS3700 enclosures,
drawer loss protection determines whether data on a logical drive is accessible or inaccessible if a drawer
fails. To help make sure that your data is accessible, set the drawerLossProtect parameter to TRUE. For
drawer loss protection to work, each drive in an array must be in separate drawers. If you have a storage
subsystem configuration in which an array spans several enclosures, you must make sure that the setting
for drawer loss protection works with the setting for enclosure loss protection. If you set the
enclosureLossProtect parameter to TRUE, you must set the drawerLossProtect parameter to FALSE, the
storage subsystem returns an error message and a storage subsystem configuration will not be created.
3
To determine if a free capacity area exists, run the show array command.
4
The default disk drive (drive type) for DS3000 is SAS. The default disk drive (drive type) for
DS4000/DS5000 is fibre (Fibre Channel).
If you set the enclosureLossProtect parameter to TRUE, the storage subsystem returns an error if the
controller firmware cannot find disk drives that will enable the new array to have enclosure loss
protection. If you set the enclosureLossProtect parameter to FALSE, the storage subsystem performs the
operation even if it means that the array might not have enclosure loss protection.
5
The T10PI parameter applies to the drives in an array. Using the T10PI parameter, you can specify that
protected drives must be selected for an array. If you want to set the T10PI parameter to enabled, all of
the drives in the array must be capable of T10 PI (Protection Information). You cannot have a mix of
drives that are capable of T10 PI (Protection Information) and drives that are not capable of T10 PI
(Protection Information) in the array.
6
The logicalDrivesPerArrayCount parameter is the number of equal-capacity logical drives per array.
7
The securityType parameter enables you to specify the security setting for an array that you are
creating. All of the arrays are also set to the security setting that you choose. Available options for setting
the security setting include:
v none The array is not secure.
v capable The array is security capable, but security has not been enabled.
v enabled The array is security enabled.
Note: A storage subsystem security key must already be created for the storage subsystem if you want to
set securityType=enabled. (To create a storage subsystem security key, use the create
storageSubsystemsecurityKey command).
8
In certain versions of Storage Manager, FullDiskEncryption was referred to as safestoreSecurity and
ExternalKeyManager was referred to as safeStoreExtenalKeyMgr. Depending on the version of the
controller firmware, you might have to use the following terms instead of the ones listed here
(storagePartition2 | storagePartition4 | storagePartition8 | storagePartition16 |
storagePartition64 | storagePartition96 | storagePartition128 | storagePartition256 |
storagePartition512 | storagePartitionMax | flashcopy | flashcopy2 | flashcopy4 | flashcopy8 |
flashcopy16 | remoteMirror8 | remoteMirror16 | remoteMirror32 | remoteMirror64 | remoteMirror128
|.
2-10 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Usage Guidelines
This list provides guidelines for writing script commands on the command line:
v You must end all commands with a semicolon (;).
v You can enter more than one command on a line, but you must separate each command with a
semicolon (;).
v You must separate each base command and its associated primary parameters and secondary
parameters with a space.
v The script engine is not case sensitive. You can enter commands by using uppercase letters, lowercase
letters, or mixed-case letters.
v Add comments to your scripts to make it easier for you and future users to understand the purpose of
the script commands. (For information about how to add comments, see Adding Comments to a
Script File.)
Note: While the CLI commands and the script commands are not case sensitive, user labels (such as for
logical drives, hosts, or host ports) are case sensitive. If you try to map to an object that is identified by a
user label, you must enter the user label exactly as it is defined, or the CLI commands and the script
commands will fail.
IBM recommends using the Storage Manager client GUI to manage your storage subsystems. The
command line interface does not have any mechanisms to prevent you from inadvertently making
unwanted changes to the storage subsystem; therefore, IBM recommends using the Storage Manager
client GUI to manage your storage subsystem configurations.
This chapter has five sections to help you use script commands:
v Naming Conventions lists the general formatting rules for entering the names of storage subsystem
entities, such as logical drives or disk drives, with the script commands.
v Firmware Compatibility Levels on page 3-2 describes how to interpret the firmware level
information.
v Formatting Rules for Script Commands on page 3-2 lists the general formatting rules that apply to
the script command syntax.
v DS3000, DS4000, and DS5000 commands with minimum firmware levels on page 3-3 indicates which
commands you can use for DS3000, DS4000, or DS5000 with their minimum controller firmware
requirements.
v Script Commands Listed by Function on page 3-280 lists the script commands organized into groups
related to the physical features, the logical features, and the operational features of the storage
subsystem.
v Finally, the script commands are listed alphabetically with detailed information including the command
name, syntax, and parameters.
Naming Conventions
v Names can have a maximum of 30 characters.
v You can use any combination of alphanumeric characters, hyphens, and underscores for the names of
the following components:
Storage subsystems
Host groups
Hosts
Arrays
Logical drives
HBA host ports
v You must use unique names. If you do not use unique names, the controller firmware returns an error.
v If the name contains more than one word, hyphens, or underscores, enclose the name in double
quotation marks ( ). In some usages, you must also surround the name with square brackets ([ ]).
The description of each parameter indicates whether you need to enclose a parameter in double
quotation marks, square brackets, or both.
v The name character string cannot contain a new line.
v On Windows operating systems, you must enclose the name between two back slashes (\) in addition
to other delimiters. For example, the following name is used in a command that runs under a
Windows operating system:
When the storage management software automatically configures a storage subsystem, the storage
management software assigns names that consist of numerical characters. Names that consist only of
numerical characters are valid names. Numerical character names, however, must be treated differently
than names that start with alphabetic characters.
When you enter a script command that requires a name, the script engine looks for a name that starts
with an alphabetic character. The script engine might not recognize the following names:
v Names that are only numbers, such as 1 or 2
v Names that start with a number, such as 1Disk or 32Volume
To enter a name that consists only of numerical characters so that the script engine will recognize the
name, use a combination of back slashes and double quotation marks. The following are examples of how
you can enter names that consist only of numerical characters or start with numerical characters:
v [\1\]
v [\1Disk\]
Note: For many commands, you can enable additional parameters by upgrading to a higher firmware
level than the minimum.
Not all models in the DS3000, DS4000, or DS5000 product lines support the same set of functionality. For
example, the DS3500 series of the DS3000 product line supports Enhanced Remote Mirroring premium
features, but the DS3200, DS3300, and DS3400 models of the DS3000 product line do not. You can only
run the commands for the functions supported by your storage subsystem model.
3-2 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Case sensitivity The script commands are not case sensitive. You can type the script commands in
lowercase, uppercase, or mixed case. (In the following command descriptions, mixed case is used as an
aid to reading the command names and understanding the purpose of the command.)
Spaces You must enter spaces in the script commands as they are shown in the command descriptions.
Parentheses Parentheses shown in the command syntax enclose specific choices for a parameter. That
is, if you want to use the parameter, you must enter one of the values enclosed in parentheses. Generally,
you do not include parentheses in a script command; however, in some instances, when you enter lists,
you must enclose the list in parentheses. Such a list might be a list of enclosure ID values and slot ID
values. The description of each parameter tells you if you need to enclose a parameter value in
parentheses.
Vertical bars Vertical bars in a script command indicate or and separate the valid values for the
parameter. For example, the syntax for the raidLevel parameter in the command description appears as
follows:
raidLevel=(0 | 1 | 3 | 5 | 6)
To use the raidLevel parameter to set a RAID level of 5, enter this value:
raidLevel=5
Drive locations When you specify disk drive locations by using enclosure ID values and slot ID values,
separate the ID values with a comma. If you enter more than one set of ID values, separate each set of
values with a space. Enclose the set of values in parentheses. For example:
(1,1 1,2 1,3 1,4 2,1 2,2 2,3 2,4)
For storage enclosures with multiple hard drive drawers, you specify drive locations by using the
combination of enclosure ID, drawer ID, and slot ID values, which are separated by commas. For
example:
(1,1,1 1,2,1 1,3,1 1,4,1 1,5,1 1,2,12 2,1,12 2,2,10)
Italicized terms Italicized terms in the command indicate a value or information that you need to
provide. For example, when you encounter the italicized term:
numberOfDrives
replace the italicized term with a value for the number of disk drives that you want to include with the
script command.
Semicolon Script commands must end with a semicolon (;). You can enter more than one script
command on the command line each time you enter a CLI command.
The DS3000, DS4000, and DS5000 products share many common Storage Manager script commands.
Some commands are specific to one of the three products, two of the three products, or all three of the
products and require a particular minimum level of controller firmware.
The following is an alphabetical listing of commands with minimum controller firmware requirements.
Activate Enhanced Remote Mirroring Feature
DS3000: 7.7x.xx.xx
DS4000: 6.1x.xx.xx
DS5000: 7.3x.xx.xx
Note:
v 7.10 adds RAID Level 6 capability
v 7.60 adds the drawerID user input, the driveMediaType parameter, and the drawerLossProtect
parameter.
v For version 7.60.xx.xx, you can change the repositoryDrive parameter to accommodate the
enclosures with internal disk drawers.
v 7.77 adds the T10 PI parameter.
Activate Host Port
DS3000: 7.35.xx.xx
DS4000: N/A
DS5000: 7.6x.xx.xx
Activate iSCSI Initiator
DS3000: 7.35.xx.xx
DS4000: N/A
DS5000: 7.6x.xx.xx
Activate Storage Subsystem Firmware
DS3000: 6.17.xx.xx
DS4000: 6.1x.xx.xx
DS5000: 7.3x.xx.xx
Add Member to Consistency Group
DS3000: 7.83.xx.xx and later
DS4000: N/A
DS5000: N/A
Autoconfigure Storage Subsystem
DS3000: 6.17.xx.xx
DS4000: 6.1x.xx.xx
DS5000: 7.3x.xx.xx
Note:
v 7.50.xx.xx adds securityType parameter.
v 7.77 adds the T10 PI parameter.
Autoconfigure Storage Subsystem Hot Spares
DS3000: 6.17.xx.xx
DS4000: 6.1x.xx.xx
3-4 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
DS5000: 7.3x.xx.xx
Check Logical Drive Parity
DS3000: 6.17.xx.xx
DS4000: 6.1x.xx.xx
DS5000: 7.3x.xx.xx
Check Remote Mirror Status
DS3000: 7.7x.xx.xx
DS4000: 6.1x.xx.xx
DS5000: 7.3x.xx.xx
Check Repository Consistency
DS3000: 7.83.xx.xx
DS4000: N/A
DS5000: N/A
Clear Drive Channel Statistics
DS3000: 6.17.xx.xx
DS4000: 6.1x.xx.xx
DS5000: 7.3x.xx.xx
Note: 7.1x.xx.xx and higher adds the all and arrays parameters.
Clear Storage Subsystem Diagnostic Data Capture
DS3000: 7.35.xx.xx
DS4000: 6.6x.xx.xx
DS5000: 7.3x.xx.xx
Clear Storage Subsystem Event Log
DS3000: 6.17.xx.xx
DS4000: 6.1x.xx.xx
DS5000: 7.3x.xx.xx
Note: This command is only compatible with Storage Manager version 10.83 and later.
Convert FlashCopy Logical Drive to Enhanced FlashCopy Group
DS3000: 7.83.xx.xx and later
DS4000: N/A
DS5000: N/A
Create Array
DS3000: 6.17.xx.xx
DS4000: 6.1x.xx.xx
DS5000: 7.3x.xx.xx
Note:
v For version 7.60.xx.xx, you can change the drive parameter to accommodate the enclosures
with internal disk drawers.
v 7.77 adds the T10 PI parameter.
Create Consistency Group
DS3000: 7.8x.xx.xx
DS4000: N/A
DS5000: N/A
Create Consistency Group Enhanced FlashCopy Image
DS3000: 7.83.xx.xx and later
DS4000: N/A
DS5000: N/A
Create Consistency Group Enhanced FlashCopy Logical Drive
DS3000: 7.83.xx.xx and later
DS4000: N/A
DS5000: N/A
Create Consistency Group Enhanced FlashCopy Logical Drive Mapping
DS3000: 7.83.xx.xx and later
DS4000: N/A
3-6 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
DS5000: N/A
Create Disk Pool
DS3000: 7.83.xx.xx and later
DS4000: N/A
DS5000: N/A
Create Enhanced FlashCopy Image
DS3000: 7.83.xx.xx and later
DS4000: N/A
DS5000: N/A
Create Enhanced FlashCopy Group
DS3000: 7.83.xx.xx and later
DS4000: N/A
DS5000: N/A
Create FlashCopy Logical Drive
DS3000: 6.17.xx.xx
DS4000: 5.2x.xx.xx
DS5000: 7.3x.xx.xx
Note:
v 7.1x.xx.xx and higher adds RAID 6 parameter.
v For version 7.60.xx.xx, you can change the repository drive parameter to accommodate the
enclosures with internal disk drawers.
Create Enhanced FlashCopy Logical Drive
DS3000: 7.83.xx.xx and later
DS4000: N/A
DS5000: N/A
Create Host
DS3000: 6.17.xx.xx
DS4000: 5.2x.xx.xx
DS5000: 7.3x.xx.xx
Create Host Group
DS3000: 6.17.xx.xx
DS4000: 5.2x.xx.xx
DS5000: 7.3x.xx.xx
Create Host Port
DS3000: 6.17.xx.xx
DS4000: 5.2x.xx.xx
DS5000: 7.3x.xx.xx
Create iSCSI Initiator
DS3000: 6.50.xx.xx
DS4000: Not supported
DS5000: 7.6x.xx.xx
Note:
v 7.1x.xx.xx and higher adds RAID 6 parameter.
v 7.50.xx.xx adds securityType parameter.
v 7.60.xx.xx adds DriveMediaType parameter.
Create RAID Logical Drive (Free Capacity-based Select)
DS3000: 6.17.xx.xx
DS4000: 5.2x.xx.xx
DS5000: 7.3x.xx.xx
Note:
v 7.1x.xx.xx and higher adds RAID 6 parameter.
v 7.50.xx.xx adds securityType parameter.
v 7.77.xx.xx and higher adds T10PI parameter.
Create RAID Logical Drive (Manual Drive Select)
DS3000: 6.17.xx.xx
DS4000: 5.2x.xx.xx
DS5000: 7.3x.xx.xx
Note:
v 7.1x.xx.xx and higher adds RAID 6 parameter
v 7.50.xx.xx adds the securityType parameter.
v For version 7.60.xx.xx, you can change the Drives parameter to accommodate the enclosures
with internal disk drawers.
v 7.77 adds the T10 PI parameter.
Create Logical Drive on Disk Pool
DS3000: 7.83.xx.xx and later
DS4000: N/A
DS5000: N/A
Create Read-Only Enhanced FlashCopy Logical Drive
DS3000: 7.83.xx.xx and later
DS4000: N/A
DS5000: N/A
Create Remote Mirror
DS3000: 7.7x.xx.xx
DS4000: 6.1x.xx.xx
DS5000: 7.3x.xx.xx
3-8 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Create Storage Subsystem Security Key
DS3000: 7.7x.xx.xx
DS4000: Not supported
DS5000: 7.3x.xx.xx
Create VolumeCopy
DS3000: 6.17.xx.xx
DS4000: 5.4x.xx.xx
DS5000: 7.3x.xx.xx
3-10 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
DS4000: 5.2x.xx.xx
DS5000: 7.3x.xx.xx
Note:
v 6.1x.xx.xx adds parameters:
readTest
writeTest
dataLoopBackTest
v 6.14.xx.xx adds the discreteLinesDiagnosticTest parameter.
Diagnose Remote Mirror
DS3000: 7.7x.xx.xx
DS4000: 6.1x.xx.xx
DS5000: 7.3x.xx.xx
Diagnose Controller iSCSI Host Cable
DS3000: 7.77.xx.xx
DS4000: N/a
DS5000: 7.77.xx.xx
Disable External Security Key Management
DS3000: N/A
DS4000: N/A
DS5000: 7.70.xx.xx
Disable FlashCopy
DS3000: 7.83.xx.xx
DS4000: N/A
DS5000: N/A
Disable Storage Subsystem Feature
DS3000: 6.17.xx.xx
DS4000: 6.1x.xx.xx
DS5000: 7.3x.xx.xx
Display Automatic Support Bundle Collection Configuration
DS3000: 7.xx.xx.xx
DS4000: 7.xx.xx.xx
DS5000: 7.3x.xx.xx
Note: This command is only compatible with Storage Manager version 10.83 and later.
Display Support Bundle Collection Schedule
DS3000: 7.xx.xx.xx
DS4000: 7.xx.xx.xx
DS5000: 7.3x.xx.xx
Note: This command is only compatible with Storage Manager version 10.83 and later.
Disable Storage Subsystem Remote Status Notification
DS3000: 7.77.xx.xx
Note: For version 7.60.xx.xx, you can change the drive parameter to accommodate the enclosures
with internal disk drawers.
Download Enclosure Configuration Settings
DS3000: 7.70.xx.xx
DS4000: 7.60.xx.xx
DS5000: 7.60.xx.xx
Download Environmental Card Firmware
DS3000: 6.17.xx.xx
DS4000: 5.2x.xx.xx
DS5000: 7.3x.xx.xx
Download Power Supply Firmware
DS3000: 7.77.xx.xx
DS4000: N/A
DS5000: 7.77.xx.xx
Download Storage Subsystem Drive Firmware
DS3000: 6.17.xx.xx
DS4000: 5.2x.xx.xx
DS5000: 7.3x.xx.xx
Download Storage Subsystem Firmware
DS3000: 6.17.xx.xx
DS4000: 5.2x.xx.xx
DS5000: 7.3x.xx.xx
Download Storage Subsystem NVSRAM
DS3000: 6.17.xx.xx
DS4000: 5.2x.xx.xx
DS5000: 7.3x.xx.xx
Enable Array Security
DS3000: Not supported
DS4000: Not supported
DS5000: 7.5x.xx.xx
Enable Controller Data Transfer
DS3000: 7.83.xx.xx
DS4000: N/A
DS5000: N/A
3-12 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Enable Disk Pool Security
DS3000: 7.83.xx.xx and later
DS4000: N/A
DS5000: N/A
Enable Controller
DS3000: 6.17.xx.xx
DS4000: 6.1x.xx.xx
DS5000: 7.3x.xx.xx
Enable External Security Key Management
DS3000: N/A
DS4000: N/A
DS5000: 7.70.xx.xx
Enable Storage Subsystem Feature Key
DS3000: 6.17.xx.xx
DS4000: 6.1x.xx.xx
DS5000: 7.3x.xx.xx
Note:
v 6.5x.xx.xx adds the featurePack parameter.
v 7.5x.xx.xx adds the highPerformanceTier parameter.
Enable Storage Subsystem Remote Status Notification
DS3000: 7.77.xx.xx
DS4000: N/A
DS5000: 7.77.xx.xx
Export Storage Subsystem Security Key
DS3000: 7.7x.xx.xx
DS4000: Not supported
DS5000: 7.5x.xx.xx
Import Storage Subsystem Security Key
DS3000: 7.7x.xx.xx
DS4000: Not supported
DS5000: 7.5x.xx.xx
Increase Logical Drive Capacity on a Disk Pool
DS3000: 7.83.xx.xx and later
DS4000: N/A
DS5000: N/A
Initialize Thin Logical Drive
DS3000: 7.83.xx.xx and later
DS4000: N/A
DS5000: N/A
Load Storage Subsytem DBM Database
DS3000: 7.77.xx.xx
Note:
v For version 7.60.xx.xx, you can change the drive/drives parameter to accommodate the
enclosures with internal disk drawers.
v 7.77 adds the T10 PI parameter.
Re-create Enhanced Remote Mirroring Repository Logical Drive
DS3000: 7.7x.xx.xx
DS4000: 6.1x.xx.xx
DS5000: 7.3x.xx.xx
Note:
v For version 7.60.xx.xx, you can change the repositoryDrive parameter to accommodate the
enclosures with internal disk drawers.
v 7.77 adds the T10 PI parameter.
Re-create External Security Key
DS3000: N/A
DS4000: N/A
DS5000: 7.70.xx.xx
Re-create FlashCopy
DS3000: 6.17.xx.xx
DS4000: 5.2x.xx.xx
DS5000: 7.3x.xx.xx
Remove Logical Drive LUN Mapping
DS3000: 6.17.xx.xx
DS4000: 6.1x.xx.xx
DS5000: 7.3x.xx.xx
Remove Member Logical Drive from Consistency Group
DS3000: 7.83.xx.xx and later
DS4000: N/A
DS5000: N/A
Remove Remote Mirror
DS3000: 7.7x.xx.xx
DS4000: 6.1x.xx.xx
3-14 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
DS5000: 7.3x.xx.xx
Remove VolumeCopy
DS3000: 6.17.xx.xx
DS4000: 5.4x.xx.xx
DS5000: 7.3x.xx.xx
Rename Enhanced FlashCopy Logical Drive
DS3000: 7.83.xx.xx and later
DS4000: N/A
DS5000: N/A
Repair Logical Drive Parity
DS3000: 6.17.xx.xx
DS4000: 6.1x.xx.xx
DS5000: 7.3x.xx.xx
Replace Drive
DS3000: 6.17.xx.xx
DS4000: 7.1x.xx.xx
DS5000: 7.3x.xx.xx
Note: For version 7.60.xx.xx, you can change the drive parameter to accommodate the enclosures
with internal disk drawers
.
Reset Controller
DS3000: 6.17.xx.xx
DS4000: 5.2x.xx.xx
DS5000: 7.3x.xx.xx
Reset Storage Subsystem SAS PHY Baseline
DS3000: 7.77.xx.xx
DS4000: N/A
DS5000: 7.77.xx.xx
Reset Storage Subsystem Battery Install Date
DS3000: 6.17.xx.xx
DS4000: 6.1x.xx.xx
DS5000: 7.3x.xx.xx
Note: 7.3x.xx.xx and higher adds the ability to reset the battery installation dates on specific
batteries that are inside the enclosure.
Reset Storage Subsystem Diagnostic Data
DS3000: 6.17.xx.xx
DS4000: 6.16.xx.xx
DS5000: 7.3x.xx.xx
Reset Storage Subsystem iSCSI Baseline
DS3000: 6.50.xx.xx
DS4000: Not supported
3-16 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Note: For version 7.60.xx.xx, you can change the drive parameter to accommodate the enclosures
with internal disk drawers.
Revive Enhanced FlashCopy Group
DS3000: 7.83.xx.xx and later
DS4000: N/A
DS5000: N/A
Revive Enhanced FlashCopy Logical Drive
DS3000: 7.83.xx.xx and later
DS4000: N/A
DS5000: N/A
Save Controller NVSRAM
DS3000: 6.17.xx.xx
DS4000: 6.1x.xx.xx
DS5000: 7.3x.xx.xx
Save Drive Channel Fault Isolation Diagnostic Status
DS3000: Not supported
DS4000: Not supported
DS5000: 7.3x.xx.xx
Save Drive Log
DS3000: 6.17.xx.xx
DS4000: 6.1x.xx.xx
DS5000: 7.3x.xx.xx
Save Enclosure Log
DS3000: 7.35.xx.xx
DS4000: 6.60.xx.xx
DS5000: 7.xx.xx.xx
Save Storage Subsystem Configuration
DS3000: 6.17.xx.xx
DS4000: 6.1x.xx.xx
DS5000: 7.3x.xx.xx
Save Storage Subsystem Diagnostic Data Capture
DS3000: 7.35.xx.xx
DS4000: 6.6x.xx.xx
DS5000: 7.3x.xx.xx
Save Storage Subsystem DBM Database
DS3000: 7.77.xx.xx
DS4000: N/A
DS5000: 7.77.xx.xx
Save Storage Subsystem Diagnostic Data
DS3000: 6.17.xx.xx
DS4000: 6.16.xx.xx
3-18 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Schedule Support Bundle Collection Configuration
DS3000: 7.83.xx.xx and later
DS4000: N/A
DS5000: N/A
Note: This command is only compatible with Storage Manager version 10.83 and later.
Set Array
DS3000: 6.17.xx.xx
DS4000: 6.10.xx.xx
DS5000: Not supported
Note:
v RAID 6 is supported with 7.xx.xx.xx and higher.
v 7.30.xx.xx removes the availability parameter.
v For version 7.60.xx.xx, you can change the addDrive parameter to accommodate the enclosures
with internal disk drawers.
Set Array Forced State
DS3000: 6.17.xx.xx
DS4000: 7.1x.xx.xx
DS5000: 7.3x.xx.xx
Set Consistency Group Attributes
DS3000: 7.83.xx.xx and later
DS4000: N/A
DS5000: N/A
Set Consistency Group Enhanced FlashCopy Logical Drive
DS3000: 7.83.xx.xx and later
DS4000: N/A
DS5000: N/A
Set Controller
DS3000: 6.17.xx.xx
DS4000: 6.14.xx.xx
DS5000: 7.3x.xx.xx
Note:
v 7.30.xx.xx removed the bootp parameter and added the new Ethernet port options and the new
iSCSI host-port options.
v 7.50.xx.xx moved the IPV4Gateway parameter and the IPV6RouterAddress parameter from
the iSCSI host port options, to the command.
Set Controller Service Action Allowed Indicator
DS3000: 6.17.xx.xx
DS4000: 6.16.xx.xx
DS5000: 7.3x.xx.xx
Set Disk Pool
DS3000: 7.83.xx.xx and later
Note: For version 7.60.xx.xx, you can change the drive parameter to accommodate the enclosures
with internal disk drawers.
Set Enclosure Alarm
DS3000: 6.17.xx.xx
DS4000: 6.16.xx.xx
DS5000: 7.3x.xx.xx
Set Enclosure Identification
DS3000: 6.17.xx.xx
DS4000: 6.1x.xx.xx
DS5000: 7.3x.xx.xx
Note:
v 6.14.xx.xx adds support for DS4800.
v 6.16.xx.xx adds support for subsystems and enclosures that set enclosure IDs through the
controller firmware.
3-20 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Set Enclosure Service Action Allowed Indicator
DS3000: 6.17.xx.xx
DS4000: 6.1x.xx.xx
DS5000: 7.3x.xx.xx
Note:
v 6.14.xx.xx adds the powerfan and interconnect parameters.
v 6.16.xx.xx adds the enclosure and esm parameters.
Set Enhanced FlashCopy Group Attributes
DS3000: 7.83.xx.xx and later
DS4000: N/A
DS5000: N/A
Set Enhanced FlashCopy Group Media Scan
DS3000: 7.83.xx.xx and later
DS4000: N/A
DS5000: N/A
Set Enhanced FlashCopy Group Repository Logical Drive Capacity
DS3000: 7.83.xx.xx and later
DS4000: N/A
DS5000: N/A
Set Enhanced FlashCopy Group Schedule
DS3000: 7.83.xx.xx and later
DS4000: N/A
DS5000: N/A
Set FlashCopy Logical Drive
DS3000: 6.17.xx.xx
DS4000: 6.1x.xx.xx
DS5000: 7.3x.xx.xx
Set Enhanced FlashCopy Logical Drive Media Scan
DS3000: 7.83.xx.xx and later
DS4000: N/A
DS5000: N/A
Set Enhanced FlashCopy Logical Drive Repository Logical Drive Capacity
DS3000: 7.83.xx.xx and later
DS4000: N/A
DS5000: N/A
Set Foreign Drive to Native
DS3000: 7.xx.xx.xx
DS4000: 7.xx.xx.xx
DS5000: 7.3x.xx.xx
Note:
v 7.1.xx.xx adds the preReadRedundancyCheck parameter.
v For version 7.60.xx.xx, you can change the addDrive parameter to accommodate the enclosures
with internal disk drawers.
Set Logical Drive Attributes for a Disk Pool
DS3000: 7.83.xx.xx and later
DS4000: N/A
DS5000: N/A
Set Logical Drive Mapping
DS3000: 6.17.xx.xx
DS4000: 5.2x.xx.xx
3-22 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
DS5000: 7.3x.xx.xx
Set Read Only to a Read/Write Enhanced FlashCopy Logical Drive
DS3000: 7.83.xx.xx and later
DS4000: N/A
DS5000: N/A
Set Remote Mirror
DS3000: 7.7x.xx.xx
DS4000: 6.1x.xx.xx
DS5000: 7.3x.xx.xx
Set Session
DS3000: 6.17.xx.xx
DS4000: 5.2x.xx.xx
DS5000: 7.3x.xx.xx
Set Storage Subsystem
DS3000: 6.17.xx.xx
DS4000: 5.2x.xx.xx
DS5000: 7.3x.xx.xx
Note:
v 5.4x.xx.xx adds the failoverAlertDelay parameter.
v 6.1x.xx.xx adds the alarm parameter.
Set Storage Subsystem Enclosure Positions
DS3000: 6.17.xx.xx
DS4000: 6.1x.xx.xx
DS5000: 7.3x.xx.xx
Note: This command is replaced by Start Storage Subsystem iSNS Server Refresh in controller.
Set Storage Subsystem Learn Cycle
DS3000: 7.35.xx.xx and higher
DS4000: N/A
DS5000: 7.6x.xx.xx
Set Storage Subsystem Redundancy Mode
DS3000: 6.17.xx.xx
DS4000: 6.1x.xx.xx
DS5000: 7.3x.xx.xx
Set Storage Subsystem Remote Status Notification Time
DS3000: 7.77.xx.xx
DS4000: N/A
DS5000: 7.7x.xx.xx
Set Storage Subsystem Security Key
DS3000: 7.7x.xx.xx
DS4000: Not supported
DS5000: 7.5x.xx.xx
Set Storage Subsystem Time
DS3000: 6.17.xx.xx
DS4000: 5.4x.xx.xx
DS5000: 7.3x.xx.xx
Set Storage Subsystem Unnamed Discovery Session
DS3000: 6.50.xx.xx
DS4000: 7.1x.xx.xx
DS5000: 7.3x.xx.xx
Set Thin Logical Drive Attributes
DS3000: 7.83.xx.xx and later
DS4000: N/A
DS5000: N/A
Set VolumeCopy
DS3000: 6.17.xx.xx
DS4000: 5.4x.xx.xx
DS5000: 7.3x.xx.xx
Show Array
DS3000: 6.17.xx.xx
3-24 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
DS4000: 6.1x.xx.xx
DS5000: 7.3x.xx.xx
Show Array Export Dependencies
DS3000: 7.35.xx.xx and higher
DS4000: 7.1x.xx.xx
DS5000: 7.3x.xx.xx
Show Array Import Dependencies
DS3000: 7.35.xx.xx and higher
DS4000: 7.1x.xx.xx
DS5000: 7.3x.xx.xx
Show Cache Backup Device Diagnostic Status
DS3000: N/A
DS4000: N/A
DS5000: 7.70.xx.xx (DS5000 only)
Show Cache Memory Diagnostic Status
DS3000: N/A
DS4000: N/A
DS5000: 7.70.xx.xx (DS5000 only)
Show Consistency Group Enhanced FlashCopy Image
DS3000: 7.83.xx.xx and later
DS4000: N/A
DS5000: N/A
Show Controller
DS3000: 6.17.xx.xx
DS4000: 5.4x.xx.xx
DS5000: 7.3x.xx.xx
3-26 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Show Host Ports
DS3000: 6.17.xx.xx
DS4000: 5.4x.xx.xx
DS5000: 7.3x.xx.xx
Show Logical Drive
DS3000: 6.17.xx.xx
DS4000: 5.4x.xx.xx
DS5000: 7.3x.xx.xx
Note: 5.43.xx.xx adds the summary parameter. 6.14.xx.xx adds the connections parameter.
Show Storage Subsystem Auto Configure
DS3000: 6.17.xx.xx
DS4000: 6.1x.xx.xx
DS5000: 7.3x.xx.xx
Show Storage Subsystem Diagnostic Data Capture
DS3000: 7.35.xx.xx
DS4000: 6.6x.xx.xx
DS5000: 7.3x.xx.xx
Show Storage Subsystem DBM Database
DS3000: 6.17.xx.xx
DS4000: 5.4x.xx.xx
DS5000: 7.3x.xx.xx
Show Storage Subsystem Features
DS3000: 6.17.xx.xx
3-28 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
DS5000: 7.3x.xx.xx
Show VolumeCopy Source Candidates
DS3000: 6.17.xx.xx
DS4000: 6.1x.xx.xx
DS5000: 7.3x.xx.xx
Show VolumeCopy Target Candidates
DS3000: 6.17.xx.xx
DS4000: 6.1x.xx.xx
DS5000: 7.3x.xx.xx
Start Array Defragment
DS3000: 6.17.xx.xx
DS4000: 7.1x.xx.xx
DS5000: 7.3x.xx.xx
Start Array Export
DS3000: 7.35.xx.xx and higher
DS4000: 7.1x.xx.xx
DS5000: 7.3x.xx.xx
Start Array Import
DS3000: 7.35.xx.xx and higher
DS4000: 7.1x.xx.xx
DS5000: 7.3x.xx.xx
Start Array Locate
DS3000: 6.17.xx.xx
DS4000: 6.16.xx.xx
DS5000: 7.3x.xx.xx
Start Cache Backup Device Diagnostic
DS3000: N/A
DS4000: N/A
DS5000: 7.70.xx.xx
Start Cache Memory Diagnostic
DS3000: N/A
DS4000: N/A
DS5000: 7.70.xx.xx
Start Consistency Group Enhanced FlashCopy Rollback
DS3000: 7.83.xx.xx and later
DS4000: N/A
DS5000: N/A
Start Configuration Database Diagnostic
DS3000: 7.77.xx.xx
DS4000: N/A
DS5000: 7.77.xx.xx
Note: For version 7.60.xx.xx, you can change the drive parameter to accommodate the enclosures
with internal disk drawers.
Start Drive Channel Locate
DS3000: 6.17.xx.xx
DS4000: 6.1x.xx.xx
DS5000: 7.3x.xx.xx
Start Drive Initialize
DS3000: 6.17.xx.xx
DS4000: 6.1x.xx.xx
DS5000: 7.3x.xx.xx
Note: For version 7.60.xx.xx, you can change the drive parameter to accommodate the enclosures
with internal disk drawers.
Start Drive Locate
DS3000: 6.17.xx.xx
DS4000: 6.1x.xx.xx
DS5000: 7.3x.xx.xx
Note: For version 7.60.xx.xx, you can change the drive parameter to accommodate the enclosures
with internal disk drawers.
Start Drive Reconstruction
DS3000: 6.17.xx.xx
DS4000: 5.43.xx.xx
DS5000: 7.3x.xx.xx
Note: For version 7.60.xx.xx, you can change the drive parameter to accommodate the enclosures
with internal disk drawers.
3-30 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Start Enclosure Locate
DS3000: 6.17.xx.xx
DS4000: 6.1x.xx.xx
DS5000: 7.3x.xx.xx
Start Enhanced Remote Mirroring Synchronization
DS3000: 7.7x.xx.xx
DS4000: 6.1x.xx.xx
DS5000: 7.3x.xx.xx
Start Enhanced FlashCopy Image Rollback
DS3000: 7.83.xx.xx and later
DS4000: N/A
DS5000: N/A
Start Host Interface Card Diagnostic
DS3000: 7.70.xx.xx
DS4000: N/A.xx.xx
DS5000: 7.70.xx.xx
Start iSCSI DHCP Refresh
DS3000: 6.50.xx.xx
DS4000: N/A
DS5000: 7.6x.xx.xx
Start Logical Drive Initialization
DS3000: 6.17.xx.xx
DS4000: 6.1x.xx.xx
DS5000: 7.3x.xx.xx
Start Secure Drive Erase
DS3000: 7.7x.xx.xx
DS4000: Not supported
DS5000: 7.5x.xx.xx
Note: For version 7.60.xx.xx, you can change the drive parameter to accommodate the enclosures
with internal disk drawers.
Start Storage Subsystem Configuration Database Diagnostic
DS3000: 7.83.xx.xx and later
DS4000: N/A
DS5000: N/A
Start Storage Subsystem Diagnostic Data Capture
DS3000: 7.35.xx.xx
DS4000: 6.6x.xx.xx
DS5000: 7.3x.xx.xx
Start Storage Subsystem iSNS Server Refresh
DS3000: 6.50.xx.xx
DS4000: N/A
Note: This command replaces Set Storage Subsystem iSNS Server Refresh starting with Storage
Manager version 10.83.xx.xx
Start Storage Subsystem Locate
DS3000: 6.17.xx.xx
DS4000: 6.1x.xx.xx
DS5000: 7.3x.xx.xx
Stop Array Locate
DS3000: 6.17.xx.xx
DS4000: 6.16.xx.xx
DS5000: 7.3x.xx.xx
Stop Cache Backup Device Diagnostic
DS3000: N/A
DS4000: N/A
DS5000: 7.70.xx.xx (DS5000 only)
Stop Configuration Database Diagnostic
DS3000: 7.77.xx.xx
DS4000: N/A
DS5000: 7.77.xx.xx
Stop Cache Memory Diagnostic
DS3000: N/A
DS4000: N/A
DS5000: 7.70.xx.xx (DS5000 only)
Stop Consistency Group Enhanced FlashCopy Logical Drive
DS3000: 7.83.xx.xx and later
DS4000: N/A
DS5000: N/A
Stop Consistency Group Enhanced FlashCopy Rollback
DS3000: 7.83.xx.xx and later
DS4000: N/A
DS5000: N/A
Stop Controller Diagnostic
DS3000: 7.70.xx.xx
DS4000: N/A
DS5000: 7.70.xx.xx
Stop Disk Pool Locate
DS3000: 7.83.xx.xx and later
DS4000: N/A
DS5000: N/A
Stop Drive Channel Fault Isolation Diagnostics
DS3000: Not supported
3-32 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
DS4000: 7.3x.xx.xx
DS5000: 7.3x.xx.xx
Stop Drive Channel Locate
DS3000: 6.17.xx.xx
DS4000: 6.1x.xx.xx
DS5000: 7.3x.xx.xx
Stop Drive Locate
DS3000: 6.17.xx.xx
DS4000: 6.1x.xx.xx
DS5000: 7.3x.xx.xx
Stop Enclosure Locate
DS3000: 6.17.xx.xx
DS4000: 6.1x.xx.xx
DS5000: 7.3x.xx.xx
Stop Enhanced FlashCopy Group Pending Enhanced FlashCopy Images
DS3000: 7.83.xx.xx and later
DS4000: N/A
DS5000: N/A
Stop Enhanced FlashCopy Image
DS3000: 7.83.xx.xx and later
DS4000: N/A
DS5000: N/A
Stop Enhanced FlashCopy Image Rollback
DS3000: 7.83.xx.xx and later
DS4000: N/A
DS5000: N/A
Stop FlashCopy
DS3000: 6.17.xx.xx
DS4000: 6.1x.xx.xx
DS5000: 7.3x.xx.xx
Stop FlashCopy Rollback
DS3000: 7.83.xx.xx
DS4000: N/A
DS5000: 7.83.xx.xx
Stop Enhanced FlashCopy Logical Drive
DS3000: 7.83.xx.xx and later
DS4000: N/A
DS5000: N/A
Stop Host Interface Card Diagnostic
DS3000: 7.70.xx.xx
DS4000: N/A
3-34 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Activate Enhanced Remote Mirroring Feature
This command creates the mirror repository logical drive and activates the Enhanced Remote Mirroring
feature. When you use this command, you can define the mirror repository logical drive in one of three
ways:
v User-defined disk drives
v User-defined array
v User-defined number of disk drives
If you choose to define a number of drives, the controller firmware chooses which disk drives to use for
the mirror repository logical drive.
Parameters
Parameter Description
repositoryRAIDLevel The RAID level for the mirror repository logical drive.
Valid values are 1, 3, 5, or 6.
3-36 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Parameter Description
freeCapacityArea The index number of the free space in an existing
array that you want to use to create the mirror
repository logical drive. Free capacity is defined as the
free capacity between existing logical drives in an
array. For example, an array might have the following
areas: logical drive 1, free capacity, logical drive 2, free
capacity, logical drive 3, free capacity. To use the free
capacity following logical drive 2, you would specify:
freeCapacityArea=2
Notes
If the disk drives that you select for the repositoryDrives parameter are not compatible with other
parameters (such as the repositoryRAIDLevel parameter), the script command returns an error, and
Enhanced Remote Mirroring is not activated. The error returns the amount of space that is needed for the
mirror repository logical drive. You can then re-enter the command, and specify the appropriate amount
of space.
If you enter a value for the repository storage space that is too small for the mirror repository logical
drives, the controller firmware returns an error message that provides the amount of space that is needed
for the mirror repository logical drives. The command does not try to activate Enhanced Remote
Mirroring. You can re-enter the command by using the value from the error message for the repository
storage space value.
When you assign the disk drives, if you set the enclosureLossProtect parameter to TRUE and have
selected more than one disk drive from any one enclosure, the storage subsystem returns an error. If you
set the enclosureLossProtect parameter to FALSE, the storage subsystem performs operations, but the
array that you create might not have enclosure loss protection.
Syntax
activate hostPort "user-label"
Parameters
Parameter Description
userLabel The name of the HCA host port. Enclose the host port name in double
quotation marks (" ").
Syntax
activate iscsiInitiator "iSCSI-ID"
Parameters
Parameter Description
iscsiInitiator The name of the iSCSI initiator. Enclose the name in double quotation
marks (" ").
Syntax
activate storageSubsystem firmware
Parameters
None.
3-38 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Add Member to Consistency Group
This command adds a base logical drive as a member to an existing consistency group. You can specify
an existing repository logical drive for the new consistency group member, or create a repository logical
drive. When you create a repository logical drive, you identify an existing array or an existing disk pool
where you want the repository logical drive.
Syntax for Use When Creating a New Repository Logical Drive in an Array
set consistencyGroup ["consistencyGroupName"]
addCGMemberLogicalDrive="baseLogicalDriveName"
repositoryLogicalDrive=("arrayName" capacity=capacityValue(KB|MB|GB|TB|bytes))
Syntax for Use When Creating a New Repository Logical Drive in a Disk Pool
set consistencyGroup ["consistencyGroupName"]
addCGMemberLogicalDrive="baseLogicalDriveName"
repositoryLogicalDrive=("diskpoolName" capacity=capacityValue(KB|MB|GB|TB|bytes))
Parameters
Parameter Description
consistencyGroup The name of the consistency group to which you want to add a
member logical drive. The new member logical drive is the base logical
drive for Enhanced FlashCopy operations. Enclose the consistency
group name in double quotation marks (" ") inside square brackets ([ ]).
addCGMemberLogicalDrive The name of a base logical drive that you want to add. Enclose the
logical drive name in square brackets ([ ]). If the logical drive name has
special characters, you also must enclose the member name in double
quotation marks (" ").
Notes
You can use any combination of alphanumeric characters, underscore (_), hyphen (-), and pound (#) for
the names. Names can have a maximum of 30 characters.
A consistency group is a collection of base logical drives that are the source logical drives for Enhanced
FlashCopies. You collect the base logical drives in a consistency group so that you can perform the same
Enhanced FlashCopy operations on each of the base logical drives. In the context of this command, the
term member means a base logical drive for Enhanced FlashCopy operations. You can manipulate
Enhanced FlashCopy images associated with members of a consistency group through batch-style
operations, while maintaining consistency across the Enhanced FlashCopy images.
You can place the repository logical drive in an array or a disk pool of your choosing. You are not
required to have the repository logical drive in the same location as other repository logical drives. To
place the repository logical drive in an array or a disk pool of your choice, use the
repositoryLogicalDrive parameter and identify the array or the disk pool and a size for the repository
logical drive. An example of this command usage is:
set consistencyGroup ["First_Images"] addCGMemberLogicalDrive="Data_020212"
repositoryLogicalDrive="12" capacity=2 GB)
In this example, "12" is the name of an existing array or an existing disk pool. The capacity parameter
defines the size that you want for the repository array.
When you create a repository logical drive in either an array or a disk pool, you must include parenthesis
around the array name and capacity, or the disk pool name and capacity.
3-40 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Syntax
autoConfigure storageSubsystem
[driveType=(fibre | SATA | SAS |)
raidLevel=(0 | 1 | 3 | 5 | 6)
arrayWidth=numberOfDrives
arrayCount=numberOfarrays
logicalDrivesPerArrayCount=numberOfLogicalDrivesPerArray
hotSpareCount=numberOfHotSpares
segmentSize=segmentSizeValue
cacheReadPrefetch=(TRUE | FALSE)
securityType=(none | capable | enabled)]
T10PI=(none | enabled)]
Parameters
Parameter Description
driveType The type of disk drives that you want to use for the
storage subsystem. You must use this parameter when
you have more than one type of drive in your storage
subsystem. Valid disk drive types are fibre, SATA, and
SAS. If you do not specify a drive type, the command
defaults to fibre.
raidLevel The RAID level of the array that contains the disk drives
in the storage subsystem. Valid RAID levels are 0, 1, 3,
5, or 6.
arrayWidth The number of disk drives in an array in the storage
subsystem.
arrayCount The number of arrays in the storage subsystem. Use
integer values.
logicalDrivesPerGroupCount The number of equal-capacity logical drives per array.
Use integer values.
hotSpareCount The number of hot spares that you want in the storage
subsystem. Use integer values.
segmentSize The amount of data (in KB) that the controller writes on
a single disk drive in a logical drive before writing data
on the next disk drive. Valid values are 8, 16, 32, 64, 128,
256, or 512.
cacheReadPrefetch The setting to turn on or turn off cache read prefetch. To
turn off cache read prefetch, set this parameter to FALSE.
To turn on cache read prefetch, set this parameter to
TRUE.
securityType The setting to specify the security level when creating
the array and all associated logical drives. These settings
are valid:
v noneThe array and logical drives are not secure.
v capableThe array and logical drives are capable of
having security set, but security has not been enabled.
v enabledThe array and logical drives have security
enabled.
Notes
An array is a set of disk drives that are logically grouped together by the controllers in the storage
subsystem. The number of disk drives in an array is a limitation of the RAID level and the controller
firmware. Follow these guidelines when you create an array:
v Beginning with firmware version 7.10, you can create an empty array to reserve the capacity for later
use.
v You cannot mix drive types, such as SAS, SATA, and Fibre Channel, within a single array.
v The maximum number of drives in an array depends on these conditions:
The type of controller
The RAID level
v RAID levels include: 0, 1, 10, 3, 5, and 6.
In a DS4700 Model 70 or a DS4700 Model 72 storage subsystem, an array with RAID level 0 and an
array with RAID level 10 can have a maximum of 112 drives.
In a DS4800 (Models 82, 84, 88) storage subsystem, an array with RAID level 0 and an array with
RAID level 10 can have a maximum of 224 drives.
An array with RAID level 3, RAID level 5, or RAID level 6 cannot have more than 30 drives.
An array with RAID level 6 must have a minimum of five drives.
If an array with RAID level 1 has four or more drives, the storage management software
automatically converts the array to a RAID level 10, which is RAID level 1 + RAID level 0.
For information about the maximum number of disk drives in a RAID array or disk pool, see Table 4-2
on page 4-8.
v If an array contains disk drives that have different capacities, the overall capacity of the array is based
on the smallest capacity drive.
v To enable enclosure loss protection, you must create an array that uses disk drives located in at least
three drive expansion enclosures.
Disk drives do not report their exact capacity (for example, a 73 GB drive does not report 73 GB as its
capacity).
Hot Spares
Hot spare disk drives can replace any failed disk drive in the storage subsystem. The hot spare must be
the same type of disk drive as the disk drive that failed (that is, a SATA hot spare cannot replace a Fibre
Channel disk drive). A hot spare must have capacity greater than or equal to any disk drive that can fail.
3-42 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
If a hot spare is smaller than a failed disk drive, you cannot use the hot spare to rebuild the data from
the failed disk drive. Hot spares are available only for RAID levels 1, 3, 5, or 6.
Segment Size
The size of a segment determines how many data blocks that the controller writes on a single disk drive
in a logical drive before writing data on the next disk drive. Each data block stores 512 bytes of data. A
data block is the smallest unit of storage. The size of a segment determines how many data blocks that it
contains. For example, an 8-KB segment holds 16 data blocks. A 64-KB segment holds 128 data blocks.
When you enter a value for the segment size, the value is checked against the supported values that are
provided by the controller at run time. If the value that you entered is not valid, the controller returns a
list of valid values. Using a single disk drive for a single request leaves other disk drives available to
simultaneously service other requests.
If the logical drive is in an environment where a single user is transferring large units of data (such as
multimedia), performance is maximized when a single data transfer request is serviced with a single data
stripe. (A data stripe is the segment size that is multiplied by the number of disk drives in the array that
are used for data transfers.) In this case, multiple disk drives are used for the same request, but each disk
drive is accessed only once. For optimal performance in a multiuser database or file system storage
environment, set your segment size to minimize the number of disk drives that are required to satisfy a
data transfer request.
Cache read prefetch lets the controller copy additional data blocks into cache while the controller reads
and copies data blocks that are requested by the host from the disk drive into cache. This action increases
the chance that a future request for data can be fulfilled from cache. Cache read prefetch is important for
multimedia applications that use sequential data transfers. The configuration settings for the storage
subsystem that you use determine the number of additional data blocks that the controller reads into
cache. Valid values for the cacheReadPrefetch parameter are TRUE or FALSE.
Security Type
The securityType parameter is valid for drives that are capable of full disk encryption (FDE). With FDE,
the controller firmware can create a key and activate the drive security feature. The drive security feature
encrypts data as the data is written to the drive and decrypts the data as the data is read from the drive.
Without the key created by the controller, the data written to the drive is inaccessible
Before you can set the securityType parameter to capable or enabled, you must create a storage subsystem
security key. Use the create storageSubsystem securityKey command to create a storage subsystem
security key. These commands are related to the security key:
v create storageSubsystem securityKey
v set storageSubsystem securityKey
v import storageSubsystem securityKey
v export storageSubsystem securityKey
v start secureErase (drive | drives)
v enable array [arrayName] security
Parameters
None.
Notes
When you run the autoconfigure storageSubsystem hotSpares command, the controller firmware
determines the number of hot spares to create based on the total number and type of disk drives in the
storage subsystem. For Fibre Channel disk drives, SATA disk drives, and SAS disk drives, the controller
firmware creates one hot spare for the storage subsystem and one additional hot spare for every 60 disk
drives in the storage subsystem.
Syntax
check logicalDrive [logicalDriveName]
parity [parityErrorFile=filename]
[mediaErrorFile=filename]
[priority=(highest | high | medium | low | lowest)]
[startingLBA=LBAvalue] [endingLBA=LBAvalue]
[verbose=(TRUE | FALSE)]
Parameters
Parameter Description
logicalDrive The name of the specific logical drive for which you want to
check parity. Enclose the logical drive name in square
brackets ([ ]). If the logical drive name has special characters,
you also must enclose the logical drive name in double
quotation marks (" ").
parityErrorFile The file path and the file name to which you want to save the
parity error information. Enclose the file name in double
quotation marks (" "). For example:
file="C:\Program Files\CLI\logs\parerr.txt"
3-44 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Parameter Description
startingLBA The starting logical block address. Use integer values.
endingLBA The ending logical block address. Use integer values.
verbose The setting to capture progress details, such as percent
complete, and to show the information as the logical drive
parity is being repaired. To capture progress details, set this
parameter to TRUE. To prevent capturing progress details, set
this parameter to FALSE.
Notes
The starting logical block address and the ending logical block address are useful for very large
single-logical drive LUNs. Running a logical drive parity check on a very large single logical drive LUN
can take a long time. By defining the beginning address and ending address of the data blocks, you can
reduce the time that a logical drive parity check takes to complete.
Related Topic
Naming Conventions
Syntax
check remoteMirror localLogicalDrive [logicalDriveName] optimalStatus
timeout=timeoutValue
Parameters
Parameter Description
localLogicalDrive The name of any remote-mirror logical drive. The
remote-mirror logical drive can be the primary logical
drive or the secondary logical drive of a remote-mirror
pair. Enclose the logical drive name in square brackets
([ ]). If the logical drive name has special characters,
you also must enclose the logical drive name in double
quotation marks ( ).
timeout The time interval within which the software can return
the remote-mirror logical drive status. The timeout
value is in minutes.
Notes
This command waits until the status becomes Optimal or the timeout interval expires. Use this command
when you run the Asynchronous Enhanced Remote Mirroring utility.
Related Topics
Naming Conventions
Syntax
check [enhancedFlashCopyGroup[enhancedFlashCopyGroupName] repositoryConsistency |
enhancedFlashCopyLogicalDrive[enhancedFlashCopyLogicalDriveName] repositoryConsistency |
logicaldrive[logicaldriveName] repositoryConsistency |
logicaldriveCopy target[targetName] repositoryConsistency |
localLogicalDrive="localLogicalDriveName"]
file="filePath"
Parameters
Parameter Description
repositoryConsistency Specifies that the Enhanced FlashCopy group, Enhanced
FlashCopy logical drive, or logical drive (depending on
which is specified by the corresponding parameter) is
checked for consistency.
enhancedFlashCopyGroup The alphanumeric identifier (including - and _) of the
Enhanced FlashCopy group on which to run a
consistency check. Enclose the Enhanced FlashCopy
group identifier in square brackets ([ ]).
enhancedFlashCopyLogicalDrive The alphanumeric identifier (including - and _) of the
Enhanced FlashCopy logical drive on which to run a
consistency check. Enclose the Enhanced FlashCopy
logical drive identifier in square brackets ([ ]).
logicaldrive The alphanumeric identifier (including - and _) of the
thin logical drive on which to run a consistency check.
Enclose the logical drive identifier in square brackets ([
]).
volumeCopy Specifies that the target of a VolumeCopy relationship is
checked for consistency.
target Use only in conjunction with the volumeCopy parameter
to specify the alphanumeric identifier of the logical drive
that is the target of the logical drive copy relationship.
Enclose the logical drive identifier in double quotation
marks (" ").
file The file path and the file name to which you want to
save the report that results from the consistency check.
Enclose the file name in double quotation marks (" ").
For example: file="C:\Program Files\CLI\logs\
repoConsistency.txt" This parameter must appear last,
after any of the optional parameters.
Syntax
clear allDriveChannels stats
3-46 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Parameters
None.
Syntax
clear (allLogicalDrives | logicaldrive [logicalDriveName] |
logicalDrives [logicalDriveName1 ... logicalDriveNameN]) reservations
Parameters
Parameter Description
allLogicalDrives The setting to clear persistent logical drive reservations
on all of the logical drives in the storage subsystem.
logicalDrive or The name of the specific logical drive for which you
logicalDrives want to clear persistent logical drive reservations. You
can enter more than one logical drive name. Enclose the
logical drive name in square brackets ([ ]). If the logical
drive name has special characters, you also must enclose
the logical drive name in double quotation marks ( ).
Notes
You can use any combination of alphanumeric characters, hyphens, and underscores for the names.
Names can have a maximum of 30 characters.
Related topics
Naming Conventions
Syntax
clear (allLogicalDrives | logicaldrive [logicalDriveName] |
logicalDrives [logicalDriveName1 ... logicalDriveNameN]) unreadableSectors
Parameters
Parameter Description
allLogicalDrives The setting to clear unreadable sector information
from all of the logical drives in the storage subsystem.
logicalDrive or The name of the specific logical drive for which you
logicalDrives want to clear unreadable sector information. You can
enter more than one logical drive name. Enclose the
logical drive name in square brackets ([ ]). If the
logical drive name has special characters, you also
must enclose the logical drive name in double
quotation marks ( ).
You can use any combination of alphanumeric characters, hyphens, and underscores for the names.
Names can have a maximum of 30 characters.
Related Topic
Naming Conventions
Attention: Possible damage to the storage subsystem configuration When you run this command,
the existing storage subsystem configuration is deleted.
Syntax
clear storageSubsystem configuration [all | arrays]
Parameters
Parameter Description
None If you do not enter a parameter, this command removes all
configuration information for the storage subsystem, except for
information related to security and identification.
all The setting to remove the entire configuration of the storage
subsystem, including security information and identification
information. Removing all configuration information returns the
storage subsystem to its initial state.
arrays The setting to remove the logical drive configuration and the
array configuration. The rest of the configuration stays intact.
Notes
When you run this command, the storage subsystem becomes unresponsive, and all script processing is
canceled. You must remove and re-add the storage subsystem to resume communication with the host. To
remove an unresponsive storage subsystem, access the Enterprise Management Window, and select Edit
Remove. To re-add the storage subsystem, access the Enterprise Management Window, select Edit Add
Storage Subsystem, and enter the appropriate IP addresses.
Syntax
3-48 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Parameters
None.
Notes
When you retrieve a diagnostic data capture from the controller cache to a host, a flag is set on the
controller to indicate that the diagnostic data capture does not need to be retrieved. This setting persists
for 48 hours. If a new diagnostic data capture occurs during that period the new diagnostic data capture
is saved to the controller cache and overwrites any previous diagnostic data capture data in cache.
You can use the set storageSubsystem ddcAllowOverWrite command to set the controller flag so that a
new diagnostic data capture will overwrite any previous diagnostic data capture. Without retrieving a
diagnostic data capture, this command sets the flag as if you had.
Attention:
Possible damage to the storage subsystem configuration As soon as you run this command, the
existing Event Log in the storage subsystem is deleted.
Syntax
clear storageSubsystem eventLog
Parameters
None.
Attention:
Possible damage to the storage subsystem configuration As soon as you run this command, the
contents of the existing pending area in the storage subsystem are deleted.
Syntax
clear storageSubsystem firmwarePendingArea
Parameters
None.
Notes
Recovery mode is entered during start-of-day operations when the system configuration is cleared and a
valid on board backup is available. This mode is exited by either restoring the system configuration from
a backup location, or by clearing the existing on board backups. While recovery mode is in force, a needs
attention condition is raised and the Recovery Guru will be available from the user interface. However,
the system configuration will be empty during recovery mode.
Syntax
Attention: The SM CLI support bundle commands must be run from the SM CLI command line
interface only. They cannot be run from the storage subsystem SM CLI script window. In addition, the
storage subsystem IP addresses are not required. Also, the -c parameter is not required to precede the SM
CLI support bundle command.
<install Path>SMcli -supportBundle auto (enable|disable) (all | storageSubsystemName) [data=pathName]
Parameters
Parameter Description
enable Enable automatic collection of support bundles when a
critical MEL event is detected.
disable Disable automatic collection of support bundles where
the feature was previously enabled.
all Apply the command to all storage subsystems detected
from the host.
storageSubsystemName Apply the command to the named storage subsystem
that is in the Storage Manager Enterprise management
window domain. The names of the storage subsystems
can be displayed using the SMcli command with the -d
parameter.
data Store the data generated by the command at the location
specified by the pathName.
Note: You must disable any FlashCopies before attempting to convert from a FlashCopy logical drive to
an Enhanced FlashCopy group. Use the disableFlashcopy command to disable a FlashCopy .
3-50 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Syntax
convert flashcopyLogicalDrive baseLogicalDrive="baseLogicalDriveName"
Parameters
Parameter Description
baseLogicalDrive The alphanumeric identifier (including - and _) of the
base logical drive that has the FlashCopies that you want
to convert into an Enhanced FlashCopy group. Enclose
the base logical drive name in double quotation marks ("
").
Create Array
This command creates either a free-capacity array or one logical drive on a set of unassigned disk drives.
Syntax
create array [userLabel]
Drives=(enclosureID1,drawerID1,slotID1 ... enclosureIDn,drawerIDn,slotIDn)
raidLevel=(0 | 1 | 3 | 5 | 6)
userLabel=arrayName
DriveMediaType=(HDD | SSD | unknown | allMedia)
enclosureLossProtect=(TRUE | FALSE)
drawerLossProtect=(TRUE | FALSE)
securityType=(none | capable | enabled)]
T10PI=(none | enabled)]
Parameters
Parameter Description
drives The disk drives that you want to assign to the array to
be created. For high-capacity disk drive expansion
enclosures, specify the enclosure ID value, the drawer ID
value, and the slot ID value for each disk drive that you
assign to the array. For low-capacity drive expansion
enclosures, specify the enclosure ID value and the slot ID
value for each disk drive that you assign to the array.
Enclosure ID values are 0 to 99. Drawer ID values are 1
to 5. Slot ID values are 1 to 32. Enclose the enclosure ID
values, the drawer ID values, and the slot ID values in
parentheses.
raidLevel The RAID level of the array that contains the logical
drive. Valid values are 0, 1, 3, 5, or 6.
userLabel The alphanumeric identifier (including - and _) that you
want to give the new array. Enclose the array identifier
in double quotation marks (" ").
You must use this parameter when you have more than
one type of drive in your storage subsystem.
3-52 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Parameter Description
T10PI The setting to specify that an array, and the logical
drives within the array, has T10 PI (Protection
Information) to help you ensure that the data maintains
its integrity. When you use this parameter, only
protected drives can be used for the array. These settings
are valid:
v noneThe array does not have T10 PI (Protection
Information).
v enabledThe array has T10 PI (Protection
Information). The array support is protected
information and is formatted with protection
information enabled.
Notes
The drives parameter lets you choose the number of disk drives that you want to use in the array. If you
choose this option, you do not need to specify the disk drives by enclosure ID and slot ID. The
controllers choose the specific disk drives to use for the array.
If you do not specify a capacity by using the capacity parameter, all of the disk drive capacity that is
available in the array is used. If you do not specify capacity units, bytes is used as the default value.
The cacheReadPrefetch command lets the controller copy additional data blocks into cache while the
controller reads and copies data blocks that are requested by the host from the disk drives into cache.
This action increases the chance that a future request for data can be fulfilled from cache. Cache read
prefetch is important for multimedia applications that use sequential data transfers. The configuration
settings for the storage subsystem that you use determine the number of additional data blocks that the
controller reads into cache. Valid values for the cacheReadPrefetch parameter are TRUE or FALSE.
You do not need to enter a value for the cacheReadPrefetch parameter or the segmentSize parameter. If
you do not enter a value, the controller firmware uses the usageHint parameter with fileSystem as the
default value. Entering a value for the usageHint parameter and a value for the cacheReadPrefetch
parameter or a value for the segmentSize parameter does not cause an error. The value that you enter for
the cacheReadPrefetch parameter or the segmentSize parameter takes priority over the value for the
usageHint parameter.
Segment Size
The size of a segment determines how many data blocks that the controller writes on a single disk drive
in a logical drive before writing data on the next disk drive. Each data block stores 512 bytes of data. A
data block is the smallest unit of storage. The size of a segment determines how many data blocks that it
contains. For example, an 8 KB segment holds 16 data blocks. A 64 KB segment holds 128 data blocks.
When you enter a value for the segment size, the value is checked against the supported values that are
provided by the controller at run time. If the value that you entered is not valid, the controller returns a
list of valid values. Using a single disk drive for a single request leaves other disk drives available to
simultaneously service other requests.
If the logical drive is in an environment where a single user is transferring large units of data (such as
multimedia), performance is maximized when a single data transfer request is serviced with a single data
For optimal performance in a multiuser database or file system storage environment, set your segment
size to minimize the number of disk drives that are required to satisfy a data transfer request.
Security Type
The securityType parameter is valid for drives that are capable of full disk encryption (FDE). With FDE,
the controller firmware can create a key and activate the drive security feature. The drive security feature
encrypts data as the data is written to the drive and decrypts the data as the data is read from the drive.
Without the key created by the controller, the data written to the drive is inaccessible.
Before you can set the securityType parameter to capable or enabled, you must create a storage subsystem
security key. Use the create storageSubsystem securityKey command to create a storage subsystem
security key. These commands are related to the security key:
v create storageSubsystem securityKey
v enable array [arrayName] security
v export storageSubsystem securityKey
v import storageSubsystem securityKey
v set storageSubsystem securityKey
v start secureErase (drive | drives)
For enclosure loss protection to work, each disk drive in an array must be in a separate enclosure. If you
set the enclosureLossProtect parameter to TRUE and have selected more than one disk drive from any
one enclosure, the storage subsystem returns an error. If you set the enclosureLossProtect parameter to
FALSE, the storage subsystem performs operations, but the array that you create might not have enclosure
loss protection.
Enclosure loss protection is not valid when you create logical drives on existing arrays.
The drawerLossProtect parameter defines if data on a logical drive is accessible even if a drawer fails.
When you assign the disk drives, if you set the drawerLossProtect parameter to TRUE and select more
than one disk drive from any one drawer, the storage subsystem returns an error. If you set the
drawerLossProtect parameter to FALSE, the storage subsystem performs operations, but the array that you
create might not have drawer loss protection.
You must set the same value for the enclosureLossProtect and drawerLossProtect parameters. Both of
the parameters must be either TRUE or FALSE. If the enclosureLossProtect parameter and the
drawerLossProtect parameter are set to different values, the storage subsystem returns an error.
This command creates a new, empty consistency group that can contains Enhanced FlashCopy groups.
You must add the Enhanced FlashCopy groups using the set consistencyGroup addCGMember command.
3-54 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Syntax
create consistencyGroup userLabel="consistencyGroupName"
[repositoryFullPolicy=(failBaseWrites | purgeEnhancedFlashcopyImages) |
repositoryFullLimit=percentValue |
autoDeleteLimit=numberOfEnhancedFlashcopyImages |
enableSchedule=(TRUE | FALSE) |
schedule (immediate | EnhancedFlashcopySchedule) |
rollbackPriority=(lowest | low | medium | high | highest)]
Parameters
Parameter Description
userLabel The name of the new consistency group that you want to
create. Enclose the new consistency group name in
double quotation marks (" ").
repositoryFullPolicy How you want Enhanced FlashCopy processing to
continue if the Enhanced FlashCopy repository logical
drives are full. You can choose to fail writes to the base
logical drive (failBaseWrites) or delete (purge) the
Enhanced FlashCopy images (
purgeEnhancedFlashcopyImages). The default action is
purgeEnhancedFlashcopyImages.
repositoryFullLimit The percentage of repository capacity at which you
receive a warning that the Enhanced FlashCopy
repository logical drive is nearing full. Use integer
values. For example, a value of 70 means 70 percent. The
default value is 75.
autoDeleteLimit The maximum number of Enhanced FlashCopy images
that you want to automatically delete if you have
selected to purge the Enhanced FlashCopy images for a
repository full policy. The default value is 32.
enableSchedule Whether the ability to schedule an Enhanced FlashCopy
operation is turned on or turned off. To turn on
Enhanced FlashCopy scheduling, set this parameter to
TRUE. To turn off Enhanced FlashCopy scheduling, set
this parameter to FALSE.
schedule Use this parameter to schedule an Enhanced FlashCopy
operation. You can use one of these options for setting a
schedule for an Enhanced FlashCopy operation:
v immediate
v startDate
v scheduleDay
v startTime
v scheduleInterval
v endDate
v timesPerDay
v timeZone
You can use any combination of alphanumeric characters, underscore (_), hyphen (-), and pound (#) for
the names. Names can have a maximum of 30 characters.
The Enhanced FlashCopy images in a consistency group can be deduced based on the existence of an
Enhanced FlashCopy image within a consistency group. All Enhanced FlashCopy images that reside
within a consistency group share a common time stamp and sequence number.
An operation on an Enhanced FlashCopy image consistency group is treated as a single request, and
causes all pending I/O operations to the associated base logical drive of each member to be drained and
suspended before creating the Enhanced FlashCopy images. If creation of the Enhanced FlashCopy
images cannot be completed successfully for all of the consistency group members, the operation fails
and has no affect (that is, new Enhanced FlashCopy images are not created).
Based on this behavior all members for a consistency group usually have the same number of Enhanced
FlashCopy images. However, when a new member is added to a consistency group, that new member
lacks the Enhanced FlashCopy images that were previously created on the established members of the
consistency group. This is not considered an error condition. Ensuing requests for deletion or rollback of
Enhanced FlashCopy images that only exist on a subset of the consistency group members will only
affect the members for which the specified Enhanced FlashCopy images actually exists
The enableSchedule parameter and the schedule parameter provide a way for you to schedule automatic
FlashCopies . Using these parameters, you can schedule Enhanced FlashCopies daily, weekly, or monthly
(by day or by date). The enableSchedule parameter turns on or turns off the ability to schedule Enhanced
FlashCopies. When you enable scheduling, you use the schedule parameter to define when you want the
Enhanced FlashCopies to occur.
This list explains how to use the options for the schedule parameter:
v immediate - As soon as you enter the command, an Enhanced FlashCopy logical drive is created and a
copy-on-write operation begins.
v startDate - A specific date on which you want to create an Enhanced FlashCopy logical drive and
perform a copy-on-write operation. The format for entering the date is MM:DD:YY. If you do not
provide a start date, the current date is used. An example of this option is startDate=06:27:11.
v scheduleDay - A day of the week on which you want to create an Enhanced FlashCopy logical drive
and perform a copy-on-write operation. The values that you can enter are: monday, tuesday, wednesday,
thursday, friday, saturday, sunday. An example of this option is scheduleDay=wednesday.
v startTime - The time of a day that you want to create an Enhanced FlashCopy logical drive and start
performing a copy-on-write operation. The format for entering the time is HH:MM, where HH is the
hour and MM is the minute past the hour. Use a 24-hour clock. For example, 2:00 in the afternoon is
14:00. An example of this option is startTime=14:27
v scheduleInterval - An amount of time, in minutes, that you want to have as a minimum between
copy-on-write operation. It is possible for you to create a schedule in which you have overlapping
copy-on-write operations because of the duration a copy operation. You can make sure that you have
time between copy-on-write operations by using this option. The maximum value for the
scheduleInterval option is 1440 minutes. An example of this option is scheduleInterval=180.
3-56 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
v endDate - A specific date on which you want to stop creating an Enhanced FlashCopy logical drive and
end the copy-on-write operations. The format for entering the date is MM:DD:YY. An example of this
option is endDate=11:26:11.
v timesPerDay - The number of times that you want the schedule to run in a day. An example of this
option is timesPerDay=4.
v timeZone - Use this parameter to define the time zone in which the storage subsystem is operating. You
can define the time zone in one of two ways:
GMTHH:MM - The time zone offset from GMT. Enter the offset in hours and minutes. For example
GMT-06:00 is the central time zone in the United States.
Text string - Standard time zone text strings. For example: "USA/Chicago" or "Germany/Berlin".
Time zone text strings s are case sensitive. If you enter an incorrect text string, GMT time is used.
Enclose the text string in double quotation marks.
If you also use the scheduleInterval option, the firmware will choose between the timesPerDay option and
the scheduleInterval option by selecting the lowest value of the two options. The firmware calculates an
integer value for the scheduleInterval option by dividing 1440 by a the scheduleInterval option value
that you set. For example, 1440/180 = 8. The firmware then compares the timesPerDay integer value with
the calculated scheduleInterval integer value and uses the smaller value.
To remove a schedule, use the delete logicaldrive command with the schedule parameter. The delete
logicaldrive command with the schedule parameter deletes only the schedule, not the Enhanced
FlashCopy logical drive.
When performing a rollback in a consistency group, the default operation is to rollback all members of
the consistency group. If a rollback cannot be started successfully for all of the members in the
consistency group, the rollback fails and has no effect. The Enhanced FlashCopy image is not rolled back.
Syntax
create mapping cgEnhancedFlashCopyLogicalDrive="enhancedFlashCopyLogicalDriveName"
(host="hostName" | hostGroup=("hostGroupName" | defaultGroup)
Parameters
Parameter Description
cgEnhancedFlashCopyLogicalDrive The name of the consistency group Enhanced FlashCopy
logical drive for which you want to create a logical
mapping. Enclose the consistency group Enhanced
FlashCopy logical drive name in double quotation marks
(" ").
host The name of a host to which you want to create a logical
mapping. Enclose the host name in double quotation
marks (" ").
Notes
A host is a computer that is attached to the storage subsystem and accesses the logical drives on the
storage subsystem through the host ports. You can define specific mappings to an individual host. You
also can assign the host to a host group that shares access to one or more logical drives.
A host group is an optional topological element that you can define if you want to designate a collection
of hosts that share access to the same logical drives. The host group is a logical entity. Define a host
group only if you have two or more hosts that share access to the same logical drives.
Syntax
Parameters
Parameter Description
consistencyGroup The name of the consistency group for which you are
creating Enhanced FlashCopy images. Enclose the
consistency group name in double quotation marks (" ").
Notes
You can use any combination of alphanumeric characters, hyphens, and underscores for the names.
Names can have a maximum of 30 characters.
The command causes all pending I/O operations to each base logical drive that is a member of the
consistency group to be drained and suspended before creating the Enhanced FlashCopy images. If the
creation of all of the Enhanced FlashCopy images cannot be completed successfully for all of the
consistency group members, the operation fails and new Enhanced FlashCopy images are not created.
Normally, all members of an Enhanced FlashCopy consistency group will have the same number of
Enhanced FlashCopy images. When you add a new member to an Enhanced FlashCopy consistency
group, that new member lacks the Enhanced FlashCopy images that were previously created on the
established members of the Enhanced FlashCopy consistency group. This is not an error condition.
Requests for deletion or rollback of Enhanced FlashCopy images that exist on only a subset of the
Enhanced FlashCopy consistency group members affects only those members for which the specified
Enhanced FlashCopy image actually exists.
3-58 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Create Consistency Group Enhanced FlashCopy Logical Drive
This command creates an Enhanced FlashCopy logical drive of specific images in the base logical drives
in a consistency group. You can select one base logical drive or more than one base logical drives from
the consistency group to include in the Enhanced FlashCopy logical drive. When you create an Enhanced
FlashCopy logical drive of a consistency group you are creating a logical drive with contents that you can
view.
Syntax When Setting the Consistency Group Enhanced FlashCopy Logical Drive to
Read Only
create cgEnhancedFlashCopyLogicalDrive userLabel="cgLogicalDriveName"
cgEnhancedFlashCopyImageID="enhancedFlashCopyCGID:imageID"
readOnly
Parameters
Parameter Description
userLabel The name that you want to give the consistency group
Enhanced FlashCopy logical drive that you are creating.
Enclose the consistency group Enhanced FlashCopy
logical drive name in double quotation marks (" ").
cgEnhancedFlashCopyImageID The identifier of the Enhanced FlashCopy image from
the Enhanced FlashCopy consistency group that you
want to include in the consistency group Enhanced
FlashCopy logical drive. Enclose the Enhanced
FlashCopyImage identifier in double quotation marks ("
").
members The identifier of one base logical drive or more than one
base logical drives that you want to add. The members
identifier is comprised of the base logical drive name
concatenated with the repository logical drive name. You
must use a colon (:) between the two names. Enclose all
of the member identifiers in parenthesizes. If you enter
more than one member separated the members with a
space.
Notes
You can use any combination of alphanumeric characters, underscore (_), hyphen (-), and pound (#) for
the names. Names can have a maximum of 30 characters.
If you do not specify the repositoryVolType or readOnly parameters, the storage management software
selects the repositories for the consistency group Enhanced FlashCopy logical drive. If the array or disk
pool where the base logical drive resides does not have enough space, this command fails.
The create cgEnhancedFlashCopyLogicalDrive command has unique forms that are explained by these
examples:
v Creating a read/write consistency group Enhanced FlashCopy logical drive on an Enhanced FlashCopy
consistency group named "enhancedFlashCopyCG1" that has three memebers cgm1, cgm2, and cgm3. The
repository logical drives already exist and are selected by the user in this command.
Note the use of the colon (:) in the name of the Enhanced FlashCopy image to be included in the
consistency group Enhanced FlashCopy logical drive. The colon is a delimiter that separates the name of
the Enhanced FlashCopy logical drive from a particular Enhanced FlashCopy image that you might want
to use. You can use one of these options following the colon:
v An integer value that is the actual sequence number of the Enhanced FlashCopy image.
v newest - Use this option when you want to show the latest consitency group Enhanced FlashCopy
image.
v oldest - Use this option when you want to show the earliest Enhanced FlashCopy image created.
The use of the colon following the names of the members of the Enhanced FlashCopy consistency group
acts define the mapping between the member and a repository logical drive. For example, in
cgm1:repos1_10, member cgm1 maps to repository logical drive repos1_0010.
v Creating a read/write consistency group Enhanced FlashCopy logical drive on an Enhanced FlashCopy
consistency group named "enhancedFlashCopyCG1" of only members cgm1 and cgm2:
3-60 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
create cgEnhancedFlashCopyLogicalDrive userLabel="cgEnhancedFlashCopyVol3"
cgEnhancedFlashCopyImageID="enhancedFlashCopyCG1:oldest" repositoryFullLimit=60;
v Creating a read/write consistency group Enhanced FlashCopy logical drive with automatic repository
selection on an Enhanced FlashCopy consistency group named enhancedFlashCopyCG1 that has three
members cgm1, cgm2, and cgm3:
Syntax
create mapping cgEnhancedFlashCopyLogicalDrive="enhancedFlashCopyLogicalDriveName"
(host="hostName" | hostGroup=("hostGroupName" | defaultGroup
Parameters
Parameter Description
cgEnhancedFlashCopyLogicalDrive The name of the consistency group Enhanced FlashCopy
logical drive for which you want to create a logical
mapping. Enclose the consistency group Enhanced
FlashCopy logical drive name in double quotation marks
(" ").
host The name of a host to which you want to create a logical
mapping. Enclose the host name in double quotation
marks (" ").
hostGroup The name of a host group to which you want to create a
logical mapping. Enclose the host group name in double
quotation marks (" "). If you use the defaultGroup
keyword, do not enclose it in quotation marks.
Notes
A host is a computer that is attached to the storage subsystem and accesses the logical drives on the
storage subsystem through the host ports. You can define specific mappings to an individual host. You
also can assign the host to a host group that shares access to one or more logical drives.
A host group is an optional topological element that you can define if you want to designate a collection
of hosts that share access to the same logical drives. The host group is a logical entity. Define a host
group only if you have two or more hosts that share access to the same logical drives.
Syntax
create diskPool
(drives=(enclosureID1,drawerID1,slotID1 ... enclosureIDN,drawerIDN,slotIDN) |
driveType=(fibre|sas|sata))
userLabel="diskPoolName"
Parameters
Parameter Description
drives The drives that you want to assign to the disk pool that
you want to create. For high capacity drive enclosures,
specify the enclosure ID value, the drawer ID value, and
the slot ID value for each drive that you assign to the
disk pool. For low-capacity drive expansion enclosures,
specify the enclosure ID value and the slot ID value for
each drive that you assign to the disk pool. Enclosure ID
values are 0 to 99. Drawer ID values are 1 to 5. Slot ID
values are 1 to 32. Enclose the enclosure ID values, the
drawer ID values, and the slot ID values in parentheses.
driveType The type of drive that you want to use in the disk pool.
You cannot mix drive types.
You must use this parameter when you have more than
one type of drive in your storage subsystem.
3-62 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Parameter Description
criticalThreshold The percentage of storage capacity at which you receive
a critical alert that the disk pool is nearing full. Use
integer values. For example, a value of 70 means 70
percent.
You must use this parameter when you have more than
one type of drive media in your storage subsystem.
Notes
Each disk pool name must be unique. You can use any combination of alphanumeric characters,
underscore (_), hyphen(-), and pound (#) for the user label. User labels can have a maximum of 30
characters.
If the parameters you specify cannot be satisfied by any of the available candidate drives, the command
fails. Normally, all drives that match the quality of service attributes will be returned as the top
candidates. However, if you specifying a drive list, some of the available drives returned as candidates
might not match the quality of service attributes.
If you do not specify a value for an optional parameter, a default value is assigned.
Drives
When you use the driveType parameter, all of the unassigned drives that are of that drive type are used
to create the disk pool. If you want to limit the number of drives found by the driveType parameter in
the disk pool, you can specify the number of drives using the driveCount parameter. You can use the
driveCount parameter only when you use the driveType parameter.
The drives parameter supports both high-capacity drive expansion enclosures and low-capacity drive
expansion enclosures. A high-capacity drive expansion enclosure has drawers that hold the drives. The
drawers slide out of the drive expansion enclosure to provide access to the drives. A low-capacity drive
expansion enclosure does not have drawers. For a high-capacity drive expansion enclosure, you must
specify the identifier (ID) of the drive expansion enclosure, the ID of the drawer, and the ID of the slot in
which a drive resides. For a low-capacity drive expansion enclosure, you need only specify the ID of the
drive expansion enclosure and the ID of the slot in which a drive resides. For a low-capacity drive
expansion enclosure, an alternative method for identifying a location for a drive is to specify the ID of
the drive expansion enclosure, set the ID of the drawer to 0, and specify the ID of the slot in which a
drive resides.
If you enter specifications for a high capacity drive expansion enclosure, but a drive expansion enclosure
is not available, the storage management software returns an error message.
Each disk pool has two progressively severe levels of alerts to inform users when the storage capacity of
the disk pool is approaching full. The threshold for an alert is a percent of the used capacity to the total
usable capacity in the disk pool. The alerts are:
3-64 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
v Warning - This is the first level of alert that the used capacity in a disk pool is approaching full. When
the threshold for the warning alert is reached a Needs Attention condition is generated and an event is
posted to the storage management software. The warning threshold is superseded by the critical
threshold. The default warning threshold is 50 percent.
v Critical - This is the most severe level of alert that the used capacity in a disk pool is approaching
full. When the threshold for the critical alert is reached a Needs Attention condition is generated and
an event is posted to the storage management software. The warning threshold is superseded by the
critical threshold. The default warning threshold is 85 percent.
To be effective, the value for a warning alert must always be less than the value for a critical alert. If
the value for the warning alert is the same as the value for a critical alert, only the critical alert is
sent.
Disk pools do not queue background commands. You can start several background commands
sequentially, but starting more than one background operation at a time delays the completion of
commands that you started previously. The relative priority levels for the supported background
operations are:
1. Reconstruction
2. Format
3. IAF
4. DCE
Security Type
The securityType parameter is valid for drives that are capable of full disk encryption (FDE). With FDE,
the controller firmware can create a key and activate the drive security feature. The drive security feature
encrypts data as the data is written to the drive and decrypts the data as the data is read from the drive.
Without the key created by the controller, the data written to the drive is inaccessible.
Before you can set the securityType parameter to capable or enabled, you must create a storage
subsystem security key. Use the create storageSubsystem securityKey command to create a storage
subsystem security key. These commands are related to the security key:
v create storageSubsystem securityKey
v enable array [arrayName] security
v export storageSubsystem securityKey
v import storageSubsystem securityKey
v set storageSubsystem securityKey
v start secureErase (drive | drives)
Syntax
create enhancedFlashCopyGroup userLabel="enhancedFlashCopyGroupName" sourceLogicalDrive="logicaldriveName"
(repositoryLogicalDrive="repos_xxxx" |
repositoryLogicalDrive=(arrayName [capacity=capacityValue])
repositoryLogicalDrive=(diskPoolName [capacity=capacityValue]))
[repositoryFullPolicy=(failBaseWrites | purgeEnhancedFlashCopyImages) |
rollbackPriority=(highest | high | medium | low | lowest) |
repositoryFullLimit=percentValue |
autoDeleteLimit=numberOfEnhancedFlashCopyImages |
enableSchedule=(TRUE | FALSE)
schedule=(immediate | flashcopySchedule)]
DITA
DITA
Parameters
Parameter Description
userLabel The name that you want to give the new Enhanced
FlashCopy group. Enclose the Enhanced FlashCopy
group identifier in double quotation marks (" ").
sourceLogicalDrive The name of the logical drive that you want to use as the
source for your Enhanced FlashCopy images. Enclose the
source logical drive name in double quotation marks ("
").
3-66 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Parameter Description
repositoryLogicalDrive The name of the repository logical drive that will contain
the Enhanced FlashCopy group.
Notes
Each Enhanced FlashCopy group name must be unique. You can use any combination of alphanumeric
characters, underscore (_), hyphen(-), and pound (#) for the user label. User labels can have a maximum
of 30 characters.
To create an Enhanced FlashCopy group, you must have an associated repository logical drive in which
you store the Enhanced FlashCopy images. You can either use an existing repository logical drive or
create a new repository logical drive. You can create the repository logical drive when you create the
Enhanced FlashCopy group. An Enhanced FlashCopy group repository logical drive is an expandable
logical drive that is structured as a concatenated collection of up to 16 standard logical drive entities.
Initially, an expandable repository logical drive has only a single element. The capacity of the expandable
repository logical drive is exactly that of the single element. You can increase the capacity of an
expandable repository logical drive by attaching additional standard logical drives to it. The composite
expandable repository logical drive capacity then becomes the sum of the capacities of all of the
concatenated standard logical drives.
3-68 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
An Enhanced FlashCopy group has a strict ordering of Enhanced FlashCopy images based on the time
that each Enhanced FlashCopy image is created. An Enhanced FlashCopy image that is created after
another Enhanced FlashCopy image is a successor relative to that other Enhanced FlashCopy image. An
Enhanced FlashCopy image that is created before another Enhanced FlashCopy image is a predecessor
relative to that other one.
An Enhanced FlashCopy group repository logical drive must satisfy a minimum capacity requirement
that is the sum of the following:
v 32 MB to support fixed overhead for the Enhanced FlashCopy group and for copy-on-write processing.
v Capacity for rollback processing, which is 1/5000th of the capacity of the base logical drive.
The minimum capacity is enforcement by the controller firmware and the storage management software.
When a you first create an Enhanced FlashCopy group, it does not contains any Enhanced FlashCopy
images. When you create Enhanced FlashCopy images, you add the Enhanced FlashCopy images to an
Enhanced FlashCopy group. Use the create enhancedFlashCopyImage command to create Enhanced
FlashCopy images and add the Enhanced FlashCopy images to an Enhanced FlashCopy group.
You can configure each Enhanced FlashCopy group to automatically delete the Enhanced FlashCopy
images group by using the autoDeleteLimit parameter. Automatically deleting the Enhanced FlashCopy
images enables you to avoid having to routinely, manually delete the images that you do not want and
that might prevent the creation of future Enhanced FlashCopy images because the repository logical drive
is full. When you use the autoDeleteLimit parameter it causes the storage management software to
automatically delete Enhanced FlashCopy images. The storage management software deletes Enhanced
FlashCopy images until it reaches a number of Enhanced FlashCopy images that is equal to the number
that you enter with autoDeleteLimit parameter. When new Enhanced FlashCopy images are added to the
repository logical drive, the storage management software deletes the oldest Enhanced FlashCopy images
until the autoDeleteLimit parameter number is reached.
The enableSchedule parameter and the schedule parameter provide a way for you to schedule creating
Enhanced FlashCopy images for an Enhanced FlashCopy group. Using these parameters, you can
schedule Enhanced FlashCopies daily, weekly, or monthly (by day or by date). The enableSchedule
parameter turns on or turns off the ability to schedule Enhanced FlashCopies. When you enable
scheduling, you use the schedule parameter to define when you want the Enhanced FlashCopies to occur.
This list explains how to use the options for the schedule parameter:
If you also use the scheduleInterval option, the firmware chooses between the timesPerDay option and
the scheduleInterval option by selecting the lowest value of the two options. The firmware calculates an
integer value for the scheduleInterval option by dividing 1440 by the scheduleInterval option value
that you set. For example, 1440/180 = 8. The firmware then compares the timesPerDay integer value with
the calculated scheduleInterval integer value and uses the smaller value.
To remove a schedule, use the delete logicaldrive command with the schedule parameter. The delete
logicaldrive command with the schedule parameter deletes only the schedule, not the Enhanced
FlashCopy logical drive.
The enableSchedule parameter and the schedule parameter provide a way for you to schedule automatic
Enhanced FlashCopy. Using these parameters, you can schedule Enhanced FlashCopy daily, weekly, or
monthly (by day or by date). The enableSchedule parameter turns on or turns off the ability to schedule
Enhanced FlashCopy. When you enable scheduling, you use the schedule parameter to define when you
want the Enhanced FlashCopy to occur.
3-70 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
This list explains how to use the options for the schedule parameter:
v immediate - As soon as you enter the command, an Enhanced FlashCopy logical drive is created, and a
copy-on-write operation begins.
v startDate - A specific date on which you want to create an Enhanced FlashCopy logical drive and
perform a copy-on-write operation. The format for entering the date is MM:DD:YY. If you do not
provide a start date, the current date is used. An example of this option is startDate=06:27:11.
v scheduleDay - A day of the week on which you want to create an Enhanced FlashCopy logical drive
and perform a copy-on-write operation. You can enter these values: monday, tuesday, wednesday,
thursday, friday, saturday, and sunday. An example of this option is scheduleDay=wednesday
v startTime - The time of a day that you want to create an Enhanced FlashCopy logical drive and start
performing a copy-on-write operation. The format for entering the time is HH:MM, where HH is the
hour and MM is the minute past the hour. Use a 24- hour clock. For example, 2:00 in the afternoon is
14:00. An example of this option is startTime=14:27.
v scheduleInterval - An amount of time, in minutes, that you want to have as a minimum between
copy-on-write operation. You can possibly create a schedule in which you have overlapping
copy-on-write operations because of the duration a copy operation. You can make sure that you have
time between copy-on-write operations by using this option. The maximum value for the
scheduleInterval option is 1440 minutes. An example of this option is scheduleInterval=180.
v endDate - A specific date on which you want to stop creating an Enhanced FlashCopy logical drive and
end the copy-on-write operation. The format for entering the date is MM:DD:YY. An example of this
option is endDate=11:26:11
v noEndDate - Use this option if you do not want your scheduled copy-on-write operation to end. If you
later decide to end the copy-on-write operations you must re-enter the set enhancedFlashCopyGroup
command and specify an end date.
v timesPerDay - The number of times that you want the schedule to run in a day. An example of this
option is timesPerDay=4.
v timeZone - Use this parameter to define the time zone in which the storage subsystem is operating. You
can define the time zone in one of two ways:
GMTHH:MM - The time zone offset from GMT. Enter the offset in hours and minutes. For example
GMT-06:00 is the central time zone in the United States.
Text string - Standard time zone text strings. For example: "USA/Chicago" or "Germany/Berlin".
Time zone text strings are case sensitive. If you enter an incorrect text string, GMT time is used.
Enclose the text string in double quotation marks.
If you also use the scheduleInterval option, the firmware chooses between the timesPerDay option and
the scheduleInterval option by selecting the lowest value of the two options. The firmware calculates an
integer value for the scheduleInterval option by dividing 1440 by the scheduleInterval option value
that you set. For example, 1440/180 = 8. The firmware then compares the timesPerDay integer value with
the calculated scheduleInterval integer value and uses the smaller value.
Syntax
create enhancedFlashCopyImage (enhancedFlashCopyGroup="enhancedFlashCopyGroupName" |
enhancedFlashCopyGroups=("enhancedFlashCopyGroupName1"... "enhancedFlashCopyGroupNamen"))
Parameters
Parameter Description
enhancedFlashCopyGroup or enhancedFlashCopyGroups The name of the Enhanced FlashCopy group that will
contain the Enhanced FlashCopy image. Enclose the
name of the Enhanced FlashCopy group in double
quotation marks (" ").
Notes
You can use any combination of alphanumeric characters, underscore (_), hyphen (-), and pound (#) for
the names. Names can have a maximum of 30 characters.
An Enhanced FlashCopy image is a logical point-in-time image of the contents of an associated base
logical drive. The Enhanced FlashCopy image is created instantly and records the state of the base logical
drive at that moment. Every Enhanced FlashCopy image is created in the context of exactly one
Enhanced FlashCopy group. An Enhanced FlashCopy group is a sequence of Enhanced FlashCopy
images of the associated base logical drive. An Enhanced FlashCopy group has one repository logical
drive used to save all of the data from the Enhanced FlashCopy images. The Enhanced FlashCopy images
in an Enhanced FlashCopy group have a specific order. The specific order of the Enhanced FlashCopy
images enables you to manage the Enhanced FlashCopy images, such as restoring a specific Enhanced
FlashCopy image to the base logical drive or deleting the Enhanced FlashCopy images that you no longer
need.
The result of creating an Enhanced FlashCopy image of a consistency group is an Enhanced FlashCopy
image of every member logical drive of the consistency group.
Note: You cannot use this command for an Enhanced FlashCopy image that is used in online logical
drive copy.
3-72 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Syntax
create enhancedFlashCopyLogicalDrive userLabel="enhancedFlashCopyLogicalDriveName"
enhancedFlashCopyImageID="enhancedFlashCopyImageID"
[repositoryLogicalDrive="repos_xxxx" |
repositoryFullLimit=percentValue]
Parameter
Parameter Description
userLabel The name that you want to give to an Enhanced
FlashCopy logical drive. Enclose the Enhanced
FlashCopy logical drive name in double quotation marks
(" ").
enhancedFlashCopyImageID The alphanumeric identifier of an Enhanced FlashCopy
image that you want to add to the new Enhanced
FlashCopy logical drive. The identifier of an Enhanced
FlashCopy image is comprised of two parts:
v The name of the Enhanced FlashCopy group
v An identifier for the Enhanced FlashCopy image in the
Enhanced FlashCopy group.
repos_xxxx
Notes
You can use any combination of alphanumeric characters, underscore (_), hyphen (-), and pound (#) for
the names. Names can have a maximum of 30 characters.
The identifier of an Enhanced FlashCopy image has two parts separated by a colon (:):
For example, if you want to create an Enhanced FlashCopy logical drive named enhancedFlashCopyData1
using the most recent Enhanced FlashCopy image in an Enhanced FlashCopy group that has the name
enhancedFlashCopyGroup1 with a maximum fill limit of 80 percent for the repository logical drive, you
would use this command:
create enhancedFlashCopyLogicalDrive userLabel="enhancedFlashCopyData1"
enhancedFlashCopyImageID="enhancedFlashCopyGroup1:newest"
repositoryLogicalDrive="repos_1234" repositoryFullLimit=80;
The repository logical drive identifier is automatically created by the storage management software and
the firmware when you create a new Enhanced FlashCopy group. You cannot rename the repository
logical drive because renaming the repository logical drive will break the linkage with the Enhanced
FlashCopy images.
If you choose to define a number of disk drives, the controller firmware chooses which disk drives to use
for the FlashCopy logical drive.
3-74 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Parameters
Parameter Description
baseLogicalDrive The name of the base logical drive from which you want
to take a FlashCopy . Enclose the base logical drive name
in double quotation marks ( ).
repositoryRAIDLevel Use this parameter when you create a new array.
You must use this parameter when you have more than
one type of drive media in your storage subsystem.
DriveType The type of disk drives that you want to use for the
FlashCopy repository logical drive. Valid disk drive
types are SCSI, fibre, or SAS.
freeCapacityArea The index number of the free space in an existing array
that you want to use to create the FlashCopy repository
logical drive. Free capacity is defined as the free capacity
between existing logical drives in an array. For example,
an array might have the following areas: logical drive 1,
free capacity, logical drive 2, free capacity, logical drive 3,
free capacity. To use the free capacity following logical
drive 2, you would specify:
freeCapacityArea=2
3-76 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Parameter Description
schedule Use this parameter to schedule a FlashCopy operation.
Notes
The logical drive that you are taking a FlashCopy of must be a standard logical drive in the storage
subsystem. The maximum number of FlashCopy logical drives that you can create is one-half of the total
number of logical drives that are supported by a controller.
You can use any combination of alphanumeric characters, hyphens, and underscores for the names.
Names can have a maximum of 30 characters.
One technique for naming the FlashCopy logical drive and the FlashCopy repository logical drive is to
add a hyphenated suffix to the original base logical drive name. The suffix distinguishes between the
FlashCopy logical drive and the FlashCopy repository logical drive. For example, if you have a base
logical drive with a name of Engineering Data, the FlashCopy logical drive can have a name of
Engineering Data-S1, and the FlashCopy repository logical drive can have a name of EngineeringData-R1.
If you do not choose a name for either the FlashCopy logical drive or the FlashCopy repository logical
drive, the storage management software creates a default name by using the base logical drive name. An
example of the FlashCopy logical drive name that the controllers might create is, if the base logical drive
name is aaa and does not have a FlashCopy logical drive, the default FlashCopy logical drive name is
aaa-1. If the base logical drive already has n-1 number of FlashCopy logical drives, the default name is
aaa-n. An example of the FlashCopy repository logical drive name that the controller might create is, if
the base logical drive name is aaa and does not have a FlashCopy repository logical drive, the default
FlashCopy repository logical drive name is aaa-R1. If the base logical drive already has n-1 number of
FlashCopy repository logical drives, the default name is aaa-Rn.
If you do not specify the unconfigured space or free space, the FlashCopy repository logical drive is
placed in the same array as the base logical drive. If the array where the base logical drive resides does
not have enough space, this command fails.
When you assign the disk drives, if you set the enclosureLossProtect parameter to TRUE and have
selected more than one disk drive from any one enclosure, the storage subsystem returns an error. If you
set the enclosureLossProtect parameter to FALSE, the storage subsystem performs operations, but the
array that you create might not have enclosure loss protection.
When the controller firmware assigns the disk drives, if you set the enclosureLossProtect parameter to
TRUE, the storage subsystem returns an error if the controller firmware cannot provide disk drives that
result in the new array having enclosure loss protection. If you set the enclosureLossProtect parameter
When you assign the drives, if you set the enclosureLossProtect parameter to TRUE and have selected
more than one drive from any one enclosure, the storage subsystem returns an error. If you set the
enclosureLossProtect parameter to FALSE, the storage subsystem performs operations, but the array that
you create might not have enclosure loss protection.
When the controller firmware assigns the drives, if you set the enclosureLossProtect parameter to TRUE,
the storage subsystem returns an error if the controller firmware cannot provide drives that result in the
new array having enclosure loss protection. If you set the enclosureLossProtect parameter to FALSE, the
storage subsystem performs the operation even if it means the array might not have enclosure loss
protection.
The drawerLossProtect parameter defines if data on a logical drive is accessible if a drawer fails. When
you assign the drives, if you set the drawerLossProtect parameter to TRUE and select more than one drive
from any one drawer, the storage subsystem returns an error. If you set the drawerLossProtect parameter
to FALSE, the storage subsystem performs operations, but the array that you create might not have drawer
loss protection.
If you have a storage configuration that includes a drive expansion enclosure that has drawers to hold
the drives, follow these guidelines when configuring enclosure loss protection:
v If you set enclosureLossProtect to TRUE, then you must set drawerLossProtect to TRUE.
v If you set enclosureLossProtect to FALSE, then you can set drawerLossProtect to either TRUE or FALSE.
If you set enclosureLossProtect to TRUE and drawerLossProtect to FALSE, the storage subsystem returns
an error.
Scheduling FlashCopies
The enableSchedule parameter and the schedule parameter provide a way for you to schedule automatic
FlashCopies . Using these parameters, you can schedule flashcopies daily, weekly, or monthly (by day or
by date). The enableSchedule parameter turns on or turns off the ability to schedule FlashCopies . When
you enable scheduling, you use the schedule parameter to define when you want the FlashCopies to
occur.
This list explains how to use the options for the schedule parameter:
v immediate As soon as you enter the command, a FlashCopy logical drive is created and a
copy-on-write operation begins.
v startDate A specific date on which you want to create a FlashCopy logical drive and perform a
copy-on-write operation. The format for entering the date is MM:DD:YY. If you do not provide a start
date, the current date is used. An example of this option is startDate=06:27:11.
v scheduleDay - A day of the week on which you want to create a FlashCopy logical drive and perform a
copy-on-write operation. The values that you can enter are: monday, tuesday, wednesday, thursday,
friday, saturday, and sunday. An example of this option is scheduleDay=wednesday.
v startTime The time of a day that you want to create a FlashCopy logical drive and start performing
a copy-on-write operation. The format for entering the time is HH:MM, where HH is the hour and MM is
the minute past the hour. Use a 24-hour clock. For example, 2:00 in the afternoon is 14:00. An example
of this option is startTime=14:27.
v scheduleInterval An amount of time, in minutes, that you want to have as a minimum between
copy-on-write operation. It is possible for you to create a schedule in which you have overlapping
copy-on-write operations because of the duration a copy operation. You can make sure that you have
3-78 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
time between copy-on-write operations by using this option. The maximum value for the
scheduleInterval option is 1440 minutes. An example of this option is scheduleInterval=180.
v endDate A specific date on which you want to stop creating a FlashCopy logical drive and end the
copy-on-write operations. The format for entering the date is MM:DD:YY. An example of this option is
endDate=11:26:11.
v timesPerDay The number of times that you want the schedule to run in a day. An example of this
option is timesPerDay=4.
v timeZone Use this parameter to define the time zone in which the storage subsystem is operating.
You can define the time zone in one of two ways:
GMTHH:MM The time zone offset from GMT. Enter the offset in hours and minutes. For example
GMT-06:00 is the central time zone in the United States.
Text string Standard time zone text strings. For example: "USA/Chicago" or "Germany/Berlin". Time
zone text strings s are case sensitive. If you enter an incorrect text string, GMT time is used. Enclose
the text string in double quotation marks.
If you also use the scheduleInterval option, the firmware will choose between the timesPerDay option
and the scheduleInterval option by selecting the lowest value of the two options. The firmware
calculates an integer value for the scheduleInterval option by dividing 1440 by a the scheduleInterval
option value that you set. For example, 1440/180 = 8. The firmware then compares the timesPerDay
integer value with the calculated scheduleInterval integer value and uses the smaller value.
To remove a schedule, use the delete logicaldrive command with the schedule parameter. The delete
logicaldrive command with the schedule parameter deletes only the schedule, not the FlashCopy logical
drive.
Related Topic
Naming Conventions
Create Host
This command creates a new host. If you do not specify a host group in which to create the new host, the
new host is created in the Default Group.
Syntax
create host userLabel=hostName
[hostGroup=(hostGroupName | defaultGroup)]
[hostType=(hostTypeIndexLabel | hostTypeIndexNumber)]
Parameters
Parameter Description
userLabel The name that you want to give the host that you are creating.
Enclose the host name in double quotation marks ( ).
Notes
You can use any combination of alphanumeric characters, hyphens, and underscores for the names.
Names can have a maximum of 30 characters.
A host is a computer that is attached to the storage subsystem and accesses the logical drives on the
storage subsystem through its HBA host ports. You can define specific logical drive-to-LUN mappings to
an individual host. You also can assign the host to a host group that shares access to one or more logical
drives.
A host group is an optional topological element that you can define if you want to designate a collection
of hosts that share access to the same logical drives. The host group is a logical entity. Define a host
group only if you have two or more hosts that share access to the same logical drives.
If you do not specify a host group in which to place the host that you are creating, the newly defined
host belongs to the default host group.
Related Topic
Naming Conventions
Syntax
create hostGroup userLabel=hostGroupName
Parameter
Parameter Description
userLabel The name that you want to give the host group that
you are creating. Enclose the host name in double
quotation marks ( ).
Notes
A host group is an optional topological element that you can define if you want to designate a collection
of hosts that share access to the same logical drives. The host group is a logical entity. Define a host
group only if you have two or more hosts that can share access to the same logical drives.
3-80 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
You can use any combination of alphanumeric characters, hyphens, and underscores for the names.
Names can have a maximum of 30 characters.
Related Topic
Naming Conventions
Syntax
create hostPort identifier=(wwID | gid)
userLabel=portLabel
host=hostName interfaceType=(FC | SAS | IB)
Parameters
Parameter Description
identifier The 8-byte World Wide Identifier (WWID) or the 16-byte
group identifier (GID) of the HBA or HCA host port.
Enclose the unique ID in double quotation marks ( ).
userLabel The name that you want to give to the new HBA or HCA
host port. Enclose the HBA host port label in double
quotation marks ( ).
host The name of the host for which you are defining an HBA or
HCA host port. Enclose the host name in double quotation
marks ( ).
interfaceType The identifier of the type of interface for the host port. The
choices are:
v FC Fibre Channel
v SAS Serial-Attached SCSI
v IB Infiniband
Notes
An HBA or HCA host port is a physical connection on a host adapter that resides within a host computer.
An HBA or HCA host port provides access to the logical drives in a storage subsystem. If the host bus
adapter has only one physical connection (one host port), the terms host port and host bus adapter are
synonymous.
You can use any combination of alphanumeric characters, hyphens, and underscores for the names. Host
names can have a maximum of 30 characters.
Naming Conventions
Syntax
create iscsiInitiator iscsiName=iSCSI-ID
userLabel=name
host=host-name
[chapSecret=securityKey]
Parameters
Parameters Description
iscsiName The default identifier of the iSCSI initiator. Enclose the name in
double quotation marks ( ).
userLabel The name that you want to use for the iSCSI initiator. Enclose
the name in double quotation marks ( ).
host The name of the host in which the iSCSI initiator is installed.
Enclose the name in double quotation marks ( ).
chapSecret The security key that you want to use to authenticate a peer
connection. Enclose the name in double quotation marks ( ).
Notes
Challenge Handshake Authentication Protocol (CHAP) is a protocol that authenticates the peer of a
connection. CHAP is based upon the peers sharing a secret. A secret is a security key that is similar to
a password.
Use the chapSecret parameter to set up the security keys for initiators that require a mutual
authentication.
Related Topic
Naming Conventions
Syntax
Important: If you have disk drives with different capacities, you cannot automatically create logical
drives by specifying the driveCount parameter. If you want to create logical drives with disk drives of
different capacities, see Create RAID Logical Drive (Manual Drive Select) on page 3-88.
create logicalDrive driveCount=numberOfDrives
arrayUserLabel=arrayName
raidLevel=(0 | 1 | 3 | 5 | 6)
userLabel=logicalDriveName
DriveType=(fibre | SATA | SAS)
DriveMediaType=(HDD | SSD | unknown | allMedia)
3-82 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
capacity=logicalDriveCapacity
owner=(a | b)
cacheReadPrefetch=(TRUE | FALSE)
segmentSize=segmentSizeValue
usageHint=(fileSystem | dataBase | multiMedia)
enclosureLossProtect=(TRUE | FALSE)
enclosureLossProtect=(TRUE | FALSE)
drawerLossProtect=(TRUE | FALSE)
dssPreAllocate=(TRUE | FALSE)]
securityType=(none | capable | enabled)]
T10PI=(none | enabled)]
Parameters
Parameter Description
driveCount The number of unassigned disk drives that you want to use in the array.
arrayUserLabel The alphanumeric identifier (including and _) that you want to give the new array.
Enclose the new array name in double quotation marks (" ").
raidLevel The RAID level of the array that contains the logical drive. Valid values are 0, 1, 3, 5,
or 6.
userLabel The name that you want to give to the new logical drivev . Enclose the new logical
drive name in double quotation marks ( ).
driveType The type of disk drive that you want to use in the logical drive. You cannot mix disk
drive types. Valid disk drive types are fibre, SATA, or SAS.
DriveMediaType The type of disk drive medium that you want to use for the create RAID logical
drive. Values are
v HDD Use this option when you have hard disk drives in the expansion drawer.
v SSD Use this option when you have solid state disk drives in the expansion
drawer.
v unknown Use if you are not sure what types of disk drive media are in the
expansion drawer.
v allMedia Use this option when you want to use all types of disk drive media that
are in the expansion drawer.
Use this parameter only when you use the DriveCount parameter. If you have only
one type of disk drive media, you do not need to use this parameter. You must use
this parameter when you have more than one type of disk drive media in your
storage subsystem.
driveType The type of drive that you want to use in the logical drive. You cannot mix drive
types.
You must use this parameter when you have more than one type of drive in your
storage subsystem.
Notes
The driveCount parameter lets you choose the number of disk drives that you want to use in the array.
You do not need to specify the disk drives by enclosure ID and slot ID. The controllers choose the
specific disk drives to use for the array.
The owner parameter defines which controller owns the logical drive.
If you do not specify a capacity using the capacity parameter, all of the disk drive capacity that is
available in the array is used. If you do not specify capacity units, bytes is used as the default value.
Cache read prefetch lets the controller copy additional data blocks into cache while the controller reads
and copies data blocks that are requested by the host from the disk drives into cache. This action
increases the chance that a future request for data can be fulfilled from cache. Cache read prefetch is
important for multimedia applications that use sequential data transfers. The configuration settings for
the storage subsystem that you use determine the number of additional data blocks that the controller
reads into cache. Valid values for the cacheReadPrefetch parameter are TRUE or FALSE.
3-84 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Segment Size
The size of a segment determines how many data blocks that the controller writes on a single disk drive
in a logical drive before writing data on the next disk drive. Each data block stores 512 bytes of data. A
data block is the smallest unit of storage. The size of a segment determines how many data blocks that it
contains. For example, an 8-KB segment holds 16 data blocks. A 64-KB segment holds 128 data blocks.
When you enter a value for the segment size, the value is checked against the supported values that are
provided by the controller at run time. If the value that you entered is not valid, the controller returns a
list of valid values. Using a single disk drive for a single request leaves other disk drives available to
simultaneously service other requests.
If the logical drive is in an environment where a single user is transferring large units of data (such as
multimedia), performance is maximized when a single data transfer request is serviced with a single data
stripe. (A data stripe is the segment size that is multiplied by the number of disk drives in the array that
are used for data transfers.) In this case, multiple disk drives are used for the same request, but each disk
drive is accessed only once.
For optimal performance in a multiuser database or file system storage environment, set your segment
size to minimize the number of disk drives that are required to satisfy a data transfer request.
You do not need to enter a value for the cacheReadPrefetch parameter or the segmentSize parameter. If
you do not enter a value, the controller firmware uses the usageHint parameter with fileSystem as the
default value. Entering a value for the usageHint parameter and a value for the cacheReadPrefetch
parameter or a value for the segmentSize parameter does not cause an error. The value that you enter for
the cacheReadPrefetch parameter or the segmentSize parameter takes priority over the value for the
usageHint parameter.
For enclosure loss protection to work, each disk drive in an array must be on a separate enclosure. If you
set the enclosureLossProtect parameter to TRUE and have selected more than one disk drive from any
one enclosure, the storage subsystem returns an error. If you set the enclosureLossProtect parameter to
FALSE, the storage subsystem performs operations, but the array that you create might not have enclosure
loss protection.
Enclosure loss protection is not valid when you create logical drives on existing arrays.
The drawerLossProtect parameter defines if data on a logical drive is accessible if a drawer fails. When
you assign the drives, if you set the drawerLossProtect parameter to TRUE and select more than one drive
from any one drawer, the storage subsystem returns an error. If you set the drawerLossProtect parameter
to FALSE, the storage subsystem performs operations, but the array that you create might not have drawer
loss protection.
You must set the enclosureLossProtect parameter and the drawerLossProtect parameter to the same
value. Both of the parameters must be either TRUE or FALSE. If the enclosureLossProtect parameter and
the drawerLossProtect parameter are set to different values, the storage subsystem returns an error.
Security Type
See Security Type on page 4-33 for an explanation of this new parameter.
Related Topic
Naming Conventions
Syntax
create logicalDrive array="arrayNumber"
userLabel=logicalDriveName
[freeCapacityArea=freeCapacityIndexNumber
capacity=logicalDriveCapacity
owner=(a | b)
cacheReadPrefetch=(TRUE | FALSE)
segmentSize=segmentSizeValue
usageHint=(fileSystem | dataBase | multiMedia)
[dssPreAllocate=(TRUE | FALSE)
securityType=(none | capable | enabled)
T10PI=(none | enabled)]
Parameters
Parameter Description
array The alphanumeric identifier (including - and _) for a
specific array in your storage subsystem.
userLabel The name that you want to give the new logical drive.
Enclose the new logical drive name in double quotation
marks ( ).
freeCapacityArea The index number of the free space in an existing array
that you want to use to create the new logical drive. Free
capacity is defined as the free capacity between existing
logical drives in an array. For example, an array might
have the following areas: logical drive 1, free capacity,
logical drive 2, free capacity, logical drive 3, free capacity.
To use the free capacity following logical drive 2, you
would specify:
freeCapacityArea=2
3-86 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Parameter Description
usageHint The settings for both the cacheReadPrefetch parameter
and the segmentSize parameter to be default values. The
default values are based on the typical I/O usage pattern
of the application that is using the logical drive. Valid
values are fileSystem, dataBase, or multiMedia.
dssPreAllocate The setting to make sure that reserve capacity is
allocated for future segment size increases. The default
value is TRUE.
securityType The setting to specify the security level when creating
the array and all associated logical drives. These settings
are valid:
v noneThe array and logical drives are not secure.
v capableThe array and logical drives are capable of
having security set, but security has not been enabled.
v enabledThe array and logical drives have security
enabled.
T10PI The setting to specify that an array, and the logical drives
within the array, has T10 PI (Protection Information)
protection to make sure that the data maintains its
integrity. When you use this parameter, only protected
drives can be used for the array. These settings are valid:
v none The array does not have T10 PI (Protection
Information) protection.
v enabled The array has T10 PI (Protection
Information) protection. The array supports protected
information and is formatted with protection
information enabled.
Notes
You can use any combination of alphanumeric characters, hyphens, and underscores for the names.
Names can have a maximum of 30 characters.
The owner parameter defines which controller owns the logical drive. The preferred controller ownership
of a logical drive is the controller that currently owns the array.
If you do not specify a capacity using the capacity parameter, all of the available capacity in the free
capacity area of the array is used. If you do not specify capacity units, bytes is used as the default value.
Segment Size
The size of a segment determines how many data blocks that the controller writes on a single disk drive
in a logical drive before writing data on the next disk drive. Each data block stores 512 bytes of data. A
data block is the smallest unit of storage. The size of a segment determines how many data blocks that it
contains. For example, an 8-KB segment holds 16 data blocks. A 64-KB segment holds 128 data blocks.
When you enter a value for the segment size, the value is checked against the supported values that are
provided by the controller at run time. If the value that you entered is not valid, the controller returns a
list of valid values. Using a single disk drive for a single request leaves other disk drives available to
simultaneously service other requests.
If the logical drive is in an environment where a single user is transferring large units of data (such as
multimedia), performance is maximized when a single data transfer request is serviced with a single data
For optimal performance in a multiuser database or file system storage environment, set your segment
size to minimize the number of disk drives that are required to satisfy a data transfer request.
Cache read prefetch lets the controller copy additional data blocks into cache while the controller reads
and copies data blocks that are requested by the host from the disk drives into cache. This action
increases the chance that a future request for data can be fulfilled from cache. Cache read prefetch is
important for multimedia applications that use sequential data transfers. The configuration settings for
the storage subsystem that you use determine the number of additional data blocks that the controller
reads into cache. Valid values for the cacheReadPrefetch parameter are TRUE or FALSE. You do not need to
enter a value for the cacheReadPrefetch parameter or the segmentSize parameter. If you do not enter a
value, the controller firmware uses the usageHint parameter with fileSystem as the default value.
Entering a value for the usageHint parameter and a value for the cacheReadPrefetch parameter or a
value for the segmentSize parameter does not cause an error. The value that you enter for the
cacheReadPrefetch parameter or the segmentSize parameter takes priority over the value for the
usageHint parameter.
Security Type
The securityType parameter is valid for drives that are capable of full disk encryption (FDE). With FDE,
the controller firmware can create a key and activate the drive security feature. The drive security feature
encrypts data as the data is written to the drive and decrypts the data as the data is read from the drive.
Without the key created by the controller, the data written to the drive is inaccessible.
Before you can set the securityType parameter to capable or enabled, you must create a storage
subsystem security key. Use the create storageSubsystem securityKey command to create a storage
subsystem security key. These commands are related to the security key:
v create storageSubsystem securityKey
v set storageSubsystem securityKey
v import storageSubsystem securityKey
v export storageSubsystem securityKey
v start secureErase (drive | drives)
v enable array [arrayName] security
v create hostPort identifier
Related Topic
Naming Conventions
Important: You cannot use mixed disk drive types in the same array and logical drive. This command
fails if you specify different types of disk drives for the RAID logical drive.
3-88 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Syntax
create logicalDrive drives=(enclosureID1,drawerID1,slotID1 ... enclosureIDn,
drawerIDn,slotIDn)
[array=[arrayName]]
raidLevel=(0 | 1 | 3 | 5 | 6)
userLabel="logicalDriveName"
owner=(a | b)
[capacity=logicalDriveCapacity
cacheReadPrefetch=(TRUE | FALSE)
segmentSize=segmentSizeValue
usageHint=(fileSystem | dataBase | multiMedia)
enclosureLossProtect=(TRUE | FALSE)
drawerLossProtect=(TRUE | FALSE)
dssPreAllocate=(TRUE | FALSE)
securityType=(none | capable | enabled)]
T10PI=(none | enabled)]
Parameters
Parameter Description
drives The disk drives that you want to assign to the logical
drive. EnclosureID1, drawerID1, slotID1 ...
enclosureIDn, drawerIDn, slotIDn is for enclosures
with multiple disk drive drawers. For enclosures
without disk drive drawers, use enclosureID1, slotID1
... enclosureIDn, slotIDn instead. Enclosure ID values
are 0 to 99. Drawer ID values are 1 to 5. Slot ID values
are 1 to 32. Enclose the values in parentheses.
arrayUserLabel The alphanumeric identifier (including and _) that
you want to give the new array. Enclose the array
identifier in double quotation marks (" ").
raidLevel The RAID level of the array that contains the logical
drive. Valid values are 0, 1, 3, 5, or 6.
userLabel The name that you want to give the new logical drive.
Enclose the new logical drive name in double quotation
marks ( ?).
capacity The size of the logical drive that you are adding to the
storage subsystem. Size is defined in units of bytes, KB,
MB, GB, or TB.
owner The controller that owns the logical drive. Valid
controller identifiers are a or b, where a is the
controller in slot A, and b is the controller in slot B. If
you do not specify an owner, the controller firmware
determines the owner.
cacheReadPrefetch The setting to turn on or turn off cache read prefetch.
To turn off cache read prefetch, set this parameter to
FALSE. To turn on cache read prefetch, set this
parameter to TRUE.
segmentSize The amount of data (in KB) that the controller writes
on a single disk drive in a logical drive before writing
data on the next disk drive. Valid values are 8, 16, 32,
64, 128, 256, or 512.
usageHint The settings for both the cachReadPrefetch parameter
and the segmentSize parameter to be default values.
The default values are based on the typical I/O usage
pattern of the application that is using the logical drive.
Valid values are fileSystem, dataBase, or multiMedia.
Notes
The drives parameter supports both high-capacity drive expansion enclosures and low-capacity drive
expansion enclosures. A high-capacity drive expansion enclosure has drawers that hold the drives. The
drawers slide out of the drive expansion enclosure to provide access to the drives. A low-capacity drive
expansion enclosure does not have drawers. For a high-capacity drive expansion enclosure, you must
specify the identifier (ID) of the drive expansion enclosure, the ID of the drawer, and the ID of the slot in
which a drive resides. For a low-capacity drive expansion enclosure, you need only specify the ID of the
drive expansion enclosure and the ID of the slot in which a drive resides. For a low-capacity drive
expansion enclosure, an alternative method for identifying a location for a drive is to specify the ID of
the drive expansion enclosure, set the ID of the drawer to 0, and specify the ID of the slot in which a
drive resides.
If you set the raidLevel parameter to RAID 1, the controller firmware takes the list of drives and pairs
them by using this algorithm:
Data drive = X
Parity drive = N/2 + X
3-90 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
In this algorithm X is 1 to N/2, and N is the number of drives in the list. For example, if you have six
drives, the mirror pairs are as follows:
Data Parity
1 N/2 + 1 = 4
2 N/2 + 2 = 5
3 N/2 + 3 = 6
You can use any combination of alphanumeric characters, hyphens, and underscores for the names.
Names can have a maximum of 30 characters.
The owner parameter defines which controller owns the logical drive. The preferred controller ownership
of a logical drive is the controller that currently owns the array.
If you do not specify a capacity using the capacity parameter, all of the disk drive capacity that is
available in the array is used. If you do not specify capacity units, bytes is used as the default value.
Segment Size
The size of a segment determines how many data blocks that the controller writes on a single disk drive
in a logical drive before writing data on the next disk drive. Each data block stores 512 bytes of data. A
data block is the smallest unit of storage. The size of a segment determines how many data blocks that it
contains. For example, an 8-KB segment holds 16 data blocks. A 64-KB segment holds 128 data blocks.
When you enter a value for the segment size, the value is checked against the supported values that are
provided by the controller at run time. If the value that you entered is not valid, the controller returns a
list of valid values. Using a single disk drive for a single request leaves other disk drives available to
simultaneously service other requests.
If the logical drive is in an environment where a single user is transferring large units of data (such as
multimedia), performance is maximized when a single data transfer request is serviced with a single data
stripe. (A data stripe is the segment size that is multiplied by the number of disk drives in the array that
are used for data transfers.) In this case, multiple disk drives are used for the same request, but each disk
drive is accessed only once.
For optimal performance in a multiuser database or file system storage environment, set your segment
size to minimize the number of disk drives that are required to satisfy a data transfer request.
Cache read prefetch lets the controller copy additional data blocks into cache while the controller reads
and copies data blocks that are requested by the host from the disk drive into cache. This action increases
the chance that a future request for data can be fulfilled from cache. Cache read prefetch is important for
multimedia applications that use sequential data transfers. The configuration settings for the storage
subsystem that you use determine the number of additional data blocks that the controller reads into
cache. Valid values for the cacheReadPrefetch parameter are TRUE or FALSE.
You do not need to enter a value for the cacheReadPrefetch parameter or the segmentSize parameter. If
you do not enter a value, the controller firmware uses the usageHint parameter with fileSystem as the
default value. Entering a value for the usageHint parameter and a value for the cacheReadPrefetch
parameter or a value for the segmentSize parameter does not cause an error. The value that you enter for
the cacheReadPrefetch parameter or the segmentSize parameter takes priority over the value for the
usageHint parameter.
For enclosure loss protection to work, each drive in an array must be on a separate enclosure. If you set
the enclosureLossProtect parameter to TRUE and have selected more than one drive from any one
enclosure, the storage subsystem returns an error. If you set the enclosureLossProtect parameter to
FALSE, the storage subsystem performs operations, but the array that you create might not have enclosure
loss protection.
Enclosure loss protection is not valid when you create logical drives on existing arrays.
The drawerLossProtect parameter defines if data on a logical drive is accessible if a drawer fails. When
you assign the drives, if you set the drawerLossProtect parameter to TRUE and select more than one drive
from any one drawer, the storage subsystem returns an error. If you set the drawerLossProtect parameter
to FALSE, the storage subsystem performs operations, but the array that you create might not have drawer
loss protection
You must set the enclosureLossProtect parameter and the drawerLossProtect parameter to the same
value. Both of the parameters must be either TRUE or FALSE. If the enclosureLossProtect parameter and
the drawerLossProtect parameter are set to different values, the storage subsystem returns an error.
Security Type
The securityType parameter is valid for drives that are capable of full disk encryption (FDE). With FDE,
the controller firmware can create a key and activate the drive security feature. The drive security feature
encrypts data as the data is written to the drive and decrypts the data as the data is read from the drive.
Without the key created by the controller, the data written to the drive is inaccessible
Before you can set the securityType parameter to capable or enabled, you must create a storage
subsystem security key. Use the create storageSubsystem securityKey command to create a storage
subsystem security key. These commands are related to the security key:
v create storageSubsystem securityKey
v enable array [arrayName] security
v export storageSubsystem securityKey
v import storageSubsystem securityKey
v set storageSubsystem securityKey
v start secureErase (drive | drives)
Related Topic
Naming Conventions
3-92 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Note: Some parameters for creating a standard RAID logical drive on an array are not compatible for
creating logical drives of any type on a disk pool. When using older scripts to create logical drives on
disk pools, make sure that all of the parameters are valid for disk pools. Invalid parameters prevent the
scripts from running correctly and cause an error to be posted.
Parameter
Parameter Description
diskPool The name of the disk pool on which to create the new
logical drive. Enclose the disk pool name in double
quotation marks (" ").
userLabel The name that you want to give the new logical drive.
Enclose the logical drive name in double quotation
marks (" ").
capacity The size of the logical drive that you are creating.
Notes
Each logical drive name must be unique. You can use any combination of alphanumeric characters,
underscore (_), hyphen(-), and pound (#) for the user label. User labels can have a maximum of 30
characters.
3-94 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
For thin logical drives, the capacity value specifies the virtual capacity of the logical drive, and the
repositoryCapacity specifies the capacity of the logical drive created as the repository logical drive. Use the
existingRepositoryLabel to specific an existing unused repository logical drive instead of creating a new
logical drive.
For best results when creating a thin logical drive, the repository logical drive must already exist or must
be created in an already existing disk pool. If you do not specify some of the optional parameters when
creating thin logical drives the storage management software will attempt to create the repository logical
drive. The most desirable candidate logical drive is a repository logical drive that already exists and that
is within the size requirements. The next most desirable candidate logical drive is a new repository
logical drive that is created on the disk pool free extent.
Repository logical drives for thin logical drives cannot be created on arrays.
Note: You cannot use this command for an Enhanced FlashCopy image that is used in online logical
drive copy.
Syntax
create enhancedFlashCopyLogicalDrive userLabel="enhancedFlashCopyLogicalDriveName"
enhancedFlashCopyImageID="enhancedFlashCopyImageID"
readOnly
Parameter
Parameter Description
userLabel The name that you want to give to an Enhanced
FlashCopy logical drive. Enclose the Enhanced
FlashCopy logical drive name in double quotation marks
(" ").
Notes
You can use any combination of alphanumeric characters, underscore (_), hyphen (-), and pound (#) for
the names. Names can have a maximum of 30 characters.
The identifier of an Enhanced FlashCopy image has two parts separated by a colon (:):
v The name of the Enhanced FlashCopy group
v The identifier of the Enhanced FlashCopy image
For example, if you want to create a read only logical drive named engData1 using the most recent
Enhanced FlashCopy image in an Enhanced FlashCopy group that has the name
enhancedFlashCopyGroup1, you would use this command:
create enhancedFlashCopyLogicalDrive userLabel="engData1"
enhancedFlashCopyImageID="enhancedFlashCopyGroup1:newest" readOnly;
3-96 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Syntax
create remoteMirror primary=primaryLogicalDriveName
secondary=secondaryLogicalDriveName
(remoteStorageSubsystemName=storageSubsystemName |
remoteStorageSubsystemWwn=wwID)
[remotePassword=password
syncPriority=(highest | high | medium | low | lowest)
autoResync=(enabled | disabled)
writeOrder=(preserved | notPreserved)
writeMode=(synchronous | asynchronous)]
Parameters
Parameter Description
primary The name of an existing logical drive on the local
storage subsystem that you want to use for the
primary logical drive. Enclose the primary logical
drive name in double quotation marks ( ).
secondary The name of an existing logical drive on the remote
storage subsystem that you want to use for the
secondary logical drive. Enclose the secondary
logical drive name in double quotation marks ( ).
remoteStorageSubsystemName The name of the remote storage subsystem. Enclose
the remote storage subsystem name in double
quotation marks ( ).
remoteStorageSubsystemWwn The WWID of the remote storage subsystem. Enclose
the WWID in double quotation marks ( ).
remotePassword The password for the remote storage subsystem. Use
this parameter when the remote storage subsystem
is password protected. Enclose the password in
double quotation marks ( ).
syncPriority The priority that full synchronization has relative to
host I/O activity. Valid values are highest, high,
medium, low, or lowest.
autoResync The settings for automatic resynchronization
between the primary logical drives and the
secondary logical drives of a remote-mirror pair.
This parameter has the following values:
v enabled Automatic resynchronization is turned
on. You do not need to do anything further to
resynchronize the primary logical drive and the
secondary logical drive.
v disabled Automatic resynchronization is turned
off. To resynchronize the primary logical drives
and the secondary logical drive, you must run the
resume remoteMirror command.
writeOrder The write order for data transmission between the
primary logical drive and the secondary logical
drive. Valid values are preserved or notPreserved.
writeMode How the primary logical drive writes to the
secondary logical drive. Valid values are
synchronous or asynchronous.
You can use any combination of alphanumeric characters, hyphens, and underscores for the names.
Names can have a maximum of 30 characters.
When you choose the primary logical drive and the secondary logical drive, the secondary logical drive
must be of equal or greater size than the primary logical drive. The RAID level of the secondary logical
drive does not have to be the same as the primary logical drive.
Product shipments using the DS4800 (Models 82, 84, 88) or DS5100, DS5300 controller define a maximum
of 128 remote mirrors. The DS4700 Model 70 and DS4700 Model 72 controllers can define a maximum of
64 remote mirrors.
Passwords are stored on each storage subsystem in a management domain. If a password was not
previously set, you do not need a password. The password can be any combination of a alphanumeric
characters with a maximum of 30 characters. (You can define a storage subsystem password by using the
set storageSubsystem command.)
Synchronization priority defines the amount of system resources that are used to synchronize the data
between the primary logical drive and the secondary logical drive of a mirror relationship. If you select
the highest priority level, the data synchronization uses the most system resources to perform the full
synchronization, which decreases performance for host data transfers.
The writeOrder parameter applies only to asynchronous mirrors and makes them become part of a
consistency group. Setting the writeOrder parameter to preserved causes the remote-mirror pair to
transmit data from the primary logical drive to the secondary logical drive in the same order as the host
writes to the primary logical drive. In the event of a transmission link failure, the data is buffered until a
full synchronization can occur. This action can require additional system overhead to maintain the
buffered data, which slows operations. Setting the writeOrder parameter to notPreserved frees the system
from having to maintain data in a buffer, but it requires forcing a full synchronization to make sure that
the secondary logical drive has the same data as the primary logical drive.
This command creates a new security key for a storage subsystem that has Full Disk Encryption drives.
This command also sets the security definitions and sets the state to Security Enabled.
create storageSubsystem securityKey
[keyIdentifier=keyIdentifierString] |
passPhrase=passPhraseString |
file=fileName |
commitSecurityKey=(TRUE | FALSE)
Parameters
Parameter Description
keyIdentifier The character string that combines the storage subsystem ID and
a randomly generated string to produce the security key
identifier.
passPhrase The character string that wraps the security key identifier with a
pass phrase that is 8 to 32 characters in length. You must use at
least one number, one lowercase letter, one uppercase letter, and
one non-alphanumeric character (a space is not permitted).
3-98 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Parameter Description
file The name of the file to which you save the security key identifier.
Enclose the file name in double quotes (" ").
Note: Add a file extension of .slk to the end of the file name.
commitSecurityKey This parameter commits the security key identifier to the storage
subsystem for all FDE drives as well as the controllers. After the
security key identifier is committed, a key is required to read data
or write data. The data can only be read or changed by using a
key, and the drive can never be used in a non-secure mode
without rendering the data useless or totally erasing the drive.
Notes
The controller firmware creates a lock that restricts access to the FDE drives. FDE drives have a state
called Security Capable. When you create a security key, the state is set to Security Enabled, which
restricts access to all FDE drives that exist within the storage subsystem.
You can have a storage subsystem configuration with more than one set of encrypted arrays or disk
pools. Each array or disk pool can have a unique security key. The character string generated by the
keyIdentifier parameter is a string that you can read and that enables you to identify the security key
that you need. You can create a keyIdentifer by using one of these methods:
You can enter up to 189 alphanumeric characters for a key identifier. The key identifier cannot have these
characters:
v White spaces
v Punctuation
v Symbols
If you do not enter the keyIdentifer parameter, the controller automatically generates the keyIdentifer
parameter.
Additional characters are automatically generated and appended to the end of the string that you enter
for the key identifier. If you do not enter any string for the keyIdentifier parameter, the key identifier
consists of only the characters that are automatically generated.
Note: If your pass phrase does not meet these criteria, you will receive an error message and will be
asked to retry the command.
Attention: Starting a VolumeCopy operation overwrites all existing data on the target logical drive,
makes the target logical drive read-only to hosts, and fails all FlashCopy logical drives associated with
the target logical drive, if any exist. If you have used the target logical drive as a copy before, be sure
you no longer need the data or have it backed up.
If you use VolumeCopy without FlashCopy you cannot write to the source logical drive until the copy
operation is complete. If you want to be able to write to the source logical drive before the copy
operation is complete, use VolumeCopy with FlashCopy . You can select VolumeCopy with FlashCopy
through the optional parameters in the command syntax.
After completion of the VolumeCopy with FlashCopy operation, the FlashCopy is disabled.
Note: You can have a maximum of eight VolumeCopies in progress at one time. If you try to create more
than eight VolumeCopies at one time, the controllers return a status of Pending until one of the
VolumeCopies that is in progress finishes and returns a status of Complete
Syntax
create volumeCopy source="sourceName"
target="targetName"
[copyPriority=(highest | high | medium | low | lowest)
targetReadOnlyEnabled=(TRUE | FALSE)
copyType=(offline | online)
repositoryPercentOfBase=(20 | 40 | 60 | 120 | default) |
repositoryGroupPreference=(sameAsSource | otherThanSource | default)]
Parameters
Parameter Description
source The name of an existing logical drive that you want to
use as the source logical drive. Enclose the source
logical drive name in double quotation marks ( ).
target The name of an existing logical drive that you want to
use as the target logical drive. Enclose the target logical
drive name in double quotation marks ( ).
copyPriority The priority that VolumeCopy has relative to host I/O
activity. Valid values are highest, high, medium, low, or
lowest.
targetReadOnlyEnabled The setting so that you can write to the target logical
drive or only read from the target logical drive. To
write to the target logical drive, set this parameter to
FALSE. To prevent writing to the target logical drive, set
this parameter to TRUE.
3-100 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Parameter Description
copyType Use this parameter to create a VolumeCopy with a
FlashCopy . Creating a VolumeCopy with a FlashCopy
enables you to continue to write to the source logical
drive while creating the VolumeCopy. To create a
VolumeCopy with a FlashCopy, set this parameter to
online. To create a VolumeCopy without a FlashCopy,
set this parameter to offline.
Notes
You can use any combination of alphanumeric characters, hyphens, and underscores for the names.
Names can have a maximum of 30 characters.
Copy priority defines the amount of system resources that are used to copy the data between the source
logical drive and the target logical drive of a VolumeCopy pair. If you select the highest priority level, the
VolumeCopy uses the most system resources to perform VolumeCopy, which decreases performance for
host data transfers.
Parameters
None.
Delete Array
This command deletes an entire array and its associated logical drives.
Attention: Possible damage to the storage subsystem configuration All of the data in the array is
lost as soon as you run this command.
Syntax
delete array [arrayName]
Parameter
Parameter Description
array The alphanumeric identifier (including - and _) of the
array that you want to delete. Enclose the array identifier
in square brackets ([ ]).
Syntax
delete consistencyGroup [enhancedFlashCopyConsistencyGroupName
[deleteRepositoryMembers=(TRUE | FALSE)]]
Parameter
Parameter Description
enhancedFlashCopyConsistencyGroup The name of the Enhanced FlashCopy consistency group
that you want to delete. Enclose the Enhanced FlashCopy
consistency group name in square brackets ([ ]). If the
Enhanced FlashCopy consistency group name has special
characters, you also must enclose the Enhanced
FlashCopy consistency group name in double quotation
marks (" ").
deleteRepositoryMembers The setting to delete on or retain the repository logical
drives. To delete the repository logical drives, set this
parameter to TRUE. To retain the repository logical drives,
set this parameter to FALSE. The default setting is FALSE.
3-102 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Delete Consistency Group Enhanced FlashCopy Logical Drive
This command deletes the Enhanced FlashCopy logical drive of a consistency group. Optionally, you can
also delete the repository members.
Syntax
delete cgEnhancedFlashCopyLogicalDrive ["enhancedFlashCopyLogicalDriveName"]
[deleteRepositoryMembers=(TRUE | FALSE)]
Parameter
Parameter Description
cgEnhancedFlashCopyLogicalDrive The name of the consistency group Enhanced FlashCopy
logical drive that you want to delete. Enclose the name
of the consistency group Enhanced FlashCopy logical
drive in double quotation marks (" ") inside square
brackets ([ ]).
deleteRepositoryMembers The parameter to save or delete the member logical
drives. To save the member logical drives, set this
parameter to TRUE. To delete the member logical drives,
set this parameter to FALSE. The default value is TRUE.
Syntax
delete cgEnhancedFlashCopyImage consistencyGroup="consistencyGroupName"
[(deleteCount=numberOfEnhancedFlashCopyImages |
retainCount=numberOfEnhancedFlashCopyImages) |
ignoreEnhancedFlashCopyLogicalDrive=(TRUE | FALSE)
Parameters
Parameter Description
consistencyGroup The name of the consistency group from which you want
to delete the Enhanced FlashCopy images. Enclose the
consistency group name in double quotation marks (" ").
deleteCount The number of Enhanced FlashCopy images that you
want to delete from the consistency group. Use integer
values.
Notes
If the Enhanced FlashCopy images cannot be deleted for all of the relevant consistency groups, the
operation fails and none of the Enhanced FlashCopy images are deleted.
When you delete a consistency group Enhanced FlashCopy image that is associated with a consistency
group Enhanced FlashCopy logical drive, the corresponding Enhanced FlashCopy logical drive member
in the consistency group Enhanced FlashCopy logical drive are transitioned to the Stopped state. An
Enhanced FlashCopy logical drive member in the Stopped state no longer has a relationship to the
Enhanced FlashCopy group of the deleted Enhanced FlashCopy image. However, an Enhanced
FlashCopy logical drive member in the Stopped state keeps its relationship to its consistency group
Enhanced FlashCopy logical drive.
Syntax
delete diskPool [diskPoolName] [force=(true | false))]
Parameter
Parameter Description
diskPoolName The name of the disk pool that you want to delete.
Enclose the disk pool name in square brackets ([ ]). If the
disk pool name has special characters, you also must
enclose the host group name in double quotation marks
(" ").
3-104 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Parameter Description
force Under normal operation, deleting a disk pool will
automatically delete the pool whether there are logical
drives present or not. The force parameter has special
meaning in the following cases: If the GlobalFeatureState.
DELETE_LOGICALDRIVE_RESTRICTION feature is present, and
the Preference Store key
DELETE_LOGICALDRIVE_RESTRICTIONS_KEY are both true,
then restrictions for deleting disk pools with logical
drives are in effect. If both conditions are true, and the
user has specified "force=true", then the disk pool will
be deleted even if it has logical drives. If both flags are
true, the disk pool has logical drives and the force flag
has not been specified, the operation will fail.
Notes
Each disk pool name must be unique. You can use any combination of alphanumeric characters,
underscore (_), hyphen(-), and pound (#) for the user label. User labels can have a maximum of 30
characters.
If the disk pool contains logical drives, the logical drives will be deleted along with the disk pool.
Attention: Possible damage to the storage subsystem configuration All of the data in the Enhanced
FlashCopy group is lost as soon as you run this command.
This command deletes an entire Enhanced FlashCopy group and optionally the associated member logical
drives.
Syntax
delete enhancedFlashCopyGroup ["enhancedFlashCopyGroupName"]
[deleteRepositoryMembers=(TRUE | FALSE)
Parameters
Parameter Description
enhancedFlashCopyGroup The alphanumeric identifier (including -and _) of the
Enhanced FlashCopy group that you want to delete.
Enclose the Enhanced FlashCopy group identifier in
double quotation marks (" ") inside square brackets ([ ]).
deleteRepositoryMembers The parameter to save or delete the member logical
drives. To save the member logical drives, set this
parameter to FALSE. To delete the member logical drives,
set this parameter to TRUE. The default value is FALSE.
Notes
You can delete an Enhanced FlashCopy group if it is empty or if it contains Enhanced FlashCopy images.
All of the Enhanced FlashCopy images in the Enhanced FlashCopy group are deleted along with the
Enhanced FlashCopy group. If any existing Enhanced FlashCopy image within the Enhanced FlashCopy
Chapter 3. Script Commands 3-105
group has an associated Enhanced FlashCopy logical drive, each Enhanced FlashCopy logical drive is
stopped and detached from the Enhanced FlashCopy image. When you delete an Enhanced FlashCopy
group the associated repository logical drive is also deleted. By default, all member logical drives in the
repository logical drive are retained as unused, unmapped standard logical drives. To remove the
member logical drives set the deleteRepositoryMembers parameter to TRUE, or do not use this parameter.
To keep the member logical drives, set the deleteRepositoryMembers parameter to FALSE.
Syntax
delete enhancedFlashCopyImage (enhancedFlashCopyGroup="enhancedFlashCopyGroupName" |
enhancedFlashCopyGroups=("enhancedFlashCopyGroupName1"... "enhancedFlashCopyGroupNamen"))
(deleteCount=numberOfEnhancedFlashCopyImages |
retainCount=numberOfEnhancedFlashCopyImages |
ignoreEnhancedFlashCopyLogicalDrive=(TRUE | FALSE) |
enhancedFlashCopyImageID=OLDEST)
Parameters
Parameter Description
enhancedFlashCopyGroup or enhancedFlashCopyGroups The name of the Enhanced FlashCopy group that has the
Enhanced FlashCopy image that you want to delete.
Enclose the name of the Enhanced FlashCopy group in
double quotation marks (" ").
3-106 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Parameter Description
retainCount The number of Enhanced FlashCopy images that you
want to keep in the Enhanced FlashCopy group. Use
integer values.
Notes
You can delete the oldest Enhanced FlashCopy image from an Enhanced FlashCopy group repository
logical drive. The definition of an Enhanced FlashCopy image that you delete is removed from the
system. The space occupied by the Enhanced FlashCopy image that you delete from the Enhanced
FlashCopy group repository logical drive is released and made available for reuse within the Enhanced
FlashCopy group.
Any Enhanced FlashCopy logical drives that exist for an Enhanced FlashCopy image transition to the
Stopped state when the Enhanced FlashCopy image is deleted.
This command will not run when the controller is in Lockdown mode.
Note: You cannot use this command for Enhanced FlashCopy images involved in online VolumeCopy.
Syntax
delete enhancedFlashCopyLogicalDrive ["enhancedFlashCopyLogicalDriveName"]
[deleteRepositoryMembers=(TRUE | FALSE)]
Attention: Possible damage to the storage subsystem configuration All of the data in the logical drive is
lost as soon as you run this command.
Syntax
delete (logicaldrive [logicaldriveName] |
logicaldrives [logicaldriveName1 ... logicaldriveNameN])
[schedule]
Parameters
Parameter Description
logicaldrive or logicaldrives The name of the FlashCopy logical drive that you want
to delete. You can enter more than one FlashCopy logical
drive name. Enclose the FlashCopy logical drive name in
square brackets ([ ]). If the FlashCopy logical drive name
has special characters, you also must enclose the
FlashCopy logical drive name in double quotation marks
(" ").
schedule This parameter deletes the schedule for a specific
FlashCopy logical drive. Only the schedule is deleted,
the FlashCopy logical drive remains.
Delete Host
This command deletes a host.
Syntax
delete host [hostName]
3-108 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Delete Host Group
This command deletes a host group.
Attention: Possible damage to the storage subsystem configuration This command deletes all of the
host definitions in the host group.
Syntax
delete hostGroup [hostGroupName]
Parameter
Parameter Description
hostGroup The name of the host group that you want to delete.
Enclose the host group name in square brackets ([ ]). If the
host group name has special characters, you also must
enclose the host group name in double quotation marks
( ).
Notes
A host group is an optional topological element that is a collection of hosts that share access to the same
logical drives. The host group is a logical entity.
Syntax
delete hostPort [hostPortName]
Parameter
Parameter Description
hostPort The name of the HBA host port that you want to delete.
Enclose the name of the HBA host port in square
brackets ([ ]).
Notes
An HBA host port is a physical connection on a host bus adapter that resides within a host computer. An
HBA host port provides a host access to the logical drives in a storage subsystem. If the host bus adapter
has only one physical connection (one host port), the terms HBA host port and host bus adapter are
synonymous.
Parameters
Parameter Description
iSCSI-ID The identifier of the iSCSI initiator that you want to delete.
Enclose the name in double quotation marks ( ).
name The name of the iSCSI initiator that you want to delete.
Enclose the name in double quotation marks ( ).
Attention: Possible damage to the storage subsystem configuration All of the data in the logical
drive is lost as soon as you run this command.
Syntax
delete (allLogicalDrives | logicalDrive [logicalDriveName] |
logicalDrives [logicalDriveName1 ... logicalDriveNameN])
removeArray=(TRUE | FALSE)
Parameters
Parameter Description
allLogicalDrives This parameter deletes all of the logical drives in a
storage subsystem.
logicalDrive or The name of the logical drive that you want to delete.
logicalDrives You can enter more than one logical drive name
separated by spaces. Enclose the logical drive name in
square brackets ([ ]). If the logical drive name has
special characters, you also must enclose the logical
drive name in double quotation marks ( ).
removeArray Deleting the last logical drive in an array does not
delete the array. You can have a stand-alone array
(minus any logical drives). To remove the stand-alone
array, set this parameter to TRUE. To keep stand-alone
arrays intact, set this parameter to FALSE.
Notes
When you use the allLogicalDrives parameter, this command deletes logical drives until all of the
logical drives are removed or until an error is encountered. If an error is encountered, this command does
not try to delete the remaining logical drives. Deleting logical drives from different arrays is possible. All
of the arrays that become empty are deleted if you set the removeArray parameter to TRUE.
If you want to delete an entire array, you can also use the delete array command.
3-110 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Delete Logical Drive on a Disk Pool
This command deletes either normal or thin logical drives on a disk pool.
Attention: Possible damage to the storage subsystem configuration All of the data in the logical drive is
lost as soon as you run this command.
Syntax
delete (allLogicalDrives |
logicaldrive [logicaldriveName] |
logicaldrives [logicaldriveName1 ... logicaldriveNameN] | allLogical drives)
[removeArray=(TRUE | FALSE)
force=(TRUE | FALSE)
schedule
retainRepositoryMembers=(TRUE | FALSE)]
Parameters
Parameter Description
allLogicalDrives This parameter deletes all of the logical drives on a disk
pool.
logicaldrive or logicaldrives The name of the logical drive that you want to delete.
You can enter more than one logical drive name. Enclose
the logical drive name in square brackets ([ ]). If the
logical drive name has special characters, you also must
enclose the logical drive name in double quotation marks
(" ").
removeArray Deleting the last logical drive in an array does not delete
the array. You can have a standalone array (minus any
logical drives). To remove the standalone array, set this
parameter to TRUE. To keep standalone arrays intact, set
this parameter to FALSE.
force Use this parameter to force the immediate deletion of a
logical drive even if the controllers are performing other
operations. To immediately force the deletion of a logical
drive, set this parameter to TRUE. To wait until the
controllers have finished performing other operations, do
not use this parameter or set this parameter to FALSE.
schedule
retainRepositoryMembers When you delete a thin logical drive, the associated
repository logical drive is deleted by default. However,
when the retainRepositoryMembers is set to TRUE, the
repository logical drive is retained. For normal logical
drives, this parameter has no effect.
Notes
When you use the allLogicalDrives parameter, this command deletes logical drives until all of the
logical drives are removed or until an error is encountered. If an error is encountered, this command does
not try to delete the remaining logical drives. Deleting logical drives from different arrays is possible. All
of the arrays that become empty are deleted if you set the removeArray parameter to TRUE.
Syntax
diagnose controller [(a | b)]
loopbackDriveChannel=(allchannels | (1 | 2 | 3 | 4 | 5 | 6 | 7 | 8))
testID=(1 | 2 | 3 | discreteLines)
[patternFile=filename]
Parameters
Parameter Description
controller The controller on which you want to run the
diagnostic tests. Valid controller identifiers are a or
b, where a is the controller in slot A, and b is the
controller in slot B. Enclose the controller identifier
in square brackets ([ ]). If you do not specify a
controller, the storage management software returns
a syntax error.
loopbackDriveChannel The disk drive channels on which you want to run
the diagnostic tests. You can either choose to run
the diagnostics on all channels or select a specific
channel on which to run diagnostics. If you select a
specific channel, valid values for the disk drive
channels are 1, 2, 3, or 4.
testID The identifier for the diagnostic test you want to
run. The identifier and corresponding tests are as
follows:
v 1 Read test
v 2 Write test
v 3 Data loop-back test
v discreteLines Discrete lines diagnostic test
patternFile The name of a file that contains a data pattern that
you want to use as test data. Enclose the file name
of the data pattern in double quotation marks ( ).
Notes
When you run a data loop-back test, you can optionally specify a file that contains a data pattern. If you
do not specify a file, the controller firmware provides a default pattern.
Discrete lines are control lines and status lines that are connected between two controllers in a controller
module. The discrete lines diagnostic test lets each controller check that control signal transitions can be
observed at the control inputs of the alternate controller. The discrete lines diagnostic test automatically
runs after each power-cycle or each controller-reset. You can run the discrete lines diagnostic test after
you have replaced a component that failed the initial discrete lines diagnostic test. This test applies only
to the DS5100, DS5300, and DS4800 (models 82, 84, and 88) series controller modules. The discrete lines
diagnostic test returns one of the following messages:
v When the discrete lines diagnostic test runs successfully, this message appears:
The controller discrete lines successfully passed the diagnostic
test. No failures were detected.
v If the discrete lines diagnostic test fails, this message appears:
3-112 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
One or more controller discrete lines failed the diagnostic test.
v If the CLI cannot run the discrete lines diagnostic test, the CLI returns Error 270, which means that the
discrete lines diagnostic test could not start nor complete.
v The discrete lines diagnostic test is not functioning in SM release version 10.60.x5.11. Check the SM
release readme files for information.
Syntax
diagnose controller [(a | b)]
iscsiHostPorts=(all | ("wwID" | "gID")
testID=cableDiagnostics
Parameters
Parameter Description
controller The controller on which you want to run the cable
diagnostic test. Valid controller identifiers are a or b, where a
is the controller in slot A, and b is the controller in slot B.
Enclose the controller identifier in square brackets ([ ]). If
you do not specify a controller, the storage management
software returns a syntax error.
iscsiHostPorts The 8-byte World Wide Identifier (WWID) or the 16-byte
group identifier (GID) of the HBA or HCA host port. Enclose
the WWID or the GID in double quotation marks (" ").
testID The identifier for the diagnostic test that you want to run.
For this diagnostic test, the only choice is cableDiagnostics.
Notes
When you run the cable diagnostic test, the firmware returns the following information:
v Host Port: The port on which the diagnostic test was run.
v HIC: The host interface card associated with this port.
v The date and time the test was run.
v Status:
OK: All of the pairs of cables are good and do not have any faults.
Open: One or more of the four pairs of cables are open.
Short: One or more of the four pairs of cables are shorted.
Incomplete: One or more of the four pairs returned incomplete or invalid test results.
v Length The Length of the cables are listed in meters and the following information about the cables
is returned:
When the cable status is OK, the approximate lengths of the cable pairs are returned. The lengths of
the cable pair is are shown as a range (L1-L2), which are the shortest and the longest lengths of the
cable pairs.
Syntax
diagnose remoteMirror (primary [primarylogicalDriveName] |
primaries [primaryLogicalDriveName1 ... primarylogicalDriveNameN])
testID=connectivity
Parameters
Parameter Description
primary or primaries The name of the primary logical drive of the remote mirror
pair that you want to test. You can enter more than one
primary logical drive name. Enclose the primary logical
drive names in square brackets ([ ]). If the primary logical
drive name has special characters, you also must enclose the
primary logical drive name in double quotation marks ( ).
Syntax
disable storageSubsystem externalKeyManagement
file="fileName"
passPhrase="passPhraseString"
Parameters
Parameter Description
file The file path and the file name that has the security key. For
example: file="C:\Program Files\CLI\sup\seckey.slk"
Important: The file name must have an extension of .slk.
passPhrase A character string that encrypts the security key so that you
can store the security key in an external file.
3-114 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Notes
Note: If your pass phrase does not meet these criteria, you will receive an error message.
Disable FlashCopy
This command stops a copy-on-write operation. This command performs the same action as the legacy
stop flashcopy command.
Syntax
disableFlashcopy (logicaldrive [logicaldriveName] |
logicaldrives [logicaldriveName1 ... logicaldriveNameN])
Parameters
Parameter Description
logicaldrive or logicaldrives The name of the specific logical drive for which you
want to stop a copy-on-write operation. You can enter
more than one logical drive name.
Notes
Names can be any combination of alphanumeric characters, underscore (_), hyphen (-), and pound (#).
Names can have a maximum of 30 characters.
One technique for naming the FlashCopy logical drive and the FlashCopy repository logical drive is to
add a hyphenated suffix to the original base logical drive name. The suffix distinguishes between the
FlashCopy logical drive and the FlashCopy repository logical drive. For example, if you have a base
logical drive with a name of Engineering Data, the FlashCopy logical drive can have a name of
Engineering Data-S1, and the FlashCopy repository logical drive can have a name of EngineeringData-R1.
If you do not choose a name for either the FlashCopy logical drive or the FlashCopy repository logical
drive, the storage management software creates a default name by using the base logical drive name. An
example of the FlashCopy logical drive name that the controllers might create is, if the base logical drive
name is aaa and does not have a FlashCopy logical drive, the default FlashCopy logical drive name is
aaa-1. If the base logical drive already has n-1 number of FlashCopy logical drives, the default name is
aaa-n. An example of the FlashCopy repository logical drive name that the controller might create is, if
the base logical drive name is aaa and does not have a FlashCopy repository logical drive, the default
FlashCopy repository logical drive name is aaa- R1. If the base logical drive already has n-1 number of
Syntax
disable storageSubsystem [featurePack |
The featureAttributeList can be one or more of these attribute values. If you enter more than one
attribute value, separate the values with a white space.
v volumeCopy
v Enhanced FlashCopy
v remoteMirror
v mixedDriveTypes
v Full Disk Encryption (safeStoreSecurity)
v storagePartition or storagePartition [2|4|8|16|32|64|96|128|192|256|512|Max]
In certain versions of the controller firmware, the form for this attribute value is a combination of the
alphabetical term merged with the numerical value, as shown by this example: storagePartition256
v driveSlotLimit or driveSlotLimit[16|24|32|48|60|64|72|96|112|10|128|136|144|180|192|256|
272|300|360|384|448|480|Max]
In certain versions of the controller firmware, the form for this attribute value is a combination of the
alphabetical term merged with the numerical value, as shown by this example: driveSlotLimit360
v ExternalKeyMgr (safeStoreExternalKeyMgr)
v T10PI
v SSDSupport
v highPerformanceTier
v raid6
v FlashCopy or FlashCopy[2|4|8|16]
The form for this attribute value is a combination of the alphabetical term merged with the numerical
value, as shown by this example: flashcopy16
In certain versions of the controller firmware, the form for this attribute value is a combination of the
alphabetical term merged with the numerical value, as shown by this example: remoteMirror128
Parameter
None
Notes
If you specify the remoteMirror parameter, this command disables the Enhanced Remote Mirroring
premium feature and takes away the structure of the mirror repository logical drive.
If you disable the High Performance Tier feature, all of the included features are disabled.
3-116 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Display Automatic Support Bundle Collection Configuration
This command displays the automatic support bundle collection settings.
Syntax
Attention: The SM CLI support bundle commands must be run from the SM CLI command line
interface only. They cannot be run from the storage subsystem SM CLI script window. In addition, the
storage subsystem IP addresses are not required. Also, the -c parameter is not required to precede the SM
CLI support bundle command.
-supportBundle auto show
program path
SMcliadd program path
SMcli
Parameters
None
Syntax
Attention: The SM CLI support bundle commands must be run from the SM CLI command line
interface only. They cannot be run from the storage subsystem SM CLI script window. In addition, the
storage subsystem IP addresses are not required. Also, the -c parameter is not required to precede the SM
CLI support bundle command.
-supportBundle schedule show
Parameters
None.
Attention: Possible damage to the storage subsystem configuration downloading drive firmware
incorrectly can result in damage to the drives or a loss of data access.
This command is intended for downloading a firmware image to only one drive at a time. If you use this
command in a script, make sure that you use this command only once. If you use this command more
than once, the operation can fail. You can download firmware images to all of the drives in a storage
subsystem at onetime by using the download storageSubsystem driveFirmware command.
download drive [enclosureID,drawerID,slotID] firmware file="filename"
Notes
When you download the firmware to the drives, you must provide the full path and file name to the
firmware image that is stored on your system.
You can use download drive command to test the firmware on one drive before you install the firmware
on all of the drives in a storage subsystem. The download returns one of these statuses:
v Successful
v Unsuccessful With Reason
v Never Attempted With Reason
The drive parameter supports both high-capacity drive enclosures and low-capacity drive enclosures. A
high-capacity drive enclosure has drawers that hold the drives. The drawers slide out of the drive
enclosure to provide access to the drives. A low-capacity drive enclosure does not have drawers. For a
high-capacity drive enclosure, you must specify the identifier (ID) of the drive enclosure, the ID of the
drawer, and the ID of the slot in which a drive resides. For a low-capacity drive enclosure, you need only
specify the ID of the drive enclosure and the ID of the slot in which a drive resides. For a low-capacity
drive enclosure, an alternative method for identifying a location for a drive is to specify the ID of the
drive enclosure, set the ID of the drawer to 0, and specify the ID of the slot in which a drive resides.
Parameters
Parameter Description
allEnclosure This parameter downloads new firmware to all of the
enclosures in the storage subsystem.
enclosure The drive enclosure that contains the ESM card to which
you want to load new firmware. Enclosure ID values are 0
to 99. Enclose the enclosure ID value in square brackets ([ ]).
file The file path and the file name of the file that contains the
firmware image. Enclose the file path and the file name of
the firmware image in double quotation marks (" "). For
example: file="C:\Program Files\CLI\dnld\
enclosureset.dlp". Valid file names have a .dlp extension.
Notes
The enclosure parameter downloads the factory default configuration settings to a specific drive
expansion enclosure. If you need to download the factory default configuration settings to more than one
drive expansion enclosure, but not all drive expansion enclosures, you must enter this command for each
drive expansion enclosure.
Syntax
download (allEnclosures | enclosure [enclosureID])
firmware file=filename
Parameters
Parameter Description
allEnclosure This parameter downloads new firmware to all of the
enclosures in the storage subsystem.
enclosure The drive expansion enclosure that contains the ESM card to
which you want to load new firmware. Enclosure ID values
are 0 to 99. Enclose the enclosure ID value in square brackets
([ ]).
file The file path and the file name of the file that contains the
firmware image. Enclose the file path and the file name of the
firmware image in double quotation marks ( ). For
example:
file="C:\Program Files\CLI\dnld\esmfrm.esm"
The enclosure parameter downloads new firmware to a specific drive expansion enclosure. If you need
to download new firmware to more than one drive expansion enclosure, but not all drive expansion
enclosures, you must enter this command for each drive expansion enclosure.
Syntax
download (allEnclosures |
...enclosure [enclosureID1]...[enclosureIDn] |
...enclosure [enclosureID])
powerSupplyUpdate file="filename"
powerSupplyUnit [(left | right) | (top | bottom)] |
[forceUpdate]
Parameters
Parameter Description
allenclosures This parameter downloads new power supplyfirmware to all
of the enclosures in the storage subsystem.
enclosure or enclosures The enclosure that contains the power supply to which you
want to download new firmware. Enclosure ID values are 0
to 99. Enclose the enclosure ID value in square brackets ([ ]).
powerSupplyUpdate file The file path and the file name of the file that contains the
firmware image. Enclose the file path and the file name of
the firmware image in double quotation marks (" "). For
example: file="C:\Program Files\CLI\dnld\esmfrm.esm".
Valid file names have an .esm extension.
powerSupplyUnit The power supply to which you want to download new
firmware. Valid power supply identifiers are left, right,
top, or bottom. Enclose the power-fan CRU/FRU identifier in
square brackets ([ ])
forceUpdate This parameter bypasses these checks:
v To determine if the new firmware version is the same as
the existing firmware version.
v To determine if the power supply is in an Optimal state.
v To determine if there is a redundant power supply that is
in an Optimal state.
3-120 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Syntax
download storageSubsystem driveFirmware file=filename
[file=filename2... file=filenameN]
Parameter
Parameter Description
file The file path and the file name of the file that contains
the firmware image. Enclose the file path and the file
name of the firmware image in double quotation marks
( ).
Notes
When you run this command, you can download more than one firmware image file to the disk drives in
a storage subsystem. The number of firmware image files that you can download depends on the storage
subsystem. The storage management software returns an error if you try to download more firmware
image files than the storage subsystem can accept.
You can schedule downloads for multiple disk drives at the same time, including multiple disk drives in
a redundant array. Each firmware image file contains information about the disk drive types on which
the firmware image runs. The specified firmware images can be downloaded only to a compatible disk
drive. Use the download drive firmware command to download a firmware image to a specific disk
drive.
The download storageSubsystem driveFirmware command blocks all I/O activity until a download try
has been made for each candidate disk drive or you run the stop storageSubsystem
downloadDriveFirmware command. When the download storageSubsystem driveFirmware command
finishes downloading the firmware image, each candidate disk drive shows the download status for each
disk drive. One of these statuses is returned:
v Successful
v Unsuccessful With Reason
v Never Attempted With Reason
Syntax
download storageSubsystem firmware [, NVSRAM ]
file= filename [, NVSRAM-filename]
[downgrade=(TRUE | FALSE)]
[activateNow=(TRUE | FALSE)]
Parameters
Parameter Description
NVSRAM The setting to download a file with NVSRAM values when
you download a firmware file. Do not include square
brackets with this parameter. Include a comma after the
firmware parameter.
Syntax
download storageSubsystem NVSRAM file=filename
Parameter
Parameter Description
file The file path and the file name that contains the
NVSRAM values. Enclose the NVSRAM file name in
double quotation marks (" "). For example:
file="C:\Program Files\CLI\dnld\afrm.dlp"
Syntax
enable array [arrayName] security
3-122 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Parameters
Parameter Description
array The alphanumeric identifier (including - and _) of the array
that you want to place in the Security Enabled state. Enclose
the array identifier in square brackets.
Notes
The following conditions must be met to successfully run this command.
v All drives in the array must be FDE drives.
v The Disk Drive Security premium feature must be enabled.
v The storage subsystem security key has to be set.
v The array is Optimal, and it does not have FlashCopy logical drives or repository logical drives.
Once the array is security enable, all of the drives in the array will be in secured state, which will be in
locked state upon power up until the controllers unlock them with the appropriate key. In addition, the
data will be encrypted or decrypted by the drive before it is written to or read from to the disk surface.
Once the FDE drive is placed into secured state, it will stay in the secure state until one re-provision
the FDE drive.
Syntax
enable controller [(a | b)] dataTransfer
Parameter
Parameter Description
controller The controller that you want to revive. Valid controller
identifiers are a or b, where a is the controller in slot A, and
b is the controller in slot B. Enclose the controller identifier
in square brackets ([ ]). If you do not specify a controller,
the storage management software returns a syntax error.
Note: All of the drives that comprise the disk pool must be security capable.
Syntax
enable diskPool [diskPoolName] security
Parameters
Parameter Description
diskPool The name of the disk pool that you want to place in the
Security Enabled state. Enclose the disk pool identifier in
square brackets ([ ]).
Each disk pool name must be unique. You can use any combination of alphanumeric characters,
underscore (_), hyphen(-), and pound (#) for the user label. User labels can have a maximum of 30
characters.
Syntax
enable storageSubsystem externalKeyManagement
file="fileName" |
passPhrase="passPhraseString"
Parameters
Parameter Description
file The file path and the file name that has the security key.
Enclose the file path and the file name that has the security
key in double quotation marks (" "). For example:
file="C:\Program Files\CLI\sup\seckey.slk"
Important: The file name must have an extension of .slk.
passPhrase A character string that encrypts the security key so that you
can store the security key in an external file. Enclose the
pass phrase character string in double quotation marks (" ").
Notes
Note: If your pass phrase does not meet these criteria, you will receive an error message.
Syntax
Attention: When enabling the featurePack, this command must be performed when the subsystem is
off-line, without IO activities from the host servers, because both storage subsystem controllers will be
rebooted during the disabling process. Schedule storage subsystem down time before running this
command.
enable storageSubsystem [featurePack |feature]
file="filename"
3-124 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Parameters
Parameter Description
file The file path and the file name of a valid feature key file.
Enclose the file path and the file name in double quotation
marks (" "). For example: file="C:\Program
Files\CLI\dnld\ftrkey.key" Valid file names for feature key
files end with a .key extension.
Notes
A premium feature is an additional application to enhance the capabilities of a storage subsystem. The
premium features are these:
v Storage partitioning
v FlashCopies
v Enhanced Remote Mirroring
v Mixed drive types
v High performance tier
v SSD support
v Full Disk Encryption
A feature pack is a predefined set of enhanced storage subsystem capabilities and/or premium features,
such as Storage Partitioning and Enhanced Remote Mirroring. These premium features are combined for
the convenience of the users.
Syntax
export storageSubsystem securityKey
passPhrase=passPhraseString |
file=fileName
Parameters
Parameter Description
passPhrase The character string that provides authentication for the
security key. The pass phrase is 8 to 32 characters in length.
You must use at least one number, one lowercase letter, one
uppercase letter, and one nonalphanumeric character in the
pass phrase. A space is not permitted.
file The name of the file to which you want to save the security
key. You must add a file extension of .slk to the end of the
file name.
Notes
For more information about exporting the storage subsystem security key, see the DS Storage Manager
Installation and User's Guide version 10.
If your pass phrase does not meet these criteria, you receive an error message and are prompted to retry
the command.
Syntax
import storageSubsystem securityKey file=fileName |
passPhrase=passPhraseString
Parameters
Parameter Description
file The file that has the original security key of the imported
FDE drives. The file has an extension of .slk.
passPhrase The character string that provides authentication for the
security key. The pass phrase is 8 to 32 characters in length.
You must use at least one number, one lowercase letter, one
uppercase letter, and one non-alphanumeric character in the
pass phrase. A space is not permitted.
Notes
For more information about exporting the storage subsystem security key, see the DS Storage Manager
version 10 Installation and User's Guide.
You must use the same pass phrase that you use when exporting the storage subsystem security key. If
your pass phrase does not match, you receive an error message and the FDE drives remain locked. For
more information about exporting the storage subsystem security key, see the DS Storage Manager
Installation and User's Guide version 10.
Note: You cannot use this command to increase the capacity of a thin logical drive.
Syntax
start increaseVolCapacity logicaldrive="logicaldriveName"
incrementalCapacity=logicaldriveCapacity
[addDrives=(enclosureID1,drawerID1,slotID1 ... enclosureIDn,drawerIDn,slotIDn)]
3-126 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Parameters
Parameter Description
logicaldrive The name of the disk pool logical drive for which you
want to increase capacity. Enclose the logical drive name
in double quotation marks (" ").
incrementalCapacity The setting to increase the storage size (capacity) for the
logical drive. Size is defined in units of bytes, KB, MB,
GB, or TB. The default value is bytes.
addDrives The setting to add new drives to the logical drive. For
high-capacity drive expansion enclosures, specify the
enclosure ID value, the drawer ID value, and the slot ID
value for the drive. For low-capacity drive expansion
enclosures, specify the enclosure ID value and the slot ID
value for the drive. Enclosure ID values are 0 to 99.
Drawer ID values are 1 to 5. Slot ID values are 1to 32.
Enclose the enclosure ID value, drawer ID value, and the
slot ID value in parentheses.
Notes
In some cases a drive parameter might appear as valid input for the command syntax. However, you
cannot use the drive parameter with this command.
Setting the incrementalCapacity parameter, starts a long-running operation that you cannot stop.
Long-running operations are performed in the background and do not prevent you from running other
commands. To show the progress of long-running operations, use the show logicaldrive actionProgress
command.
The addDrives parameter supports both high-capacity drive expansion enclosures and low-capacity drive
expansion enclosures. A high-capacity drive expansion enclosure has drawers that hold the drives. The
drawers slide out of the drive expansion enclosure to provide access to the drives. A low capacity drive
expansion enclosure does not have drawers. For a high-capacity drive expansion enclosure, you must
specify the identifier (ID) of the drive expansion enclosure, the ID of the drawer, and the ID of the slot in
which a drive resides. For a low-capacity drive expansion enclosure, you need to only specify the ID of
the drive expansion enclosure and the ID of the slot in which a drive resides. For a low-capacity drive
expansion enclosure, an alternative method for identifying a location for a drive is to specify the ID of
the drive expansion enclosure, set the ID of the drawer to 0, and specify the ID of the slot in which a
drive resides.
Note: Initializing a thin logical drive starts a long-running operation that you cannot stop.
Syntax
start logicaldrive [logicaldriveName] initialize
[existingRepositoryLabel=existingRepositoryName |
diskPool="diskPoolName" capacity=capacityValue|
retainRepositoryMembers=[TRUE|FALSE]]
Before using this command with the file option, you must first obtain a validator string (a security code)
from your IBM Technical Support representative. To obtain a validator, use the save storageSubsystem
dbmValidator command to generate an XML file that contains validator information. Your IBM Technical
Support representative uses the XML file to generate the validator string required for this command.
Syntax
load storageSubsystem dbmDatabase
((file="filename" validator="validatorValue") | sourceLocation=onboard)
[controller [(a|b)]]
3-128 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Parameters
Parameter Description
file The file path and the file name of the DBM database you
want to upload. Enclose the file name in double quotation
marks (" "). For example: file="C:\Subsystem
Backups\DBMbackup_03302010.dbm"
Notes
Depending on the size of the database image, restoring the database might take up as much as 30
minutes. The host software will not show the controllers in an Optimal state until after all actions for
loading the database image are completed on the controllers.
Recopy VolumeCopy
This command re-initiates a VolumeCopy operation by using an existing VolumeCopy pair.
Attention: Starting a VolumeCopy operation overwrites all existing data on the target logical drive,
makes the target logical drive read-only to hosts, and fails all FlashCopy logical drives associated with
the target logical drive, if any exist. If you have used the target logical drive as a copy before, be sure
you no longer need the data or have it backed up.
This command works with VolumeCopy pairs that you created with a FlashCopy logical drive or without
a FlashCopy logical drive.
Syntax
recopy volumeCopy target [
targetName]
[source [sourceName]]
[copyPriority=(highest | high | medium | low | lowest)
targetReadOnlyEnabled=(TRUE | FALSE)
copyType=(online | offline)]
Notes
Copy priority defines the amount of system resources that are used to copy the data between the source
logical drive and the target logical drive of a VolumeCopy pair. If you select the highest priority level, the
VolumeCopy uses the most system resources to perform the VolumeCopy, which decreases performance
for host data transfers.
Note: You can run this command only from a command line. You cannot run this command from the
GUI script editor. You cannot use the DS Storage Management GUI to recover a logical drive.
Syntax
recover logicalDrive (drive=(enclosureID,drawerID,slotID) |
Drives=(enclosureID1,drawerID1,slotID1 ... enclosureIDn,drawerIDn,slotIDn) |
array=ArrayName)
[newArray=arrayName]
userLabel=(logicalDriveName
logicaldriveWWN="logicaldriveWWN")
3-130 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
capacity=logicalDriveCapacity
offset=offsetValue
raidLevel=(0 | 1 | 3 | 5 | 6)
segmentSize=segmentSizeValue
dssPreallocate=(TRUE | FALSE)
SSID=subsystemLogicalDriveID
[owner=(a | b)
cacheReadPrefetch=(TRUE | FALSE)]
T10PI=(none | enabled)]
Parameters
Parameter Description
drive or drives The disk drives that you want to assign to the
logical drive that is to be recovered. For
high-capacity drive expansion enclosures, specify
the enclosure ID value, the drawer ID value, and
the slot ID value for each disk drive that you
assign to the logical drive. For low-capacity drive
expansion enclosures, specify the enclosure ID
value and the slot ID value for each disk drive
that you assign to the logical drive. Enclosure ID
values are 0 to 99. Drawer ID values are 1 to 5.
Slot ID values are 1 to 32. Enclose the enclosure
ID, drawer ID, and slot ID values in square
parentheses ([]).
array The name of the array in which you want to
create the logical drive. (To determine the names
of the arrays in your storage subsystem, run the
show storageSubsystem profile command.)
newArray The name that you want to give to a new array.
Enclose the new array name in double quotation
marks (" ").
userLabel The name of the logical drive that you want to
recover. Enclose the logical drive name in double
quotation marks ( ).
logicaldriveWWN The world wide name of the logical drive that
you want to recover. The name is a 16-byte
identifier, for example,
60080E500017B4320000000049887D77. Enclose the
identifier in double quotation marks ( ).
capacity The size of the logical drive that you are adding
to the storage subsystem. Size is defined in units
of bytes, KB, MB, GB, or TB.
offset The number of blocks from the start of the array
to the start of the referenced logical drive.
raidLevel The RAID level of the array that contains the
disk drives. Valid values are 0, 1, 3, 5, or 6.
segmentSize The amount of data (in KB) that the controller
writes on a single disk drive in an array before
writing data on the next disk drive. Valid values
are 8, 16, 32, 64, 128, 256, or 512.
dssPreallocate The setting to turn on or turn off allocating
logical drive storage capacity for future segment
size changes. To turn on allocation, set this
parameter to TRUE. To turn off allocation, set this
parameter to FALSE.
Notes
The storage management software collects recovery profiles of the monitored storage subsystems and
saves the profiles on a storage management station.
The drive parameter supports both high-capacity and low-capacity drive expansion enclosures. A
high-capacity drive expansion enclosure has drawers that hold the drives. The drawers slide out of the
drive expansion enclosure to provide access to the drives. A low-capacity drive expansion enclosure does
not have drawers. For a high-capacity drive expansion enclosure, you must specify the identifier (ID) of
the drive expansion enclosure, the ID of the drawer, and the ID of the slot in which a drive resides. For a
low-capacity drive expansion enclosure, you need to specify the ID of the drive expansion enclosure and
the ID of the slot in which a drive resides. For a low-capacity drive expansion enclosure, an alternative
method for identifying a location for a drive is to specify the ID of the drive expansion enclosure, set the
ID of the drawer to 0, and specify the ID of the slot in which a drive resides.
If you attempt to recover a logical drive using the drive parameter or the drives parameter and the
drives are in an unassigned state, the controller automatically creates a new array. Use the
newLogicalDriveGroup parameter to specify a name for the new array.
You can use any combination of alphanumeric characters, underscore (_), hyphen (-), and pound (#) for
the names. Names can have a maximum of 30 characters.
The owner parameter defines which controller owns the logical drive. The preferred controller ownership
of a logical drive is the controller that currently owns the array.
With the dssPreallocate parameter, you can assign space in a logical drive for storing information that is
used to rebuild a logical drive. When you set the dssPreallocate parameter to TRUE, the storage space
3-132 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
allocation logic in the controller firmware preallocates space for future segment size changes. The
preallocated space is the maximum allowable segment size. The dssPreallocate parameter is necessary
for recovering logical drive configurations that are not retrievable from the controller database. To turn
off the preallocation capability, set dssPreallocate to FALSE.
Segment Size
The size of a segment determines how many data blocks that the controller writes on a single disk drive
in a logical drive before writing data on the next disk drive. Each data block stores 512 bytes of data. A
data block is the smallest unit of storage. The size of a segment determines how many data blocks that it
contains. For example, an 8-KB segment holds 16 data blocks. A 64-KB segment holds 128 data blocks.
When you enter a value for the segment size, the value is checked against the supported values that are
provided by the controller at run time. If the value that you entered is not valid, the controller returns a
list of valid values. Using a single disk drive for a single request leaves other disk drives available to
simultaneously service other requests.
If the logical drive is in an environment where a single user is transferring large units of data (such as
multimedia), performance is maximized when a single data transfer request is serviced with a single data
stripe. (A data stripe is the segment size that is multiplied by the number of disk drives in the array that
are used for data transfers.) In this case, multiple disk drives are used for the same request, but each disk
drive is accessed only once.
For optimal performance in a multiuser database or file system storage environment, set your segment
size to minimize the number of disk drives that are required to satisfy a data transfer request.
Cache read prefetch lets the controller copy additional data blocks into cache while the controller reads
and copies data blocks that are requested by the host from disk into cache. This action increases the
chance that a future request for data can be fulfilled from cache. Cache read prefetch is important for
multimedia applications that use sequential data transfers. The configuration settings for the storage
subsystem that you use determine the number of additional data blocks that the controller reads into
cache. Valid values for the cacheReadPrefetch parameter are TRUE or FALSE.
This command creates a new Enhanced Remote Mirroring repository logical drive (also called a mirror
repository logical drive) by using the parameters defined for a previous mirror repository logical drive.
The underlying requirement is that you have previously created a mirror repository logical drive. When
you use this command, you can define the mirror repository logical drive in one of three ways:
user-defined disk drives, user-defined subsystem, or user-defined number of disk drives for the mirror
repository logical drive. If you choose to define a number of disk drives, the controller firmware chooses
which disk drives to use for the mirror repository logical drive.
Parameters
Parameter Description
repositoryRAIDLevel The RAID level for the mirror repository logical drive.
Valid values are 1, 3, 5, or 6.
repositoryDrives The disk drives for the mirror repository logical drive.
EnclosureID1,drawerID1,slotID1 ...
enclosureIDn,drawerIDn,slotIDn is for enclosures with
multiple disk drive drawers. For enclosures without
disk drive drawers, use enclosureID1,slotID1 ...
enclosureIDn,slotIDn instead. Enclosure ID values are
0 to 99. Drawer ID values are 1 to 5. Slot ID values are
1 to 32. Enclose the enclosure ID values and slot ID
values in parentheses.
repositoryArray The name of the array where the mirror repository
logical drive is located.
freeCapacityArea The index number of the free space in an existing
array that you want to use to recreate the mirror
repository logical drive. Free capacity is defined as the
free capacity between existing logical drives in an
array. For example, an array might have the following
areas: logical drive 1, free capacity, logical drive 2, free
capacity, logical drive 3, free capacity. To use the free
capacity following logical drive 2, you would specify:
freeCapacityArea=2
3-134 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Parameter Description
T10PI The setting to specify that an array, and the logical
drives within the array, has T10 PI (Protection
Information) to help you ensure that the data
maintains its integrity. When you use this parameter,
only protected drives can be used for the array. These
settings are valid:
v noneThe array does not have T10 PI (Protection
Information).
v enabledThe array has T10 PI (Protection
Information). The array support is protected
information and is formatted with protection
information enabled.
Notes
If you enter a value for the storage space of the mirror repository logical drive that is too small, the
controller firmware returns an error message, which states the amount of space that is needed for the
mirror repository logical drive. The command does not try to change the mirror repository logical drive.
You can re-enter the command by using the value from the error message for the storage space value of
the mirror repository logical drive.
When you assign the disk drives, if you set the enclosureLossProtect parameter to TRUE and have
selected more than one disk drive from any one enclosure, the storage subsystem returns an error. If you
set the enclosureLossProtect parameter to FALSE, the storage subsystem performs operations, but the
mirror repository logical drive that you create might not have enclosure loss protection.
When the controller firmware assigns the disk drives, if you set the enclosureLossProtect parameter to
TRUE, the storage subsystem returns an error if the controller firmware cannot provide disk drives that
result in the new mirror repository logical drive having enclosure loss protection. If you set the
enclosureLossProtect parameter to FALSE, the storage subsystem performs the operation even if it means
that the mirror repository logical drive might not have enclosure loss protection.
Syntax
recreate storageSubsystem securityKey
passPhrase="passPhraseString"
file="fileName"
Parameters
Parameter Description
passPhrase A character string that encrypts the security key so that you
can store the security key in an external file.
file The file path and the file name that has the security key. For
example: file="C:\Program Files\CLI\sup\seckey.slk"
Important: The file name must have an extension of .slk.
Note: If your pass phrase does not meet these criteria, you will receive an error message.
Recreate FlashCopy
This command starts a fresh copy-on-write operation by using an existing FlashCopy logical drive.
Syntax
recreate FlashCopy (logical drive
[logicalDriveName] | logical drives [logicalDriveName1 ... logicalDriveNameN)
[userLabel="flashcopyLogicalDriveName"
[warningThresholdPercent=percentValue
repositoryFullPolicy (failBaseWrites | failFlashCopy)]
Parameters
Parameter Description
logicalDrive or logicalDrives The name of the specific logical drive. You can
enter more than one logical drive name. Enclose
the logical drive name in square brackets ([ ]). If
the logical drive name has special characters,
you must also enclose the logical drive name in
double quotation marks ( ).
userLabel The name of the FlashCopy logical drive.
Enclose the FlashCopy logical drive name in
double quotation marks ( ). If you enter more
than one FlashCopy logical drive name, this
command fails.
warningThresholdPercent The percentage of repository capacity at which
you receive a warning that the FlashCopy
repository logical drive is nearing full. Use
integer values. For example, a value of 70 means
70 percent. The default value is 50.
repositoryFullPolicy The type of processing that you want to
continue if the FlashCopy repository logical
drive is full. You can choose to fail writes to the
base logical drive (failBaseWrites) or fail writes
to the FlashCopy logical drive (failFlashCopy).
The default value is failFlashCopy.
Notes
You can use any combination of alphanumeric characters, hyphens, and underscores for the names.
Names can have a maximum of 30 characters.
If you do not specify a value for the warningThresholdPercent parameter or the repositoryFullPolicy
parameter, the previously set value is used.
3-136 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Recreating Multiple FlashCopy Logical Drives without Optional Parameters
v If you list multiple FlashCopy logical drives to be recreated but do not specify any of the optional
parameters, the recreate operation processes the FlashCopy logical drives as a "batch" process.
v Before restarting any FlashCopy, validation checks for the necessary restarted preconditions of the
FlashCopy are performed. If any of the listed FlashCopy logical drives fail the validation, the entire
command fails and the FlashCopy logical drives are not recreated. If the validation is successful for all
of the FlashCopy logical drives in the list, but one or more of the legacy FlashCopies in the list fail to
restart, the entire command fails and none of the FlashCopies are recreated.
v During FlashCopy recreation, all affected logical drives (FlashCopy, base, and repository) are
appropriately quiesced and I/O operations are resumed to all affected logical drives after all
FlashCopy are recreated.
Syntax
remove (allLogicalDrives | logicalDrive [logicalDriveName] |
logicalDrives [logicalDriveName1 ... logicalDriveNameN] | accesslogicalDrive)
lunMapping (host=hostName |
hostGroup=(hostGroupName | defaultGroup))
Parameters
Parameter Description
allLogicalDrives This parameter removes the LUN mapping from all of the
logical drives.
logicalDrive or The name of the specific logical drive that you want to
logicalDrives remove from the LUN mapping. You can enter more than
one logical drive name. Enclose the logical drive name in
double quotation marks ( ) inside of square brackets
([ ]).
accessLogicalDrive This parameter removes the access logical drive.
host The name of the host to which the logical drive is mapped.
Enclose the host name in double quotation marks ( ).
hostGroup The name of the host group that contains the host to which
the logical drive is mapped. Enclose the host group name
in double quotation marks ( ). The defaultGroup value is
the host group that contains the host to which the logical
drive is mapped. The HostGroup and Host parameters can
not be specifed together. You can specify either parameter
but not both at the same time.
Notes
The access logical drive is the logicalDrive in a SAN environment that is used for communication
between the storage management software and the storage subsystem controller. The access logical drive
uses a LUN address and consumes 20 MB of storage space that is not available for application data
storage. An access logical drive is required only for in-band managed storage subsystems.
Attention: Removing an access logical drive can damage your configuration The agent uses the
access logical drives to communicate with a storage subsystem. If you remove an access logical drive
mapping for a storage subsystem from a host that has an agent running on it, the storage management
software is no longer able to manage the storage subsystem through the agent.
Chapter 3. Script Commands 3-137
You must use the host parameter and the hostGroup parameter when you specify a non-access logical
drive or an access logical drive. The script engine ignores the host parameter or the hostGroup parameter
when you use the allLogicalDrives parameter or the logicalDrives parameter.
Syntax
set consistencyGroup ["consistencyGroupName"] removeCGMemberLogicalDrive=memberName
[deleteRepositoryMembers=(TRUE | FALSE)]
Parameters
Parameter Description
consistencyGroupName The name of the consistency group from which you want
to remove a member. Enclose the consistency group
name in double quotation marks (" ") inside square
brackets ([ ]).
memberName The name of the member logical drive that you want to
remove.
deleteRepositoryMembers Determines whether to remove all of the repository
members from the consistency group.
Syntax
remove remoteMirror (localLogicalDrive [logicalDriveName] |
localLogicalDrives [logicalDriveName1 ... logicalDriveNameN])
Parameters
Parameter Description
localLogicalDrive or The name of the primary logical drive (the logical drive on
localLogicalDrives the local storage subsystem) that you want to remove. You
can enter more than one logical drive name. Enclose the
logical drive name in square brackets ([ ]). If the logical
drive name has special characters, you also must enclose
the logical drive name in double quotation marks ( ).
Remove VolumeCopy
This command removes a VolumeCopy pair.
Syntax
remove volumeCopy target [
targetName] [source [sourceName]
copyType=(online | offline)]
3-138 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Parameters
Parameter Description
target The name of the target logical drive that you want to
remove. Enclose the target logical drive name in square
brackets ([ ]). If the target logical drive name has special
characters, you also must enclose the target logical drive
name in double quotation marks ( ).
source The name of the source logical drive that you want to
remove. Enclose the source logical drive name in square
brackets ([ ]). If the source logical drive name has special
characters, you also must enclose the source logical drive
name in double quotation marks ( ).
copyType Use this parameter to identify that a VolumeCopy has a
FlashCopy . If the VolumeCopy has a FlashCopy , set this
parameter to online. If the VolumeCopy does not have a
FlashCopy, set this parameter to offline.
Syntax
set enhancedFlashCopyLogicalDrive ["enhancedFlashCopyLogicalDriveName"]
userLabel="enhancedFlashCopyImageLogicalDriveName
Parameters
Parameter Description
enhancedFlashCopyLogicalDrive The name of the Enhanced FlashCopy logical drive that
you want to rename. Enclose the Enhanced FlashCopy
logical drive name in double quotation marks (" ") inside
of square brackets ([ ]).
userLabel A new name that you want to give to the Enhanced
FlashCopy logical drive. Enclose the new Enhanced
FlashCopy logical drive name in double quotation marks
(" ").
Notes
You can use any combination of alphanumeric characters, underscore (_), hyphen (-), and pound (#) for
the names. Names can have a maximum of 30 characters.
Syntax
repair logicaldrive [logicalDriveName] parity
parityErrorFile=filename
[verbose=(TRUE | FALSE)]
Syntax
replace Drive [enclosureID,drawerID,slotID]|
Drive "wwID") replacementDrive=enclosureID,drawerID,slotID
Parameters
Parameter Description
drive The location of the disk drive that you want to replace.
For high-capacity expansion drawers, specify the
enclosure ID, the drawer ID, and the slot ID. For
low-capacity expansion drawers, specify the enclosure
ID and the slot ID. Enclosure ID values are 0 to 99.
Drawer ID values are 1 to 5. Slot ID values are 1 to 32.
Enclose the enclosure ID value, the drawer ID value, and
the slot ID value in square brackets ([ ]).
Notes
The diskDrive parameter supports both high-capacity expansion drawers and low-capacity expansion
drawers. A high-capacity expansion drawer has drawers that hold the disk drives. The drawers slide out
of the expansion drawer to provide access to the disk drives. A low-capacity expansion drawer does not
have drawers. For a high-capacity expansion drawer, you must specify the identifier (ID) of the
expansion drawer, the ID of the drawer, and the ID of the slot in which a disk drive resides. For a
3-140 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
low-capacity expansion drawer, you need only specify the ID of the expansion drawer and the ID of the
slot in which a disk drive resides. For a low-capacity expansion drawer, an alternative method for
identifying a location for a disk drive is to specify the ID of the expansion drawer, set the ID of the
drawer to 0, and specify the ID of the slot in which a disk drive resides.
Reset Controller
This command resets a controller, and it is disruptive to I/O operations.
Important: When you reset a controller, the controller is removed from the data path and is not available
for I/O operations until the reset operation is complete. If a host is using logical drives that are owned
by the controller being reset, the I/O directed to the controller is rejected. Before resetting the controller,
either make sure that the logical drives that are owned by the controller are not in use or make sure that
a multi-path driver is installed on all of the hosts that use these logical drives.
Syntax
reset controller [(a | b)]
Parameter
Parameter Description
controller The controller that you want to reset. Valid controller identifiers
are a or b, where a is the controller in slot A, and b is the
controller in slot B. Enclose the controller identifier in square
brackets ([ ]). If you do not specify a controller owner, the
controller firmware returns a syntax error.
Notes
The controller that receives the reset controller command resets the controller specified. For example, if
the reset controller command is sent to controller A to request a reset of controller A, then controller A
reboots itself by doing a soft reboot. If the reset controller command is sent to controller A to request a
reset of controller B, then controller A holds controller B in reset and then releases controller B from reset,
which is a hard reboot. A soft reboot in some products only resets the IOC chip. A hard reboot resets both
the IOC and the expander chips in the controller.
Syntax
reset storageSubsystem batteryInstallDate [controller=(a | b)
| batteryPack=(left | right)]
Parameter
Parameter Description
controller The controller that contains the battery for which you want
to reset the age. Valid controller identifiers are a or b, where
a is the controller in slot A, and b is the controller in slot B.
Notes
A controller might have a battery associated with it, so the controller is identified as either a or b. With
the release of the DS5100, DS5300 controller enclosure, battery packs inside the interconnect-battery
CRU/FRU are identified as either left or right. If the command statement uses the wrong parameter, an
error appears.
Attention: Run this command only with the assistance of an IBM Technical Support representative.
Syntax
reset storageSubsystem diagnosticData
Parameters
None.
Syntax
reset storageSubsystem iscsiStatsBaseline
Parameters
None.
Notes
This command resets the baseline to 0 for both controllers in the storage subsystem. The purpose of
resetting both of the controller baselines is to help make sure that the controller counts are synchronized
between the controllers. If one controller resets but the second controller does not reset, the host is
3-142 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
informed that the controllers are out of synchronization. The host is informed by the time stamps that are
reported with the statistics.
Syntax
reset storageSubsystem logicalDriveDistribution
Parameters
None.
Notes
If you use this command on a host without a multi-path driver, to prevent application errors, you must
stop I/O operations to the logical drives until this command has completed.
Under certain host operating system environments, you might be required to reconfigure the multi-path
host driver. You might also need to make operating system modifications to recognize the new I/O path
to the logical drives.
Syntax
reset storageSubsystem RLSBaseline
Parameters
None.
Note: The previous release of the reset storageSubsystem SASPHYBaseline command cleared error
counts for all devices except the drives. The reset storageSubsystem SASPHYBaseline command now
resets the SAS PHY baseline for the drives as well as the other devices. All errors are deleted from the
.csv file.
Syntax
reset storageSubsystem SASPHYBaseline
Parameters
None.
Syntax
reset storageSubsystem SOCBaseline
Parameters
None.
Syntax
resume cgEnhancedFlashCopyLogicalDrive ["enhancedFlashCopyLogicalDriveName"]
cgEnhancedFlashCopyImage="enhancedFlashCopyImageName"
Parameters
Parameter Description
cgEnhancedFlashCopyLogicalDrive The name of the consistency group Enhanced FlashCopy
logical drive for which you want to restart a rollback
operation. Enclose the name of the consistency group
Enhanced FlashCopy logical drive in double quotation
marks (" ") inside square brackets ([ ]).
cgEnhancedFlashCopyImage The name of the Enhanced FlashCopy image in a
consistency group that you are restarting. The name of
an Enhanced FlashCopy image is comprised of two
parts:
v The name of the consistency group
v An identifier for the Enhanced FlashCopy image in the
consistency group.
3-144 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Notes
The name of an Enhanced FlashCopy image has two parts separated by a colon (:):
v The identifier of the Enhanced FlashCopy group
v The identifier of the Enhanced FlashCopy image
For example, if you want to restart a copy-on-write operation for Enhanced FlashCopy image 12345
which is in Enhanced FlashCopy consistency group enhancedFlashCopygroup1 in a consistency group
Enhanced FlashCopy logical drive that has the name enhancedFlashCopyVol1, you would use this
command:
If the rollback operation cannot be resumed, the selected Enhanced FlashCopy logical drive reverts to a
paused state, and the Needs Attention condition is displayed.
Note: You cannot use this command for Enhanced FlashCopy images involved in online VolumeCopy.
Syntax
resume enhancedFlashCopyImage [enhancedFlashCopyImageName] rollback
Parameters
Parameter Description
enhancedFlashCopyImage The name of the Enhanced FlashCopy image for which
you want to restart a rollback operation. The name of an
Enhanced FlashCopy image is comprised of two parts:
v The name of the Enhanced FlashCopy group
v An identifier for the Enhanced FlashCopy image in the
Enhanced FlashCopy group.
The name of an Enhanced FlashCopy image has two parts separated by a colon (:):
v The identifier of the Enhanced FlashCopy group
v The identifier of the Enhanced FlashCopy image
For example, if you want to restart a rollback operation for Enhanced FlashCopy image 12345 in an
Enhanced FlashCopy group that has the name enhancedFlashCopygroup1, you would use this command:
resume enhancedFlashCopyImage ["enhancedFlashCopygroup1:12345"] rollback;
Syntax
resume enhancedFlashCopyLogicalDrive [enhancedFlashCopyLogicalDriveName]
enhancedFlashCopyImage="enhancedFlashCopyImageName"
Parameters
Parameter Description
enhancedFlashCopyLogicalDrive The name of the specific Enhanced FlashCopy logical
drive for which you want to resume a rollback operation.
Enclose the Enhanced FlashCopy logical drive identifier
in square brackets ([ ]). If the Enhanced FlashCopy
logical drive identifier has special characters, you must
also enclose the Enhanced FlashCopy logical drive
identifier in double quotation marks (" ").
enhancedFlashCopyImage The name of the Enhanced FlashCopy image for which
you want to resume Enhanced FlashCopy logical drive
operations. The name of an Enhanced FlashCopy image
is comprised of two parts:
v The name of the Enhanced FlashCopy group
v An identifier for the Enhanced FlashCopy image in the
Enhanced FlashCopy group.
Notes
The name of an Enhanced FlashCopy image has two parts separated by a colon (:):
v The identifier of the Enhanced FlashCopy group
3-146 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
v The identifier of the Enhanced FlashCopy image
For example, if you want to resume Enhanced FlashCopy logical drive operations for Enhanced
FlashCopy image 12345 in an Enhanced FlashCopy group that has the name enhancedFlashCopyGroup1,
you would use this command:
resume enhancedFlashCopyLogicalDrive [enhancedFlashCopyVol1]
enhancedFlashCopyImage=["enhancedFlashCopyGroup1:12345"];
To resume Enhanced FlashCopy logical drive operations for the most recent Enhanced FlashCopy image
in an Enhanced FlashCopy group that has the name enhancedFlashCopyGroup1, you would use this
command:
resume enhancedFlashCopyLogicalDrive [enhancedFlashCopyVol1]
enhancedFlashCopyImage=["enhancedFlashCopyGroup1:newest"];
If the rollback operation cannot be resumed, the selected FlashCopy logical drive reverts to a paused
state, and the Needs Attention condition is displayed.
Syntax
resume rollback logicaldrive [flashcopyLogicalDriveName]
Parameters
Parameter Description
logicaldrive The name of the specific FlashCopy logical drive for
which you want to resume a rollback operation. Enclose
the FlashCopy logical drive name in square brackets ([ ]).
If the FlashCopy logical drive name has special
characters, you must also enclose the FlashCopy logical
drive name in double quotation marks (" ").
Syntax
resume remoteMirror (primary [logicalDriveName] |
primaries [logicalDriveName1 ... logicalDriveNameN])
[writeConsistency=(TRUE | FALSE)}
Notes
If you set the writeConsistency parameter to TRUE, the logical drives must be in a write-consistency
group (or groups). This command resumes all write-consistency groups that contain the logical drives.
For example, if logical drives A, B, and C are in a write-consistency group and they have remote
counterparts A, B, and C, the resume remoteMirror logicalDrive [A] writeConsistency=TRUE
command resumes A-A, B-B, and C-C.
Revive Array
This command forces the specified array and its associated failed disk drives to the Optimal state.
Attention: Possible loss of data access or data integrity issues Correct use of this command depends
on the data configuration on all of the disk drives in the array. Never try to revive a disk drive unless
you are supervised by an IBM Technical Support representative.
Syntax
revive array [arrayName]
Parameter
Parameter Description
array The alphanumeric identifier (including - and _) of the array
to be set to the Optimal state. Enclose the array identifier in
square brackets ([ ]).
Attention: Possible loss of data access or possible data integrity issues Correct use of this command
depends on the data configuration on all of the disk drives in the array. Never try to revive a disk drive
unless you are supervised by an IBM Technical Support representative.
Syntax
revive drive [enclosureID,drawerID,slotID]
3-148 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Parameter
Parameter Description
drive The location of the drive that you want to revive. For
high-capacity disk drive expansion enclosures, specify the
enclosure ID value, the drawer ID value, and the slot ID
value for the disk drive. For low-capacity drive expansion
enclosures, specify the enclosure ID value and the slot ID
value for the disk drive. Enclosure ID values are 0 to 99.
Drawer ID values are 1 to 5. Slot ID values are 1 to 32.
Enclose the enclosure ID value, the drawer ID value, and
the slot ID value in square brackets ([ ]).
Notes
The drive parameter supports both high-capacity drive expansion enclosures and low-capacity drive
expansion enclosures. A high-capacity drive expansion enclosure has drawers that hold the drives. The
drawers slide out of the drive expansion enclosure to provide access to the drives. A low-capacity drive
expansion enclosure does not have drawers. For a high-capacity drive expansion enclosure, you must
specify the identifier (ID) of the drive expansion enclosure, the ID of the drawer, and the ID of the slot in
which a drive resides. For a low-capacity drive expansion enclosure, you need only specify the ID of the
drive expansion enclosure and the ID of the slot in which a drive resides. For a low-capacity drive
expansion enclosure, an alternative method for identifying a location for a drive is to specify the ID of
the drive expansion enclosure, set the ID of the drawer to 0, and specify the ID of the slot in which a
drive resides.
Syntax
revive enhancedFlashCopyGroup [enhancedFlashCopyGroupName]
Parameters
Parameter Description
enhancedFlashCopyGroup The alphanumeric identifier (including - and _) of the
Enhanced FlashCopy group that you want to set to the
Optimal state. Enclose the Enhanced FlashCopy group
identifier in square brackets ([ ]).
If the Enhanced FlashCopy logical drive is not in a Failed state, the firmware displays an error message
and does not run this command.
Syntax
revive enhancedFlashCopyLogicalDrive [enhancedFlashCopyLogicalDriveName]
Parameters
Parameter Description
enhancedFlashCopyLogicalDrive The name of the Enhanced FlashCopy logical drive that
you want to set to the Optimal state. Enclose the
Enhanced FlashCopy logical drive name in square
brackets ([ ]).
Notes
You can use any combination of alphanumeric characters, underscore (_), hyphen (-), and pound (#) for
the names. Names can have a maximum of 30 characters.
Syntax
save controller [(a | b)]
NVSRAM file=filename
Parameters
Parameter Description
controller The controller with the NVSRAM values that you
want to save. Valid controller identifiers are a or b,
where a is the controller in slot A, and b is the
controller in slot B. Enclose the controller identifier in
square brackets ([ ]).
file The file path and the file name to which you want to
save the NVSRAM values. Enclose the NVSRAM file
name in double quotation marks (" "). For example:
file="C:\Program Files\CLI\logs\nvsramb.txt"
See the Start Drive Channel Fault Isolation Diagnostics on page 3-257 command for more information.
3-150 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Syntax
save DriveChannel [drive-channel-Identifier] faultDiagnostics file=filename
Parameter
Parameter Description
file The file path and the file name to which you want to save
the results of the fault isolation diagnostics test on the disk
drive channel. Enclose the file name in double quotation
marks ( ). For example: file="C:\Program
Files\CLI\sup\fltdiag.txt"
Notes
A file extension is not automatically appended to the saved file. You must specify the applicable format
suffix for the file. If you specify a file extension of .txt, then the output will be in a text file format. If
you specify a file extension of .xml, then the output will be in an XML file format.
Syntax
save allDrives logFile=filename
Parameter
Parameter Description
logFile The file path and the file name to which you want to
save the log sense data. Enclose the file name in double
quotation marks (" "). For example:
file="C:\Program Files\CLI\logs\lgsendat.txt"
Syntax
save allEnclosures logFile="filename"
Syntax
save storageSubsystem configuration file=filename
[(allconfig | globalSettings=(TRUE | FALSE)
logicalDriveConfigAndSettings=(TRUE | FALSE)
hostTopology=(TRUE | FALSE)
lunMappings=(TRUE | FALSE))]
Parameters
Parameter Description
file The name of the file that contains the
configuration values. Enclose the file name in
double quotation marks ( ).
allConfig The setting to save all of the configuration values
to the file. (If you choose this parameter, all of the
configuration parameters are set to TRUE.)
globalSettings The setting to save the global settings to the file.
To save the global settings, set this parameter to
TRUE. To prevent saving the global settings, set this
parameter to FALSE. The default value is TRUE.
logicalDriveConfigAndSettings The setting to save the logical drive configuration
settings and all of the global settings to the file. To
save the logical drive configuration settings and
global settings, set this parameter to TRUE. To
prevent saving the logical drive configuration
settings and global settings, set this parameter to
FALSE. The default value is TRUE.
hostTopology The setting to save the host topology to the file. To
save the host topology, set this parameter to TRUE.
To prevent saving the host topology, set this
parameter to FALSE. The default value is FALSE.
lunMappings The setting to save the LUN mapping to the file.
To save the LUN mapping, set this parameter to
TRUE. To prevent saving the LUN mapping, set this
parameter to FALSE. The default value is FALSE.
3-152 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Notes
When you use this command, you can specify any combination of the parameters for the global setting,
the logical drive configuration setting, the host topology, or the LUN mapping. If you want to enter all
settings, use the allConfig parameter. The parameters are all optional.
Syntax
save storageSubsystem dbmDatabase file="filename"
Parameter
Parameter Description
file The file path and the file name of the DBM database you
want to save. Enclose the file name in double quotation
marks (" "). For example: file="C:\Subsystem
Backups\DBMbackup_03302010.dbm"
Syntax
save storageSubsystem dbmValidatorInfo file="filename" dbmDatabase="filename"
Parameters
Parameter Description
file The file path and the file name of the DBM Validator
required for IBM Technical Support representative. Enclose
the file name in double quotation marks (" "). For example:
file="C:\Subsystem Backups \DBMvalidator.xml"
Notes
If you are generating the XML information file in order to obtain a validator string, you must run this
command while you are connected to the controller where you intend to restore the database. The
following example show the format of the XML file:
<?xml version="1.0" encoding="utf-8"?>
<DbmImageMetadata>
<Controllers>
<A>1IT0nnnnnnnnnABCD</A>
<B>1T0nnnnnnnnnABCD</B>
</Controllers>
<Header>
<ImageVersion>1</ImageVersion>
<TimeStamp>1269388283</TimeStamp>
</Header>
<Trailer>
<CRC>nnnnnnnnnn</CRC><
/Trailer>
</DbmImageMetadata>
After you saving the diagnostic data, you can reset the NVSRAM registers that contain the diagnostic
data so that the old data can be overwritten. Use the reset storageSubsystem diagnosticData command
to reset the diagnostic data registers.
Important: Run this command only with the assistance of an IBM Technical Support representative.
Syntax
save storageSubsystem diagnosticData [(controller | esm)]
file=filename
Parameters
Parameter Description
diagnosticData This parameter allows you to downloads the diagnostic data
from either the controllers or the ESMs.
file The name of the file to which you want to save the diagnostic
data. Enclose the file name in double quotation marks ( ).
3-154 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Save Storage Subsystem Diagnostic Data Capture
This command saves a diagnostic data capture to a specified file on a host.
Syntax
save storageSubsystem ddc file="filename"
Parameters
Parameter Description
file The file path and the file name to which you save the
diagnostic data capture. Enclose the file name in double
quotation marks (" "). For example:
file="C:\Array Backups\DBMbackup_03302010.core"
Syntax
save storageSubsystem (allEvents | criticalEvents)
file=filename
[count=numberOfEvents]
Parameters
Parameter Description
file The name of the file to which you want to save the events. Enclose
the file name in double quotation marks ( ).
count The number of events or critical events that you want to save to a
file. If you do not enter a value for the count, all events or all critical
events are saved to the file. If you enter a value for the count, only
that number of events or critical events (starting with the last event
entered) are saved to the file. Use integer values.
Notes
You have the option to save all events (allEvents) or only the critical events (criticalEvents).
You can use the information to help identify out-of-date firmware or firmware that does not match the
other firmware in your storage subsystem. You can also send the report to your IBM Technical Support
representative for further review.
Parameter
Parameter Description
file The file path and the file name to which you want to save
the firmware inventory. Enclose the file name in double
quotation marks (" "). For example: file="C:\Subsystem
Backups\DBMbackup_03302010.dbm"C:\Program
Files\CLI\logs\fwinvent.txt"
Syntax
save storageSubsystem iscsiStatistics [raw | baseline]
file=filename
Parameters
Parameter Description
raw The statistics collected are all statistics from the controller
start-of-day. Enclose the parameter in square brackets ([ ]).
baseline The statistics that are collected are all statistics from the time the
controllers were reset to zero using the reset storageSubsystem
iscsiStatsBaseline command. Enclose the parameter in square
brackets ([ ]).
file The name of the file to which you want to save the performance
statistics. Enclose the file name in double quotation marks ( ).
Notes
If you have not reset the iSCSI baseline statistics since the controller startofday, the time at the
startofday is the default baseline time.
Syntax
save storageSubsystem performanceStats file=filename
3-156 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Parameter
Parameter Description
file The name of the file to which you want to save the performance statistics. Enclose the
file name in double quotation marks ( ). For example:
save storageSubsystem performanceStats
file="C:\Program Files\CLI\reports\stats.csv"
This command does not automatically append a file extension to the saved file. You
can use any file name, but you must specify the .csv extension.
Syntax
save storageSubsystem RLSCounts file=filename
Parameter
Parameter Description
file The name of the file to which you want to save the RLS
counters. Enclose the file name in double quotation marks
( ).
Notes
Syntax
save storageSubsystem SASPHYCounts file="filename"
Parameter
Parameter Description
file The file path and the file name to which you want to save
the SYSPHY counters. Enclose the file path and the file name
in double quotation marks (" "). For example:
file="C:\Program Files\CLI\logs\sasphy.csv"
Syntax
save storageSubsystem SOCCounts file=filename
Parameter
Parameter Description
file The name of the file to which you want to save the SOC error
statistics. Enclose the file name in double quotation marks
( ).
Notes
To more effectively save SOC error statistics to a file, perform these steps:
1. Run the reset storageSubsystem SOCBaseline command to set all of the SOC counters to 0.
2. Run the storage subsystem for a predetermined amount of time (for example, two hours).
3. Run the save storageSubsystem SOCCounts file=filename command.
Syntax
save storageSubsystem stateCapture file=filename
Parameter
Parameter Description
file The name of the file to which you want to save the state
capture. Enclose the file name in double quotation marks
( ). For example:
file="C:\Program Files\CLI\logs\state.zip"
CAUTION:
Only do this when Technical Support requests it.
3-158 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
v The NVSRAM data
v Current problems and associated recovery information
v The performance statistics for the entire storage subsystem
v The persistent registration information and the persistent reservation information
v Detailed information about the current status of the storage subsystem
v The diagnostic data for the disk drive
v A recovery profile for the storage subsystem
v The unreadable sectors that are detected on the storage subsystem
v The state capture data
v An inventory of the versions of the firmware running on the controllers, the drives, the drawers, and
the environmental services modules (ESMs)
Syntax
save storageSubsystem supportData file="
filename" [force=(TRUE | FALSE)]
Parameter
Parameter Description
file The name of the file to which you want to save the support-related
data for the storage subsystem. Enclose the file name in double
quotation marks ( ).
force This parameter forces the collection of support data if there are any
failures in securing a lock on controller operations. To force the
collection of support data, set this parameter to TRUE. The default
value is FALSE.
Syntax
Attention: The SM CLI support bundle commands must be run from the SM CLI command line
interface only. They cannot be run from the storage subsystem SM CLI script window. In addition, the
storage subsystem IP addresses are not required. Also, the -c parameter is not required to precede the SM
CLI support bundle command.
<installed-SM-Directory>SMcli -supportBundle schedule (enable|disable) (all|storageSubsystemName)
[data=pathName]
[startTime=HH:MM]
[startDate=MM:DD:YY]
[endDate=MM:DD:YY]
(daysOfWeek={} | months={}
(onDays={} |
weekNumber=(First|Second|Third|Fourth|Lasdta)y
OfWeek=(Sunday|Monday|Tuesday|Wednesday|Thursday|Friday|Saturday))
Parameters
Parameter Description
enable Enable automatic collection of support bundles when a
critical MEL event is detected.
Note: The defined schedule is stored in the management station that the Storage Manager host software
has been installed. This is where the schedule is initially defined and enabled for the managed storage
subsystems. For example, you have installed the Storage Manager host software on two different
management stations, and defined the schedule in only one subsystem. The schedule show command in
the management station where the schedule is not defined will display a no schedule found message. In
addition, if multiple management stations have been enabled for the schedule to automatically collect the
support data from a single storage subsystem, this subsystem will have support data collected multiple
times, depending on the schedule defined within the management stations. IBM recommends that you
define support data collection in only one workstation, if there are multiple management stations that are
available to manage a given storage subsystem.
An example of the SMcli command to disable automatic support bundle in a Microsoft Windows
management station, with default Storage Manager software installed path, is as follows:
c:\Program Files (x86)\IBM_DS\client>SMcli -supportBundle auto disable all
SMcli completed successfully.
Another example of the SMcli command that displays the automatically support bundle collection
schedule in a Microsoft Windows management station is as follows:
c:\Program Files (x86)\IBM_DS\client>SMcli -supportBundle schedule show
Array Name Existing Schedule Starting Ending
DS3524-DTL139140 Daily / Weekly - Mon - Fri 05/23/2012 02:00AM 05/30/2012
DS3524-DTL Daily / Weekly - Mon - Fri 05/23/2012 02:00AM 05/30/2012
DS3400A None
DS5100-DTL None
Note: In Microsoft Windows OS, the command prompt window must have administrator authority or the
command will fail with an error message as shown below:
C:\Program Files (x86)\IBM_DS\client>SMcli -supportBundle auto disable all
Incorrect Usage
Do not modify any parameters to the command. Some examples are as follows:
3-160 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Set Array
This command defines the properties for an array.
Syntax
set array [arrayNumber]
addDrives=(enclosureID1,drawerID1,slotID1 ... enclosureIDn,drawerIDn,slotIDn)
raidLevel=(0 | 1 | 3 | 5 | 6)
owner=(a | b)
Parameters
Parameter Description
array The alphanumeric identifier (including - and _) of the array
for which you want to set properties. Enclose the array
identifier in square brackets ([ ]).
addDrives The location of the disk drive that you want to add to the
array. For high-capacity disk drive expansion enclosures,
specify the enclosure ID value, the drawer ID value, and the
slot ID value for the disk drive. For low-capacity drive
expansion enclosures, specify the enclosure ID value and the
slot ID value for the disk drive. Enclosure ID values are 0 to
99. Drawer ID values are 1 to 5. Slot ID values are 1 to 32.
Enclose the enclosure ID value, the drawer ID value, and the
slot ID value in parentheses.
raidLevel The RAID level for the array. Valid values are 0, 1, 3, 5, or 6.
owner The controller that owns the array. Valid controller identifiers
are a or b, where a is the controller in slot A, and b is the
controller in slot B. Use this parameter only if you want to
change the array owner.
Notes
Host I/O errors might result in arrays with more than 32 logical drives. This operation also might result
in internal controller reboots because the timeout period ends before the array definition is set. If you
experience this issue, quiesce the host I/O operations, and try the command again.
When you use this command, you can specify one or more of the parameters.
Important: Specifying the addDrives parameter or the raidLevel parameter starts a long-running
operation that you cannot stop.
The addDrives parameter supports both high-capacity and low-capacity drive expansion enclosures. A
high-capacity drive expansion enclosure has drawers that hold the drives. The drawers slide out of the
drive expansion enclosure to provide access to the drives. A low-capacity drive expansion enclosure does
not have drawers. For a high-capacity drive expansion enclosure, you must specify the identifier (ID) of
the drive expansion enclosure, the ID of the drawer, and the ID of the slot in which a drive resides. For a
low-capacity drive expansion enclosure, you need to specify the ID of the drive expansion enclosure and
the ID of the slot in which a drive resides. For a low-capacity drive expansion enclosure, an alternative
method for identifying a location for a drive is to specify the ID of the drive expansion enclosure, set the
ID of the drawer to 0, and specify the ID of the slot in which a drive resides.
An attempt to expand large arrays by adding drives, also called Dynamic Capacity Expansion (DCE),
might fail with the following message:
Return code: Error 26 - The modification operation cannot complete because
of the number of drives in the array and the segment size of the associated
logical drives. Reduce the segment size of all logical drives in the array
to 128 KB or below using the Change Segment Size option. Then, retry the
operation.
Systems running 7.35.xx.xx firmware might fail with the following message instead of the message given
earlier:
Return code: Error 462 - A SYMbol procedure could not be carried out because
the firmware could not allocate sufficient cache memory. Operation when
error occurred: PROC_startVolum
In addition to the above messages, a Major Event Log (MEL) event that indicates unavailability of
sufficient cache to complete the DCE operation might occur.
Any controller running 7.xx firmware can encounter this problem. DCE requires enough memory to
buffer the data read from the original logical drive and the data to be written to the expanded logical
drive. Some combination of number of drives in the expansion operation, stripe size, and whether
mirroring is enabled may result in not enough memory being available to complete the DCE operation.
Syntax
set array [arrayName] forcedState
Parameter
Parameter Description
array The alphanumeric identifier (including - and _) of the array
that you want to place in a Forced state. Enclose the array
identifier in square brackets ([ ]).
Notes
You can move the disk drives that comprise an array from one storage subsystem to another storage
subsystem. The CLI provides three commands that let you move the disk drives. The commands are
start array export, start array import, and set array forcedState.
In the Forced state, you can perform an import operation on the array.
3-162 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Set Consistency Group Attributes
This command defines the properties for an Enhanced FlashCopy consistency group.
Syntax
set consistencyGroup ["consistencyGroupName"]
[userLabel="consistencyGroupName" |
repositoryFullPolicy=(failBaseWrites | purgeEnhancedFlashCopyImages)|
repositoryFullLimit=percentValue|
autoDeleteLimit=numberOfEnhancedFlashCopyImages|
rollbackPriority=(lowest | low | medium | high | highest)]
Parameters
Parameter Description
consistencyGroupName The name of the consistency group for which you are
setting properties. Enclose the consistency group name in
double quotation marks (" ") inside square brackets ([ ]).
userLabel The new name that you want to give to the Enhanced
FlashCopy consistency group. Enclose the new
consistency group name in double quotation marks (" ").
repositoryFullPolicy How you want Enhanced FlashCopy processing to
continue if the Enhanced FlashCopy repository logical
drives are full. You can choose to fail writing to the base
logical drive (failBaseWrites) or delete (purge) the
Enhanced FlashCopy images
(purgeEnhancedFlashCopyImages). The default action is
purgeEnhancedFlashCopyImages.
repositoryFullLimit The percentage of repository capacity at which you
receive a warning that the Enhanced FlashCopy
repository logical drive is nearing full. Use integer
values. For example, a value of 70 means 70 percent. The
default value is 75.
autoDeleteLimit The maximum number of Enhanced FlashCopy images
that you want to automatically delete if you have
selected to purge the Enhanced FlashCopy images for a
repository full policy. The default value is 32.
rollBackPriority The priority for rollback operations for a consistency
group while the storage subsystem is operational. Valid
values are highest, high, medium, low, or lowest.
Notes
You can use any combination of alphanumeric characters, underscore (_), hyphen (-), and pound (#) for
the names. Names can have a maximum of 30 characters.
When you use this command, you can specify one or more of the parameters. You do not, however, need
to use all of the parameters.
The rollback priority defines the amount of system resources that should be allocated to the rollback
operation at the expense of system performance. A value of high indicates that the rollback operation is
prioritized over all other host I/O. A value of low indicates that the rollback operation should be
performed with minimal impact to host I/O.
Syntax
set cgEnhancedFlashCopyLogicalDrive [consistencyGroupName]
userLabel="enhancedFlashCopyLogical DriveName"
Parameters
Parameter Description
cgEnhancedFlashCopyLogicalDrive The name of the consistency group logical drive that you
want to rename. Enclose the name of the consistency
group Enhanced FlashCopy logical drive in square
brackets ([ ]).
userLabel The new name that you want to give to the Enhanced
FlashCopy logical drive in the consistency group. Enclose
the new Enhanced FlashCopy logical drive name in
double quotation marks (" ").
Notes
You can use any combination of alphanumeric characters, underscore (_), hyphen (-), and pound (#) for
the names. Names can have a maximum of 30 characters.
Set Controller
This command defines the attributes for the controllers.
Syntax
set controller [(a | b)]
availability=(online | offline | serviceMode) |
ethernetPort [(1 | 2)] ethernetPortOptions |
globalNVSRAMByte [nvsramOffset]=(nvsramByteSetting | nvsramBitSetting) |
hostNVSRAMByte [hostType, nvsramOffset]=(nvsramByteSetting | nvsramBitSetting) |
IPv4GatewayIP=ipAddress | IPv6RouterAddress=ipv6Address |
iscsiHostPort [(1 | 2 | 3 | 4)] iscsiHostPortOptions |
rloginEnabled=(TRUE | FALSE) |
serviceAllowedIndicator=(on | off
Parameters
Parameter Description
controller The controller for which you want to define
properties. Valid identifiers for the controller are a or
b, where a is the controller in slot A and b is the
controller in slot B. Enclose the controller identifier
in square brackets ([ ]). If you do not specify a
controller, the firmware for the controller returns a
syntax error.
availability The mode for the controller. The controller modes are
online, offline, or serviceMode.
3-164 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Parameter Description
ethernetPort The attributes (options) for the management Ethernet
ports. The entries to support this parameter are listed
in the Syntax Element Statement Data table that
follows. Many settings are possible, including setting
the IP address, the gateway address, and the subnet
mask address.
globalNVSRAMByte A portion of the controller NVSRAM. Specify the
region that you want to modify by using the starting
byte offset within the region, and the size and value
of the new data to be stored into NVSRAM.
hostNVSRAMByte The NVSRAM for the host-specific region. The
setting specifies the host index for the specific host,
the starting offset within the region, the number of
bytes, and the values to be written.
hostNVSRAMByte The NVSRAM for the host-specific region. The
setting specifies the host index for the specific host,
the starting offset within the region, the number of
bytes, and the the byte value or bit value of the new
data to be stored into the NVSRAM.
IPv4GatewayIP The IP address of the node that provides the
interface to the network. The address format for the
IPv4 gateway is (0255).(0255).(0255).(0255)
IPv6RouterAddress The IP address of IPv6 router that connects two or
more logical subnets. The address format for the
IPv6 router is (0FFFF):(0FFFF):(0FFFF):(0FFFF):
(0FFFF):(0FFFF):(0FFFF):(0FFFF).
iscsiHostPort The entries to support this parameter are listed in
the Syntax Element Statement Data table that
follows. Many settings are possible, including setting
the IP address, the gateway address, the subnet mask
address, the IPv4 priority, and the IPv6 priority.
rloginEnabled The setting for whether the remote login feature is
turned on or turned off. To turn on the remote login
feature, set this parameter to TRUE. To turn off the
remote login feature, set this parameter to FALSE.
serviceAllowedIndicator The setting for whether the Service Action Allowed
indicator light is turned on or turned off. To turn on
the Service Action Allowed indicator light, set this
parameter to on. To turn off the Service Action
Allowed indicator light, set this parameter to off.
Notes
Before firmware version 7.75, the set controller command supported an NVSRAMByte parameter. The
NVSRAMByte parameter is deprecated and must be replaced with either the hostNVSRAMByte
parameter or the globalNVSRAMByte parameter.
When you use this command, you can specify one or more of the parameters. You do not need to use all
of the parameters.
Setting the availability parameter to serviceMode causes the alternate controller to take ownership of all
of the virtual disks. The specified controller no longer has any logical drives and refuses to take
ownership of any more logical drives. Service mode is persistent across reset cycles and power cycles
until the availability parameter is set to online.
To make sure that the IPv4 settings or the IPv6 settings are applied, you must set these iscsiHostPort
options:
v enableIPV4= TRUE
v enableIPV6= TRUE
The IPv6 address space is 128 bits. It is represented by eight 16-bit hexadecimal blocks separated by
colons.
The maxFramePayload parameter is shared between IPv4 and IPv6. The payload portion of a standard
Ethernet frame is set at 1500, and a jumbo Ethernet frame is set at 9000. When using jumbo frames, all of
the devices that are in the network path should be capable of handling the larger frame size.
Values for the portSpeed option of the iscsiHostPort parameter are in megabits per second (Mb/s).
The following values are the default values for the iscsiHostOptions:
v The IPv6HopLimit option is 64.
v The IPv6NdReachableTime option is 30000 milliseconds.
v The IPv6NdRetransmitTime option is 1000 milliseconds.
v The IPv6NdTimeOut option is 30000 milliseconds.
v The tcpListeningPort option is 3260.
Syntax
set controller=[(a | b)] serviceAllowedIndicator=(on | off
Parameters
Parameter Description
controller The controller that has the Service Action
Allowed indicator light that you want to turn
on or turn off. Valid controller identifiers are a
or b, where a is the controller in slot A, and b
is the controller in slot B. Enclose the controller
identifier in square brackets ([ ]). If you do not
specify a controller, the controller firmware
returns a syntax error.
Notes
This command was originally defined for use with the DS4800 (models 82, 84, and 88) controller module.
This command is not supported by controller modules that were shipped before the introduction of the
DS4800 (models 82, 84, and 88) controller module. The DS3500 series, DS3950, DS4200, DS4700, DS5020,
DS5100, and DS5300 controllers also support this command.
Syntax
set diskPool (diskPool=[
diskPoolName] | diskPools=[diskPoolName1... diskPoolNamen] | allDiskPools)
[reserveDriveCount=reserveDriveCountValue |
warningThreshold=(warningThresholdValue | default) |
criticalThreshold=(criticalThresholdValue | default) |
criticalPriority=(highest|high|medium|low|lowest) |
degradedPriority=(highest|high|medium|low|lowest)
backgroundPriority=(highest|high|medium|low|lowest) | userLabel=diskPoolName]
Parameters
Parameter Description
diskPool or diskPools The name of the disk pool for which you are setting
attributes. Enclose the disk pool name in square brackets
([ ]).
You can enter more than one disk pool name if you use
the diskPools parameter. Enclose all of the disk pool
names in a single set of square brackets ([ ]). Separate
each disk pool name with a space. If you have special
characters in a disk pool name, you must also enclose
that name in double quotation marks (" ").
allDiskPools This parameter sets attributes for all of the disk pools in
the storage subsystem
reserveDriveCount This parameter sets the number of drives to be reserved
in the disk pool for drive failures or drive removals.
Setting this value to 0 results in a possible loss of data if
a drive failure occurs in a disk pool.
warningThreshold The percentage of disk pool capacity at which you
receive a warning alert that the disk pool is nearing full.
Use integer values. For example, a value of 70 means 70
percent. For best operation, the value for this parameter
must be less than the value for the criticalThreshold
parameter.
3-168 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Parameter Description
criticalThreshold The percentage of disk pool capacity at which you
receive a critical alert that the disk pool is nearing full.
Use integer values. For example, a value of 70 means 70
percent. For best operation, the value for this parameter
must be greater than the value for the warningThreshold
parameter.
Notes
Each disk pool name must be unique. You can use any combination of alphanumeric characters,
underscore (_), hyphen(-), and pound (#) for the user label. User labels can have a maximum of 30
characters.
You can specify an arbitrary set of disk pools. If you select multiple disk pools, setting a value for the
userLabel parameter causes an error.
If you do not specify a value for an optional parameter, a default value is assigned.
Each disk pool has two progressively severe levels of alerts to inform users when the storage capacity of
the disk pool is approaching full. The threshold for an alert is a percent of the used capacity to the total
usable capacity in the disk pool. The alerts are:
v Warning This is the first level of alert that the used capacity in a disk pool is approaching full. When
the threshold for the warning alert is reached a Needs Attention condition is generated and an event is
posted to the storage management software. The warning threshold is superseded by the critical
threshold. The default warning threshold is 50 percent.
v Critical This is the most severe level of alert that the used capacity in a disk pool is approaching
full. When the threshold for the critical alert is reached a Needs Attention condition is generated and
an event is posted to the storage management software. The warning threshold is superseded by the
critical threshold. The default warning threshold is 85 percent.
To be effective, the value for a warning alert must always be less than the value for a critical alert. If the
value for the warning alert is the same as the value for a critical alert, only the critical alert is sent.
Disk pools do not queue background commands. You can start several background commands
sequentially, but starting more than one background operation at a time delays the completion of
commands that you started previously. The relative priority levels for the supported background
operations are:
1. Reconstruction
2. Format
3. IAF
4. DCE
Syntax
set diskPool [
diskPoolName] ((addDrives=[enclosureID1,drawerID1,slotID1 ... enclosureIDn,drawerIDn,slotIDn] |
addCapacity=(diskPoolCapacity)) | owner=(a | b))
Parameters
Parameter Description
diskPool The name of the disk pool that you want to modify.
Enclose the disk pool name in square brackets ([ ]).
addDrives The drive s that you want to add to the disk pool. For
high-capacity drive enclosures, specify the enclosure ID
value, the drawer ID value, and the slot ID value of the
drive that you want to add. For low-capacity drive
enclosures, specify the enclosure ID value and the slot ID
value of the drive that you want to add. Enclosure ID
values are 0 to 99. Drawer ID values are 1 to 5. Slot ID
values are 1 to 32. Enclose the enclosure ID value, the
drawer ID value, and the slot ID value in square brackets
([ ]).
addCapacity The amount of additional storage capacity that you want
to add to the disk pool. This parameter automatically
selects the drives to meet the capacity that you want to
add. The capacity is defined in units of bytes, KB, MB, GB,
or TB.
owner The controller that owns the disk pool. Valid controller
identifiers are a or b, where a is the controller in slot A,
and b is the controller in slot B. If you do not specify an
owner, the controller firmware determines the owner.
3-170 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Notes
Logical Drives already in the disk pool remain on line and available for I/O operations while you add
new drives. The disk pool must be in the Complete state before you add capacity.
To add capacity, specify individual drives with the addDrives parameter, or an amount of drive capacity
with the addCapacity parameter. If you use addDrives, the host must validate the drive set before
allowing the operation to run. If you use the addCapacity parameter, the capacity you specify is taken as
the minimum capacity to be added. The candidate drives with the best match for quality of service and a
capacity greater than or equal to what you specified are used. If no candidate is available with a
minimum match, or the drive list specified is not available or attribute mismatches are detected, the
operation fails.
You can also use this command to change ownership of a disk pool from one controller in the storage
subsystem to the other. Using this command to change ownership is mutually exclusive with using the
command to add drives or to add capacity.
Syntax
set enclosure [enclosureID]
drawer [drawerID]
serviceAllowedIndicator=(on | off | forceOnWarning)
Parameters
Parameter Description
enclosure The enclosure where the drawer resides. Enclosure ID
values are 0 to 99. Enclose the enclosure ID value in
square brackets ([ ]). If you do not enter an enclosure ID
value, the enclosure ID of the controller module is the
default value.
drawer The location of the drawer for which you want to turn
on or turn off the service action allowed indicator.
Drawer ID values are 1 to 5. Enclose the value in square
brackets ([ ]).
serviceAllowedIndicator The setting to turn on or turn off the Service Action
Allowed indicator light. To turn on the Service Action
Allowed indicator light, set this parameter to on. To turn
off the Service Action Allowed indicator light, set this
parameter to off.
Notes
Before you can enter this command, the expansion drawer must meet these conditions:
v The expansion drawer cannot be over temperature.
v The fans must have a status of Optimal.
Attention
Syntax
set driveChannel [(1 | 2 | 3 | 4 | 5 | 6 | 7 | 8)]
status=(optimal | degraded)
Parameters
Parameter Description
driveChannel The identifier number of the disk drive channel for which
you want to set the status. Valid disk drive channel values are
1, 2, 3, or 4. Enclose the disk drive channel number in square
brackets ([ ]).
status The condition of the disk drive channel. You can set the disk
drive channel status to optimal or degraded.
Notes
Use the optimal value to move a degraded disk drive channel back to the Optimal state. Use the
degraded value when the disk drive channel is experiencing problems, and the storage subsystem
requires additional time for data transfers.
Syntax
set (Drive [enclosureID,drawerID1,slotID] |
Drives (enclosureID1,drawerID1,slotID1 ... enclosureIDn,drawerIDn,slotIDn)
hotSpare=(TRUE | FALSE)
3-172 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Parameters
Parameter Description
drive or drives EnclosureID1,drawerID1,slotID1 ...
enclosureIDn,drawerIDn,slotIDn is for enclosures with
multiple disk drive drawers. For enclosures without disk
drive drawers, use enclosureID1,slotID1 ...
enclosureIDn,slotIDn instead. Enclosure ID values are 0 to 99.
Drawer ID values are 1 to 5. Slot ID values are 1 to 32.
Enclose the values in square brackets ([ ]).
hotSpare The setting to assign the disk drive as the hot spare. To assign
the disk drive as the hot spare, set this parameter to TRUE. To
remove a hot spare assignment from a disk drive, set this
parameter to FALSE.
Notes
The drive parameter supports both high-capacity drive expansion enclosures and low-capacity drive
expansion enclosures. A high-capacity drive expansion enclosure has drawers that hold the drives. The
drawers slide out of the drive expansion enclosure to provide access to the drives. A low-capacity drive
expansion enclosure does not have drawers. For a high-capacity drive expansion enclosure, you must
specify the identifier (ID) of the drive expansion enclosure, the ID of the drawer, and the ID of the slot in
which a drive resides. For a low-capacity drive expansion enclosure, you need only specify the ID of the
drive expansion enclosure and the ID of the slot in which a drive resides. For a low-capacity drive
expansion enclosure, an alternative method for identifying a location for a drive is to specify the ID of
the drive expansion enclosure, set the ID of the drawer to 0, and specify the ID of the slot in which a
drive resides.
Syntax
set (Drive [enclosureID,drawerID1,slotID] |
Drives (enclosureID1,drawerID1,slotID1 ... enclosureIDn,drawerIDn,slotIDn)
serviceAllowedIndicator=(on | off)
Parameters
Parameter Description
drive or drives The location of the disk drive for which you want to
turn on or turn off the Service Action Allowed indicator
light. For high-capacity drive expansion enclosures,
specify the enclosure ID value, the drawer ID value, and
the slot ID value for the drive. For low-capacity drive
expansion enclosures, specify the enclosure ID value and
the slot ID value for the drive. Enclosure ID values are 0
to 99. Drawer ID values are 1 to 5. Slot ID values are 1 to
32. Enclose the enclosure ID value, the drawer ID value,
and the slot ID value in square brackets ([ ]).
Notes
The drive parameter supports both high-capacity and low-capacity drive expansion enclosures. A
high-capacity drive expansion enclosure has drawers that hold the drives. The drawers slide out of the
drive expansion enclosure to provide access to the drives. A low-capacity drive expansion enclosure does
not have drawers. For a high-capacity drive expansion enclosure, you must specify the identifier (ID) of
the drive expansion enclosure, the ID of the drawer, and the ID of the slot in which a drive resides. For a
low-capacity drive expansion enclosure, you need to specify the ID of the drive expansion enclosure and
the ID of the slot in which a drive resides. For a low-capacity drive expansion enclosure, an alternative
method for identifying a location for a drive is to specify the ID of the drive expansion enclosure, set the
ID of the drawer to 0, and specify the ID of the slot in which a drive resides.
Syntax
set Drive [enclosureID1,drawerID1,slotID1 ... enclosureIDn,drawerIDn,slotIDn]
operationalState=failed
Parameter
Parameter Description
drive The enclosure, drawer, and the slot where the disk drive resides.
EnclosureID1,drawerID1,slotID1 ... enclosureIDn,drawerIDn,slotIDn
is for enclosures with multiple disk drive drawers. For enclosures
without disk drive drawers, use enclosureID1,slotID1 ...
enclosureIDn,slotIDn instead. Enclosure ID values are 0 to 99.
Drawer ID values are 1 to 5. Slot ID values are 1 to 32. Enclose the
values in square brackets ([ ]).
Notes
The drive parameter supports both high-capacity drive expansion enclosures and low-capacity drive
expansion enclosures. A high-capacity drive expansion enclosure has drawers that hold the drives. The
drawers slide out of the drive expansion enclosure to provide access to the drives. A low-capacity drive
expansion enclosure does not have drawers. For a high-capacity drive expansion enclosure, you must
specify the identifier (ID) of the drive expansion enclosure, the ID of the drawer, and the ID of the slot in
which a drive resides. For a low-capacity drive expansion enclosure, you need only specify the ID of the
drive expansion enclosure and the ID of the slot in which a drive resides. For a low-capacity drive
expansion enclosure, an alternative method for identifying a location for a drive is to specify the ID of
the drive expansion enclosure, set the ID of the drawer to 0, and specify the ID of the slot in which a
drive resides.
3-174 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Set Enclosure Alarm
This command turns on, turns off, or mutes the audible alarm for a specific enclosure or all of the
enclosures in a storage subsystem.
Syntax
set (allenclosures | enclosure [enclosureID]
alarm=(enable | disable | mute))
Parameters
Parameter Description
allEnclosures The setting to select all of the enclosures in a storage
subsystem that have audible alarms that you want to turn on,
turn off, or mute.
enclosure The specific enclosure that has the audible alarm that you
want to turn on, turn off, or mute. Enclosure ID values are 0
to 99. Enclose the enclosure ID value in square brackets ([ ]).
You can specify only one enclosure ID at a time
alarm The setting for the audible alarm. This alarm has these values:
v enable The audible alarm is turned on and sounds if a
fault occurs.
v disable The audible alarm is turned off and does not
sound if a fault occurs.
v mute The audible alarm is turned off if it is sounding.
(If another fault occurs after you set the audible alarm to mute,
the audible alarm sounds again.)
Syntax
set enclosure [serial-number] id=enclosureID
Parameters
Parameter Description
enclosure The serial number of the controller module, controller module,
or the expansion drawer for which you are setting the
enclosure ID. Serial numbers can be any combination of
alphanumeric characters and any length. Enclose the serial
number in double quotation marks ( ).
id The value for the controller module enclosure ID, controller
module enclosure ID, or the expansion drawer enclosure ID.
Enclosure ID values are 00 through 99. You do not need to
enclose the enclosure ID value in parentheses.
This command originally supported the DS4800 (models 82, 84, and 88) controller module. The DS4200,
DS4700, and DS4800 (models 82, 84, and 88) series controller modules can connect to a variety of
expansion drawers, including those whose enclosure IDs are set by switches. When connecting a
controller module to expansion drawers whose enclosure IDs are set by switches, recommended values
for enclosure IDs for the controller module are 80 through 99. This range avoids conflicts with enclosure
IDs that are used for attached expansion drawers.
To turn on or turn off the Service Action Allowed indicator light on the controller CRU, use the set
controller serviceAllowedIndicator command.
Syntax
set enclosure [enclosureID]
(powerFan [(left | right)] |
interconnect |
battery [(left | right)] |
esm [(left | right)])
serviceAllowedIndicator=(on | off)
Parameters
Parameter Description
enclosure The enclosure where the power-fan CRU, the
interconnect-battery CRU, or the ESM CRU resides.
Enclosure ID values are 0 to 99. Enclose the enclosure ID
value in square brackets ([ ]). If you do not enter a
enclosure ID value, the enclosure ID of the controller
module is the default value.
powerFan The Service Action Allowed indicator light on the
power-fan CRU that you want to turn on or turn off.
Valid power-fan CRU identifiers are left or right. The
values left and right are with respect to the front of the
DS5300, DS5100, and DS4800series controller
modules. Enclose the power-fan CRU identifier in square
brackets ([ ]).
interconnect The Service Action Allowed indicator light for the
interconnect-battery CRU DS5300, DS5100, and
DS4800series controller modules only.
battery The Service Action Allowed indicator light for a battery.
Valid battery identifiers are left or right. The values
left and right are with respect to the front of the
DS5300, DS5100, and DS4800series controller
modules.
esm The Service Action Allowed indicator light for an ESM
CRU. Valid ESM CRU identifiers are left or right. (The
values left and right are with respect to the rear of the
drive expansion enclosure.)
3-176 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Parameter Description
serviceAllowedIndicator The setting to turn on or turn off the Service Action
Allowed indicator light. To turn on the Service Action
Allowed indicator light, set this parameter to on. To turn
off the Service Action Allowed indicator light, set this
parameter to off.
Example
This command turns on the Service Action Allowed indicator light for the left ESM on enclosure 5 with
the IP address of 155.155.155.155.
SMcli 155.155.155.155 -c set enclosure [5] ESM [left] serviceAllowedIndicator=on;
Notes
This command was originally defined for use with the DS4800 (Models 82, 84, 88) controller enclosure.
This command is not supported by controller enclosures that were shipped before the introduction of the
DS4800 (Models 82, 84, 88) controller enclosure.
Syntax
set enhancedFlashCopyGroup ["
enhancedFlashCopyGroupName"]
[userLabel="enhancedFlashCopyGroupName" |
repositoryFullPolicy=(failBaseWrites |
purgeEnhancedFlashCopyImages) |
repositoryFullLimit=percentValue |
autoDeleteLimit=numberOfEnhancedFlashCopyImages |
rollbackPriority=(lowest | low | medium | high | highest)
Parameters
Parameter Description
enhancedFlashCopyGroup The alphanumeric identifier (including - and _) of the
Enhanced FlashCopy group for which you are setting
properties. Enclose the Enhanced FlashCopy group name
in double quotation marks (" ") inside of square brackets
([ ]).
userLabel The new alphanumeric identifier (including - and _) that
you want to give to the Enhanced FlashCopy group. Use
this parameter when you want to rename the Enhanced
FlashCopy group. Enclose the new Enhanced FlashCopy
group name in double quotation marks (" ").
repositoryFullPolicy How you want Enhanced FlashCopy image processing to
continue if the repository logical drives for the Enhanced
FlashCopy group are full. You can choose to fail writes to
the base logical drive ( failBaseWrites) or delete (purge)
the Enhanced FlashCopy images
(purgeEnhancedFlashCopyImages). The default action is
purgeEnhancedFlashCopyImages
Notes
You can use any combination of alphanumeric characters, underscore (_), hyphen (-), and pound (#) for
the names. Names can have a maximum of 30 characters.
When you use this command, you can specify one or more of the parameters. You do not, however, need
to use all of the parameters.
Syntax
set enhancedFlashCopyGroup ["
enhancedFlashCopyGroupName"] mediaScanEnabled=(TRUE | FALSE) redundancyCheckEnabled=(TRUE | FALSE)
Parameters
Parameter Description
enhancedFlashCopyGroup The alphanumeric identifier (including - and _) of the
Enhanced FlashCopy group on which you want to run a
media scan. Enclose the Enhanced FlashCopy group
name in double quotation marks (" ") inside of square
brackets ([ ]).
mediaScanEnabled The setting to turn on or turn off media scan for the
logical drive. To turn on media scan, set this parameter
to TRUE. To turn off media scan, set this parameter to
FALSE. (If media scan is disabled at the storage subsystem
level, this parameter has no effect.)
redundancyCheckEnabled The setting to turn on or turn off redundancy checking
during a media scan. To turn on redundancy checking,
set this parameter to TRUE. To turn off redundancy
checking, set this parameter to FALSE.
3-178 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Set Enhanced FlashCopy Group Schedule
This command defines the schedule for taking Enhanced FlashCopy images for an Enhanced FlashCopy
group.
Syntax
set enhancedFlashCopyGroup ["
enhancedFlashCopyGroupName"] enableSchedule=(TRUE | FALSE) schedule=(immediate | flashcopySchedule)
Parameters
Parameter Description
enhancedFlashCopyGroup The name of the Enhanced FlashCopy group for which
you are setting properties. Enclose the Enhanced
FlashCopy group name in double quotation marks (" ")
inside of square brackets ([ ]).
enableSchedule Use this parameter to turn on or to turn off the ability to
schedule an Enhanced FlashCopy operation. To turn on
Enhanced FlashCopy scheduling, set this parameter to
TRUE. To turn off Enhanced FlashCopy scheduling, set this
parameter to FALSE.
schedule Use this parameter to schedule an Enhanced FlashCopy
group operation.
Notes
You can use any combination of alphanumeric characters, underscore (_), hyphen (-), and pound (#) for
the names. Names can have a maximum of 30 characters.
The enableSchedule parameter and the schedule parameter provide a way for you to schedule creating
Enhanced FlashCopy images for an Enhanced FlashCopy group. Using these parameters, you can
schedule Enhanced FlashCopies daily, weekly, or monthly (by day or by date). The enableSchedule
parameter turns on or turns off the ability to schedule Enhanced FlashCopies. When you enable
scheduling, you use the schedule parameter to define when you want the Enhanced FlashCopies to occur.
This list explains how to use the options for the schedule parameter:
If you also use the scheduleInterval option, the firmware chooses between the timesPerDay option and
the scheduleInterval option by selecting the lowest value of the two options. The firmware calculates an
integer value for the scheduleInterval option by dividing 1440 by the scheduleInterval option value
that you set. For example, 1440/180 = 8. The firmware then compares the timesPerDay integer value
with the calculated scheduleInterval integer value and uses the smaller value.
To remove a schedule, use the delete logicaldrive command with the schedule parameter. The delete
logicaldrive command with the schedule parameter deletes only the schedule, not the Enhanced
FlashCopy logical drive.
The enableSchedule parameter and the schedule parameter provide a way for you to schedule automatic
Enhanced FlashCopy. Using these parameters, you can schedule Enhanced FlashCopy daily, weekly, or
monthly (by day or by date). The enableSchedule parameter turns on or turns off the ability to schedule
Enhanced FlashCopy. When you enable scheduling, you use the schedule parameter to define when you
want the Enhanced FlashCopy to occur.
This list explains how to use the options for the schedule parameter:
3-180 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
v immediate As soon as you enter the command, an Enhanced FlashCopy logical drive is created, and a
copy-on-write operation begins.
v startDate A specific date on which you want to create an Enhanced FlashCopy logical drive and
perform a copy-on-write operation. The format for entering the date is MM:DD:YY. If you do not
provide a start date, the current date is used. An example of this option is startDate=06:27:11.
v scheduleDay - A day of the week on which you want to create an Enhanced FlashCopy logical drive
and perform a copy-on-write operation. You can enter these values: monday, tuesday, wednesday,
thursday, friday, saturday, and sunday. An example of this option is scheduleDay=wednesday.
v startTime The time of a day that you want to create an Enhanced FlashCopy logical drive and start
performing a copy-on-write operation. The format for entering the time is HH:MM, where HH is the
hour and MM is the minute past the hour. Use a 24-hour clock. For example, 2:00 in the afternoon is
14:00. An example of this option is startTime=14:27
v scheduleInterval An amount of time, in minutes, that you want to have as a minimum between
copy-on-write operation. You can possibly create a schedule in which you have overlapping
copy-on-write operations because of the duration a copy operation. You can make sure that you have
time between copy-on-write operations by using this option. The maximum value for the
scheduleInterval option is 1440 minutes. An example of this option is scheduleInterval=180.
v endDate A specific date on which you want to stop creating an Enhanced FlashCopy logical drive and
end the copy-on-write operation. The format for entering the date is MM:DD:YY. An example of this
option is endDate=11:26:11.
v noEndDate Use this option if you do not want your scheduled copy-on-write operation to end. If you
later decide to end the copy-on-write operations you must re-enter the set enhancedFlashCopyGroup
command and specify an end date.
v timesPerDay The number of times that you want the schedule to run in a day. An example of this
option is timesPerDay=4.
v timeZone Use this parameter to define the time zone in which the storage subsystem is operating.
You can define the time zone in one of two ways:
GMTHH:MM The time zone offset from GMT. Enter the offset in hours and minutes. For example
GMT-06:00 is the central time zone in the United States.
Text string Standard time zone text strings. For example: "USA/Chicago" or "Germany/Berlin".
Timezone text strings are case sensitive. If you enter an incorrect text string, GMT time is used.
Enclose the text string in double quotation marks.
If you also use the scheduleInterval option, the firmware chooses between the timesPerDay option and
the scheduleInterval option by selecting the lowest value of the two options. The firmware calculates an
integer value for the scheduleInterval option by dividing 1440 by the scheduleInterval option value
that you set. For example, 1440/180 = 8. The firmware then compares the timesPerDay integer value with
the calculated scheduleInterval integer value and uses the smaller value.
Parameters
Parameter Description
enhancedFlashCopyLogicalDrive The name of the Enhanced FlashCopy logical drive for
which you are setting properties. Enclose the Enhanced
FlashCopy logical drive identifier in double quotation
marks (" ") inside of square brackets ([ ]).
mediaScanEnabled The setting to turn on or turn off media scan for the
Enhanced FlashCopy logical drive. To turn on media
scan, set this parameter to TRUE. To turn off media scan,
set this parameter to FALSE. (If media scan is disabled at
the storage subsystem level, this parameter has no
effect.)
redundancyCheckEnabled The setting to turn on or turn off redundancy checking
during a media scan. To turn on redundancy checking,
set this parameter to TRUE. To turn off redundancy
checking, set this parameter to FALSE.
Notes
You can use any combination of alphanumeric characters, underscore (_), hyphen (-), and pound (#) for
the names. Names can have a maximum of 30 characters.
Syntax
set enhancedFlashCopyLogicalDrive ["enhancedFlashCopyLogicalDriveName"]
(repositoryFullLimit=percentValue |
increaseRepositoryCapacity (repositoryLogicalDrive=(repos_xxxx) |
decreaseRepositoryCapacity count=numberOfLogicalDrives)
Parameters
Parameter Description
enhancedFlashCopyLogicalDrive The name of the Enhanced FlashCopy logical drive for
which you are setting properties. Enclose the Enhanced
FlashCopy logical drive identifier in double quotation
marks (" ") inside of square brackets ([ ]).
repositoryFullLimit The percentage of repository logical drive capacity at
which you receive a warning that the Enhanced
FlashCopy repository logical drive is nearing full. Use
integer values. For example, a value of 70 means 70
percent. The default value is 75.
3-182 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Parameter Description
repositoryLogicalDrive The alphanumeric identifier of the repository logical
drive has the Enhanced FlashCopy image. All repository
identifiers have this form:
repos_xxxx
Notes
You can use any combination of alphanumeric characters, underscore (_), hyphen (-), and pound (#) for
the names. Names can have a maximum of 30 characters.
When you use this command, you can specify only one of the parameters. You cannot enter more than
one parameter when you run this command.
Parameters
Parameter Description
enhancedFlashCopyGroup The alphanumeric identifier (including - and _) of the
Enhanced FlashCopy group on which you want to run a
media scan. Enclose the Enhanced FlashCopy group
name in double quotation marks (" ") inside of square
brackets ([ ]).
repositoryLogicalDrive The name of the repository logical drive for which you
want to increase capacity. An available standard logical
drive is added to the repository logical drive to increase
the capacity of the repository logical drive.
Syntax
set (logicalDrive [logicalDriveName] |
logicalDrives [logicalDriveName1 ... logicalDriveNameN])
warningThresholdPercent=percentValue
repositoryFullPolicy=(failBaseWrites | failFlashCopy)
Parameters
Parameter Description
logicalDrive or logicalDrives The name of the specific FlashCopy logical drive
for which you want to define properties. (You
can enter more than one logical drive name if
you use the logicalDrives parameter). Enclose
the FlashCopy logical drive name in double
quotation marks ( ) inside of square brackets
([ ]).
userLabel A new name that you want to give to a
FlashCopy logical drive. Enclose the new
FlashCopy logical drive name in double
quotation marks ( ).
warningThresholdPercent The percentage of repository capacity at which
you receive a warning that the FlashCopy
repository is nearing full. Use integer values. For
example, a value of 70 means 70 percent. The
default value is 50.
repositoryFullPolicy How you want FlashCopy processing to continue
if the FlashCopy repository logical drive is full.
You can choose to fail writes to the base logical
drive (failBaseWrites) or fail writes to the
FlashCopy logical drive (failFlashCopy). The
default value is failFlashCopy.
Notes
When you use this command, you can specify one or more of the optional parameters.
You can use any combination of alphanumeric characters, hyphens, and underscores for the names.
Names can have a maximum of 30 characters.
You can set the warningThresholdPercent parameter and the repositoryFullPolicy parameter for both
the FlashCopy repository logical drive or the FlashCopy logical drive.
3-184 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Set Foreign Disk Drive to Native
A drive is considered to be native when it is a part of the storage subsystem's array configuration. A
drive is considered to be foreign when it does not belong to the storage subsystem's array configuration
or when it fails to be imported with the drives of an array that is transferred to a new storage subsystem.
The latter failure creates an incomplete array on the new storage subsystem.
Run this command to add the missing (foreign) drives back into their original array and to make them
part of the new storage subsystem array configuration of the new storage subsystem.
Use this operation for emergency recovery only: when one or more drives need to be changed from a
foreign drive status and returned to a native status within their original array.
Attention: Possible data corruption or data lossUsing this command for reasons other than what is
stated previously might result in data loss without notification.
Syntax
set (drive [enclosureID1,drawerID1,slotID1 ... enclosureIDn,drawerIDn,slotIDn] |
allDrives) nativeState
Parameters
Parameter Description
drive EnclosureID1,drawerID1,slotID1 ...
enclosureIDn,drawerIDn,slotIDn is for enclosures with
multiple disk drive drawers. For enclosures without disk
drive drawers, use enclosureID1,slotID1 ...
enclosureIDn,slotIDn instead. Enclosure ID values are 0 to 99.
Drawer ID values are 1 to 5. Slot ID values are 1 to 32.
Enclose the values in square brackets ([ ]).
allDrives The setting to select all of the drives.
Notes
The drive parameter supports both high-capacity drive expansion enclosures and low-capacity drive
expansion enclosures. A high-capacity drive expansion enclosure has drawers that hold the drives. The
drawers slide out of the drive expansion enclosure to provide access to the drives. A low-capacity drive
expansion enclosure does not have drawers. For a high-capacity drive expansion enclosure, you must
specify the identifier (ID) of the drive expansion enclosure, the ID of the drawer, and the ID of the slot in
which a drive resides. For a low-capacity drive expansion enclosure, you need only specify the ID of the
drive expansion enclosure and the ID of the slot in which a drive resides. For a low-capacity drive
expansion enclosure, an alternative method for identifying a location for a drive is to specify the ID of
the drive expansion enclosure, set the ID of the drawer to 0, and specify the ID of the slot in which a
drive resides.
Set Host
This command assigns a host to a host group or moves a host to a different host group. You can also
create a new host group and assign the host to the new host group with this command. The actions
performed by this command depend on whether the host has individual logical drive-to-LUN mappings
or does not have individual logical drive-to-LUN mappings.
Parameters
Parameter Description
host The name of the host that you want to assign to a host group. Enclose
the host name in square brackets ([ ]). If the host name has special
characters, you also must enclose the host name in double quotation
marks ( ).
hostGroup The name of the host group to which you want to assign the host.
(The following table defines how the command runs if the host does
or does not have individual logical drivetoLUN mappings.) Enclose
the host group name in double quotation marks ( ). The
defaultGroup option is the host group that contains the host to which
the logical drive is mapped.
userLabel The new host name. Enclose the host name in double quotation marks
( ).
hostType The index label or number of the host type for the HBA host port. Use
the show storageSubsystem hostTypeTable command to generate a list
of available host type identifiers. If the host type has special
characters, enclose the host type in double quotation marks ( ).
Host Group Host Has Individual Logical Host Does Not Have Individual
Parameter drive-to-LUN Mappings Logical drive-to-LUN Mappings
hostGroupName The host is removed from the The host is removed from the
present host group and is present host group and is placed
placed under the new host under the new host group
group defined by defined by hostGroupName.
hostGroupName.
none The host is removed from the The host is removed from the
host group as an independent present host group and is placed
partition and is placed under under the default group.
the root node.
defaultGroup The command fails. The host is removed from the
present host group and is placed
under the default group.
Notes
When you use this command, you can specify one or more of the optional parameters.
For the names, you can use any combination of alphanumeric characters, hyphens, and underscores.
Names can have a maximum of 30 characters.
Related Topic
Naming Conventions
3-186 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Set Host Channel
This command defines the loop ID for the host channel.
Syntax
set hostChannel [hostChannelNumber]
preferredID=portID
Parameters
Parameter Description
hostChannel The identifier number of the host channel for which you want to
set the loop ID. Enclose the host channel identifier number in
square brackets ([ ]).
Valid host channel values are a1, a2, a3, a4, a5, a6, a7, or
a8 for controller A host ports, and b1, b2, b3, b4, b5, b6, b7,
or b8 for controller B host ports. Depending on the number of
host channels that are currently installed in your storage
subsystems, you can specify two, four or up to 8 host channels
per controller.
Syntax
set hostGroup [hostGroupName]
userLabel=newHostGroupName
Parameters
Parameter Description
hostGroup The name of the host group that you want to rename. Enclose the
host group name in square brackets ([ ]). If the host group name
has special characters, you also must enclose the host group name
in double quotation marks ( ).
userLabel The new name for the host group. Enclose the new host group
name in double quotation marks ( ).
Notes
You can use any combination of alphanumeric characters, hyphens, and underscores for the names.
Names can have a maximum of 30 characters.
Related Topic
Naming Conventions
Syntax
set hostPort [portLabel] host=hostName userLabel=newPortLabel
Parameters
Parameter Description
hostPort The name of the HBA host port for which you want to
change the host type, or for which you want to create a new
name. Enclose the HBA host port name in square brackets
([ ]). If the HBA host port label has special characters, enclose
the HBA host port label in double quotation marks ( ).
host The name of the host to which the HBA host port is
connected. Enclose the host name in double quotation marks
( ).
userLabel The new name that you want to give to the HBA host port.
Enclose the new name of the HBA host port in double
quotation marks ( ).
Notes
When you use this command, you can specify one or more of the optional parameters.
You can use any combination of alphanumeric characters, hyphens, and underscores for the names.
Names can have a maximum of 30 characters.
Related Topic
Naming Conventions
Syntax
set iscsiInitiator iscsiName] |
userLabel=newName |
host=newHostName |
chapSecret=newSecurityKey
Parameters
Parameter Description
iscsiName The name of the iSCSI initiator for which you want to
set attributes. Enclose the value in double quotation
marks ( ).
userLabel The new name that you want to use for the iSCSI
initiator. Enclose the value in double quotation marks
( ).
3-188 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Parameter Description
host The name of the new host to which the HBA host port
is connected. Enclose the value in double quotation
marks ( ).
chapSecret The security key that you want to use to authenticate a
peer connection. Enclose the value in double quotation
marks ( ).
Notes
You can use any combination of alphanumeric characters, hyphens, and underscores for the names.
Names can have a maximum of 30 characters.
Challenge Handshake Authentication Protocol (CHAP) is a protocol that authenticates the peer of a
connection. CHAP is based upon the peers sharing a secret. A secret is a security key that is similar to a
password.
Use the chapSecret parameter to set up the security keys for initiators that require a mutual
authentication.
Related Topic
Naming Conventions
Syntax
set iscsiTarget [iSCSI-ID] authenticationMethod=chap chapSecret=securityKey
[targetAlias=user-label]
Or
set iscsiTarget [iSCSI-ID] authenticationMethod= none
[targetAlias=user-label]
Parameters
Parameter Description
iscsiTarget The iSCSI target for which you want to set
properties. Enclose the userLabel in double
quotation marks (" "). You must also enclose the
userLabel in either square brackets ([ ]) or angle
brackets (< >).
authenticationMethod The means of authenticating your iSCSI session.
chapSecret The security key that you want to use to
authenticate a peer connection.
targetAlias The name that you want to use for the target.
Challenge Handshake Authentication Protocol (CHAP) is a protocol that authenticates the peer of a
connection. CHAP is based upon the peers sharing a secret. A secret is a security key that is similar to a
password.
Use the chapSecret parameter to set up the security keys for initiators that require a mutual
authentication.
Note: In configurations with arrays that have more than 32 logical drives, the timeout period might
expire before an operation completes. This causes host I/O errors or internal controller reboots. If such
errors or reboots occur, quiesce the host I/O and retry the operation.
Parameters
Parameter Description
alllogicalDrives The properties for all logical drives in the
storage subsystem.
logicalDrive or logicalDrives The name of the specific logical drive for which
you want to define properties. (You can enter
more than one logical drive name if you use the
logicalDrives parameter). Enclose the logical
drive name in double quotation marks ( )
inside of square brackets ([ ]).
3-190 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Parameter Description
logicalDrive The World Wide Identifier (WWID) of the
logical drive for which you are setting
properties. You can use the WWID instead of
the logical drive name to identify the logical
drive. Enclose the WWID in angle brackets
(< >).
cacheFlushModifier The maximum amount of time that data for the
logical drive stays in cache before the data is
flushed to physical storage. Valid values are
listed in the "Notes" section.
cacheWithoutBatteryEnabled The setting to turn on or turn off caching
without batteries. To turn on caching without
batteries, set this parameter to TRUE. To turn off
caching without batteries, set this parameter to
FALSE.
mediaScanEnabled The setting to turn on or turn off media scan for
the logical drive. To turn on media scan, set this
parameter to TRUE. To turn off media scan, set
this parameter to FALSE. (If media scan is
disabled at the storage subsystem level, this
parameter has no effect.)
mirrorCacheEnabled The setting to turn on or turn off the mirror
cache. To turn on the mirror cache, set this
parameter to TRUE. To turn off the mirror cache,
set this parameter to FALSE.
modificationPriority The priority for logical drive modifications
while the storage subsystem is operational.
Valid values are highest, high, medium, low, or
lowest.
owner The controller that owns the logical drive. Valid
controller identifiers are a or b, where a is the
controller in slot A, and b is the controller in
slot B. Use this parameter only if you want to
change the logical drive owner.
preReadRedundancyCheck The setting to turn on or turn off preread
redundancy checking. Turning on preread
redundancy checking verifies the consistency of
RAID redundancy data for the stripes
containing the read data. Preread redundancy
checking is performed on read operations only.
To turn on preread redundancy checking, set
this parameter to TRUE. To turn off preread
redundancy checking, set this parameter to
FALSE.
Note: Do not use this parameter on
non-redundant logical drives, such as RAID 0
logical drives.
readCacheEnabled The setting to turn on or turn off the read
cache. To turn on the read cache, set this
parameter to TRUE. To turn off the read cache,
set this parameter to FALSE.
writeCacheEnabled The setting to turn on or turn off the write
cache. To turn on the write cache, set this
parameter to TRUE. To turn off the write cache,
set this parameter to FALSE.
3-192 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Parameter Description
redundancyCheckEnabled The setting to turn on or turn off redundancy
checking during a media scan. To turn on
redundancy checking, set this parameter to
TRUE. To turn off redundancy checking, set this
parameter to FALSE.
segmentSize The amount of data (in KB) that the controller
writes on a single disk drive in a logical drive
before writing data on the next disk drive. Valid
values are 8, 16, 32, 64, 128, 256, or 512.
userLabel The new name that you want to give an
existing logical drive. Enclose the new logical
drive name in double quotation marks ( ).
preReadRedundancyCheck The setting to check the consistency of RAID
redundancy data on the stripes during read
operations. Do not use this operation for
non-redundant logical drives, for example RAID
Level 0. To check redundancy consistency, set
this parameter to TRUE. For no stripe checking,
set this parameter to FALSE.
accesslogicalDrive The logical unit number for the access logical
drive. The logical unit number is the only
property that you can set for the access logical
drive.
logicalUnitNumber Specific logical drive-to-LUN mappings to an
individual host. This parameter also assigns the
host to a host group.
host The name of the host to which the logical drive
is mapped. Enclose the host name in double
quotation marks ( ).
hostGroup The name of the host group to which the logical
drive is mapped. Enclose the host group name
in double quotation marks ( ). defaultGroup
is the host group that contains the host to which
the logical drive is mapped.
Notes
In configurations with arrays that have more than 32 logical drives, the timeout period might expire
before an operation completes. This causes host I/O errors or internal controller reboots. If such errors or
reboots occur, quiesce the host I/O and retry the operation.
When you use this command, you can specify one or more of the optional parameters.
You can apply these parameters to only one logical drive at a time:
v addCapacity
v segmentSize
v userLabel
v logicalUnitNumber
Setting the addCapacity parameter, the addDrives parameter, or the segmentSize parameter starts a
long-running operation that you cannot stop. These long-running operations are performed in the
background and do not prevent you from running other commands. To show the progress of
long-running operations, use the show logicalDrive actionProgress command.
The addDrives parameter supports both high-capacity and low-capacity drive expansion enclosures. A
high-capacity drive expansion enclosure has drawers that hold the drives. The drawers slide out of the
drive expansion enclosure to provide access to the drives. A low-capacity drive expansion enclosure does
not have drawers. For a high-capacity drive expansion enclosure, you must specify the identifier (ID) of
the drive expansion enclosure, the ID of the drawer, and the ID of the slot in which a drive resides. For a
low-capacity drive expansion enclosure, you need to specify the ID of the drive expansion enclosure and
the ID of the slot in which a drive resides. For a low-capacity drive expansion enclosure, an alternative
method for identifying a location for a drive is to specify the ID of the drive expansion enclosure, set the
ID of the drawer to 0, and specify the ID of the slot in which a drive resides.
Value Description
Immediate Data is flushed as soon as it is placed into the cache.
250 Data is flushed after 250 ms.
500 Data is flushed after 500 ms.
750 Data is flushed after 750 ms.
1 Data is flushed after 1 s.
1500 Data is flushed after 1500 ms.
2 Data is flushed after 2 s.
5 Data is flushed after 5 s.
10 Data is flushed after 10 s.
20 Data is flushed after 20 s.
60 Data is flushed after 60 s (1 min.).
120 Data is flushed after 120 s (2 min.).
300 Data is flushed after 300 s (5 min.).
1200 Data is flushed after 1200 s (20 min.).
3600 Data is flushed after 3600 s (1 hr).
Infinite Data in cache is not subject to any age or time constraints. The
data is flushed based on other criteria that are managed by the
controller.
Write caching without batteries enables write caching to continue if the controller batteries are completely
discharged, not fully charged, or not present. If you set this parameter to TRUE without an uninterruptible
power supply (UPS) or other backup power source, you can lose data if the power to the storage
subsystem fails. This parameter has no effect if write caching is disabled.
3-194 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Modification Priority
Modification priority defines the amount of system resources that are used when modifying logical drive
properties. If you select the highest priority level, the logical drive modification uses the most system
resources, which decreases the performance for host data transfers.
The cacheReadPrefetch parameter enables the controller to copy additional data blocks into cache while
the controller reads and copies data blocks that are requested by the host from the disk drive into cache.
This action increases the chance that a future request for data can be fulfilled from cache. Cache read
prefetch is important for multimedia applications that use sequential data transfers. The configuration
settings for the storage subsystem that you use determine the number of additional data blocks that the
controller reads into cache. Valid values for the cacheReadPrefetch parameter are TRUE or FALSE.
Segment Size
The size of a segment determines how many data blocks that the controller writes on a single disk drive
in a logical drive before writing data on the next disk drive. Each data block stores 512 bytes of data. A
data block is the smallest unit of storage. The size of a segment determines how many data blocks that it
contains. For example, an 8-KB segment holds 16 data blocks. A 64-KB segment holds 128 data blocks.
When you enter a value for the segment size, the value is checked against the supported values that are
provided by the controller at run time. If the value that you entered is not valid, the controller returns a
list of valid values. Using a single disk drive for a single request leaves other disk drives available to
simultaneously service other requests.
If the logical drive is in an environment where a single user is transferring large units of data (such as
multimedia), performance is maximized when a single data transfer request is serviced with a single data
stripe. (A data stripe is the segment size that is multiplied by the number of disk drives in the array that
are used for data transfers.) In this case, multiple disk drives are used for the same request, but each disk
drive is accessed only once.
For optimal performance in a multiuser database or file system storage environment, set your segment
size to minimize the number of disk drives that are required to satisfy a data transfer request.
Note: In configurations where arrays consist of more than 32 logical drives, the operation can result in
host I/O errors or internal controller reboots due to the expiration of the timeout period before the
operation completes. If you experience host I/O errors or internal controller reboots, quiesce the host I/O
and try the operation again.
Parameters
Parameter Description
allLogicalDrives The properties for all logical drives in the storage
subsystem.
logicaldrive or logicaldrives The name of the specific logical drive for which you
want to define properties. (You can enter more than one
logical drive name if you use the logicaldrives
parameter.) Enclose the logical drive name in double
quotation marks (" ") inside of square brackets ([ ]).
logicaldrive The World Wide Identifier (WWID) of the logical drive
for which you are setting properties. You can use the
WWID instead of the logical drive name to identify the
logical drive. Enclose the WWID in angle brackets (< >).
cacheFlushModifier The maximum amount of time that data for the logical
drive stays in cache before the data is flushed to physical
storage. Valid values are listed in the Notes section.
cacheWithoutBatteryEnabled The setting to turn on or turn off caching without
batteries. To turn on caching without batteries, set this
parameter to TRUE. To turn off caching without batteries,
set this parameter to FALSE.
mediaScanEnabled The setting to turn on or turn off media scan for the
logical drive. To turn on media scan, set this parameter to
TRUE. To turn off media scan, set this parameter to FALSE.
(If media scan is disabled at the storage subsystem level,
this parameter has no effect.)
mirrorCacheEnabled The setting to turn on or turn off the mirror cache. To
turn on the mirror cache, set this parameter to TRUE. To
turn off the mirror cache, set this parameter to FALSE.
modificationPriority The priority for logical drive modifications while the
storage subsystem is operational. Valid values are
highest, high, medium, low, or lowest.
owner The controller that owns the logical drive. Valid
controller identifiers are a or b, where a is the controller
in slot A, and b is the controller in slot B. Use this
parameter only if you want to change the logical drive
owner.
3-196 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Parameter Description
preReadRedundancyCheck The setting to turn on or turn off pre-read redundancy
checking. Turning on pre-read redundancy checking
verifies the consistency of RAID redundancy data for the
stripes containing the read data. Pre-read redundancy
checking is performed on read operations only. To turn
on pre-read redundancy checking, set this parameter to
TRUE. To turn off pre-read redundancy checking, set this
parameter to FALSE.
Note: Do not use this parameter on non-redundant
logical drives, such as RAID 0 logical drives.
readCacheEnabled The setting to turn on or turn off the read cache. To turn
on the read cache, set this parameter to TRUE. To turn off
the read cache, set this parameter to FALSE.
writeCacheEnabled The setting to turn on or turn off the write cache. To turn
on the write cache, set this parameter to TRUE. To turn off
the write cache, set this parameter to FALSE.
cacheReadPrefetch The setting to turn on or turn off cache read prefetch. To
turn off cache read prefetch, set this parameter to FALSE.
To turn on cache read prefetch, set this parameter to
TRUE.
T10PIDisabled The setting to turn on or turn off T10 PI (Protection
Information) for a specific logical drive.
Notes
Host I/O errors might result in arrays with more than 32 logical drives. This operation might also result
in internal controller reboots due to the expiration of the timeout period before the operation completes.
If you experience this issue, quiesce host I/O, and try the operation again.
When you use this command, you can specify one or more of the optional parameters.
You can apply these parameters to only one logical drive at a time:
v addCapacity
v segmentSize
v userLabel
v logicalUnitNumber
Setting the addCapacity parameter, the addDrives parameter, or the segmentSize parameter starts a
long-running operation that you cannot stop. These long-running operations are performed in the
background and do not prevent you from running other commands. To show the progress of
long-running operations, use the show logicaldrive actionProgress command.
The addDrives parameter supports both high-capacity drive expansion enclosures and low-capacity drive
expansion enclosures. A high-capacity drive expansion enclosure has drawers that hold the drives. The
drawers slide out of the drive expansion enclosure to provide access to the drives. A low-capacity drive
3-198 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
expansion enclosure does not have drawers. For a high-capacity drive expansion enclosure, you must
specify the identifier (ID) of the drive expansion enclosure, the ID of the drawer, and the ID of the slot in
which a drive resides. For a low-capacity drive expansion enclosure, you need only specify the ID of the
drive expansion enclosure and the ID of the slot in which a drive resides. For a low-capacity drive
expansion enclosure, an alternative method for identifying a location for a drive is to specify the ID of
the drive expansion enclosure, set the ID of the drawer to 0, and specify the ID of the slot in which a
drive resides.
Valid values for the cache flush modifier are listed in this table.
Value Description
Immediate Data is flushed as soon as it is placed into the cache.
250 Data is flushed after 250 ms.
500 Data is flushed after 500 ms.
750 Data is flushed after 750 ms.
1 Data is flushed after 1 s.
1500 Data is flushed after 1500 ms.
2 Data is flushed after 2 s.
5 Data is flushed after 5 s.
10 Data is flushed after 10 s.
20 Data is flushed after 20 s.
60 Data is flushed after 60 s (1 min.).
120 Data is flushed after 120 s (2 min.).
300 Data is flushed after 300 s (5 min.).
1200 Data is flushed after 1200 s (20 min.).
3600 Data is flushed after 3600 s (1 hr).
Infinite Data in cache is not subject to any age or time
constraints. The data is flushed based on other criteria
that are managed by the controller.
Write caching without batteries enables write caching to continue if the controller batteries are completely
discharged, not fully charged, or not present. If you set this parameter to TRUE without an uninterruptible
power supply (UPS) or other backup power source, you can lose data if the power to the storage
subsystem fails. This parameter has no effect if write caching is disabled.
Modification Priority
Modification priority defines the amount of system resources that are used when modifying logical drive
properties. If you select the highest priority level, the logical drive modification uses the most system
resources, which decreases the performance for host data transfers.
The cacheReadPrefetch parameter enables the controller to copy additional data blocks into cache while
the controller reads and copies data blocks that are requested by the host from the drive into cache. This
action increases the chance that a future request for data can be fulfilled from cache. Cache read prefetch
Segment Size
The size of a segment determines how many data blocks that the controller writes on a single drive in a
logical drive before writing data on the next drive. Each data block stores 512 bytes of data. A data block
is the smallest unit of storage. The size of a segment determines how many data blocks that it contains.
For example, an 8-KB segment holds 16 data blocks. A 64-KB segment holds 128 data blocks.
When you enter a value for the segment size, the value is checked against the supported values that are
provided by the controller at run time. If the value that you entered is not valid, the controller returns a
list of valid values. Using a single drive for a single request leaves other drives available to
simultaneously service other requests.
If the logical drive is in an environment where a single user is transferring large units of data (such as
multimedia), performance is maximized when a single data transfer request is serviced with a single data
stripe. (A data stripe is the segment size that is multiplied by the number of drives in the array that are
used for data transfers.) In this case, multiple drives are used for the same request, but each drive is
accessed only once.
For optimal performance in a multiuser database or file system storage environment, set your segment
size to minimize the number of drives that are required to satisfy a data transfer request.
Related Topic
Naming Conventions
Note: In configurations where arrays consist of more than 32 logical drives, the operation can result in
host I/O errors or internal controller reboots due to the expiration of the timeout period before the
operation completes. If you experience host I/O errors or internal controller reboots, bring the host to a
quiescent state and try the operation again.
Syntax
set (allLogicalDrives | logicaldrive ["
logicaldriveName"] | logicaldrives ["logicaldriveName1" ... "logicaldriveNameN"] | logicaldrive <wwID>)
[(addCapacity = capacityValue[KB|MB|GB|TB|Bytes] |
[addDrives = (drive-spec-list)])|
cacheFlushModifier=cacheFlushModifierValue |
cacheReadPrefetch = (TRUE | FALSE) |
cacheWithoutBatteryEnabled=(TRUE | FALSE) |
mediaScanEnabled=(TRUE | FALSE) |
mirrorCacheEnabled=(TRUE | FALSE) |
modificationPriority=(highest | high | medium | low | lowest) | owner=(a | b) |
preReadRedundancyCheck = (TRUE | FALSE) |
readCacheEnabled=(TRUE | FALSE) |
redundancyCheckEnabled = (TRUE | FALSE) |
3-200 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
segmentSize = segmentSizeValue
userLabel = userlabelValue
writeCacheEnabled=(TRUE | FALSE) |
T10PIDisabled=(TRUE | FALSE)]
Parameters
Parameter Description
allLogicalDrives The properties for all logical drives in the storage
subsystem.
logicaldrive or logicaldrives The name of the specific logical drive for which you
want to define properties. (You can enter more than one
logical drive name if you use the logicaldrives
parameter.) Enclose the logical drive name in double
quotation marks (" ") inside of square brackets ([ ]).
logicaldrive The World Wide Identifier (WWID) of the logical drive
for which you are setting properties. You can use the
WWID instead of the logical drive name to identify the
logical drive. Enclose the WWID in angle brackets (< >).
addCapacity The setting to increase the storage size (capacity) of the
logical drive for which you are defining properties. Size
is defined in units of bytes, KB, MB, GB, or TB. The
default value is bytes.
Notes
When you use this command, you can specify one or more of the optional parameters.
You can apply these parameters to only one logical drive at a time:
v addCapacity
v segmentSize
v userLabel
Setting the addCapacity parameter, the addDrives parameter, or the segmentSize parameter starts a
long-running operation that you cannot stop. These long-running operations are performed in the
background and do not prevent you from running other commands. To show the progress of
long-running operations, use the show logicaldrive actionProgress command.
3-202 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
The addDrives parameter supports both high-capacity drive expansion enclosures and low-capacity drive
expansion enclosures. A high-capacity drive expansion enclosure has drawers that hold the drives. The
drawers slide out of the drive expansion enclosure to provide access to the drives. A low-capacity drive
expansion enclosure does not have drawers. For a high-capacity drive expansion enclosure, you must
specify the identifier (ID) of the drive expansion enclosure, the ID of the drawer, and the ID of the slot in
which a drive resides. For a low-capacity drive expansion enclosure, you need only specify the ID of the
drive expansion enclosure and the ID of the slot in which a drive resides. For a low-capacity drive
expansion enclosure, an alternative method for identifying a location for a drive is to specify the ID of
the drive expansion enclosure, set the ID of the drawer to 0, and specify the ID of the slot in which a
drive resides.
Valid values for the cache flush modifier are listed in this table.
Value Description
Immediate Data is flushed as soon as it is placed into the cache.
250 Data is flushed after 250 ms.
500 Data is flushed after 500 ms.
750 Data is flushed after 750 ms.
1 Data is flushed after 1 s.
1500 Data is flushed after 1500 ms.
2 Data is flushed after 2 s.
5 Data is flushed after 5 s.
10 Data is flushed after 10 s.
20 Data is flushed after 20 s.
60 Data is flushed after 60 s (1 min.).
120 Data is flushed after 120 s (2 min.).
300 Data is flushed after 300 s (5 min.).
1200 Data is flushed after 1200 s (20 min.).
3600 Data is flushed after 3600 s (1 hr).
Infinite Data in cache is not subject to any age or time
constraints. The data is flushed based on other criteria
that are managed by the controller.
Write caching without batteries enables write caching to continue if the controller batteries are completely
discharged, not fully charged, or not present. If you set this parameter to TRUE without an uninterruptible
power supply (UPS) or other backup power source, you can lose data if the power to the storage
subsystem fails. This parameter has no effect if write caching is disabled.
Modification Priority
Modification priority defines the amount of system resources that are used when modifying logical drive
properties. If you select the highest priority level, the logical drive modification uses the most system
resources, which decreases the performance for host data transfers.
The cacheReadPrefetch parameter enables the controller to copy additional data blocks into cache while
the controller reads and copies data blocks that are requested by the host from the drive into cache. This
action increases the chance that a future request for data can be fulfilled from cache. Cache read prefetch
is important for multimedia applications that use sequential data transfers. The configuration settings for
the storage subsystem that you use determine the number of additional data blocks that the controller
reads into cache. Valid values for the cacheReadPrefetch parameter are TRUE or FALSE.
Segment Size
The size of a segment determines how many data blocks that the controller writes on a single drive in a
logical drive before writing data on the next drive. Each data block stores 512 bytes of data. A data block
is the smallest unit of storage. The size of a segment determines how many data blocks that it contains.
For example, an 8-KB segment holds 16 data blocks. A 64-KB segment holds 128 data blocks.
When you enter a value for the segment size, the value is checked against the supported values that are
provided by the controller at run time. If the value that you entered is not valid, the controller returns a
list of valid values. Using a single drive for a single request leaves other drives available to
simultaneously service other requests.
If the logical drive is in an environment where a single user is transferring large units of data (such as
multimedia), performance is maximized when a single data transfer request is serviced with a single data
stripe. (A data stripe is the segment size that is multiplied by the number of drives in the array that are
used for data transfers.) In this case, multiple drives are used for the same request, but each drive is
accessed only once.
For optimal performance in a multiuser database or file system storage environment, set your segment
size to minimize the number of drives that are required to satisfy a data transfer request.
Note: You cannot use this command for an Enhanced FlashCopy logical drive that is used in online
logical drive copy.
Syntax
set (logicaldrive ["logicaldriveName"] | logicaldrive <wwID> | accessLogicalDrive)
logicalUnitNumber=LUN
(host="hostName" |
hostGroup=("hostGroupName" | defaultGroup)
Parameters
Parameter Description
logicaldrive The name of the specific logical drive for which you
want to define mapping. Enclose the logical drive name
in double quotation marks (" ") inside of square brackets
([ ]).
3-204 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Parameter Description
accessLogicalDrive The logical unit number for the access logical drive. The
logical unit number is the only property that you can set
for the access logical drive.
logicalUnitNumber The logical unit number that you want to use to map to
a specific host. This parameter also assigns the host to a
host group.
host The name of the host to which the logical drive is
mapped. Enclose the host name in double quotation
marks (" ").
hostGroup The name of the host group to which the logical drive is
mapped. Enclose the host group name in double
quotation marks (" "). defaultGroup is the host group
that contains the host to which the logical drive is
mapped.
Notes
A host group is an optional topological element that you can define if you want to designate a collection
of hosts that share access to the same logical drives. The host group is a logical entity. Define a host
group only if you have two or more hosts that can share access to the same logical drives.
You can use any combination of alphanumeric characters, hyphens, and underscores for the names.
Names can have a maximum of 30 characters.
The access logical drive is the logical drive in a SAN environment that is used for in-band
communication between the storage management software and the storage subsystem controller. This
logical drive uses a LUN address and consumes 20 MB of storage space that is not available for
application data storage. An access logical drive is required only for in-band managed storage
subsystems. If you specify the accessLogicalDrive parameter, the only property you can set is the
logicalUnitNumber parameter.
Syntax
set enhancedFlashCopyLogicalDrive ["
enhancedFlashCopyImageLogicalDriveName"] convertReadOnlyToReadWrite
[repositoryLogicalDrive="repos_xxxx" |
repositoryFullLimit=percentValue]
Parameters
Parameter Description
enhancedFlashCopyLogicalDrive The name of the Enhanced FlashCopy logical drive that
you want to change from read-only to read/write.
Enclose the Enhanced FlashCopy logical drive identifier
in double quotation marks (" ") inside of square brackets
([ ]).
Notes
The repository logical drive name is automatically created by the storage management software and the
firmware when you create a new Enhanced FlashCopy group. You cannot rename the repository logical
drive because renaming the repository logical drive will break the linkage with the Enhanced FlashCopy
images.
Syntax
set remoteMirror (localLogicalDrive [logicalDrive] |
localLogicalDrives [logicalDriveName1 ... logicalDriveNameN])
role=(primary | secondary)
[force=(TRUE | FALSE)]
syncPriority=(highest | high | medium | low | lowest)
autoResync=(enabled | disabled)
writeOrder=(preserved | notPreserved)
writeMode=(synchronous | asynchronous)
Parameters
Parameter Description
localLogicalDrive The name of the primary logical drive for which you
or want to define properties. You can enter more than one
localLogicalDrives primary logical drive name. Enclose the primary logical
drive name in square brackets ([ ]). If the primary
logical drive name has special characters, you also must
enclose the primary logical drive name in double
quotation marks ( ).
role The setting for the logical drive to act as the primary
logical drive or the secondary logical drive. To define
the logical drive as the primary logical drive, set this
parameter to primary. To define the logical drive as the
secondary logical drive, set this parameter to
secondary. This parameter applies only when the
logical drive is part of a mirror relationship.
3-206 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Parameter Description
force The role reversal is forced if the communications link
between the storage subsystems is down and
promotion or demotion on the local side results in a
dual-primary condition or a dual-secondary condition.
To force a role reversal, set this parameter to TRUE. The
default value is FALSE.
syncPriority The priority that full synchronization has relative to
host I/O activity. Valid values are highest, high,
medium, low, or lowest.
autoResync The settings for automatic resynchronization between
the primary logical drives and the secondary logical
drives of a remote-mirror pair. This parameter has these
values:
v enabled Automatic resynchronization is turned on.
You do not need to do anything further to
resynchronize the primary logical drive and the
secondary logical drive.
v disabled Automatic resynchronization is turned
off. To resynchronize the primary logical drives and
the secondary logical drive, you must run the resume
remoteMirror command.
writeOrder This parameter defines write order for data
transmission between the primary logical drive and the
secondary logical drive. Valid values are preserved or
notPreserved.
writeMode This parameter defines how the primary logical drive
writes to the secondary logical drive. Valid values are
synchronous or asynchronous.
Notes
When you use this command, you can specify one or more of the optional parameters.
Synchronization priority defines the amount of system resources that are used to synchronize the data
between the primary logical drives and the secondary logical drives of a mirror relationship. If you select
the highest priority level, the data synchronization uses the most system resources to perform the full
synchronization, which decreases the performance for host data transfers.
The writeOrder parameter applies only to asynchronous mirrors and makes them become part of a
consistency group. Setting the writeOrder parameter topreserved causes the remote-mirror pair to
transmit data from the primary logicalDrive to the secondary logicalDrive in the same order as the host
writes to the primary logicalDrive. In the event of a transmission link failure, the data is buffered until a
full synchronization can occur. This action can require additional system overhead to maintain the
buffered data, which slows operations. Setting the writeOrderparameter to notPreserved frees the system
from having to maintain data in a buffer, but it requires forcing a full synchronization to make sure that
the secondary logicalDrive has the same data as the primary logical drive.
Set Session
This command defines how you want the current script engine session to run. For the purpose of this
command a session is the duration for the running of the commands. This command does not
permanently set the parameters for the storage subsystem.
Parameters
Parameter Description
errorAction How the session responds if an error is
encountered during processing. You can choose
to stop the session if an error is encountered, or
you can continue the session after encountering
an error. The default value is stop. (This
parameter defines the action for execution
errors, not syntax errors. Some error conditions
might override the continue value.)
password The password for the storage subsystem.
Enclose the password in double quotation
marks ( ).
performanceMonitorInterval The frequency of gathering performance data.
Enter an integer value for the polling interval, in
seconds, for which you want to capture data.
The range of values is 3 to 3600 seconds. The
default value is 5 seconds.
performanceMonitorIterations The number of samples to capture. Enter an
integer value. The range of values for samples
captured is 1 to 3600. The default value is 5.
Notes
When you use this command, you can specify one or more of the optional parameters.
Passwords are stored on each storage subsystem in a management domain. If a password was not
previously set, you do not need a password. The password can be any combination of alphanumeric
characters with a maximum of 30 characters. (You can define a storage subsystem password by using the
set storageSubsystem command.)
The polling interval and the number of iterations that you specify remain in effect until you end the
session. After you end the session, the polling interval and the number of iterations return to their default
values.
Syntax
set storageSubsystem alarm=(enable | disable | mute)|
{autoSupportConfig (enable | disable) |
cacheBlockSize=cacheBlockSizeValue
cacheFlushStart=cacheFlushStartSize
cacheFlushStop=cacheFlushStopSize
defaultHostType=(hostTypeName | hostTypeIdentifier)
failoverAlertDelay=delayValue |
3-208 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
mediaScanRate=(disabled | 1-30) |
password=password |
userLabel=storageSubsystemName
isnsRegistration=(TRUE | FALSE))
Parameters
Parameter Description
alarm The setting for the audible alarm. This parameter has
these values:
v enable The audible alarm is turned on and sounds
if a fault occurs.
v disable The audible alarm is turned off and does
not sound if a fault occurs.
v mute The audible alarm is turned off if it is
sounding.
Notes
When you use this command, you can specify one or more of the optional parameters.
When enabled, the set storageSubsystem autoSupportConfig command causes all configuration and state
information for the storage subsystem to be returned each time a critical Major Event Log (MEL) event is
detected. The configuration and state information is returned in the form of an object graph. The object
graph contains all relevant logical and physical objects and their associated state information for the
storage subsystem.
The set storageSubsystem autoSupportConfig command collects configuration and state information in
this way:
v Automatic collection of the configuration and state information occurs every 72 hours. The
configuration and state information is saved to the storage subsystem zip archive file. The archive file
has a time stamp that is used to manage the archive files.
v Two storage subsystem zip archive files are maintained for each storage subsystem. The zip archive
files are kept on a disk drive. After the 72-hour time period is exceeded, the oldest archive file is
always overwritten during the new cycle.
v After you enable automatic collection of the configuration and state information using this command,
an initial collection of information starts. Collecting information after the you issue the command
makes sure that one archive file is available and starts the time stamp cycle.
You can run the set storageSubsystem autoSupportConfig command on more than one storage
subsystem.
When you define cache block sizes, use the 4-KB cache block size for storage subsystems that require I/O
streams that are typically small and random. Use the 8-KB cache block size when the majority of your
I/O streams are larger than 4 KB but smaller than 8 KB. Use the 16-KB cache block size or the 32-KB
cache block size for storage subsystems that require large data transfer, sequential, or high-bandwidth
applications.
This parameter defines the supported cache block size for all of the logical drives in the storage
subsystem. Not all controller types support all cache block sizes. For redundant configurations, this
parameter includes all of the logical drives that are owned by both controllers within the storage
subsystem.
When you define values to start a cache flush, a value that is too low increases the chance that data
needed for a host read is not in the cache. A low value also increases the number of disk drive writes that
are necessary to maintain the cache level, which increases system overhead and decreases performance.
3-210 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
When setting storage subsystem cache settings, the value of cacheFlushStart must be greater than or
equal to the value of cacheFlushStop. For example, if the value of cacheFlushStart is set to 80, set the
value of cacheFlushStop within the range of 0 to 80.
When you define values to stop cache flush, the higher the value, the higher the chance that the data for
a host read requires a drive read, rather than a reading from the cache.
When you define host types, if Storage Partitioning is enabled, the default host type affects only those
logical drives that are mapped in the default group. If Storage Partitioning is not enabled, all of the hosts
that are attached to the storage subsystem must run the same operating system and be compatible with
the default host type.
Media scan runs on all of the logical drives in the storage subsystem that have Optimal status, do not
have modification operations in progress, and have the mediaScanRate parameter enabled. Use the set
logicalDrive command to enable or disable the mediaScanRate parameter.
Password
Passwords are stored on each storage subsystem. For best protection, the password must:
v Be between eight and 32 characters long.
v Contain at least one uppercase letter.
v Contain at least one lowercase letter.
v Contain at least one number.
v Contain at least one non-alphanumeric character, for example, < > @ +.
Note: If you are using Full Disk Encryption (FDE) disk drives in your storage subsystem, you must use
these criteria for your storage subsystem password.
If you are using full disk encryption drives in your storage subsystem, you must use these criteria for
your storage subsystem password.
Important: You must set a password for your storage subsystem before you can create a security key for
encrypted Full Disk Encryption (FDE) disk drives.
Syntax
set storageSubsystem enclosurePositions=(controller |
enclosureID ... enclosureIDn)
Notes
This command defines the position of a enclosure in a storage subsystem by the position of the enclosure
ID in the enclosurePositions list. For example, if you have a controller module with an ID set to 84 and
expansion drawers with IDs set to 1, 12, and 50, the enclosurePositions sequence (84 1 12 50) places the
controller module in the first position, expansion drawer 1 in the second position, expansion drawer 12 in
the third position, and expansion drawer 50 in the fourth position. The enclosurePositions sequence (1
84 50 12) places the controller module in the second position, expansion drawer 1 in the first position,
expansion drawer 50 in the third position, and expansion drawer 12 in the fourth position.
You must include all of the enclosures in the storage subsystem in the list defined by the
enclosurePositions parameter. If the number of enclosures in the list does not match the total number of
enclosures in the storage subsystem, an error message appears.
Syntax
set storageSubsystem icmpPingResponse=(TRUE | FALSE)
Parameter
Parameter Description
icmpPingResponse This parameter turns on or turns off Echo
Request messages. Set the parameter to TRUE
to turn on Echo Request messages. Set the
parameter to FALSE to turn off Echo Request
messages.
Notes
The Internet Control Message Protocol (ICMP) is used by operating systems in a network to send error
messages, test packets, and informational messages related to the IP, such as a requested service is not
available or that a host or router could not be reached. The ICMP response command sends ICMP Echo
Request messages and receives Echo Response messages to determine if a host is reachable and how long
packets take to get to and from that host.
3-212 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Set Storage Subsystem iSNS Server IPv4 Address
This command sets the configuration method and address for an IPv4 Internet Storage Name Service
(iSNS).
Syntax
set storageSubsystem isnsIPV4ConfigurationMethod=[static | dhcp]
isnsIPV4Address=ip-address
Parameters
Parameters Description
isnsIPv4ConfigurationMethod The method that you want to use to define the
iSNS server configuration. You can enter the IP
address for the IPv4 iSNS servers by selecting
static. For IPv4, you can choose to have a
Dynamic Host Configuration Protocol (DHCP)
server select the iSNS server IP address by
entering dhcp. To enable DCHP, you must set the
isnsIPv4Address parameter to 0.0.0.0.
isnsIPv4Address The IP address that you want to use for the
iSNS server. Use this parameter with the static
value for IPv4 configurations. If you choose to
have a DHCP server set the IP address for an
IPv4 Internet iSNS server, you must set the
isnsIPv4Address parameter to 0.0.0.0.
Notes
The iSNS protocol facilitates the automated discovery, management, and configuration of iSCSI devices
and Fibre Channel devices on a TCP/IP network. iSNS provides intelligent storage discovery and
management services comparable to those found in Fibre Channel networks, which allow a commodity IP
network to function in a similar capacity as a storage area network. iSNS also facilitates a seamless
integration of IP networks and Fibre Channel networks, due to its ability to emulate Fibre Channel fabric
services and manage both iSCSI devices and Fibre Channel devices.
The DHCP server passes configuration parameters, such as network addresses, to IP nodes. DHCP
enables a client to acquire all of the IP configuration parameters that it needs to operate. DHCP lets you
automatically allocate reusable network addresses.
Syntax
set storageSubsystem isnsIPV6Address=ip-address
Parameters
Parameters Description
isnsIPv6Address The IPv6 address that you want to use for the iSNS server.
The iSNS protocol facilitates the automated discovery, management, and configuration of iSCSI and Fibre
Channel devices on a TCP/IP network. iSNS provides intelligent storage discovery and management
services comparable to those found in Fibre Channel networks, permitting a commodity IP network to
function in a similar capacity as a storage area network. iSNS also facilitates a seamless integration of IP
networks and Fibre Channel networks, due to its ability to emulate Fibre Channel fabric services, and
manage both iSCSI devices and Fibre Channel devices. iSNS thereby provides value in any storage
network that has iSCSI devices, Fibre Channel devices, or any combination thereof.
Syntax
set storageSubsystem isnsListeningPort=listeningPortIPAddress
Parameter
Parameter Description
isnsListeningPort The IP address that you want to use for the iSNS server
listening port. The range of values for the listening port
is 49152 to 65535. The default value is 3205.
Notes
A listening port resides on the database server and is responsible for these activities:
v Listening (monitoring) for incoming client connection requests
v Managing the traffic to the server
When a client requests a network session with a server, a listener receives the actual request. If the client
information matches the listener information, then the listener grants a connection to the database server.
Note: With controller firmware 10.83.xx.xx, use the command Storage Subsystem iSNS Server Refresh
instead.
Syntax
set storageSubsystem isnsServerRefresh
Parameters
None.
Notes
If the DHCP server is not operating at full capability, or if the DHCP server is unresponsive, the refresh
operation can take between two and three minutes to complete.
3-214 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
The set storageSubsystem isnsServerRefresh command returns an error if you did not set the
configuration method to DHCP. To set the configuration method to DHCP, use the set storageSubsystem
isnsIPV4ConfigurationMethod command.
Syntax
set storageSubsystem learnCycleDate
(daysToNextLearnCycle=numberOfDays |
day=dayOfTheWeek) time=HH:MM
Parameters
Parameter Description
daysToNextLearnCycle Valid values are 0 through 7, where 0 is immediately and 7 is in seven days.
The daysToNextLearnCycle parameter takes place up to seven days after the
next scheduled learn cycle.
day Valid values for the day parameter include the days of the week (Sunday,
Monday, Tuesday, Wednesday, Thursday, Friday, and Saturday). Setting the day
causes the next learn cycle to be scheduled on the specified day, after the
currently scheduled learn cycle.
time The time in 24-hour format; for example 8:00 a.m. is entered as 08:00. Nine
oclock p.m. is entered as 21:00, and 9:30 p.m. is entered as 21:30.
Notes
You can set the learn cycle to occur only once during a seven-day period.
The time parameter selects a specific time that you want to run the learn cycle. If a value is not entered,
the command uses a default value of 00:00 (midnight).
If the day and time specified are in the past, the next learn cycle takes place on the next possible day
specified.
Syntax
set storageSubsystem redundancyMode=(simplex | duplex)
Parameter
Parameter Description
redundancyMode Use simplex mode when you have a single controller. Use
duplex mode when you have two controllers.
Syntax
set storageSubsystem securityKey
Parameters
None.
Notes
Security-capable disk drives have hardware to accelerate cryptographic processing and each has a unique
disk drive key. A security-capable disk drive behaves like any other disk drive until it is added to a
secured array. When a security-capable disk drive is added to a secured array, it becomes
security-enabled.
Whenever a security-enabled disk drive is powered on, it requires the correct security key from the
controller before it can read or write data. So, a security-enabled drive uses two keys: the disk drive key
that encrypts and decrypts the data and the security key that authorizes the encryption and decryption
processes. The set storageSubsystem securityKey command commits the security key to all of the
controllers and security-enabled disk drives in the storage subsystem. The Full Disk Encryption (FDE)
feature ensures that if a security-enabled disk drive is physically removed from a storage subsystem, its
data cannot be read by any other device unless the security key is known.
Syntax
set storageSubsystem time
Parameters
None.
Syntax
set (logicaldrive ["
logicaldriveName"] | logicaldrives ["logicaldriveName1" ...
"logicaldriveNameN"] | logicaldrive <wwID>)
[newCapacity=capacity-spec |repositoryMaxCapacity=capacity-spec |
repositoryExpansionPolicy=(automatic|manual) |
warningThresholdPercent=integer-literal |
addRepositoryCapacity=capacity-spec]
3-216 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Parameters
Parameter Description
logicaldrive or logicaldrives The name of the specific logical drive for which you
want to define properties. (You can enter more than one
logical drive name if you use the logicaldrives
parameter.) Enclose the logical drive name in double
quotation marks (" ") inside of square brackets ([ ]).
logicaldrive The World Wide Identifier (WWID) of the logical drive
for which you are setting properties. You can use the
WWID instead of the logical drive name to identify the
logical drive. Enclose the WWID in angle brackets (< >).
newCapacity Increase the virtual capacity of the thin logical drive.
This is the value that the logical drive will report to a
host that is mapped to the logical drive. Values smaller
or equal to the existing capacity will cause an error.
repositoryMaxCapacity Set the maximum capacity of the repository logical drive.
The value must not be smaller that the physical capacity
of the repository logical drive. If the new value results in
a reduction in capacity to a level below the warning
threshold, the command will produce an error.
repositoryExpansionPolicy Set the expansion policy to automatic or manual. When
you change the policy from automatic to manual, the
maximum capacity value (quota) changes to the physical
capacity of the repository logical drive.
warningThresholdPercent Adjust the warning threshold. If a change to this value
would cause a warning condition, the command will fail
and produce an error.
addRepositoryCapacity Allocate capacity from the free extent of the disk pool. If
insufficient space is available the command fails.
Notes
When you use this command, you can specify one or more of the optional parameters.
Syntax
set storageSubsystem unnamedDiscoverySession=(TRUE | FALSE)
Parameter
Parameter Description
unnamedDiscoverySession This parameter turns on or turns off unnamed
discovery sessions. Set the parameter to TRUE to turn
on unnamed discovery sessions. Set the parameter to
FALSE to turn off unnamed discovery sessions.
Discovery is the process where initiators determine the targets that are available. Discovery occurs at
power-on/initialization and also if the bus topology changes, for example, if an extra device is added.
An unnamed discovery session is established without specifying a target ID in the login request. For
unnamed discovery sessions, neither the target ID nor the target portal group ID are available to the
targets.
Set VolumeCopy
This command defines the properties for a VolumeCopy pair.
Syntax
set volumeCopy target [targetName]
[source [sourceName]]
copyPriority=(highest | high | medium | low | lowest)
targetReadOnlyEnabled=(TRUE | FALSE)
copyType=(online | offline)
Parameters
Parameter Description
target The name of the target logical drive for which you want
to define properties. Enclose the target logical drive name
in square brackets ([ ]). If the target logical drive name
has special characters, you also must enclose the target
logical drive name in double quotation marks ( ).
source The name of the source logical drive for which you want
to define properties. Enclose the source logical drive
name in square brackets ([ ]). If the source logical drive
name has special characters, you also must enclose the
source logical drive name in double quotation marks
( ).
copyPriority The priority that the VolumeCopy has relative to host
I/O activity. Valid values are highest, high, medium, low,
or lowest.
targetReadOnlyEnabled The setting so that you can write to the target logical
drive or only read from the target logical drive. To write
to the target logical drive, set this parameter to FALSE. To
prevent writing to the target logical drive, set this
parameter to TRUE.
copyType Use this parameter to identify that a VolumeCopy has a
FlashCopy . If the VolumeCopy has a FlashCopy , set this
parameter to online. If the VolumeCopy does not have a
FlashCopy, set this parameter to offline.
Notes
When you use this command, you can specify one or more of the optional parameters.
3-218 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Show Array
This command returns this information about an array:
v The status (online or offline)
v The disk drive type (Fibre Channel, SATA, or SAS)
v Enclosure loss protection (yes or no)
v The current owner (the controller in slot A or the controller in slot B)
v The associated logical drives and free capacity
v The associated disk drives
Syntax
show array [arrayName]
Parameter
Parameter Description
array The alphanumeric identifier of the array (including -
and _) for which you want to show information.
Enclose the array identifier in square brackets ([ ]).
Syntax
show array [arrayName] exportDependencies
Parameter
Parameter Description
array The alphanumeric identifier (including - and _) of the array
for which you want to show export dependencies. Enclose
the array identifier in square brackets ([ ]).
Notes
This command spins up the disk drives in an array, reads the DACstore, and shows a list of import
dependencies for the array. The array must be in an Exported state or a Forced state.
Syntax
show array [arrayName] importDependencies
[cancelImport=(TRUE | FALSE)]
Notes
This command returns the dependencies of a specific array, which must be in an Exported state or a
Forced state. If a decision is made to retain the listed dependencies, then the cancelImport parameter can
be enforced to spin the disk drives back down.
The show array importDependencies command must be run before the start array import command.
Syntax
show cacheBackupDevice controller [(a | b)] diagnosticStatus [file="fileName"]
Parameters
Parameter Description
controller The controller that has the cache backup device on which
you are running the diagnostic tests. Valid controller
identifiers are a or b, where a is the controller in slot A, and
b is the controller in slot B. Enclose the controller identifier
in square brackets ([ ]). If you do not specify a controller, the
storage management software returns a syntax error.
file The name of the file that contains the result of the diagnostic
tests. Enclose the file name in double quotation marks (" ").
This command does not automatically append a file
extension to the file name. You must add an extension when
you enter the file name.
Syntax
show cacheMemory controller [(a | b)] diagnosticStatus file="fileName"
3-220 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Parameters
Parameter Description
controller The controller that has the cache memory on which you are
running the diagnostic tests. Valid controller identifiers are a
or b, where a is the controller in slot A, and b is the
controller in slot B. Enclose the controller identifier in square
brackets ([ ]).
file The name of the file that contains the result of the diagnostic
tests. Enclose the file name in double quotation marks (" ").
This command does not automatically append a file
extension to the file name. You must add an extension when
you enter the file name.
Syntax
show ((cgEnhancedFlashCopyImage [(cgEnhancedFlashCopyImageName |
cgEnhancedFlashCopyImageSequenceNumber)]) |
(cgEnhancedFlashCopyImages [(cgEnhancedFlashCopyImageNumber1 ...
cgEnhancedFlashCopyImageNumbern |
cgEnhancedFlashCopyImageSequenceNumber1 ...
cgEnhancedFlashCopyImageSequenceNumbern)]) |
allCGEnhancedFlashCopyImages
[summary]
Notes
The name of an Enhanced FlashCopy image has two parts separated by a colon (:):
v The identifier of the Enhanced FlashCopy consistency group
v The identifier of the Enhanced FlashCopy image
For example, if you want to show Enhanced FlashCopy image 12345 in an Enhanced FlashCopy
consistency group that has the name enhancedFlashCopyCGroup1, you would use this command:
show enhancedFlashCopyImage ["enhancedFlashCopyCGroup1:12345"];
To show the most recent Enhanced FlashCopy image in an Enhanced FlashCopy consistency group that
has the name enhancedFlashCopyCGroup1, you would use this command:
show enhancedFlashCopyImage ["enhancedFlashCopyCGroup1:newest"];
To show the Enhanced FlashCopy images in several Enhanced FlashCopy consistency groups that have
the names enhancedFlashCopyCGroup1, enhancedFlashCopyCGroup2, and enhancedFlashCopyCGroup3, you
would use this command:
show enhancedFlashCopyImages ["enhancedFlashCopyCGroup1:12345
enhancedFlashCopyCGroup2:newest enhancedFlashCopyCGroup3:oldest"];
3-222 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Note: In these examples, the Enhanced FlashCopy consistency group name is separated from the
Enhanced FlashCopy image identifier by a colon (:).
Show Controller
For each controller in a storage subsystem, this command returns the following information:
v The status (Online or Offline)
v The current firmware and NVSRAM configuration
v The pending firmware configuration and NVSRAM configuration (if any)
v The board ID
v The product ID
v The product revision
v The serial number
v The date of manufacture
v The cache size or the processor size
v The date and the time to which the controller is set
v The associated logical drives (including the preferred owner)
v The Ethernet port
v The physical disk interface
v The host interface, which applies only to Fibre Channel host interfaces
Syntax
show (allControllers | controller [(a | b)]) [summary]
Parameters
Parameter Description
allControllers The setting to return information about both controllers in
the storage subsystem.
controller The setting to return information about a specific controller
in the storage subsystem. Valid controller identifiers are a or
b, where a is the controller in slot A, and b is the controller
in slot B. Enclose the controller identifier in square brackets
([ ]).
summary The setting to return a concise list of information about both
controllers in the storage subsystem.
Syntax
show controller [(a | b)] diagnosticStatus [file=filename]
Syntax
show (allControllers | controller [(a | b)]) NVSRAM [hostType=hostTypeIndexLabel
| host=hostName]
Parameters
Parameter Description
allControllers The setting to return information about both controllers in the
storage subsystem.
controller The setting to return information about a specific controller in
the storage subsystem. Valid controller identifiers are a or b,
where a is the controller in slot A, and b is the controller in
slot B. Enclose the controller identifier in square brackets ([ ]).
hostType The index label or number of the host type. Use the show
storageSubsystem hostTypeTable command to generate a list
of available host type identifiers.
host The name of the host that is connected to the controllers.
Enclose the host name in double quotation marks ( ).
Notes
Use the show controller NVSRAM command to show parts of or all of the NVSRAM before using the set
controller command to change the NVSRAM values. Before making any changes to the NVSRAM,
contact your IBM Technical Support representative to learn what regions of the NVSRAM you can
modify.
Syntax
show (iscsiInitiator | iscsiTarget) [iSCSI-ID] iscsiSessions
3-224 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Parameters
Parameter Description
iSCSI-ID The name of the iSCSI initiator or target for which you
want to obtain session information. Enclose the iSCSI
initiator name or target in square brackets ([ ]).
Notes
If you enter this command without defining any arguments, this command returns information about all
of the iSCSI sessions that are currently running. To limit the information that is returned, enter a specific
iSCSI initiator or a specific iSCSI target. This command then returns information about the session for
only the iSCSI initiator or the iSCSI target that you named.
Syntax
show diskPool [diskPoolName]
Parameters
Parameter Description
diskPool The name of the disk pool for which you are retrieving
information. Enclose the disk pool name in square
brackets ([ ]).
Notes
Use this command to show the disk pool content of the storage subsystem profile.
For disk pools, the show diskPool command returns information in this form:
DETAILS
Name: 1
Status: Optimal
Capacity: 67.860 GB
Current owner: Controller in slot 0,1
Depending on the size of your storage subsystem, this information can be several pages long. In addition,
the disk drive information is returned for the show storageSubsystem profile command.
Syntax
show (allDrives
[DriveMediaType=(HDD | SSD | unknown | allMedia)] |
[DriveType=(fibre | SATA | SAS | PATA)]) |
Drive [enclosureID,drawerID,slotID] |
Drives [enclosureID1,drawerID1,slotID1 ... enclosureIDn,drawerIDn,slotIDn])
summary
Parameters
Parameter Description
allDrives The setting to return information about all of the disk
drives in the storage subsystem.
3-226 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Parameter Description
DriveMediaType The type of disk drive media for which you want to
retrieve information. Valid are:
v HDD Use this option when you have hard disk
drives in the expansion drawer.
v SSD Use this option when you have solid state disk
drives in the expansion drawer.
v unknown Use if you are not sure what types of disk
drive media are in the expansion drawer.
v allMedia Use this option when you want to use all
types of disk drive media that are in the expansion
drawer.
DriveType The type of disk drive for which you want to retrieve
information. Valid are fibre, SATA, SAS, or PATA.
Drive or Drives EnclosureID1,drawerID1,slotID1 ...
enclosureIDn,drawerIDn,slotIDn is for enclosures with
multiple disk drive drawers. For enclosures without
disk drive drawers, use enclosureID1,slotID1 ...
enclosureIDn,slotIDn instead. Enclosure ID values are 0
to 99. Drawer ID values are 1 to 5. Slot ID values are 1
to 32. Enclose the values in parentheses.
summary The setting to return the status, the capacity, the data
transfer rate, the product ID, and the firmware version
for the specified disk drives.
Notes
To determine information about the type and location of all of the disk drives in the storage subsystem,
use the allDrives parameter.
To determine the information about the Fibre Channel, SATA, SAS, PATA disk drives in the storage
subsystem, use the DriveType parameter.
To determine the type of disk drive in a specific location, use the Drive parameter, and enter the
enclosure ID and the slot ID for the disk drive.
The drive parameter supports both high-capacity drive expansion enclosures and low-capacity drive
expansion enclosures. A high-capacity drive expansion enclosure has drawers that hold the drives. The
drawers slide out of the drive expansion enclosure to provide access to the drives. A low-capacity drive
expansion enclosure does not have drawers. For a high-capacity drive expansion enclosure, you must
specify the identifier (ID) of the drive expansion enclosure, the ID of the drawer, and the ID of the slot in
which a drive resides. For a low-capacity drive expansion enclosure, you need only specify the ID of the
drive expansion enclosure and the ID of the slot in which a drive resides. For a low-capacity drive
expansion enclosure, an alternative method for identifying a location for a drive is to specify the ID of
the drive expansion enclosure, set the ID of the drawer to 0, and specify the ID of the slot in which a
drive resides.
Parameters
Parameter Description
driveChannel The identifier number of the disk drive channel for
which you want to show information. Valid disk drive
channel values are 1, 2, 3, 4, 5, 6, 7, or 8. Enclose the
disk drive channel in square brackets ([ ]).
driveChannels The identifier number of the disk drive channels for
which you want to show information. Valid disk drive
channel values are 1, 2, 3, 4, 5, 6, 7, or 8. Enclose the
disk drive channels in square brackets ([ ]) with the
disk drive channel value separated by a space.
allDriveChannels The identifier that selects all of the disk drive channels.
Syntax
show allDrives downloadProgress
Parameters
None.
Notes
When all of the firmware downloads have successfully completed, this command returns good status. If
any firmware downloads fail, this command shows the firmware download status of each disk drive that
was targeted. This command returns the statuses shown in this table.
Status Definition
Successful The downloads completed without errors.
Not Attempted The downloads did not start.
Partial Download The download is in progress.
Failed The downloads completed with errors.
Syntax
show (allEnhancedFlashCopyGroups | enhancedFlashCopyGroup [
enhancedFlashCopyGroupName] | enhancedFlashCopyGroups
[enhancedFlashCopyGroupName1 ... enhancedFlashCopyGroupNamen])
[summary | schedule]
3-228 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Parameters
Parameter Description
allEnhancedFlashCopyGroups The parameter to return information about all of the
Enhanced FlashCopy groups in the storage subsystem.
enhancedFlashCopyGroup or enhancedFlashCopyGroups The name of the specific Enhanced FlashCopy group for
which you are retrieving information. Enclose the
Enhanced FlashCopy group name in square brackets
([ ]).
Notes
This command returns Enhanced FlashCopy group information as shown in this example:
FLASHCOPY GROUP DETAILS
FLASHCOPY GROUPS-----------------------------
SUMMARY
DETAILS
Status: Optimal
Type: Standard
Associated base logical drive: 2
Cluster size: 65,536 bytes
Repository
Parameters
Parameter Description
enhancedFlashCopyImage or enhancedFlashCopyImages The name of the Enhanced FlashCopy image. The name
of an Enhanced FlashCopy image is comprised of two
parts:
v The name of the Enhanced FlashCopy group
v An identifier for the Enhanced FlashCopy image in the
Enhanced FlashCopy group.
3-230 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Notes
The name of an Enhanced FlashCopy image has two parts separated by a colon (:):
v The identifier of the Enhanced FlashCopy group
v The identifier of the Enhanced FlashCopy image
For example, if you want to show Enhanced FlashCopy image 12345 in an Enhanced FlashCopy group
that has the name enhancedFlashCopyGroup1, you would use this command:
show enhancedFlashCopyImage ["enhancedFlashCopyGroup1:12345"];
To show the most recent Enhanced FlashCopy image in an Enhanced FlashCopy group that has the name
enhancedFlashCopyGroup1, you would use this command:
show enhancedFlashCopyImage ["enhancedFlashCopyGroup1:newest"];
To show the Enhanced FlashCopy images in several Enhanced FlashCopy consistency groups that has the
names enhancedFlashCopyGroup1, enhancedFlashCopyGroup2, and enhancedFlashCopyGroup3, you would
use this command:
show enhancedFlashCopyImages ["enhancedFlashCopyGroup1:12345
enhancedFlashCopyGroup2:newest enhancedFlashCopyGroup3:oldest"];
Syntax
show (allEnhancedFlashCopyLogicalDrives | enhancedFlashCopyLogicalDrive
[enhancedFlashCopyLogicalDriveName] |
enhancedFlashCopyLogicalDrives
[enhancedFlashCopyLogicalDriveName1 ... enhancedFlashCopyLogicalDriveNamen])
[summary]
Parameters
Parameter Description
allEnhancedFlashCopyLogicalDrives The parameter to return information about all of the
Enhanced FlashCopy logical drives in the storage
subsystem.
enhancedFlashCopyLogicalDrive or The name of a specific Enhanced FlashCopy logical drive
enhancedFlashCopyLogicalDrives about which you are retrieving information. Enclose the
Enhanced FlashCopy logical drive name in square
brackets ([ ]).
Notes
You can use any combination of alphanumeric characters, underscore (_), hyphen (-), and pound (#) for
the names. Names can have a maximum of 30 characters.
This command returns Enhanced FlashCopy logical drive information as shown in this example:
Enhanced FlashCopy Logical drive Timestamp Enhanced FlashCopy Image Timestamp Mode
1/23/12 6:44:31 PM IST 1/23/12 6:27:36 PM IST Read Write
The size of your monitor determines how the information wraps and will affect how the information
appears.
Syntax
show remoteMirror candidates primary=logicalDriveName
remoteStorageSubsystemName=storageSubsystemName
Parameters
Parameter Description
primary The name of the local logical drive that you want for
the primary logical drive in the remote-mirror pair.
Enclose the primary logical drive name in double
quotation marks ( ).
remoteStorageSubsystemName The remote storage subsystem that contains possible
logical drives for a secondary logical drive. If the
remote storage subsystem name has special
characters, you must also enclose the remote storage
subsystem name in double quotation marks ( ).
Syntax
show remoteMirror (localLogicalDrive [logicalDriveName] |
localLogicalDrives [logicalDriveName1 ... logicalDriveNameN])
synchronizationProgress
3-232 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Parameter
Parameter Description
localLogicalDrive or The name of the primary logical drive of the remote mirror
localLogicalDrives pair for which you want to check synchronization progress.
Enclose the primary logical drive name in double quotation
marks ( ) inside of square brackets ([ ]).
Syntax
show hostCard controller [(a | b)] diagnosticStatus [progressOnly] [file=filename]
Parameters
Parameter Description
controller The controller that has the host interface card on which you
are running the diagnostic tests. Valid controller identifiers
are a or b, where a is the controller in slot A, and b is the
controller in slot B. Enclose the controller identifier in square
brackets ([ ]). If you do not specify a controller, the storage
management software returns a syntax error.
progressOnly The progressOnly parameter, shows the progress of the
diagnostic test without waiting for the diagnostic tests to
completely finish.
file The name of the file that contains the results of the
diagnostic tests. This command does not automatically
append a file extension to the file name. You must add an
extension when you enter the file name.
Note: The progressOnly parameter is useful for seeing the progress of command scripts that need to
sequentially complete operations.
Syntax
show allHostPorts
None.
Notes
This command returns HBA host port information similar to this example:
HOST PORT IDENTIFIER HOST PORT NAME HOST TYPE
12:34:56:54:33:22:22:22 Jupiter1 Solaris
12:34:56:78:98:98:88:88 Pluto1 Windows 2000/Server 2003 Clustered
54:32:12:34:34:55:65:66 Undefined Undefined
Syntax
show (allLogicalDrives | logicalDrive [logicalDriveName] |
logicalDrives [logicalDriveName1 ... logicalDriveNameN]) summary
Parameters
Parameter Description
allLogicalDrives The setting to return information about all of the logical drives
in the storage subsystem.
3-234 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Parameter Description
logicalDrive or The name of the specific logical drive for which you are
logicalDrives retrieving information. You can enter more than one logical
drive name. Enclose the logical drive name in square brackets
([ ]). If the logical drive name has special characters, you also
must enclose the logical drive name in double quotation marks
( ).
summary The setting to return a concise list of information about the
logical drives.
Note: For FlashCopy logical drive copies, the show logical drive command returns information about the
schedules for the FlashCopy logical drive copies. The schedule information is in this form:
Schedule State: Active | Disabled | Completed
Last Run Time: <mm/dd/yyyy> <hh:mm a.m. | p.m.>
Next Run Time: <mm/dd/yyyy> <hh:mm a.m. | p.m.>
Start Date: <mm/dd/yyyy>End Date: <mm/dd/yyyy> | "No End Date"
Days of Week: <Sunday - Saturday>, <Sunday - Saturday>, ....
Times for flashcopy recreate: <hh:mm a.m. | p.m.>, <hh:mm a.m. | p.m.>
For a long-running operation that is currently running on a logical drive, this command returns
information about the logical drive action and amount of the long-running operation that is completed.
The amount of the long-running operation that is completed is shown as a percentage (for example, 25
means that 25 percent of the long-running operation is completed).
Syntax
show logicalDrive [logicalDriveName] actionProgress
Parameters
Parameter Description
logicalDrive The name of the logical drive that is running the
long-running operation. Enclose the logical drive name
in double quotation marks ( ) inside of square
brackets ([ ]).
Syntax
show (alllogicalDrives | logicalDrive [logicalDriveName]
logicalDrives [logicalDriveName1 ... logicalDriveNameN] performanceStats
Parameters
Parameter Description
alllogicalDrives The setting to return performance statistics about all
of the logical drives in the storage subsystem.
Syntax
show (alllogicalDrives | logicalDrive [logicalDriveName] |
logicalDrives [logicalDriveName1 ... logicalDriveNameN]) reservations
Parameters
Parameter Description
allLogicalDrives The setting to return persistent reservation information
about all of the logical drives in the storage subsystem.
logicalDrive or The name of the specific logical drive for which you are
logicalDrives retrieving persistent reservation information. You can enter
more than one logical drive name. Enclose the logical drive
name in square brackets ([ ]). If the logical drive name has
special characters, you also must enclose the logical drive
name in double quotation marks ( ).
Syntax
Parameters
Parameter Description
autoSupportConfig The parameter to show the status of the automatic
support data collection when a critical event occurs
along with the location where the Support Data
bundle was saved.
profile The parameter to show all of the properties of the
logical components and the physical components that
comprise the storage subsystem. The information
appears in several screens.
3-236 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Parameter Description
batteryAge The parameter to show the status, the age of the
battery in days, and the number of days until the
battery needs to be replaced.
connections The parameter to show a list of where the drive
channel ports are located and where the drive
channels are connected.
defaultHostType The parameter to show the default host type and the
host type index.
healthStatus The parameter to show the health, logical properties,
and physical component properties of the storage
subsystem.
hostTypeTable The parameter to show a table of all of the host types
that are known to the controller. Each row in the
table shows a host type index and the platform that
the host type index represents.
hotSpareCoverage The parameter to show information about which
logical drives of the storage subsystem have hot
spare coverage and which logical drives do not.
features The parameter to show a list of the feature identifiers
for all enabled features in the storage subsystem.
time The parameter to show the current time to which
both controllers in the storage subsystem are set.
logicalDriveDistribution The parameter to show the current controller owner
for each logical drive in the storage subsystem.
longRunningOperations The parameter to show the long running operations
for each array and each logical drive in the storage
subsystem.
Notes
The profile parameter shows detailed information about the storage subsystem. The information appears
on several screens on a display monitor. You might need to increase the size of your display buffer to see
all of the information. Because this information is so detailed, you might want to save the output of this
parameter to a file. To save the output to a file, run the show storageSubsystem command that looks like
this example:
c:\...\...\client>smcli 123.45.67.89 -c show storageSubsystem profile; -o
c:\\folder\\storageSubsystemprofile.txt
The previous command syntax is for a host that is running a Windows operating system. The actual
syntax varies depending on your operating system.
The information fields returned by the longRunningOperations parameter have these meanings:
v NAME is the name of a logical drive that is currently in a long running operation. The logical drive name
must have the "Logical Drive" as a prefix.
v OPERATION lists the operation being performed on the array or logical drive.
v % COMPLETE shows how much of the long running operation has been performed.
3-238 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
v STATUS can have one of these meanings:
Pending The long running operation has not started but will start after the current operation is
completed.
In Progress The long running operation has started and will run until completed or stopped by
user request.
v TIME LEFT indicates the duration remaining to completing the current long running operation. The time
is in an "hours minute" format. If less than an hour remains, only the minutes are shown. If less than a
minute remains, the message "less than a minute" is shown.
The feature parameter returns information about the premium features in this form:
Syntax
show storageSubsystem autoConfiguration
[driveType=(fibre | SATA | SAS)
driveMediaType=(HDD | SSD | unknown | allMedia)
raidLevel=(0 | 1 | 3 | 5 | 6)
arrayWidth=numberOfDrives
arrayCount=numberOflogical driveGroups
logicalDrivesPerArrayCount=numberOfLogicalDrivesPerArray
hotSpareCount=numberOfHotspares
segmentSize=segmentSizeValue
cacheReadPrefetch=(TRUE | FALSE)]
securityType=(none | capable | enabled)
3-240 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Parameter Description
securityType The setting to specify the security level when
creating the arrays and all associated logical drives.
These settings are valid:
v none The array and logical drives are not
secure.
v capable The array and logical drives are
capable of having security set, but security has
not been enabled.
v enabled The array and logical drives have
security enabled.
Note: If you do not specify any properties, this command returns the RAID Level 5 candidates for each
drive type. If RAID Level 5 candidates are not available, this command returns candidates for RAID
Level 6, RAID Level 3, RAID Level 1, or RAID Level 0. When you specify auto configuration properties,
the controllers validate that the firmware can support the properties
A array is a set of drives that are logically grouped together by the controllers in the storage subsystem.
The number of drives in an array is a limitation of the RAID level and the controller firmware. When you
create an array, follow these guidelines:
v Beginning with firmware version 7.10, you can create an empty array so that you can reserve the
capacity for later use.
v You cannot mix drive types, such as SAS and Fibre Channel, within a single array.
v The maximum number of drives in an array depends on these conditions:
The type of controller
The RAID level
v RAID levels include: 0, 1, 10, 3, 5, and 6.
In a DS4700 Model 70 or a DS4700 Model 72 storage subsystem, a array with RAID level 0 and an
array with RAID level 10 can have a maximum of 112 drives.
In a DS4800 (Models 82, 84, 88) storage subsystem, an array with RAID level 0 and an array with
RAID level 10 can have a maximum of 224 drives.
An array with RAID level 3, RAID level 5, or RAID level 6 cannot have more than 30 drives.
An array with RAID level 6 must have a minimum of five drives.
If an array with RAID level 1 has four or more drives, the storage management software
automatically converts the array to a RAID level 10, which is RAID level 1 + RAID level 0.
v If an array contains drives that have different capacities, the overall capacity of the array is based on
the smallest capacity drive.
v To enable enclosure loss protection, you must create an array that uses drives located in at least three
drive expansion enclosures.
Hot Spares
Hot spare drives can replace any failed drive in the storage subsystem. A hot spare drive must have
capacity greater than or equal to any drive that can fail. If a hot spare drive is smaller than a failed drive,
you cannot use the hot spare drive to rebuild the data from the failed drive. Hot spare drives are
available only for RAID Level 1, RAID Level 3, RAID Level 5, or RAID Level 6.
The size of a segment determines how many data blocks that the controller writes on a single drive in a
logical drive before writing data on the next drive. Each data block stores 512 bytes of data. A data block
is the smallest unit of storage. The size of a segment determines how many data blocks that it contains.
For example, an 8 KB segment holds 16 data blocks. A 64 KB segment holds 128 data blocks.
When you enter a value for the segment size, the value is checked against the supported values that are
provided by the controller at run time. If the value that you entered is not valid, the controller returns a
list of valid values. Using a single drive for a single request leaves other drives available to
simultaneously service other requests. If the logical drive is in an environment where a single user is
transferring large units of data (such as multimedia), performance is maximized when a single data
transfer request is serviced with a single data stripe. (A data stripe is the segment size that is multiplied
by the number of drives in the array that are used for data transfers.) In this case, multiple drives are
used for the same request, but each drive is accessed only once.
For optimal performance in a multiuser database or file system storage environment, set your segment
size to minimize the number of drives that are required to satisfy a data transfer request.
Cache read prefetch lets the controller copy additional data blocks into cache while the controller reads
and copies data blocks that are requested by the host from the drive into cache. This action increases the
chance that a future request for data can be fulfilled from cache. Cache read prefetch is important for
multimedia applications that use sequential data transfers. The configuration settings for the storage
subsystem that you use determine the number of additional data blocks that the controller reads into
cache. Valid values for the cacheReadPrefetch parameter are TRUE or FALSE.
Syntax
show storageSubsystem dbmDatabase
Parameters
None.
Syntax
show storageSubsystem ddc
Parameters
None.
3-242 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Show Storage Subsystem Features
This command lists the feature configuration of a storage subsystem. This command returns information
that shows which features are enabled, disabled, evaluation, and available to be installed.
Syntax
show storageArray features
Parameters
None.
Notes
This command returns the feature information in a format similar to this example.
Syntax
show storageSubsystem hostTopology
Parameters
None.
Syntax
show storageArray profile
Parameters
Parameter Description
profile The parameter to show all of the properties of the logical
components and the physical components that comprise
the storage subsystem. The information appears in
several screens.
The profile parameter shows detailed information about the storage subsystem. The information appears
on several screens on a display monitor. You might need to increase the size of your display buffer to see
all of the information. Because this information is so detailed, you might want to save the output of this
parameter to a file. To save the output to a file, run the show storageSubsystem command that looks like
this example.
-c "show storageSubsystem profile;" -o "c:\\folder\\storageSubsystemProfile.txt"
The previous command syntax is for a host that is running a Windows operating system. The actual
syntax varies depending on your operating system.
When you save information to a file, you can use the information as a record of your configuration and
as an aid during recovery.
Syntax
show storageSubsystem lunMappings [host [hostName] |
hostgroup [hostGroupName]]
Parameters
Parameter Description
host The name of a specific host for which you want to see
the LUN mappings. Enclose the host name in double
quotation marks ( ) inside of square brackets ([ ]).
hostGroup The name of a specific host group for which you want
to see the LUN mappings. Enclose the host group
name in double quotation marks ( ) inside of square
brackets ([ ]).
Syntax
show storageSubsystem iscsiNegotiationDefaults
Parameters
None.
Notes
Information returned includes RAID controller enclosure default settings (that is, those settings that are
the starting point for negotiation) and the current active settings.
3-244 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Show Storage Subsystem Unreadable Sectors
This command returns a table of the addresses of all of the sectors in the storage subsystem that cannot
be read. The table is organized with column headings for the following information:
1. Logical drive user label
2. LUN
3. Accessible by (host or host group)
4. Date/time
5. Logical drive-relative logical block address (hexadecimal format 0xnnnnnnnn)
6. Disk drive location (enclosure t, slot s)
7. Disk drive-relative logical block address (hexadecimal format 0xnnnnnnnn)
8. Failure type
The data is sorted first by the logical drive user label and second by the logical block address (LBA).
Each entry in the table corresponds to a single sector.
Syntax
show storageSubsystem unreadableSectors
Parameters
None.
Show String
This command shows a string of text from a script file. This command is similar to the echo command in
MS-DOS and UNIX.
Syntax
show string
Parameters
None.
Notes
Syntax
show (allLogicalDrives | logicaldrive [logicaldriveName] |
logicaldrives [logicaldriveName1 ... logicaldriveNameN])
(consumedCapacity | (expansionHistory [file=fileName]))
Notes
With the expansionHistory parameter, the command returns information similar to the example shown
below:
Thin logical drive name: logical drive-nameRepository logical drive Name: REPOS_NNNN
Logged Time Expansion Type Start Capacity End Capacity
MM/DD/YYYY HH:MM:SS Manual|Automatic NNNNNNNN bytes NNNNNNNN bytes
With the consumedCapacity parameter, the command returns information similar to the example shown
below:
Syntax
show storageSubsystem unconfiguredIscsiInitiators
Parameters
None.
3-246 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Show VolumeCopy
This command returns this information about VolumeCopy operations:
v The copy status
v The start time stamp
v The completion time stamp
v The copy priority
v The source logical drive World-Wide Identifier (WWID) or the target logical drive WWID
v The target logical drive Read-Only attribute setting
You can retrieve information about a specific VolumeCopy pair or all of the VolumeCopy pairs in the
storage subsystem.
Syntax
show volumeCopy (allLogicalDrives | source [sourceName] |
target [targetName])
Parameters
Parameter Description
allLogicalDrives The setting to return information about VolumeCopy
operations for all of the VolumeCopy pairs.
source The name of the source logical drive about which you
want to retrieve information. Enclose the source logical
drive name in double quotation marks ( ) inside of
square brackets ([ ]).
target The name of the target logical drive about which you
want to retrieve information. Enclose the target logical
drive name in double quotation marks ( ) inside of
square brackets ([ ]).
Syntax
show VolumeCopy sourcecandidates
Parameters
None.
Notes
This command returns VolumeCopy source information as shown in this example:
Logical Drive Name: R1_2drives
Capacity: 40.0 GB
Array: 0
Logical Drive Name: R6_5drives_SATA
Capacity: 46.0 GB
Syntax
show volumeCopy source [sourceName] targetCandidates
Parameter
Parameter Description
source The name of the source logical drive for which you are
trying to find a candidate target logical drive. Enclose the
source logical drive name in double quotation marks ( )
inside of square brackets ([ ]).
Note: Defragmenting an array starts a long-running operation that you cannot stop.
Syntax
start array [arrayNumber] defragment
Parameter
Parameter Description
array The alphanumeric identifier of the array (including - and
_) that you want to defragment. Enclose the array
identifier in square brackets ([ ]).
Notes
Host I/O errors might result in the arrays with more than 32 logical drives. This operation also might
result in internal controller reboots because the timeout period ends before the array definition is set. If
you experience this issue, quiesce the host I/O operations, and try the command again.
Note: Within the array, you cannot move logical drives that are associated with the premium features
from one storage subsystem to another storage subsystem.
3-248 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Syntax
start array [arrayNumber] export
Parameter
Parameter Description
array The alphanumeric identifier of the array (including - and _)
that you want to export. Enclose the array identifier in square
brackets ([ ]).
Notes
When this command is successful, you can run the start array import command to finish moving the
array to a Complete state, which makes the array available to the new storage subsystem.
If this command is unsuccessful because hardware problems prevented the completion of the export, use
the set array forceState command. The set array forceState command lets you use the start array
import command to import an array.
After the array is in an Exported state or a Forced state, you can remove the disk drives that comprise
the array from the storage subsystem. You can reinstall the disk drives in a different storage subsystem.
Note: Within the array, you cannot move logical drives that are associated with the premium features
from one storage subsystem to another storage subsystem.
Syntax
start array [arrayNumber] import
Parameter
Parameter Description
array The alphanumeric identifier of the array (including - and _)
that you want to import. Enclose the array identifier in square
brackets ([ ]).
Notes
Higher-level logical drives that are specifically related to premium features (FlashCopy, Enhanced Remote
Mirroring, VolumeCopy, host-to-logical drive mapping, and persistent reservations) are removed as part
of the import operation.
The show array importDependencies command must be run before the start array import command.
Syntax
start array [arrayNumber] locate
Parameter
Parameter Description
array The alphanumeric identifier of the array (including - and
_) for which you want to locate the disk drives that belong
to that array. Enclose the array identifier in square brackets
([ ]).
This command runs diagnostic tests to evaluate the functionality of the device that you use to backup the
data in the cache if you lose power to the controller. The diagnostic tests are specific to the backup device
that is in the controller. Before you run these tests, make these changes to the controller that has the
backup device on which you want to run diagnostics:
v Place the controller into service mode (use the set controller [(a | b)]availability=serviceMode
command).
v Attach the management client directly to the controller through the management Ethernet port.
Note: In a dual-controller configuration, you must run these diagnostic tests through the controller that
you want to evaluate. You cannot run these diagnostic tests through the partner controller.
Syntax
start cacheBackupDevice [(1 | n | all)]
controller [(a | b)]
diagnostic diagnosticType=(basic | extended)
[extendedTestID=(writePatterns | random)]
3-250 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Parameters
Parameter Description
cacheBackupDevice The identifier for the cache backup device on which you
want to run the diagnostic tests. Valid cache backup device
identifiers are 1, 2, 3, 4 or 5.
v 1 for USB1 on the controller circuit board
v 2 for USB2 on the controller circuit board
v 3 for USB3 on the controller circuit board
v 4 for USB4 on the controller circuit board
v all for all of the USBs on the controller circuit board
Note: If you have only one cache backup device, the all
identifier does not work. Enclose the identifier for the cache
backup device in square brackets ([ ]).
controller The controller that has the cache backup device on which
you want to run the diagnostic tests. Valid controller
identifiers are a or b, where a is the controller in slot A, and
b is the controller in slot B. Enclose the controller identifier
in square brackets ([ ]). If you do not specify a controller, the
storage management software returns a syntax error.
diagnosticType The level of diagnostic testing that you want to run on the
cache backup device. You can run one of these levels of
testing:
Note: In a dual controller configuration, you must run these diagnostic tests through the controller that
you want to evaluate. You cannot run these diagnostic tests through the partner controller.
Syntax
start cacheMemory controller [(a | b)] diagnostic
diagnosticType=(basic | extended)
[extendedTestID=(marchC | patterns | psuedoRndm| DMACopy)]
Parameters
Parameter Description
controller The controller that has the cache memory on which you
want to run the diagnostic tests. Valid controller identifiers
are a or b, where a is the controller in slot A, and b is the
controller in slot B. Enclose the controller identifier in square
brackets ([ ]). If you do not specify a controller, the storage
management software returns a syntax error.
diagnosticType The level of diagnostic testing that you want to run on the
host interface card. You can run one of these levels of
testing:
3-252 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Extended Test Option Description
marchC This option performs a March C test on specific regions of
the Reconfigurable Processor Assembly (RPA) memory. This
option tests for only one set of inverse patterns.
patterns This option performs a word pattern test where the test
sequence proceeds with a series of read/write operations for
all locations in the specified memory region. The test uses a
set of special patterns. The test writes and verifies several
patterns at 32-bit widths.
pseudoRndm This option generates a non-repetitive pattern for double
word length, writes the pattern to the entire region, and
reads back the pattern for verification.
DMAcopy This option tests the capability of Direct Memory Access
(DMA) copy operations across regions in the cache memory.
This options uses the RPA hardware capabilities to move the
data from one region to another region.
Notes
You can run the diagnostic test on only one controller in the storage subsystem at any one time.
Syntax
start diskPool [diskPoolName] locate
Parameters
Parameter Description
diskPool The name of the disk pool that you want to locate.
Enclose the disk pool name in square brackets ([ ]).
The repository logical drive that is associated with the consistency group Enhanced FlashCopy logical
drive continues to track any new changes between the base logical drive and the consistency group
Enhanced FlashCopy logical drive that occur after the rollback operation is completed.
To stop a rollback operation to the member base logical drives use the stop cgEnhancedFlashCopyImage
rollback command.
Parameters
Parameter Description
consistencyGroupName The name of the consistency group for which you want
to start a rollback operation. Enclose the name of the
consistency group in double quotation marks (" ") inside
square brackets ([ ]). When the memberLogicalDriveSet
parameter is not used, the rollback process applies to all
member logical drives of the consistency group.
memberLogicalDriveSet The name of one or more member base logical drives in
a consistency group that you want to rollback. Enclose
each member base logical drive name in double
quotation marks (" ") inside parenthesizes (( )).
You can enter more than one member logical drive name.
Enclose all of the member logical drive names in one set
of double quotation marks (" ") inside parenthesizes (( )).
Separate each member logical drive name with a white
space.
Notes
To start a roll back operation for an entire consistency group that has the name congroup1, you would use
this command:
start cgEnhancedFlashCopyImage ["congroup1"] rollback;
To start a roll back operation for base logical drive members memVol1, memVol2, and memVol3 in a
consistency group that has the name congroup2, you would use this command:
start cgEnhancedFlashCopyImage ["congroup2"] rollback memberLogicalDriveset=("memVol1 memVol2 memVol3");
Note: In a dual controller configuration, you must run these diagnostic tests through the controller that
you want to evaluate. You cannot run these diagnostic tests through the partner controller.
Syntax
start controller [(a | b)] diagnostic diagnosticType=(basic | extended)
[extendedTestID=(SRAM | FIFO | dataCopy| RAID5Parity | RAID6Parity)]
3-254 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Parameters
Parameter Description
controller The controller on which you want to run the diagnostic
tests. Valid controller identifiers are a or b, where a is the
controller in slot A, and b is the controller in slot B. Enclose
the controller identifier in square brackets ([ ]). If you do not
specify a controller, the storage management software
returns a syntax error.
diagnostic The level of diagnostic testing that you want to run on the
host interface card. You can run one of these levels of
testing:
Notes
You can run the diagnostic test on only one controller in the storage subsystem at any one time.
This command starts an operation that saves debug trace information to a compressed file. The debug
trace information can be used by an IBM Technical Support representative to help analyze how well a
storage subsystem is running.
start controller [(a | b | both)] trace
dataType=(current | flushed | currentFlushed | all)
[forceFlush=(TRUE | FALSE)]
Parameters
Parameter Description
controller The controller for which you want to collect the trace debug
information. Valid controller identifiers are a or b, where a is
the controller in slot A, and b is the controller in slot B. You
can also simultaneously collect debug for both controllers by
entering both. Enclose the controller identifier in square
brackets ([ ]). If you do not specify a controller, the storage
management software returns a syntax error.
dataType The type of data that you want to collect:
v current Retrieves the current DQ traces
v flushed Retrieves all flushed DQ traces
v currentFlushed Retrieves both the current DQ trace and
the flushed DQ trace
v all Retrieves the current DQ trace, flushed DQ trace,
and all platform DQ traces
Note: If dataType=flushed and forceFlush=True, an error
message is returned indicating that only active traces can be
flushed to the buffer on retrieval.
forceFlush The setting to move the DQ information in the current
buffer to the flushed buffer when the DQ trace information
defined by the dataType parameter is retrieved. To enable
force flush, set this parameter to TRUE. To disable force
flush, set this parameter to FALSE.
Note: If dataType=flushed and forceFlush=True, an error
message is returned indicating that only active traces can be
flushed to the buffer on retrieval.
3-256 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Parameter Description
file The file path and the file name to which you want to save
the DQ trace information. Refer to the Notes section for
information about naming the files.
Notes
The DQ trace information is written to a compressed file with an extension of .zip. The file name is a
combination of a user-defined file name and the storage subsystem identifier (SAID). A constant of "dq" is
also added to the file name. The complete file name has this form: user_defined_file_name-SAID-dq.zip
Syntax
start diskDriveChannel [(1 | 2 | 3 | 4 | 5 | 6 | 7 | 8)]
controller [(a | b)] faultDiagnostics
{testDevices=[all | controller=(a | b) |
esms=[enclosureID1 (left | right), ... enclosureIDn (left | right)] |
Drives=[enclosureID1, drawerID1, slotID1, ... , enclosureIDn, drawerIDn, slotIDn]] |
dataPattern=(fixed | pseudoRandom) |
patternNumber=[(0xhexadecimal | number)] |
maxErrorCount=integer |
testIterations=integer |
timeout=timeInterval}
Parameter
Parameter Description
controller The identifier letter of the controller that you want to test.
Valid controller identifier values are a or b, where a is the
controller in slot A, and b is the controller in slot B.
testDevices The identifiers of the devices (controllers, ESMs, or drives) that
you want to test. You can specify all or enter the specific
identifiers for the devices that you want to diagnose.
Notes
Use the save driveChannel faultDiagnostics command and the stop driveChannel faultDiagnostics
command in association with the start driveChannel faultDiagnostics command. These commands are
needed to save the diagnostic test results to a file and to stop the diagnostic test.
You can also stop this command at any time by pressing Ctrl+C
Syntax
start driveChannel [(1 | 2 | 3 | 4 | 5 | 6 |7 | 8)] locate
Parameter
Parameter Description
driveChannel The identifier number of the disk drive channel that you
want to locate. Valid values for the identifier number for
the disk drive channel are 1, 2, 3, 4, 5, 6, 7, or 8. Enclose the
disk drive channel identifier number in square brackets
([ ]).
Attention: Possible damage to the storage subsystem configuration As soon as you enter this
command, all user data is destroyed.
3-258 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Syntax
start drive [enclosureID,drawerID,slotID] initialize
Parameter
Parameter Description
drive EnclosureID1,drawerID1,slotID1 ...
enclosureIDn,drawerIDn,slotIDn is for enclosures with
multiple disk drive drawers. For enclosures without disk
drive drawers, use enclosureID1,slotID1 ...
enclosureIDn,slotIDn instead. Enclosure ID values are 0 to
99. Drawer ID values are 1 to 5. Slot ID values are 1 to 32.
Enclose the values in square brackets ([ ]).
Notes
The drive parameter supports both high-capacity drive expansion enclosures and low-capacity drive
expansion enclosures. A high-capacity drive expansion enclosure has drawers that hold the drives. The
drawers slide out of the drive expansion enclosure to provide access to the drives. A low-capacity drive
expansion enclosure does not have drawers. For a high-capacity drive expansion enclosure, you must
specify the identifier (ID) of the drive expansion enclosure, the ID of the drawer, and the ID of the slot in
which a drive resides. For a low-capacity drive expansion enclosure, you need only specify the ID of the
drive expansion enclosure and the ID of the slot in which a drive resides. For a low-capacity drive
expansion enclosure, an alternative method for identifying a location for a drive is to specify the ID of
the drive expansion enclosure, set the ID of the drawer to 0, and specify the ID of the slot in which a
drive resides.
Syntax
start drive [enclosureID,drawerID,slotID] locate
Parameter
Parameter Description
drive EnclosureID1,drawerID1,slotID1 ...
enclosureIDn,drawerIDn,slotIDn is for enclosures with
multiple disk drive drawers. For enclosures without
disk drive drawers, use enclosureID1,slotID1 ...
enclosureIDn,slotIDn instead. Enclosure ID values are 0
to 99. Drawer ID values are 1 to 5. Slot ID values are 1
to 32. Enclose the values in square brackets ([ ]).
Notes
The drive parameter supports both high-capacity drive expansion enclosures and lowcapacity drive
expansion enclosures. A high-capacity drive expansion enclosure has drawers that hold the drives. The
drawers slide out of the drive expansion enclosure to provide access to the drives. A lowcapacity drive
expansion enclosure does not have drawers. For a high-capacity drive expansion enclosure, you must
specify the identifier (ID) of the drive expansion enclosure, the ID of the drawer, and the ID of the slot in
which a drive resides. For a lowcapacity drive expansion enclosure, you need only specify the ID of the
Syntax
start Drive [enclosureID1,drawerID1,slotID1 ... enclosureIDn,drawerIDn,slotIDn]
reconstruct
Parameter
Parameter Description
drive EnclosureID1,drawerID1,slotID1 ...
enclosureIDn,drawerIDn,slotIDn is for enclosures with
multiple disk drive drawers. For enclosures without disk
drive drawers, use enclosureID1,slotID1 ...
enclosureIDn,slotIDn instead. Enclosure ID values are 0 to 99.
Drawer ID values are 1 to 5. Slot ID values are 1 to 32.
Enclose values in square brackets ([ ]).
Notes
The drive parameter supports both high-capacity drive expansion enclosures and lowcapacity drive
expansion enclosures. A high-capacity drive expansion enclosure has drawers that hold the drives. The
drawers slide out of the drive expansion enclosure to provide access to the drives. A lowcapacity drive
expansion enclosure does not have drawers. For a high-capacity drive expansion enclosure, you must
specify the identifier (ID) of the drive expansion enclosure, the ID of the drawer, and the ID of the slot in
which a drive resides. For a lowcapacity drive expansion enclosure, you need only specify the ID of the
drive expansion enclosure and the ID of the slot in which a drive resides. For a lowcapacity drive
expansion enclosure, an alternative method for identifying a location for a drive is to specify the ID of
the drive expansion enclosure, set the ID of the drawer to 0, and specify the ID of the slot in which a
drive resides.
Syntax
start enclosure [enclosureID] locate
Parameter
Parameter Description
enclosure The enclosure that you want to locate. Enclosure ID values
are 0 to 99. Enclose the enclosure ID value in square brackets
([ ]).
3-260 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Start Enhanced FlashCopy Image Rollback
This command starts a rollback operation for a set of Enhanced FlashCopy images. The content of the
base logical drive changes immediately to match the point-in-time content of the selected Enhanced
FlashCopy image logical drive. The base logical drive immediately becomes available for read/write
requests after the rollback operation has successfully completed. To stop an Enhanced FlashCopy image
rollback operation, use the stop rollback enhancedFlashCopyImage command.
The repository logical drive that is associated with the Enhanced FlashCopy image continues to track any
new changes between the base logical drive and the Enhanced FlashCopy image logical drive that occur
after the rollback operation is completed.
Note: You cannot use this command for Enhanced FlashCopy images involved in online VolumeCopy.
Syntax
start enhancedFlashCopyImage ["enhancedFlashCopyImageName"] rollback
Parameters
Parameter Description
enhancedFlashCopyImage The name of the Enhanced FlashCopy image. The name
of an Enhanced FlashCopy image is comprised of two
parts:
v The name of the Enhanced FlashCopy group
v An identifier for the Enhanced FlashCopy image in the
Enhanced FlashCopy group.
Notes
The name of an Enhanced FlashCopy image has two parts separated by a colon (:):
v The identifier of the Enhanced FlashCopy group
v The identifier of the Enhanced FlashCopy image
For example, if you want to start a rollback operation for Enhanced FlashCopy image 12345 in an
Enhanced FlashCopy group that has the name enhancedFlashCopyGroup1, you would use this command:
start enhancedFlashCopyImage ["enhancedFlashCopyGroup1:12345"] rollback;
To start a rollback operation for the most recent Enhanced FlashCopy image in an Enhanced FlashCopy
group that has the name enhancedFlashCopyGroup1, you would use this command:
start enhancedFlashCopyImage ["enhancedFlashCopyGroup1:newest"]rollback;
Syntax
start remoteMirror primary [logicalDriveName] synchronize
Parameter
Parameter Description
primary The name of the primary logical drive for which you want to
start synchronization. Enclose the primary logical drive name
in double quotation marks ( ) inside of square brackets ([ ]).
The repository logical drive that is associated with the FlashCopy continues to track any new changes
between the base logical drive and the FlashCopy logical drive that occur after the rollback operation is
completed.
Syntax
start rollback (logicaldrive [flashcopyLogicalDriveName |
logicaldrives [flashcopyLogicalDriveName1 ... flashcopyLogicalDriveNamen])
Parameters
Parameter Description
logicaldrive or logicaldrives The name of the specific FlashCopy logical drive or
FlashCopy logical drives for which you want to start a
rollback operation. Enclose the FlashCopy logical drive
name in square brackets ([ ]). If the FlashCopy logical
drive name has special characters, you must also enclose
the FlashCopy logical drive name in double quotation
marks (" ").
Note: In a dual controller configuration, you must run these diagnostic tests through the controller that
you want to evaluate. You cannot run these diagnostic tests through the partner controller.
3-262 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Syntax
tart hostCard [(1 | 2 | 3 | 4)] controller [(a | b)] diagnostic
diagnosticType=(basic | extended)
[extendedTestID=(EDC | DMA | RAM | internalLoopback)]
Parameters
Parameter Description
hostCard The identifier for host interface card on which you want to
run the diagnostic tests. Valid host interface card identifiers
are 1, 2, 3, or 4. The value of the identifier is for the position
of the host interface card in the controller enclosure or
controller-drive enclosure. The position of the host interface
card depends on the type of controller enclosure or
controller-drive enclosure in your storage subsystem. See the
Notes for more information about the host interface card
identifier and the position of the host interface cards in a
controller enclosure. Enclose the controller identifier in
square brackets ([ ]).
controller The controller that has the host interface card on which you
want to run the diagnostic tests. Valid controller identifiers
are a or b, where a is the controller in slot A, and b is the
controller in slot B. Enclose the controller identifier in square
brackets ([ ]). If you do not specify a controller, the storage
management software returns a syntax error.
diagnosticType The level of diagnostic testing that you want to run on the
host interface card. You can run one of these levels of
testing:
If you choose the extended parameter, you also must use the
extendedTestID parameter and one of the extended test
options.
testIterations The number of times that you want to repeat the test.
Notes
You can run the diagnostic test on only one controller in the storage subsystem at any one time.
Syntax
start storageSubsystem [iscsi-host-port] dhcpRefresh
3-264 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Parameter
Parameter Description
iscsi-host-port The identifier of the port on the storage subsystem on
which you want to refresh the DHCP parameters. Enclose
the iSCSI host port name in square brackets ([ ]).
Notes
This operation ends the iSCSI connections for the portal and brings down the portal temporarily.
Note: Formatting a logical drive starts a long-running operation that you cannot stop.
Syntax
start logicalDrive [logicalDriveName] initialize
Parameter
Parameter Description
logicalDrive The name of the logical drive for which you are starting the
formatting. Enclose the logical drive name in square brackets
([ ]). If the logical drive name has special characters, you also
must enclose the logical drive name in double quotation
marks ( ).
Syntax
start secureErase (Drive [enclosureID,drawer ID,slotID] |
Drives [enclosureID1,drawerID1,slotID1 ... enclosureIDn,drawerIDn,slotIDn])
Parameters
Parameter Description
Drive or Drives EnclosureID1,drawerID1,slotID1 ...
enclosureIDn,drawerIDn,slotIDn is for enclosures with
multiple disk drive drawers. For enclosures without disk
drive drawers, use enclosureID1,slotID1 ...
enclosureIDn,slotIDn instead Enclosure ID values are 0 to 99.
Drawer ID values are 1 to 5. Slot ID values are 1 to 32.
Enclose the values in square brackets ([ ]).
Note:
The controller firmware creates a lock that restricts access to the FDE drives. FDE drives have a state
called Security Capable. When you create a security key, the state is set to Security Enabled, which
restricts access to all FDE drives that exist within the storage subsystem.
Syntax
start storageSubsystem locate
Parameters
None.
Syntax
start storageSubsystem configDbDiagnostic
[sourceLocation=(disk | onboard) |
diagnosticType=fileSystem |
controller[(a | b)]]
Parameters
Parameter Description
sourceLocation This parameter specifies the location of the database:
v disk indicates that data comes directly from the
database on the drive
v onboard indicates that data comes from the RPA
memory location
3-266 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Notes
This command runs a consistency check against a configuration database. All database records are
checked. Error data is written to a file in the data folder on disk automatically. You do not need to specify
an output file.
Executing a consistency check with the diagnosticType parameter set to a value other than filesystem
and with the sourceLocation parameter set to onboard can cause the operation to run for a long time.
This can have adverse effects on host I/O processing. This operation should be done only under direction
from the support organization.
Upon completion of the diagnostic test, the controller firmware returns one of these results:
v Diagnosis completed without errors. No ZIP file created.
v Diagnosis completed with errors. Refer to the ZIP file created at:
...\Install_dir\data\FirmwareUpgradeReports\timestamp_buildNo.zip
If the diagnostic test detects an inconsistency in the configuration database, the controller firmware
performs these actions:
v Returns a description of the inconsistency
v Saves a ZIP file containing raw binary data
...\Install_dir\data\FirmwareUpgradeReports\timestamp_buildNo.zip
You can use the binary data to help determine the cause of the problem, or you can send the file
containing the binary data to a IBM Technical Support representative.
To stop the database configuration diagnostic test, use the stop storageSubsystem configDbDiagnostic
command.
In addition, you can start the database configuration diagnostic test through the storage management
software GUI; however, you cannot stop the database configuration diagnostic test through the storage
management software GUI. If you want to stop a running diagnostic test, you must use the stop
storageSubsystem configDbDiagnostic command
Syntax
start storageSubsystem ddc controller [(a|b)]
Parameters
Parameter Description
controller This parameter specifies the controller from which to
produce the diagnostic data capture. Valid controller
identifiers are a or b, where a is the controller in slot A,
and b is the controller in slot B. Enclose the controller
identifier in square brackets ([ ]). If you do not specify a
controller, the storage management software returns a
syntax error.
Syntax
start storageSubsystem isnsServerRefresh
Parameters
None.
Notes
If you used the set storageSubsystem isnsIPv4ConfigurationMethod command to set the configuration
but did not set the configuration to DHCP, running the start storageSubsystem isnsServerRefresh
command returns an error.
Syntax
stop array locate
Parameters
None.
Syntax
stop cacheBackupDevice controller [(a | b)] diagnostic
Parameters
Parameter Description
controller The controller that has the cache backup device on which
you are running the diagnostic tests. Valid controller
identifiers are a or b, where a is the controller in slot A, and
b is the controller in slot B. Enclose the controller identifier
in square brackets ([ ]). If you do not specify a controller, the
storage management software returns a syntax error.
3-268 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Stop Cache Memory Diagnostic
This command stops the cache memory diagnostic tests that were started by the start
cacheMemorydiagnostic command.
Syntax
stop cacheMemory controller [(a | b)] diagnostic
Parameters
Parameter Description
controller The controller that has the cache memory on which you are
running the diagnostic tests. Valid controller identifiers are a
or b, where a is the controller in slot A, and b is the
controller in slot B. Enclose the controller identifier in square
brackets ([ ]). If you do not specify a controller, the storage
management software returns a syntax error.
Note: Canceling a consistency group Enhanced FlashCopy rollback operation leaves the base logical drive
in an indeterminate state with potentially invalid or inconsistent data. The related consistency group
Enhanced FlashCopy logical drive becomes disabled and unusable.
Syntax
stop cgEnhancedFlashCopyImage["consistencyGroupName"]| rollback
[memberLogicalDriveSet ["memberLogicalDriveName1 ... memberLogicalDriveNamen"]]
Parameters
Parameter Description
consistencyGroupName The name of the consistency group for which you want
to stop a rollback operation. Enclose the name of the
consistency group in double quotation marks (" ") inside
square brackets ([ ]). When the memberLogicalDriveSet
parameter is not used the rollback process applies to all
member logical drives of the consistency group.
memberLogicalDriveSet The name of one or more member base logical drives in
a consistency group that you want to stop a rollback
operation. Enclose each member base logical drive name
in double quotation marks (" ") inside parenthesizes (( )).
You can enter more than one member logical drive name.
Enclose all of the member logical drive names in one set
of double quotation marks (" ") inside parenthesizes (( )).
Separate each member logical drive name with a white
space.
To stop a roll back operation for an entire consistency group that has the name congroup1, you would use
this command:
stop cgEnhancedFlashCopyImage ["congroup1"] rollback;
To start a roll back operation for base logical drive members memVol1, memVol2, and memVol3 in a
consistency group that has the name congroup2, you would use this command:
stop cgEnhancedFlashCopyImage ["congroup2"] rollback memberLogicalDriveset=("memVol1 memVol2 memVol3");
Note: This command does not delete a consistency group Enhanced FlashCopy logical drive. To delete a
consistency group Enhanced FlashCopy logical drive use the delete cgEnhancedFlashCopyLogicalDrive
command.
Syntax
stop cgEnhancedFlashCopyLogicalDrive [enhancedFlashCopyLogicalDriveName]
Parameters
Parameter Description
cgEnhancedFlashCopyLogicalDrive The name of the consistency group Enhanced FlashCopy
logical drive that you want to stop creating. Enclose the
name of the consistency group Enhanced FlashCopy
logical drive in square brackets ([ ]) The name of the
consistency group Enhanced FlashCopy logical drive that
you want to delete. Enclose the consistency group
Enhanced FlashCopy logical drive name in square
brackets ([ ]). If the consistency group Enhanced
FlashCopy logical drive name has special characters, you
also must enclose the Enhanced FlashCopy logical drive
name in double quotation marks (" ").
Syntax
stop controller [(a | b)] diagnostic
3-270 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Parameters
Parameter Description
controller The setting to return information about a specific controller
in the storage subsystem. Valid controller identifiers are aor
b, where a is the controller in slot A, and b is the controller
in slot B. Enclose the controller identifier in square brackets
([ ]). If you do not specify a controller, the storage
management software returns a syntax error.
Syntax
stop diskPool locate
Parameters
None.
See the Start Drive Channel Fault Isolation Diagnostics on page 3-257 command for more information.
Syntax
stop driveChannel faultDiagnostics
Parameters
None.
Notes
Use the start driveChannel faultDiagnostics command and the save driveChannel faultDiagnostics
command with the stop driveChannel faultDiagnostics command. These commands are needed to start
the diagnostic test and save diagnostic test results to a file.
You can also stop the start driveChannel faultDiagnostics command at any time by pressing Ctrl+C.
Syntax
stop driveChannel locate
None.
Syntax
stop drive locate
Parameters
None.
Syntax
stop enclosure locate
Parameters
None.
Syntax
stop (enhancedFlashCopyGroup [enhancedFlashCopyGroupName] |
consistencyGroup [enhancedFlashCopyConsistencyGroupName])
pendingEnhancedFlashCopyImageCreation
Parameters
Parameter Description
enhancedFlashCopyGroup The alphanumeric identifier (including - and _) of the
Enhanced FlashCopy group for which you want to stop
pending Enhanced FlashCopy images. Enclose the
Enhanced FlashCopy group identifier in square brackets
([ []).
consistencyGroup The alphanumeric identifier (including - and _) of the
Enhanced FlashCopy consistency group for which you
want to stop pending Enhanced FlashCopy images.
Enclose the Enhanced FlashCopy group identifier in
square brackets ([ []).
3-272 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Stop Enhanced FlashCopy Image
This command cancels a pending Enhanced FlashCopy image copy-on-write operation on an Enhanced
FlashCopy group. If the Enhanced FlashCopy group does not have any pending Enhanced FlashCopy
images, this command returns an error message.
Syntax
stop(enhancedFlashCopyGroup [enhancedFlashCopyGroupName] |
consistencyGroup [consistencyGroupName])
pendingEnhancedFlashCopyImageCreation
Parameters
Parameter Description
enhancedFlashCopyGroup The alphanumeric identifier (including - and _) of the
Enhanced FlashCopy group that has the pending
Enhanced FlashCopy image copy-on-write operation that
you want to stop. Enclose the Enhanced FlashCopy
group name in double quotation marks (" ").
consistencyGroup The alphanumeric identifier (including - and _) of an
Enhanced FlashCopy consistency group that has the
pending Enhanced FlashCopy image copy-on-write
operation that you want to stop. Enclose the Enhanced
FlashCopy consistency group name in double quotation
marks (" ").
CAUTION:
Canceling an Enhanced FlashCopy image rollback operation leaves the base logical drive in an
indeterminate state with potentially invalid or inconsistent data. The related Enhanced FlashCopy
image logical drive becomes disabled and unusable.
Syntax
stop enhancedFlashCopyImage [enhancedFlashCopyImageName] rollback
Notes
The name of an Enhanced FlashCopy image has two parts separated by a colon (:):
v The identifier of the Enhanced FlashCopy group
v The identifier of the Enhanced FlashCopy image
For example, if you want to stop a rollback operation for Enhanced FlashCopy image 12345 in an
Enhanced FlashCopy group that has the name enhancedFlashCopyGroup1, you would use this command:
stop enhancedFlashCopyImage ["enhancedFlashCopyGroup1:12345"] rollback;
To stop a rollback operation for the most recent Enhanced FlashCopy image in an Enhanced FlashCopy
group that has the name enhancedFlashCopyGroup1, you would use this command:
stop enhancedFlashCopyImage ["enhancedFlashCopyGroup1:newest"] rollback;
Syntax
stop enhancedFlashCopyLogicalDrive ["enhancedFlashCopyLogicalDriveName"]
Parameters
Parameter Description
enhancedFlashCopyLogicalDrive The name of the Enhanced FlashCopy logical drive that
you want to stop. Enclose the Enhanced FlashCopy
logical drive name in double quotation marks (" ") inside
square brackets ([ ]).
3-274 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Notes
You can use any combination of alphanumeric characters, underscore (_), hyphen (-), and pound (#) for
the names. Names can have a maximum of 30 characters.
Stop FlashCopy
This command stops a copy-on-write operation.
Syntax
stop flashcopy (logicaDrive [logicaDriveName] |
logicaDrives [logicaDriveName1 ... logicaDriveNameN])
Parameters
Parameter Description
logicaDrive or The name of the specific logical drive for which you want to
logicaDrives stop a copy-on-write operation. You can enter more than one
logical drive name. Enclose the logical drive names using one of
these forms:
v On a Windows command line: \" logicaldriveName\"
v In a Windows script engine window: [" logicaldriveName"]
v On a Linux command line: \" logicaldriveName\"
v In a Linux script engine window: [\" logicaldriveName\"]
Notes
Names can be any combination of alphanumeric characters, underscore (_), hyphen (-), and pound (#).
Names can have a maximum of 30 characters.
One technique for naming the FlashCopy logical drive and the FlashCopy repository logical drive is to
add a hyphenated suffix to the original base logical drive name. The suffix distinguishes between the
FlashCopy logical drive and the FlashCopy repository logical drive. For example, if you have a base
logical drive with a name of Engineering Data, the FlashCopy logical drive can have a name of
Engineering Data-S1, and the FlashCopy repository logical drive can have a name of EngineeringData-R1.
If you do not choose a name for either the FlashCopy logical drive or the FlashCopy repository logical
drive, the storage management software creates a default name by using the base logical drive name. An
example of the FlashCopy logical drive name that the controllers might create is, if the base logical drive
name is aaa and does not have a FlashCopy logical drive, the default FlashCopy logical drive name is
aaa-1. If the base logical drive already has n-1 number of FlashCopy logical drives, the default name is
aaa-n. An example of the FlashCopy repository logical drive name that the controller might create is, if
the base logical drive name is aaa and does not have a FlashCopy repository logical drive, the default
FlashCopy repository logical drive name is aaa-R1. If the base logical drive already has n-1 number of
FlashCopy repository logical drives, the default name is aaa-Rn.
CAUTION:
Canceling a rollback operation leaves the base logical drive in an indeterminate state with potentially
invalid or inconsistent data. The related FlashCopy logical drive becomes disabled and unusable.
Parameters
Parameter Description
logicaldrive The name of the specific FlashCopy logical drive for
which you want to stop a rollback operation. Enclose the
FlashCopy logical drive name in square brackets ([ ]). If
the FlashCopy logical drive name has special characters,
you must also enclose the FlashCopy logical drive name
in double quotation marks (" ").
Syntax
stop host card controller [(a | b)] diagnostic
Parameters
Parameter Description
controller The controller that has the host interface card on which you
are running the diagnostic tests. Valid controller identifiers
are a or b, where a is the controller in slot A, and b is the
controller in slot B. Enclose the controller identifier in square
brackets ([ ]). If you do not specify a controller, the storage
management software returns a syntax error.
Syntax
stop storageSubsystem iscsiSession [integer]
Parameter
Parameter Description
iscsiSession The identifier number of the iSCSI session. Enclose the
identifier number of the iSCSI session in square brackets ([ ]).
3-276 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Syntax
stop consistencyGroup [consistencyGroupName] pendingEnhancedFlashCopyImageCreation
Parameters
Parameter Description
consistencyGroupName The name of the consistency group for which you want
to stop any pending Enhanced FlashCopy operation.
Enclose the name of the consistency group in square
brackets ([ ]).
Syntax
stop storageSubsystem configDbDiagnostic
Parameters
None.
Notes
The controller firmware returns a confirmation that the diagnostic test was cancelled.
In addition, you can start the database configuration diagnostic test through the storage management
software GUI; however, you cannot stop the database configuration diagnostic test through the storage
management software GUI. If you want to stop a running diagnostic test, you must use the
stopstorageSubsystem configDbDiagnostic command.
If you try to use the stop storageSubsystem configDbDiagnostic command after validation of the storage
subsystem configuration has finished, you do not receive any message that the validation has finished.
This behavior is expected.
Syntax
stop storageSubsystem driveFirmwareDownload
Parameters
None.
Syntax
stop storageSubsystem locate
Parameters
None.
Stop VolumeCopy
This command stops a VolumeCopy operation.
Syntax
stop volumeCopy target [targetName] source [sourceName]
Parameters
Parameter Description
target The name of the target logical drive for which you want to
stop a VolumeCopy operation. Enclose the target logical
drive name in square brackets ([ ]). If the target logical drive
name has special characters, you also must enclose the
target logical drive name in double quotation marks ( ).
source The name of the source logical drive for which you want to
stop a VolumeCopy operation. Enclose the source logical
drive name in square brackets ([ ]). If the source logical
drive name has special characters, you also must enclose the
source logical drive name in double quotation marks ( ).
Syntax
suspend remoteMirror (primary [primarylogicalDriveName]
primaries [primarylogicalDriveName1 ... primarylogicalDriveNameN])
writeConsistency=(TRUE | FALSE)
Parameters
Parameter Description
primary or primaries The name of the logical drive for which you want to
suspend operation. Enclose the logical drive name in
square brackets ([ ]). If the logical drive name has
special characters, you must also enclose the logical
drive name in double quotation marks ( ).
3-278 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Parameter Description
writeConsistency This parameter defines whether the logical drives
identified in this command are in a write-consistency
group or are separate. For the logical drives in the same
write-consistency group, set this parameter to TRUE. For
the logical drives that are separate, set this parameter to
FALSE.
Notes
If you set the writeConsistency parameter to TRUE, the logical drives must be in a write-consistency
group (or groups). This command suspends all write-consistency groups that contain the logical drives.
For example, if logical drives A, B, and C are in a write-consistency group and they have remote
counterparts A, B, and C, the command:
suspend
remoteMirror logicalDrive [A] writeConsistency=TRUE
suspends A-A, B-B, and C-C. If you have a write-consistency group 1={A, B, C} and write-consistency
group 2={D, E, F}, the command:
suspend remoteMirror logicalDrives=[A, D] writeConsistency=TRUE
Syntax
validate storageSubsystem securityKey
file="fileName"
passPhrase="passPhraseString"
Parameters
Parameter Description
file The file path and the file name that has the security key.
Enclose file path and the file name in double quotation
marks (" "). For example: file="C:\Program
Files\CLI\sup\seckey.slk"
Important: The file name must have an extension of .slk.
passPhrase A character string that encrypts the security key so that you
can store the security key in an external file. Enclose the
pass phrase in double quotation marks (" ").
Notes
Note: If your pass phrase does not meet these criteria, you will receive an error message.
Array Commands
Create Array on page 3-51
Controller Commands
Clear Drive Channel Statistics on page 3-46
Save Disk Drive Channel Fault Isolation Diagnostic Status on page 3-150
3-280 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Set Host Channel on page 3-187
Database Commands
Clear Storage Subsystem Configuration on page 3-48
Save Disk Drive Channel Fault Isolation Diagnostic Status on page 3-150
3-282 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Show Disk Drive on page 3-226
Enclosure Commands
Download Enclosure Configuration Settings on page 3-118
Set Enhanced FlashCopy Group Repository Logical Drive Capacity on page 3-183
Stop Enhanced FlashCopy Group Pending Enhanced FlashCopy Images on page 3-272
Set Enhanced FlashCopy Logical Drive Repository Logical Drive Capacity on page 3-182
Set Read Only Enhanced FlashCopy Logical Drive to a Read/Write Logical Drive on page 3-205
3-284 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Consistency Group Commands
Add Member to Consistency Group on page 3-39
Create Consistency Group Enhanced FlashCopy Logical Drive Mapping on page 3-61
Show Enhanced Remote Mirroring Logical Drive Synchronization Progress on page 3-232
FlashCopy Commands
Create FlashCopy Logical Drive on page 3-74
3-286 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Delete Host Port on page 3-109
iSCSI Commands
Create iSCSI Initiator on page 3-82
Logical Drive Commands (For Standard and Thin Logical Drives and
Logical Drives in a Disk pool)
Check Logical Drive Parity on page 3-44
Create RAID Logical Drive (Free Extent Based Select) on page 3-86
Session Command
Set Session on page 3-207
3-288 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Clear Storage Subsystem Firmware Pending Area on page 3-49
3-290 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Stop Storage Subsystem Drive Firmware Download on page 3-277
String Commands
Show String on page 3-245
VolumeCopy Commands
Create VolumeCopy on page 3-100
Configuring a RAID storage subsystem requires caution and planning to make sure that you define the
correct RAID level and configuration for your storage subsystem. You configure a storage subsystem to
create logical drives, which are addressable by the hosts, from a collection of disk drives. The commands
described in this chapter help you to set up and run a RAID storage subsystem. Additional commands
are also available to provide you with more control and flexibility.
Note: Many of these commands require a thorough understanding of the firmware as well as an
understanding of the network components that need to be mapped. Use the CLI commands and the
script commands with caution.
The sections in this chapter show some, but not all, of the CLI commands and the script commands. The
commands in this chapter show how you can use the commands to configure a storage subsystem. These
presentations do not describe all possible usage and syntax for the commands. (For complete definitions
of the commands, including syntax, parameters, and usage notes, see Chapter 3, Script Commands, on
page 3-1.
This chapter contains examples of CLI command usage and script command usage. The command syntax
that is used in the examples is for a host running a Microsoft operating system. As part of the examples,
the complete C:\ prompt and the DOS path for the commands are shown. Depending on your operating
system, the prompt and path construct will vary.
For most commands, the syntax is the same for all Windows operating systems and UNIX operating
systems, as well as for a script file. Windows operating systems, however, have an additional requirement
when entering names in a command. On Windows operating systems, you must enclose the name
between two back slashes (\ \) in addition to other delimiters. For example, the following name is used
in a command running under a Windows operating system:
[\Engineering\]
For a UNIX operating system, and when used in a script file, the name appears as follows:
[Engineering]
When you configure a storage subsystem, you allocate parts of this logical structure for use by one or
more of the hosts that are attached to the storage subsystem. Each disk drive and drive expansion
enclosure is numbered to allow the storage to be organized into arrays and logical drives. This
organization helps to provide storage capacity and data protection so that the hosts can safely store and
retrieve data from the storage subsystem.
This section defines the physical components and the logical components that are required to organize
and configure a storage subsystem. This section also describes how the components relate to each other.
Controllers
All storage subsystems have one or two controllers. The controllers are circuit-board assemblies that
manage data and communication between the hosts and the storage subsystem. The controller manages
the data flow between the hosts and the disk drives, keeping track of the logical address of where the
data resides. In general, each controller has a processor for performing control operations, NVSRAM for
storing the firmware code that operates the storage subsystem, and the buses along which the data flows.
The controllers are located in a controller module, which provides two positions for controllers: slot A
and slot B. The script commands identify each controller by the slot in which the controller is installed. If
a storage subsystem has only one controller, the controller must be in slot A. Controllers are identified by
using model numbers.
4-2 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Controller models DS4400 and DS4500 use minihubs; two connected to each controller. When viewed
from the rear of the controller module, the host-side minihubs are numbered from left-to-right a1, b1, a2,
b2. The script commands identify the host channels by using these identifiers. Minihubs also supported
the drive-side, where each minihub represents a single channel to the disk drives. When viewed from the
rear of the controller module, the disk drive minihubs are numbered from left to right 4, 3, 2, 1. The
script commands use these numbers to identify the disk drive channels.
Controllers manage the interface by using the controller firmware to transmit and receive commands
between the hosts and the disk drives. Host bus adapters facilitate the communication through whatever
interface is selected. Typically, two host bus adapters and two paths are used to optimize redundancy.
These controller modules and controller modules incorporate all host connections and expansion drawer
connections into each controller. The host ports must be identified in your command statements to let
you complete their network configurations.
The more recent controllers do not use minihubs. These controllers have host ports that are integrated
into the controller circuit boards or auxiliary circuit boards that are directly connected to the controller
circuit boards.
The following table lists the controller modules that do not use minihubs, the type of host port, and the
number of host ports.
Table 4-1. Host Ports and the Type of Host Interfaces on Controller Modules
Available
Host Ports
Per Type of Host
Model Controller Interface
DS3200 controller module (without optional SAS expansion card) 1 SAS
DS3200 controller module (with optional SAS expansion card) 3 SAS
DS3300 controller module 2 iSCSI
DS3400 controller module 2 Fibre Channel
DS3500 series controller module up to 6 Fibre Channel,
SAS, or iSCSI
DCS3700 series controller module up to 6 Fibre Channel,
SAS, iSCSI1
DS3950 4 Fibre Channel and
iSCSI
DS4100, DS4200, and DS4300 2 Fibre Channel
DS4700 (model 70) controller module 2 Fibre Channel
DS4700 (model 72) controller module 4 Fibre Channel
DS4400, DS4500, and DS4800 4 Fibre Channel
DS5020 4 Fibre Channel and
iSCSI
DS5100 and DS5300 up to 8 Fibre Channel and
iSCSI
1
iSCSI will be supported in a future update.
The DS4800 (models 82, 84, and 88)-series controller module has four host ports and four channel ports
on each controller.
1 2 3 1 2 3
Controller A Controller B
The DS3300 and DS3400 controller modules have two host ports on each controller, which are numbered
from left to right: host port 1 and host port 2 as shown in the following figure:
1 2 1 2
Controller A Controller B
The DS3500 series controller modules can have up to six host ports, depending on the configuration,
which are numbered from left to right as shown in the following figure:
Controller A 1 2 3 4 5 6 Controller B 1 2 3 4 5 6
The DCS3700 series controller modules can have up to six host ports, depending on the configuration,
which are numbered from left to right as shown in the following figure:
4-4 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
FC host port 3
FC host port 4
SAS host port 2 FC host port 5
SAS host port 1 FC host port 6
2
1
I
O DC AC
2 4 2 4 2 4 2 4
1 2 8 8 8 8
FC FC FC
3 4 6
8 8 ID/Diag 5
2 4 2 4 2 4 2 4
1 2 8 8 8 8
FC FC FC
3 4 6
8 8 ID/Diag 5
2
1
I
O DC AC
Controller A Controller B
The host ports on the DS4200 and DS4700 (model 72) controller module are numbered from left-to-right
on controller B as Ch 1, Ch 2, Ch 3, and Ch 4. Controller A, which is installed upside-down in the
enclosure, is numbered from right-to-left in the same sequence, as shown in the following figure:
4 3 2 1
ds 47_ho s t_por ts
A
1 2 3 4
Figure 4-6. DS4200 and DS4700 Host Ports
The controller in the DS4800 controller module can have up to four host channels with one port for each
channel; up to two drive channels with two ports per channel (for a total of four drive ports); and, up to
two Ethernet ports. In the DS4800 (models 82, 84, and 88) controller module, the controllers are stacked
one above the other. The top controller is A. The bottom controller is B.
For controller A, the host channel identifiers are a1, a2, a3, and a4 (you will need this reference for the
CLI commands and the script commands): the host bus adapter (HBA) host ports are labeled 1, 2, 3, and
4. For controller B, the host channel identifiers are b1, b2, b3, and b4: the host bus adapter (HBA) host
ports are labeled 1, 2, 3, and 4.
The HBA host ports are labeled as shown in the following figure:
ds48_host_ports
B
1 2 3 4
Figure 4-7. DS4800 Host Ports
Controller A has drive channels 1 and 2. Controller A drive port pairs labeled 4 and 3 and 2 and 1
connect to controller A drive channels 1, and 2, respectively. Similarly, controller B also has two drive
channels, labeled as channels 3 and 4. Controller B drive port pairs labeled 1 and 2 and 3 and 4 connect
to controller B drive channel 3 and 4, respectively. Each Ethernet port on a controller can have a unique
IP address; however, both Ethernet ports share the same gateway IP address and remote login settings.
The controller in the DS3950 and DS5020 controller module can have up to four host channels with one
port for each channel, up to two drive channels with two ports per channel (for a total of four drive
ports), and up to two Ethernet ports.
For controller A, the host channel identifiers are a1, a2, a3, and a4 (you will need this reference for the
CLI commands and the script commands). For controller B, the host channel identifiers are b1, b2, b3,
and b4. The following illustration shows the HBA host ports.
4-6 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Controller A has one drive channel with two drive ports, labeled P1 and P2 from right to left. Controller
B has one drive channel with two ports, labeled P1 and P2 from left to right. Each Ethernet port on a
controller can have a unique IP address; however, both Ethernet ports share the same gateway IP address
and remote login settings.
The DS5300 and DS5100 controller modules can have up to eight host channels with two ports for each
channel; up to four drive channels with two ports per channel (for a total of eight drive ports); and, up to
two Ethernet ports.
For controller A, the host channel identifiers are a1, a2, a3, a4, a5, a6. a7, and a8 (you will need this
reference for the CLI commands and the script commands). The controller A host ports are numbered
from the right most port (a1) to the left most port (a8) as shown in Figure 4-9. For controller B, the host
channel identifiers are b1, b2, b3, b4, b5, b6, b7, and b8. The controller B host ports are numbered from
the left most port (b1) to the right most port (b8) as shown in Figure 4-9.
Note: The host ports are physically labeled on the host port covers in groups of 4 (1, 2, 3 and 4).
The HBA host ports are labeled as shown in the following figure:
8 7 6 5 4 3 2 1
A
Host ports Host ports
B
1 2 3 4 5 6 7 8
ds5_022309
Controller A has drive channels 1, 2, 3, and 4. Controller A drive port pairs, labeled 8 and 7, 6 and 5, 4
and 3, and 2 and 1, connect to controller A drive channels 1, 2, 3 and 4, respectively. Similarly, controller
B also has four drive channels, labeled as channels 5, 6, 7, and 8. Controller B drive port pairs, labeled 1
and 2, 3 and 4, 5 and 6, and 7 and 8, connect to controller B drive channels 5, 6, 7 and 8, respectively.
Each Ethernet port on a controller can have a unique IP address; however, both Ethernet ports share the
same gateway IP address and remote login settings.
Disk Drives
The disk drives provide the actual storage of the data that is sent to the storage subsystem. The disk
drives are mounted in an expansion drawer. The expansion drawer is an enclosure that, in addition to the
disk drives, contains power supplies, fans, environmental cards, and other supporting components.
Disk drives are located in a storage subsystem by enclosure ID and slot ID. Enclosure ID values are 0 to
99. In older enclosures, enclosure ID values are set during installation by switches on the rear of the
enclosures. In newer enclosures, enclosure ID values are set automatically when the power is applied.
The slot ID is the disk drive position in the expansion drawer. Slot ID values range from 1 to 16. An
expansion drawer can contain either 10, 12, 14, or 16 disk drives. The total number of disk drives in a
storage subsystem depends on the model of the controller and the type of expansion drawer.
Note: A maximum of seven expansion drawers can be on a channel when mixing 14-slot expansion
drawers and 16-slot expansion drawers.
The following table lists, by controller number and expansion drawer capacity, the maximum number of
disk drives in a storage subsystem.
Hot Spares
A hot spare is a disk drive that acts as a standby in the event that a disk drive containing data fails. The
hot spare is a disk drive that has not been assigned to a particular array and, as such, can be used in any
array. You can use the hot spare feature with RAID 1, RAID 3, RAID 5, or RAID 6 for arrays. This
concept is not applicable for disk pools. Disk pools have reserve capacity for reconstructed data.
Note: Some DS3000 and DS4000 controller firmware versions do not support RAID 6. (Firmware version
7.3x.xx.xx for the DS5000 supports RAID 6.) For more information, see the DS3000 and DS4000 controller
firmware readme files or the interoperability matrices.
If a disk drive in an array fails, the controllers automatically replace the failed disk drive with a hot
spare. The controllers use redundancy data to reconstruct the data from the failed disk drive onto the hot
spare. To be most effective, the disk drive that you assign as a hot spare must have a capacity equal to or
greater than the capacity of the largest disk drive in the storage subsystem. The hot spare must be the
same type of disk drive as the disk drive that failed (for example, a Serial Advanced Technology
Attachment [SATA] hot spare cannot replace a Fibre Channel hot spare).
You can assign disk drives to act as hot spares manually or have the script commands automatically
assign hot spares. If you manually assign a disk drive to be a hot spare, you must identify the disk drive
4-8 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
by enclosure ID and slot ID. When you let the script commands automatically assign hot spares, you
must enter the number of hot spares that you want in the storage subsystem. The maximum number of
hot spare disk drives per storage subsystem is 15.
Arrays
An array is a set of disk drives that are logically grouped together by the controllers in a storage
subsystem. After you create an array, you can create one or more logical drives in the array. An array is
identified by a sequence number that is defined by the controller firmware when you created the array.
Note: You can give a unique name to an array if your Storage Manager version is 10.77 or later with
controller firmware version 7.77.xx.xx or later.
To create an array, you must define the capacity and the RAID level.
Capacity is the size of the array. Capacity is determined by the number of disk drives that you assign to
the array. You can use only unassigned disk drives to create an array. (In this programming guide, the
storage space on unassigned disk drives constitutes the unconfigured capacity of a storage subsystem.)
Free capacity is a contiguous region of unassigned capacity in a designated array. Before you create a new
logical drive in an array, you need to know the free capacity space so that you can determine the size of
the logical drive.
The number of disk drives you can include in an array is constrained by the capacity of each disk drive.
the following table relates the capacity of individual disk drives to the number of disk drives that you
can include in an array.
Table 4-3. Maximum Number of Disk Drives in an Array Based on Capacity
Controller firmware PRIOR to 7.10 Controller firmware 7.10 or later
(DS4000) or 6.xx (DS3000) (DS3000/DCS3700/DS4000 / DS5000 only)
Number of drives per 30 for all RAID levels v RAID 3 and RAID 5: 30 drives
array
v RAID 0 and RAID 1: Maximum of drives
supported for a given storage subsystem
Maximum logical drive 2 TB Number of drives in an array multiplied by
size the size of the smallest capacity drive in the
array
Disk Pools
About disk pools
A disk pool is a set of disk drives that is logically grouped together in the storage subsystem. The disk
drives in each disk pool must be of the same drive type and drive media type, and they must be similar
in size. As with an array, you can create one or more logical drives in the disk pool. However, the disk
pool is different from the logical drive group in the way that the data is distributed across the disk drives
that comprise the disk pool.
In an array, the data is distributed across the disk drives based on a RAID level. You can specify the
RAID level when you create the array. The data for each logical drive is written sequentially across the
set of disk drives in the array.
In a disk pool, the storage management software distributes the data for each logical drive randomly
across a set the disk drives in the disk pool. Each disk pool must have a minimum of eleven disk drives.
Although there is no limit on the maximum number of disk drives that can comprise a disk pool, the
disk pool cannot contain more disk drives than the maximum limit for each storage subsystem. The
Note: Because disk pools can coexist with arrays, a storage subsystem can contain both disk pools and
arrays.
Note: You have the option to manually create a disk pool, if you prefer not to proceed with the
automatic disk pool creation process. Refer to the Create Disk Pool on page 3-61 topic for more
information.
v Reduced Hot Spots A host might access some disk drives in the array for data more frequently than
other disk drives because of the sequential manner in which the data is written to the disk drives. This
frequency of access to disk drives creates hot spots in the array. In a disk pool, the hot spots are
significantly reduced because of the random manner in which the data is spread across a large number
of disk drives. The reduction of hot spots in the disk pool improves performance of the storage
subsystem.
v Faster Reconstruction of Data Disk pools do not use hot spare disk drives for data protection like an
array does. Instead of hot spare disk drives, disk pools use spare capacity within each drive that
comprises the disk pool.
In hot spare drive coverage, the maximum drive IOPS (I/O per second) limits the speed of
reconstruction of data from the failed drive to the hot spare drive. In a disk pool, the reconstruction of
data is much faster because the spare capacity in all of the disk drives that comprise the disk pool is
used. Additionally, the data to reconstruct after a drive failure is reduced because the data is spread
randomly across more disk drives in a disk pool.
Faster reconstruction of data in a disk pool also reduces the risk of additional drive failures during a
reconstruction operation. For example, consider a drive failure in a RAID Level 5 array that is
comprised of three disk drives. The time it takes to reconstruct the data from the failed drive is
relatively longer for an array. During the reconstruction of data, if another drive fails in this array, data
loss occurs. Unlike arrays, the time period for which the disk pool is exposed to multiple drive failures
during a reconstruction operation is significantly reduced.
v Reduced Maintenance You can configure the storage management software to send alert notifications
when the configured capacity of a disk pool is reaching a specified percentage of free capacity.
Additionally, you do not need to manage any hot spare disk drives. You can replace a set of disk
drives during a scheduled maintenance of the storage subsystem.
4-10 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
v The maximum size of disk pool is 256 TB with controllers having 1 GB or 2 GB cache per controllers
and iSCSI host Interface ports installed.
v The maximum size of the logical drive in a disk pool is 64 TB.
v Disk pool cannot be imported from, or exported to another storage subsystem.
Logical Drives
A logical drive is a logical component (object) that is the basic structure that is created on the storage
subsystem to store data. A logical drive is a contiguous subsection of an array that is configured to meet
application needs for data availability and I/O performance. The IBM Storage Manager client software
administers a logical drive as if the logical drive is one disk drive for data storage. Logical drives are
identified by names or labels that users choose. The logical drive names can be any combination of
alphanumeric characters, hyphens (-), and underscores (_). The maximum length of a logical drive name
is 30 characters.
Note: You must use the access logical drive only for in-band-managed storage subsystems.
v FlashCopy logical drive A logical point-in-time image of another logical drive. A FlashCopy logical
drive is the logical equivalent of a complete physical copy; however, it is not an actual, physical copy.
Instead, the firmware tracks only the data blocks that are overwritten and copies those blocks to a
FlashCopy repository logical drive.
v FlashCopy repository logical drive A special logical drive in the storage subsystem that is created as
a resource for a FlashCopy logical drive. A FlashCopy repository logical drive contains FlashCopy data
and copy-on-write data for a particular FlashCopy logical drive.
v Base logical drive A standard logical drive from which you create a FlashCopy logical drive. The
term base logical drive is used only to show the relationship between a standard logical drive from
which you are taking the point-in-time image and a FlashCopy logical drive.
v Primary logical drive A standard logical drive in a Enhanced Remote Mirroring relationship. The
primary logical drive accepts host data transfers and stores application data. When you first create the
mirror relationship, data from the primary logical drive is copied in its entirety to the associated
secondary logical drive.
v Secondary logical drive A standard logical drive in a Enhanced Remote Mirroring relationship that
maintains a mirror (or copy) of the data from its associated primary logical drive. The secondary
logical drive remains unavailable to host applications while mirroring is underway. In the event of a
disaster or a catastrophic failure of the primary site, a system administrator can promote the secondary
logical drive to a primary role.
v Mirror repository logical drive A special logical drive in a Enhanced Remote Mirroring
configuration that is created as a resource for each controller in both the local storage subsystem and
the remote storage subsystem. The controller stores mirroring information on this logical drive,
including information about remote writes that are not yet complete. A controller can use this
information to recover from controller resets and accidental power shutdown of the storage
subsystems.
The number and capacity of the logical drives in your storage subsystem depends on the type of
controller in the storage subsystem. The following table lists the maximum values for the logical drives in
a storage subsystem by specific controllers.
Table 4-4. Logical Drive Specifications by Supported Controller Model
DS3200,
DS3300, DS3500 DS4200, DS5100, DS3950,
Specification DS3400 series DCS3700 DS4700 DS4800 DS5300 DS5020
Maximum 256 5121 512 1024 2048 2048 1024
logical
drives per
storage
subsystem
Maximum 256 2562 256 256 256 256 256
logical
drives per
array
Maximum See Table 4-3 on page 4-9.
logical drive
size (less 12
GB for
overhead)
Maximum See Table 4-3 on page 4-9.
disk drives
per array
using RAID
5
Maximum N/A 163 16 64 128 128 64
remote
mirrors
Note: Addressable capacities greater than 2 TB are possible with some operating systems. Currently these
operating systems are Windows, Solaris 9, Solaris 10, AIX 5.2, AIX 5.3, HP-UX 11.23, and Linux 2.6.
A Windows operating system and a Linux 2.6 operating system using 500 GB disk drives can have a
maximum logical drive size of 112 TB (224 x 500) when controller firmware version 7.10.xx.xx or later is
installed in the DS4000 storage subsystem, or when controller firmware version 7.30.xx.xx is installed in
the DS5000 storage subsystem.
1
Firmware 7.77.xx.xx and later supports 512 logical drives per storage subsystem. Firmware 7.70.xx.xx
supports only 25 logical drives per subsystem.
2
Firmware 7.77.xx.xx and later supports 256 logical drives per partition. 7.70.xx.xx supports only 32
logical drives per partition
3
Requires firmware 7.77.xx.xx and later and enabling of the 16 remote mirrors premium feature.
RAID Levels
The RAID level defines a storage architecture in which the storage capacity on the disk drives in an array
is separated into two parts: part of the capacity stores the user data, and the remainder stores redundant
4-12 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
or parity information about the user data. The RAID level that you choose determines how user data is
written to and retrieved from the disk drives. Using the script commands, you can define five RAID
levels: RAID 0, RAID 1, RAID 3, RAID 5, and RAID 6. Each level provides different performance and
protection features.
RAID 0 provides the fastest storage access but does not provide any redundant information about the
stored data. RAID 1, RAID 3, RAID 5, and RAID 6 write redundancy information to the disk drives to
provide fault tolerance. The redundancy information might be a copy of the data or an error-correcting
code that is derived from the data. In RAID 1, RAID 3, RAID 5, or RAID 6 configurations, if a disk drive
fails, the redundancy information can be used to reconstruct the lost data. Regardless of the RAID level
that you choose, you can configure only one RAID level across each array. All redundancy information
for an array is stored within the array. The following table lists the RAID levels and describes the
configuration capabilities of each level.
Table 4-5. RAID Level Configurations
RAID
Level Configuration
0 Non-redundant striping mode Use this level for high-performance
needs. RAID 0 does not provide any data redundancy. RAID 0 stripes
data across all of the disk drives in the array. If a single disk drive fails,
all of the associated logical drives fail and all data is lost. RAID 0 is
suited for noncritical data. It is not recommended for high-availability
needs.
1
Striping mirroring mode RAID 1 uses disk drive mirroring to create
an exact copy from one disk drive to another disk drive. A minimum of
two disk drives are required; one for the user data, and one for the
mirrored data. RAID 1 offers high performance and the best data
availability.
If a single disk drive fails in a RAID 3 array, all of the associated logical
drives become degraded, but the redundancy data lets the data be
reconstructed. If two or more disk drives fail, all of the associated
logical drives fail, and all data is lost.
If a single disk drive fails in a RAID 5 array, all of the associated logical
drives become degraded, and the redundancy data permits the data to
be reconstructed. If two or more disk drives fail, all of the associated
logical drives fail, and all data is lost.
6
Data protection or continuous access mode RAID 6 stripes both user
data and redundancy data (in the form of parity) across the disk drives.
A minimum of five disk drives are required for a RAID 6 array. The
equivalent capacity of two disk drives is used for the redundancy data.
Two different algorithms calculate redundancy data, which are in the
form of both a P parity and a Q parity.
RAID 6 works well for larger disk drive sizes. Recovery from a second
disk drive failure in the same array is possible. If two disk drives fail in
a RAID 6 array, all of the associated logical drives become degraded,
but the redundancy data permits the data to be reconstructed. If three
or more disk drives fail, all of the associated logical drives fail, and all
data is lost.
Hosts
A host is a computer that is attached to the storage subsystem for accessing the logical drives in the
storage subsystem. The host is attached to the storage subsystem through HBA host ports, which are
connectors on host bus adapter circuit boards. You can define specific logical drive-to-LUN mappings to
an individual host or assign the host to a host group that shares access to one or more logical drives.
Hosts are identified by names or labels that users choose. The host name can be any combination of
alphanumeric characters, hyphens, and underscores. The maximum length of the host name is 30
characters.
In addition to a host name, some script commands require you to identify a host by its type. A host
type identifies the operating system under which the host is running (such as Windows, Solaris, or
Linux). Specifying the host type lets the controllers in the storage subsystem adapt their behavior (such as
LUN reporting and error conditions) to the operating system of the host that is sending the information.
Host types are identified by a label or an index number that is generated by the controller firmware.
4-14 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Host Groups
A host group is a topological element that you can define if you want to designate a collection of hosts
that will share access to the same logical drives. A host group is a logical entity. Host groups are
identified by names or labels that users choose. The host group name can be any combination of
alphanumeric characters with a maximum length of 30 characters.
When you first turn on the power to a storage subsystem, the Storage Manager software automatically
detects the HBA host ports. Initially, all detected host ports belong to a default group. You can use script
commands to identify the WWIDs on a storage subsystem and, if you choose, change them. If you move
an HBA host port, you must remap any logical drive-to-LUN mappings. Access to your data is lost until
you remap the logical drives.
The maximum number of HBA host ports that you can logically define for your storage subsystem
depends on the type of controller in the storage subsystem. The following table lists the maximum
number of HBA host ports that you can define.
Table 4-6. Maximum Number of HBA Host Ports per Controller
Controller Models Maximum Number of Host Ports
DS3200 64
DS3300 64
DS3400 64
DS3500 256
DCS3700 256
DS3950 640
DS4100 256
DS4300 256
DS4200 256 (before controller firmware
7.xx.xx.xx)
1024 (with controller firmware 7.xx.xx.xx
and higher)
DS4400 512
DS4500 512
DS4700 256 (before controller firmware
7.xx.xx.xx)
640 (with controller firmware 7.xx.xx.xx
and higher)
DS4800 512 (before controller firmware
7.xx.xx.xx)
2048 (with controller firmware 7.xx.xx.xx
and higher)
DS5020 640
DS5100 2048
DS5300 2048
Data protection is determined by the RAID level, hardware redundancy (such as global hot spares), and
software redundancy (such as the Enhanced Remote Mirroring premium feature and the FlashCopy
Logical Drive premium feature).
In general, you configure a storage subsystem by defining an array and its associated RAID level,
defining the logical drives, and defining which hosts have access to the logical drives. This section
explains how to use the script commands to perform the general steps to create a configuration from an
array of disk drives.
The command that returns general information about the storage subsystem is the show
storageSubsystem command. This command returns information about the components and properties of
your storage subsystem, including these items:
v A detailed profile of the components and features in the storage subsystem
v The age of the battery
v The default host type (which is the current host type)
v Other host types that you can select
v The hot spare locations
v The identifiers for enabled features
v The logical component profiles and the physical component profiles
v The time to which both controllers are set
4-16 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
v The controller that currently owns each logical drive in the storage subsystem
To return the most information about the storage subsystem, run the show storageSubsystem command
with the profile parameter. This example shows the complete CLI command and script command
running on a Windows operating system:
c:\...\...\client>smcli 123.45.67.89 -c show storageSubsystem profile;
This example identifies the storage subsystem by the example IP address 123.45.67.89. You can also
identify the storage subsystem by name.
The show storageSubsystem profile command returns detailed information about the storage subsystem.
The information appears in several display screens. You might need to increase the size of your display
buffer to see all of the information. Because this information is so detailed, you might want to save the
output to a file. To save the output to a file, enter the command as shown in this example:
c:\...\...\client>smcli 123.45.67.89 -c show storageSubsystem profile;
-o c:\folder\storageSubsystemprofile.txt
In this example, the name folder is the folder in which you choose to place the profile file, and
storageSubsystemprofile.txt is the name of the file. You can choose any folder and any file name.
Note: Attention: Possible loss of data When you are writing information to a file, the script engine
does not check to determine if the file name already exists. If you choose the name of a file that already
exists, the script engine writes over the information in the file without warning.
Chapter 10, Examples of Information Returned by the Show Commands, on page 10-1 shows the type
of information returned. When you save the information to a file, you can use the information as a record
of your configuration and as an aid during recovery.
To return a brief list of the storage subsystem features and components, use the summary parameter. The
command looks like this example:
c:\...\...\client>smcli 123.45.67.89 -c show storageSubsystem summary;
Following is the type of information that is returned by the show storageSubsystem command with the
summary parameter.
PROFILE FOR STORAGE SUBSYSTEM: DS5300_middle (1/27/09 3:23:25 PM)
SUMMARY------------------------------
Number of controllers: 2
Number of arrays: 5
RAID 6: Enabled
VolumeCopy: Disabled
Number of copies used: 0
Number of copies allowed: 0
Number of drives: 32
Mixed drive types: Enabled
Current drive type(s): Fibre (5), Fibre/FDE (21), Serial ATA (SATA) (6)
Total hot spare drives: 2
Standby: 2
In use: 0
Access logical drive: LUN 31,31,31 (see Mappings section for details)
Default host OS: Windows 2000/Server 2003/Server 2008 Non-Clustered
(Host OS index 2)
Current configuration
Firmware version: 07.50.00.00
NVSRAM version: N1818D53R1050V03
EMW version: 10.50.G5.02
AMW version: 10.50.G5.02
Pending configuration
Staged firmware download supported: Yes
Firmware version: None
NVSRAM version: None
Transferred on: None
Controller enclosure audible alarm: Disabled
CONTROLLERS------------------------------
Number of controllers: 2
4-18 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Controller in Enclosure 85, Slot A
Status: Online
Current configuration
Firmware version: 07.50.00.00
Appware version: 07.50.00.00
Bootware version: 07.50.00.00
NVSRAM version: N1818D53R1050V03
Pending configuration
Firmware version: None
Appware version: None
Bootware version: None
NVSRAM version: None
Transferred on: None
Current ID (ALPA)
On drive channel 1: 125/0x1
Replacement part number: memSpyTesting_9
Model name: 7000-88
Board ID: 7091
Submodel ID: 93
Product ID: 1818
Revision: 0730
Replacement part number: memSpyTesting_9
Part number: 32847-10
Serial number: SF74700554
Vendor: IBM
Date of manufacture: January 24, 2008
Data Cache
Total present: 8192 MB
Total used: 8192 MB
Data Cache Module
Status: Optimal
Location: Controller A, Slot 1
Capacity: 1,024 MB
Replacement Part number: Not Available
Manufacturer Part Number: M3 93T2953EZ3-CD5
Part Number: Not Available
Serial number: 1426196510
Manufacturer: Samsung
Date of manufacture: October 29, 2007
Data Cache Module
Status: Optimal
Location: Controller A, Slot 2
Capacity: 1,024 MB
Replacement Part number: Not Available
Manufacturer Part Number: M3 93T2953EZ3-CD5
Part Number: Not Available
Serial number: 1426196542
Manufacturer: Samsung
Date of manufacture: October 29, 2007
Data Cache Module
Status: Optimal
Location: Controller A, Slot 3
Capacity: 1,024 MB
Replacement Part number: Not Available
Manufacturer Part Number: M3 93T2953EZ3-CD5
Part Number: Not Available
Serial number: 1426196568
Manufacturer: Samsung
Date of manufacture: October 29, 2007
Data Cache Module
Status: Optimal
Location: Controller A, Slot 4
Capacity: 1,024 MB
Replacement Part number: Not Available
4-20 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Date of manufacture: Not available
Status: Optimal
Type: USB flash drive
Location: Controller A, Connector USB 3
Capacity: 3,919 MB
Product ID: TS4GUFM-V
Part number: Not Available
Serial number: 00000000000007
Revision level: 0.00
Manufacturer: Not Available
Date of manufacture: Not available
Host Interface Board
Status: Optimal
Location: Slot 2
Type: Fibre channel
Number of ports: 4
Board ID: 0801
Replacement part number: Not Available
Part number: PN L2-25023-02
Serial number: SN SF84300044
Vendor: VN LSI
Date of manufacture: November 1, 2008
Host Interface Board
Status: Optimal
Location: Slot 1
Type: Fibre channel
Number of ports: 4
Board ID: 0801
Replacement part number: Not Available
Part number: PN L2-25023-02
Serial number: SN SF84300041
Vendor: VN LSI
Date of manufacture: November 1, 2008
Date/Time: Tue Jan 27 15:19:38 EST 2009
Ethernet port: 1
Link status: Up
MAC address: 00:a0:b8:29:ed:8a
Negotiation mode: Auto-negotiate
Port speed: 10 Mbps
Duplex mode: Half duplex
IPv4 settings: Enabled
Network configuration: Static
IP address: 192.168.70.70
Subnet mask: 255.255.255.0
Gateway: 0.0.0.0
IPv6 settings: Enabled
Auto-configuration: Stateless
Local IP address: FE80:0000:0000:0000:02A0:B8FF:FE29:ED8A
Ethernet port: 2
Link status: Failed
MAC address: 00:a0:b8:29:ed:8b
Negotiation mode: Auto-negotiate
Port speed: Unknown
Duplex mode: Half duplex
IPv4 settings: Enabled
Network configuration: Static
IP address: 192.168.129.101
4-22 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Maximum data rate: 4 Gbps
Current data rate: 4 Gbps
Data rate control: Auto
Link status: Up
Status: Online
Current configuration
Firmware version: 07.50.00.00
Appware version: 07.50.00.00
4-24 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Bootware version: 07.50.00.00
NVSRAM version: N1818D53R1050V03
Pending configuration
Firmware version: None
Appware version: None
Bootware version: None
NVSRAM version: None
Transferred on: None
Current ID (ALPA)
On drive channel 1: 124/0x2
Replacement part number: Not Available
Model name: 7000-88
Board ID: 7091
Submodel ID: 93
Product ID: 1818
Revision: 0730
Replacement part number:
Part number: 32847-10
Serial number: SF74600024
Vendor: IBM
Date of manufacture: January 23, 2008
Data Cache
Total present: 8192 MB
Total used: 8192 MB
Data Cache Module
Status: Optimal
Location: Controller B, Slot 9
Capacity: 1,024 MB
Replacement Part number: Not Available
Manufacturer Part Number: M3 93T2953EZ3-CD5
Part Number: Not Available
Serial number: 1127652678
Manufacturer: Samsung
Date of manufacture: December 31, 2007
Data Cache Module
Status: Optimal
Location: Controller B, Slot 10
Capacity: 1,024 MB
Replacement Part number: Not Available
Manufacturer Part Number: M3 93T2953CZ3-CD5
Part Number: Not Available
Serial number: 4076997590
Manufacturer: Samsung
Date of manufacture: January 29, 2007
Data Cache Module
Status: Optimal
Location: Controller B, Slot 11
Capacity: 1,024 MB
Replacement Part number: Not Available
Manufacturer Part Number: M3 93T2953CZ3-CD5
Part Number: Not Available
Serial number: 4076997577
Manufacturer: Samsung
Date of manufacture: January 29, 2007
Data Cache Module
Status: Optimal
Location: Controller B, Slot 12
Capacity: 1,024 MB
Replacement Part number: Not Available
Manufacturer Part Number: M3 93T2953CZ3-CD5
Part Number: Not Available
Serial number: 4076997790
Manufacturer: Samsung
Date of manufacture: January 29, 2007
Data Cache Module
Status: Optimal
Location: Controller B, Slot 13
4-26 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Revision level: 0.00
Manufacturer: Not Available
Date of manufacture: Not available
Host Interface Board
Status: Optimal
Location: Slot 3
Type: Fibre channel
Number of ports: 4
Board ID: 0801
Replacement part number: Not Available
Part number: PN L2-25023-02
Serial number: SN SF84300021
Vendor: VN LSI
Date of manufacture: November 1, 2008
Host Interface Board
Status: Optimal
Location: Slot 4
Type: Fibre channel
Number of ports: 4
Board ID: 0801
Replacement part number: Not Available
Part number: PN L2-25023-02
Serial number: SN SF84300014
Vendor: VN LSI
Date of manufacture: November 1, 2008
Date/Time: Tue Jan 27 15:19:47 EST 2009
Ethernet port: 1
Link status: Up
MAC address: 00:a0:b8:29:ec:e6
Negotiation mode: Auto-negotiate
Port speed: 10 Mbps
Duplex mode: Half duplex
IPv4 settings: Enabled
Network configuration: Static
IP address: 192.168.70.71
Subnet mask: 255.255.255.0
Gateway: 0.0.0.0
IPv6 settings: Enabled
Auto-configuration: Stateless
Local IP address: FE80:0000:0000:0000:02A0:B8FF:FE29:ECE6
Ethernet port: 2
Link status: Failed
MAC address: 00:a0:b8:29:ec:e7
Negotiation mode: Auto-negotiate
Port speed: Unknown
Duplex mode: Half duplex
IPv4 settings: Enabled
Network configuration: Static
IP address: 192.168.129.102
Subnet mask: 255.255.255.0
Gateway: 0.0.0.0
IPv6 settings: Enabled
Auto-configuration: Stateless
Local IP address: FE80:0000:0000:0000:02A0:B8FF:FE29:ECE7
4-28 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Maximum data rate: 4 Gbps
Current data rate: 4 Gbps
Data rate control: Auto
Link status: Up
The summary information is also returned as the first section of information when you use the profile
parameter.
The show commands return information about the specific components of a storage subsystem. The
information returned by each of the show commands is the same as the information returned by the show
storageSubsystem profile command, but the information is constrained to the specific component. For
information about a command, refer to the page number shown.
v Show Controller on page 3-223
v Show Disk Drive on page 3-226
v Show Drive Channel Statistics on page 3-227
v Show Storage Subsystem Host Topology on page 3-243
v Show Storage Subsystem LUN Mappings on page 3-244
4-30 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
v Show Logical Drive on page 3-234
v Show Array on page 3-219
v Show Logical Drive Reservations on page 3-236
There are other commands that can help you learn about your storage subsystem. To see a list of the
commands, see Chapter 3, Script Commands, on page 3-1. These commands are organized by the
storage subsystem activities that the commands support, such as logical drive commands, host
commands, enclosure commands, and others.
Attention: Possible damage to the storage subsystem configuration As soon as you run this
command, the existing storage subsystem configuration is deleted.
With controller firmware 7.xx.xx.xx and higher, this command supports two parameters that you can use
to limit the amount of configuration information removed:
v all Removes the entire configuration of the storage subsystem, including security information and
identification information. Removing all of the configuration information returns the storage subsystem
to its initial state. (This is what the command will assume if no parameters are specified.)
v arrays Removes the logical drive configuration and the array configuration, but leaves the rest of
the configuration intact.
Note: With controller firmware earlier than 7.xx.xx.xx,, there are no parameters. The default is the action
described for the all parameter.
If you want to create new arrays and logical drives within the storage subsystem, you can use the clear
storageSubsystem configuration command with the arrays parameter to remove existing arrays in a
pre-existing configuration. This action destroys the pre-existing configuration. Use the clear
storageSubsystem configuration command only when you create a new configuration.
Before you run the autoConfigure storageSubsystem command, run the show storageSubsystem
autoConfigure command. The latter command returns a list of parameter values that the Storage
Manager software uses to automatically create a storage subsystem. If you would like to change any of
the parameter values, you can do so by entering new values for the parameters when you run the
autoConfigure storageSubsystem command. If you are satisfied with the parameter values that the show
storageSubsystem autoConfiguration command returns, run the autoConfigure storageSubsystem
command without new parameter values.
When you use the autoConfigure storageSubsystem command, two symbol functions
(getAutoConfigCandidates and createAutoConfig) are used that let the client retrieve default settings for
the various automatic configuration parameters, change the settings, query what the results of those
changes would be and, finally, apply the desired parameters to create a configuration. The configurability
portion of this feature provides enhancements to the automatic array creation algorithms, which produce
arrays with improved performance and more information about disk drive and logical drive attributes so
the user can make better choices when configuring logical drives manually.
The arrayWidth parameter defines the number of unassigned disk drives that you want to use for each
new array.
The arrayCount parameter defines the number of new arrays that you want in the storage subsystem.
The LogicalDrivesPerArrayCount parameter defines the number of logical drives that you want in each
array.
The hotSpareCount parameter defines the number of hot spares that you want in each array.
The segmentSize parameter defines the amount of data, in KB, that the controller writes on a single disk
drive in a logical drive before writing data on the next disk drive. The smallest units of storage are data
blocks. A data block stores 512 bytes of data. The size of a segment determines how many data blocks
that it contains. An 8-KB segment holds 16 data blocks. A 64-KB segment holds 128 data blocks.
4-32 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Important: For optimal performance in a multiuser database or file system storage environment, set the
segment size to minimize the number of disk drives that are needed to satisfy an I/O request.
Using a single disk drive for a single request leaves other disk drives available to simultaneously service
other requests. Valid segment size values are 8, 16, 32, 64, 128, 256, and 512.
Note: If you set the cache block size to 16, you cannot create a logical drive with a segment size of 8.
If the logical drive is for a single user with large I/O requests (such as multimedia), performance is
maximized when a single I/O request can be serviced with a single data stripe. A data stripe is the
segment size multiplied by the number of disk drives in the array that are used for data storage. In this
environment, multiple disk drives are used for the same request, but each disk drive is accessed only
once.
The cacheReadPrefetch parameter turns on or turns off the ability of the controller to read additional
data blocks into the cache. When you turn on cache read prefetch, the controller copies additional data
blocks into the cache while it is reading requested data blocks from a disk drive into the cache. This
action increases the chance that a future request for data can be fulfilled from the cache, which improves
the speed with which data is accessed. The number of additional data blocks that the controller reads into
the cache is determined by the configuration settings for the storage subsystem that you use. Cache read
prefetch is important for applications that use sequential I/O, such as multimedia applications.
Valid values for the cacheReadPrefetch parameter are TRUE or FALSE. If you want to turn on cache read
prefetch, set the cacheReadPrefetch parameter to TRUE. If you want to turn off cache read prefetch, set the
cacheReadPrefetch parameter to FALSE.
The following table lists the default values for the segment size and cache read prefetch settings for
different storage subsystem uses.
Table 4-7. Default Values for Segment Size and Cache Read Prefetch
Storage Subsystem Use Segment Size (KB) Cache Read Prefetch
File system 128 TRUE
Database 128 TRUE
Multimedia 256 TRUE
After you have finished creating the arrays and the logical drives by using the autoConfigure
storageSubsystem command, you can further define the properties of the logical drives in a configuration
by using the set logicalDrive command. (For a description about how to further define your
configuration, see Modifying Your Configuration on page 4-44.)
Security Type
The securityType parameter is used to specify the security subsystems with Full Disk Encryption (FDE)
drives. A Disk Encryption Activation premium feature must be purchased and enabled before you can
take advantage of the FDE drive security feature. The minimum version of controller firmware that
supports FDE drive security features is 07.5x.xx.xx. If this parameter is set to none, the created arrays and
logical drives will not be encrypted. If the parameter is set to enabled, the arrays and logical drives will
have security enabled and encrypted.
With FDE, the controller firmware can create a key and activate the drive security feature. The drive
security feature encrypts data as the data is written to the drive and decrypts the data as the data is read
from the drive. Without the key created by the controller, the data written to the drive is inaccessible.
The command in this example creates a storage subsystem configuration by using Fibre Channel disk
drives set to RAID level 5. Three arrays are created, and each array consists of eight disk drives, which
are configured into four logical drives. The storage subsystem has two hot spares. The segment size for
each logical drive is 8 KB. The cache read prefetch is turned on, which causes additional data blocks to be
written into the cache.
T10PI protection
T10PI protection checks and corrects errors that might occur as data is communicated between a host and
a storage subsystem. Thus, enabling this feature for a new logical drive ensures that errors are detected
and corrected. To enable T10PI, storage subsystem must support T10PI and the disk pool must be T10PI
capable.
You must have unassigned disk drives in the array. You do not need to assign the entire capacity of the
array to a logical drive.
4-34 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
cacheReadPrefetch=(TRUE | FALSE)
segmentSize=segmentSizeValue]
enclosureLossProtect=(TRUE | FALSE)
securityType=(none | capable | enabled) T10PI=(none|enabled)]
Note: The capacity parameter, the owner parameter, the cacheReadPrefetch parameter, the segmentSize
parameter, and the enclosureLossProtect parameter are optional parameters (indicated by the items
inside the square brackets). You can use one or all of the optional parameters as needed to define your
configuration. If you choose not to use any of the optional parameters, the default values of the
parameters are used for your configuration.
The userLabel parameter is the name that you want to give to the logical drive. The logical drive name
can be any combination of alphanumeric characters, hyphens, and underscores. The maximum length of
the logical drive name is 30 characters. You must enclose the logical drive name with double quotation
marks ( ).
The drives parameter is a list of the disk drives that you want to use for the array. Enter the enclosure ID
and the slot ID of each disk drive that you want to use. Enclose the list in parentheses, separate the
enclosure ID value and the slot ID value of a disk drive with a comma, and separate each enclosure ID
and slot ID pair with a space. This example shows you how to enter enclosure ID values and slot ID
values:
(1,1 1,2 1,3 1,4 1,5)
The capacity parameter defines the size of the logical drive. You do not need to assign the entire capacity
of the disk drives to the logical drive. Later, you can assign any unused space to another logical drive.
The owner parameter defines the controller to which you want to assign the logical drive. If you do not
specify a controller, the controller firmware determines the logical drive owner.
The cacheReadPrefetch parameter and the segmentSize parameter are the same as those described for the
autoConfigure storageSubsystem command.
The enclosureLossProtect parameter defines enclosure loss protection for the array. (For a description of
how enclosure loss protection works, see Enclosure Loss Protection on page 4-37.)
The securityType parameter is used to specify the security level when creating arrays and logical drives
in storage subsystems with Full Disk Encryption (FDE) drives.
The command in this example automatically creates a new array and a logical drive with the name
Engineering_1. The array has a RAID level of 5 (RAID 5). The command uses six disk drives to construct
the array. The disk drives have a total logical drive capacity of 20 GB. If each disk drive has a capacity of
18 GB, the total capacity of all the assigned disks is 108 GB.
18 GB x 6 disk drives = 108 GB
Because only 20 GB is assigned to the logical drive, 88 GB remains available (as unconfigured capacity)
for other logical drives that a user can add to this array later.
108 GB - 20 GB subsystem size = 88 GB
Cache read prefetch is turned on, which causes additional data blocks to be written into the cache. The
segment size for each logical drive is 128 KB. Enclosure loss protection is set to TRUE, which prevents any
operations to disk drives in the expansion drawer if the expansion drawer fails. Hot spares are not
This command is similar to the previous create logicalDrive command in which users assign the disk
drives. The difference between this command and the previous one is that this version of the command
requires only the number and the type of disk drives you want to use in the array. You do not need to
enter a list of disk drives. All of the other parameters are the same. Enclosure loss protection is
performed differently when the Storage Manager software assigns the disk drives than when a user
assigns the disk drives. (For a description of the difference, see Enclosure Loss Protection on page 4-37.)
The command in this example creates the same logical drive as the example for the previous create
logicalDrive command in which a user assigns the disk drives. The difference is that a user does not
know which disk drives are assigned to this array.
Note: Parameters wrapped in square brackets or curly brackets are optional. You can use one or all of the
optional parameters as needed to define your configuration. If you choose not to use any of the optional
parameters, the default values of the parameter are provided for your configuration.
The array parameter is the number of the array in which you want to create a new logical drive. If you
do not know the array numbers on the storage subsystem, you can use the show allLogicalDrives
summary command to get a list of the logical drives and the arrays to which the logical drives belong.
The userLabel parameter is the name that you want to give to the logical drive. The logical drive name
can be any combination of alphanumeric characters, hyphens, and underscores. The maximum length of
the logical drive name is 30 characters. You must enclose the logical drive name with double quotation
marks ( ).
The freeCapacityArea parameter defines the free capacity area to use for the logical drive. If a array has
several free capacity areas, you can use this parameter to identify which free capacity area to use for
4-36 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
logical drive creation. You do not have to assign the entire capacity of the disk drives to the logical drive.
Later, you can assign any unused space to another logical drive.
The usage of the capacity parameter, the owner parameter, the cacheReadPrefetch parameter, and the
segmentSize parameter is the same as described in the previous examples of the create logicalDrive
command.
When you assign the disk drives, if you set enclosureLossProtect=TRUE and have selected more than one
disk drive from any one enclosure, the storage subsystem returns an error. If you set
enclosureLossProtect=FALSE, the storage subsystem performs operations, but the array that you create
does not have enclosure loss protection.
When the controller firmware assigns the disk drives, if enclosureLossProtect=TRUE the storage
subsystem posts an error if the controller firmware cannot provide disk drives that result in the new
array having enclosure loss protection. If enclosureLossProtect=FALSE, the storage subsystem performs
the operation even if it means that the array might not have enclosure loss protection.
Enclosure loss protection is not valid when creating logical drives on existing arrays.
You do not need to assign the entire capacity of the storage subsystem to the disk pool. You can mix both
disk pools and storage subsystems in a storage system.
When you create a new disk pool you want to assign the largest number of drives possible to the disk
pool. The more drives that you have in a disk pool, the more robust the disk pool is, with faster rebuild
times and simplified management requirements. The minimum number of drives that you can have in a
disk pool is 11; the maximum number of drives is as many as required to support the maximum number
of logical drives that a controller can manage. The maximum number of logical drives that a DS3500 and
DCS3700 support is 512. You must have at least 11 unassigned disk drives in the storage subsystem to
configure a disk pool.
The only supported RAID level for a disk pool is RAID 6, with a stripe width of 10. The storage
subsystem must have a minimum drive count of 11 disk drives to create a pool. The number of drives in
the pool also influences how much reserved capacity is needed in order to redistribute data for rebuilds.
The following table shows the drive counts and the number of disk drives reserved for reconstruction:
Hot spares are not required or needed for disk pools. Spare capacity for reconstruction is divided among
the drives within a disk pool. A small amount of each drive is reserved as reconstruction space to hold
reconstructed data in the event of loss of access to a drive or a drive failure. Because of this behavior, the
system can sustain drive failures until the capacity is exhausted or the number of drives in the disk pool
falls below the minimum drive count. As long as free capacity exists on the system, failed drives are
rebuilt and degraded logical drives are brought back to optimal. The only constraint to rebuilding failed
drives is the RAID level of the logical drives in the disk pool.
In your storage subsystem with controller firmware version 7.83.xx.xx and later, you can create upto 10
disk pools. Reasons for having several disk pools in a storage subsystem might include separate disk
pools to use certain types of drives, or to create different pools for different applications. For the most
efficient disk pool, all of the drives need to have the same characteristics:
v Drive type (SAS)
v Drive media (HDD)
v Spindle speed
v Full-Disk Encryption (FDE)
v T10PI
v Capacity
Before you create a disk pool, run the show storageSubsystem command to determine the drives that are
available, and to make sure that you have enough drives in the storage subsystem to create a disk pool.
The create diskPool command has several optional parameters to enable you create the configuration
that you want. The use of these parameters is shown in the examples in the following sections. For more
information about the use of the optional parameters refer to Chapter 3 of this guide.
In a disk pool, you must create the disk pool first and then the logical drives.
4-38 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
degradedPriority=(highest|high|medium|low|lowest) |
securityType=(none|capable|enabled) |
diskDriveMediaType=(hdd | ssd | allMedia | unknown) |
T10PI=(none|enabled)]
The diskDrives parameter is a list of the disk drives that you want to use for the disk pool. Enter the
Enclosure ID and the slot ID of each drive that you want to use. For high capacity drive Enclosures that
have drawers to hold the disk drives also use the drawer number. For high capacity drive enclosures, the
sequence of the location identifiers is drive Enclosure, drawer, slot. Enclose the list in parentheses,
separate the Enclosure ID value, drawer ID value, and the slot ID value of a drive with a comma, and
separate each Enclosure ID, drawer ID, and slot ID set with a space. This example shows you how to
enter enclosure ID values and slot ID values for low capacity drive enclosures:
(1,1 1,2 1,3 1,4 1,5)
This example shows you how to enter enclosure ID values, drawer ID values, and slot ID values for high
capacity drive enclosures:
(1,1,1 1,2,3 1,3,5 1,4,6 1,5,8)
4-40 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
v The disk pool will use only disk drives with protected data capability.
The create logicalDrive diskPool command enables you to create a logical drive in a disk pool. You
can create either one of these types of logical drives:
v Standard logical drive
v Thin logical drive
A standard logical drive has a fixed capacity that you can define when you create the logical drive. The
standard logical drive reports only the fixed capacity to the host. In disk pools, the logical drive capacity
is distributed across all of the applicable disk drives. You do not need to identify specific disk drives for
the logical drive.
A thin logical drive is an expandable logical drive with both physical capacity and virtual capacity.
Physical capacity is the size of the logical drive at a given time that is currently allocated for writing data.
This size can increase over time. Virtual capacity is capacity reported to the hosts and is the "size" of the
logical drive. Thin provisioning enables you to create logical drives with a large virtual capacity and
relatively small physical capacity, which is beneficial for storage utilization and efficiency. Thin logical
drives can help simplify storage administration because the physical capacity can increase as the
application needs change, without disrupting the application, allowing for better storage utilization.
Keep these guidelines in mind when choosing a name for your logical drive:
v A logical drive name can consist of letters, numbers, and the special characters underscore (_), hyphen
(-), and pound (#). If you choose any other characters, an error message appears. You are prompted to
choose another name.
v Limit the name to 30 characters. Any leading and trailing spaces in the name are deleted.
v Use a unique, meaningful name that is easy to understand and remember.
v Avoid arbitrary names or names that would quickly lose their meaning in the future.
v If you choose a logical drive name that duplicates that of another logical drive, an error message
appears. You are prompted to choose another name.
Note: iSCSI host ports do not support T10PI. If there are one or more iSCSI host ports in your storage
subsystem, a warning appears.
T10PI protection checks for, and corrects errors that might occur as data is communicated between a
host and a storage subsystem. Enabling this feature for a new logical drive helps make sure that errors
are detected and corrected. To enable T10PI, these conditions must be in place:
v The storage subsystem must be able to support T10PI
v The disk pool must be T10PI capable
v The T10PI premium feature must be enabled
If any of the host connections on the controllers in your storage subsystem do not support T10PI, the
associated hosts cannot access data on T10PI-enabled logical drives. Before creating a T10PI-enabled
logical drive, make sure that the host connection that you are planning to use supports T10PI.
Dynamic cache read prefetch allows the controller to (optionally) copy additional sequential data blocks
into the cache while it is reading data blocks from a drive to cache. This caching increases the chance that
future requests for data can be filled from the cache. Cache read-ahead is important for multimedia
Note:
v When you are creating a thin logical drive, the dynamic cache read prefetch option is not available.
v Regardless of the capacity specified, capacity in a disk pool is allocated in 4 GB increments. Any
capacity that is not a multiple of 4 GB is allocated, however not usable. To make sure that the entire
capacity is usable, specify the capacity in 4 GB increments. If unusable capacity exists, the only way to
regain it is to increase the capacity of the logical drive.
The diskPool parameter is the name of the disk pool in which you want to create a new logical drive. If
you do not know the disk pool names on the storage subsystem, you can use the show storageSubsystem
summary command to get a list of the disk pool.
The userLabel parameter is the name that you want to give to the logical drive. The logical drive name
can be any combination of alphanumeric characters, hyphens, and underscores. The maximum length of
the logical drive name is 30 characters. You must enclose the logical drive name with double quotation
marks ( ).
The capacity parameter defines the capacity to use for the logical drive.
The thinProvisioned parameter sets the logical drive to either standard or thin. For a standard logical
drive, the thinProvisioned parameter must be set to FALSE.
The owner parameter defines which controller is designated to be the primary controller of the logical
drive. For best performance ensure that the controllers are balanced as closely as possible for total I/Os.
The mapping parameter defines whether you want the storage management software to map the logical
drive to a host, or if you want to map the logical drive to a host at a later time. To allow the storage
management software to map the logical drive to a host use the default parameter. To map the logical
drive to a host at a later time, use the none parameter. To map a logical drive to a host, use the set
logicalDrive logicalUnitNumber command.
The usage of the owner parameter, the cacheReadPrefetch parameter, and the segmentSize parameter is
the same as described in the previous examples of the create logicalDrive command.
4-42 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
create logicalDrive diskPool="diskPoolName"
userLabel="logicalDriveName" capacity=logicalDriveVirtualCapacity
thinProvisioned=TRUE
[owner=(a|b) |
mapping=(none|default) |
T10PI=(none|enabled) |
(existingRepositoryLabel=existingRepositoryName |
newRepositoryCapacity=newRepositoryCapacityValue [KB | MB | GB | TB | Bytes]) |
repositoryMaxCapacity=repositoryMaxCapacityValue[KB|MB|GB|TB|Bytes] |
repositoryExpansionPolicy=(automatic|manual) |
warningThresholdPercent=warningThresholdPercentValue |
cacheReadPrefetch=(TRUE | FALSE)]
The diskPool parameter is the name of the disk pool in which you want to create a new thin logical
drive. If you do not know the disk pool names on the storage subsystem, you can use the show
alllogicalDrives summary command to get a list of the logical drives and the disk pools to which the
logical drives belong.
The userLabel parameter is the name that you want to give to the disk pool. The disk pool name can be
any combination of alphanumeric characters, hyphens, and underscores. The maximum length of the disk
pool name is 30 characters. You must enclose the disk pool name with double quotation marks ( ).
The capacity parameter defines the virtual capacity of the thin logical drive. The capacity is the value
that is reported to the host. As users add information to the thin logical drive, the physical size of the
logical drive increases. When you define the capacity of the thin logical drive you must define a capacity
of at least 32 GB. The maximum capacity that you can define is 63 TB.
The mapping parameter defines whether you want the storage management software to map the logical
drive to a host, or if you want to map the logical drive to a host at a later time. To allow the storage
management software to map the logical drive to a host use the default parameter. To map the logical
drive to a host at a later time use the none parameter. To map a logical drive to a host, use the set
logicalDrive logicalUnitNumber command.
The repository capacity is the actual physical capacity of the thin logical drive. The value that you use for
the repository capacity is the starting size of the physical component of a thin logical drive. When you
define the capacity of the repository must define a capacity of at least 4 GB. The maximum capacity that
you can define is 64 TB. You can use a small starting value for the repository. As data increases in the
repository, additional standard logical drives are added to the repository to increase the capacity. You can
either use an existing repository or create a new repository with this command. The repository capacity is
governed by these parameters:
v existingRepositoryLabel Use this parameter when you want to associate the logical drive with an
existing repository logical drive.
v newRepositoryCapacity Use this parameter when you want to create a new repository logical drive.
v repositoryMaxCapacity Use this parameter to define the maximum size that you want for the
repository logical drive.
v repositoryExpansionPolicy Use this parameter to define whether the repository logical drive
expands automatically or if you need to expand the repository logical drive.
The warningThresholdPercent parameter defines when you receive a warning that the repository logical
drive is nearing maximum capacity. The value for this parameter is percent of the maximum capacity of
the repository logical drive.
The password parameter defines a password for the storage subsystem. Passwords provide added security
to a storage subsystem to help reduce the possibility of implementing destructive commands.
Attention: Possible data corruption or data loss Implementing destructive commands can cause
serious damage, including data loss.
Unless you define a password for the storage subsystem, you can run all of the script commands. A
password protects the storage subsystem from any command that the controllers consider destructive. A
destructive command is any command that can change the state of the storage subsystem, such as logical
drive creation; cache modification; or reset, delete, rename, or change commands.
If you have more than one storage subsystem in a storage configuration, each storage subsystem has a
separate password. Passwords can have a maximum length of 30 alphanumeric characters. You must
enclose the password in double quotation marks ( ). This example shows how to use the set
storageSubsystem command to define a password:
c:\...\...\client>smcli 123.45.67.89 -c set storageSubsystem
password=1a2b3c4d5e;
Important: Password cannot be reset without current password If you forget the storage subsystem
password, you cannot reset the password using Storage Manager. To reset the password in that situation,
you must contact your IBM support representative.
The defaultHostType parameter defines how the controllers in the storage subsystem will communicate
with the operating system on undefined hosts that are connected to the storage subsystem SAN. This
4-44 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
parameter defines the host type only for data I/O activities of the storage subsystem. This parameter
does not define the host type for the management station. The operating system can be Windows, Linux,
or Solaris.
For example, if you set the defaultHostType parameter to Linux, the controller communicates with any
undefined host if the undefined host is running a Linux operating system. Typically, you would need to
change the host type only when you are setting up the storage subsystem. The only time that you might
need to use this parameter is if you need to change how the storage subsystem behaves relative to the
hosts that are connected to it.
Before you can define the default host type, you need to determine what host types are connected to the
storage subsystem. To return information about host types that are connected to the storage subsystem,
use the show storageSubsystem command with the defaultHostType parameter or the hostTypeTable
parameter. This command returns a list of the host types with which the controllers can communicate.
This command does not return a list of the hosts. These examples show the use of the show
storageSubsystem command:
c:\...\...\client>smcli 123.45.67.89 -c show storageSubsystem defaultHostType;
c:\...\...\client>smcli 123.45.67.89 -c show storageSubsystem hostTypeTable;
This example shows how to define a specific default host type after displaying the host type table:
c:\...\...\client>smcli 123.45.67.89 -c set storageSubsystem defaultHostType=xx;
where xx is the host type index value. For value xx, refer to the previously-displayed host type table.
From the table, select the appropriate value for the host server that the LUN from the storage subsystem
is mapped to.
The cache acts as a buffer so that data transfers between the host and the disk drive do not need to be
synchronized. In read caching, the data for a read operation from the host might already be in the cache
from a previous operation, which eliminates the need to access the disk drives. The data stays in the read
cache until it is flushed. For write caching, a write operation stores data from the host in cache until it
can be written to the disk drives.
Important: Changing default cache settings is not recommended IBM recommends that you do not
change the default cache setting values. Incorrect cache settings might severely affect the storage
subsystem performance.
The script command set provides two commands to define cache properties:
v set storageSubsystem
v set logicalDrive
Use the set storageSubsystem command to change the cache block size, the cache flush start value, and
the cache stop value. The command takes this form:
set storageSubsystem cacheBlockSize=cacheBlockSizeValue |
cacheFlushStart=cacheFlushStartSize |
cacheFlushStop=cacheFlushStopSize
You can enter one, two, or all three of the parameters on the command line.
To prevent data loss or corruption, the controller periodically writes cache data to the disk drives (flushes
the cache) when the amount of unwritten data in the cache reaches a predefined level, called a start
percentage. The controller also writes cache data to the disk drives when data has been in the cache for a
predetermined amount of time. The controller writes data to the disk drives until the amount of data in
the cache drops to a stop percentage level. Use the set storageSubsystem command to set the start value
and the stop value as percentages of the filled and unfilled, respectively, capacity of the cache. For
example, you can specify that the controller start flushing the cache when it reaches 80 percent full (the
default, which can be overridden) and stop flushing the cache when it reaches 84 percent empty. This
example shows how to set these parameters:
c:\...\...\client>smcli 123.45.67.89 -c set storageSubsystem
cacheFlushStart=80 cacheFlushStop=84;
Low start percentages and low stop percentages provide for maximum data protection. For both low start
percentages and low stop percentages, the chance that data requested by a read command is not in the
cache is increased. When the data is not in the cache, the cache hit percentage for writes and I/O requests
decreases. Low start values and low stop values also increase the number of writes that are necessary to
maintain the cache level. Increasing the number of writes increases the system overhead and further
decreases performance.
Use the set logicalDrive command to change settings for the cache flush modifier, cache without
batteries enabled, mirror cache enabled, the read ahead multiplier, read cache enabled, and write cache
enabled. Use this command to set properties for all of the logical drives or for a specific logical drive in a
array. The command takes this form:
set (allLogicalDrives | logicalDrive [logicalDriveName] |
logicalDrives [logicalDriveName1 ... logicalDriveNameN]
logicalDrive <wwID>) |
cacheFlushModifier=cacheFlushModifierValue |
cacheWithoutBatteryEnabled=(TRUE | FALSE) |
mirrorCacheEnabled=(TRUE | FALSE) |
readCacheEnabled=(TRUE | FALSE) |
writeCacheEnabled=(TRUE | FALSE) |
cacheReadPrefetch=(TRUE | FALSE)
The cacheFlushModifier parameter defines the amount of time that data stays in the cache before it is
written to the disk drives. The following table lists the values for the cacheFlushModifier parameter.
Table 4-8. Values for the cacheFlushModifier Parameter
Value Meaning
Immediate Data is flushed as soon as it is placed into the cache.
250 Data is flushed after 250 ms.
500 Data is flushed after 500 ms.
750 Data is flushed after 750 ms.
1 Data is flushed after 1 s.
1500 Data is flushed after 1500 ms.
4-46 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Table 4-8. Values for the cacheFlushModifier Parameter (continued)
Value Meaning
2 Data is flushed after 2 s.
5 Data is flushed after 5 s.
10 Data is flushed after 10 s.
20 Data is flushed after 20 s.
60 Data is flushed after 60 s (1 min.).
120 Data is flushed after 120 s (2 min.).
300 Data is flushed after 300 s (5 min.).
1200 Data is flushed after 1200 s (20 min.).
3600 Data is flushed after 3600 s (1 hr.).
Infinite Data in cache is not subject to any age or time constraints.
The data is flushed based on other criteria managed by the
controller.
This example shows how to set this parameter value for all of the logical drives in the storage subsystem:
c:\...\...\client>smcli 123.45.67.89 -c set alllogicalDrives
cacheFlushModifier=10;
Important: Do not set the value of the cacheFlushModifier parameter above 10 seconds. An exception is
for testing purposes. After running any tests in which you have set the values of the cacheFlushModifier
parameter above 10 seconds, return the value of the cacheFlushModifier parameter to 10 or less seconds.
The cacheWithoutBatteryEnabled parameter turns on or turns off the ability of a host to perform write
caching without backup batteries in a controller. To enable write caching without batteries, set this
parameter to TRUE. To disable write caching without batteries, set this parameter to FALSE. If you set this
parameter to TRUE, write caching continues, even when the controller batteries are completely discharged,
not fully charged, or not present. If you do not have an uninterruptible power supply (UPS) and you
enable this parameter, you can lose data if power to the storage subsystem fails.
Note: Attention: Possible loss of data Because you can lose data when the
cacheWithoutBatteryEnabled parameter is enabled, IBM recommends that you do not enable this
parameter in a production environment.
The mirrorCacheEnabled parameter turns on or turns off write caching with mirroring. Write caching with
mirroring permits cached data to be mirrored across redundant controllers that have the same cache size.
Data written to the cache memory of one controller is also written to the cache memory of the second
controller. If one controller fails, the second controller can complete all outstanding write operations.
Attention: Possible loss of data If the mirrorCacheEnabled parameter is disabled and one of the
controllers fails, you might lose data that was cached in the failed controller memory but not yet written
to disk. Therefore, IBM recommends that you do not disable this parameter in a production environment.
The readCacheEnabled parameter turns on or turns off the ability of the host to read data from the cache.
Read caching enables read operations from the host to be stored in controller cache memory. If a host
requests data that is not in the cache, the controller reads the needed data blocks from the disk drives
and places them in the cache. Until the cache is flushed, all of the other requests for this data are fulfilled
with cache data rather than from a read, which increases throughput. To enable read caching, set this
parameter to TRUE. To disable read caching, set this parameter to FALSE. This example shows how to set
this parameter:
c:\...\...\client>smcli 123.45.67.89 -c set logicalDrive
[\Balance_04\] readCacheEnabled=TRUE;
The writeCacheEnabled parameter turns on or turns off the ability of the host to write data to the cache.
Write caching enables write operations from the host to be stored in cache memory. The logical drive data
in the cache is automatically written to the disk drives every 10 seconds. To enable write caching, set this
parameter to TRUE. To disable write caching, set this parameter to FALSE. This example shows how to set
this parameter:
c:\...\...\client>smcli 123.45.67.89 -c set allLogicalDrives
writeCacheEnabled=TRUE;
The cacheReadPrefetch parameter turns on or turns off the ability of the controller to read additional
data blocks into cache. When you turn on cache read prefetch, the controller copies additional data blocks
into cache while it is reading requested data blocks from a disk drive into cache. This action increases the
chance that a future request for data can be fulfilled from the cache, which improves the speed with
which data is accessed. The number of additional data blocks that the controller reads into cache is
determined by the storage subsystem configuration settings that you use. Cache read prefetch is
important for applications that use sequential I/O, such as multimedia applications.
Valid values for the cacheReadPrefetch parameter are TRUE or FALSE. If you want to turn on cache read
prefetch, set the cacheReadPrefetch parameter to TRUE. If you want to turn off cache read prefetch, set the
cacheReadPrefetch parameter to FALSE. This example shows how to set this parameter:
c:\...\...\client>smcli 123.45.67.89 -c set logicalDrive
[\Engineering_1\ \Engineering_2\] cacheReadPrefetch=TRUE;
The lowest priority rate favors system performance, but the modification operation takes longer. The
highest priority rate favors the modification operation, but the system performance might be degraded.
4-48 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Use the set logicalDrive command to define the modification priority for a logical drive. The command
takes this form:
set (allLogicalDrives | logicalDrive [logicalDriveName] |
logicalDrives [logicalDriveName1 ... logicalDriveNameN] logicalDrive <wwID> |
accessLogicalDrive)
modificationPriority=(highest | high | medium | low | lowest)
This example shows how to use this command to set the modification priority for logical drives named
Engineering_1 and Engineering_2:
The modification rate is set to lowest so that system performance is not significantly reduced by
modification operations.
Enter the enclosure ID and the slot ID of each disk drive that you want to use. Enclose the list in square
brackets, separate the enclosure ID value and the slot ID value of a disk drive with a comma, and
separate each enclosure ID and slot ID pair with a space.
Attention: Possible loss of data When information is written to a file, the script engine does not
check to determine if the file name already exists. If you choose the name of a file that already exists, the
script engine writes over the information in the file without warning.
You can choose to save the entire configuration or specific configuration features. This example shows
how to set this parameter value:
In this example, the name folder is the folder in which you choose to place the profile file and
storageSubsystemconfig1.scr is the name of the file. You can choose any folder and any file name. The
file extension for a configuration file is .scr. The Storage Manager software uses this extension when it
creates the configuration file.
Based on information that you provide through the script commands, the storage management software
creates an empty FlashCopy repository logical drive and defines the mapping from a base logical drive to
the FlashCopy repository logical drive. The FlashCopy repository logical drive holds changed data that a
host writes to the base logical drive. When the FlashCopy repository logical drive is first created, it holds
only the metadata about the FlashCopy logical drive with which it is associated.
When the host writes to the base logical drive, the new data is also copied to the FlashCopy repository
logical drive. This action is called copy-on-write. A FlashCopy is constructed by combining the updated
data in the FlashCopy repository logical drive with data in the base logical drive that has not been
altered. This action creates a complete copy of the base logical drive at a specific point in time. The
FlashCopy appears as a logical drive that contains the original data at the time of creation, but the
FlashCopy is actually an image that is the combination of the FlashCopy repository logical drive and the
original base logical drive. The FlashCopy repository logical drive, which houses original data that has
been changed, is the only additional disk drive space that is needed for the FlashCopy logical drive. The
additional disk drive space is typically 10 percent to 20 percent of the disk drive space of the base logical
drive and varies depending on the amount of changes to the data. The longer a FlashCopy logical drive
is active, the larger the FlashCopy repository logical drive must be. The default size of the FlashCopy
repository logical drive is 20 percent of the base logical drive; however, you can set the size of the
FlashCopy repository logical drive to other values.
You can read, write, and copy a FlashCopy logical drive. Data written by a host to the FlashCopy logical
drive is handled in the FlashCopy repository logical drive. When a write occurs to the base logical drive
of a FlashCopy logical drive, the new data also overwrites the appropriate FlashCopy repository logical
drive data. The following table lists the FlashCopy logical drive commands.
Table 5-2. FlashCopy Logical Drive Commands
Command Description
create flashcopyLogicalDrive This command creates a FlashCopy logical
drive.
recreate flashcopy This command starts a fresh copy-on-write
operation by using an existing FlashCopy
logical drive.
recreate flashcopy collection This command restarts multiple FlashCopy
logical drives as one batch operation using one
or many existing FlashCopy logical drives.
set (flashcopyLogicalDrive) This command defines the properties for a
FlashCopy logical drive and lets you rename a
FlashCopy logical drive.
stop flashcopy This command stops a copy-on-write
operation.
When you use the create FlashCopyLogicalDrive command to create a FlashCopy logical drive, the
minimum information that you need to provide is the standard logical drive that you want to use for the
5-2 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
base logical drive. When you create a FlashCopy logical drive by using minimum information, the
storage management software provides default values for the other property parameters that are required
for a completely defined FlashCopy logical drive.
This example shows a command in which users assign the disk drives:
The command in this example creates a new FlashCopy of the base logical drive Mars_Spirit_4. The
FlashCopy repository logical drive consists of five disk drives that form a new array. The new array has a
RAID level of 5. This command also takes a FlashCopy of the base logical drive, which starts the
copy-on-write operation.
The command in this example creates a new FlashCopy for the base logical drive Mars_Spirit_4. The
FlashCopy repository logical drive is created in the same array as the base logical drive, which means
that the FlashCopy repository logical drive has the same RAID level as the base logical drive. This
command starts the copy-on-write operation.
This example shows a command in which the storage management software assigns the disk drives:
c:\...\...\client>smcli 123.45.67.89 -c create
FlashCopyLogicalDrive baseLogicalDrive=\Mars_Spirit_4\
repositoryArray=2 freeCapacityArea=2;
The command in this example creates a new FlashCopy repository logical drive in array 2. The base
logical drive is Mars_Spirit_4. The size of the FlashCopy repository logical drive is 4 GB. This command
also takes a FlashCopy of the base logical drive, starting the copy-on-write operation.
When you define the capacity of a FlashCopy repository logical drive, specify a size that is 20 percent of
the size of the base logical drive. In the previous example, the size of the FlashCopy repository logical
drive is set to 4 GB. The underlying assumption is that the base logical drive size is 20 GB (0.2 x 20 GB=
4 GB).
This example shows how to use a command in which users specify the number of disk drives:
The command in this example creates a new FlashCopy repository logical drive that consists of three disk
drives. Three disk drives comprise a new array that has a RAID level of 5. This command also takes a
FlashCopy of the base logical drive, which starts the copy-on-write operation.
5-4 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
User-Defined Parameters
Use the parameters in the create flashcopyLogicalDrive command to define the FlashCopy logical drive
to suit the requirements of your storage subsystem. The following table lists the parameters and briefly
describes what the parameters do.
Table 5-3. FlashCopy Logical Drive Parameters
Parameter Description
driveType The type of disk drive that you want to use for the
FlashCopy repository logical drive. Valid disk drive
types are fibre, SATA, or SAS. This parameter works
only with the count-based repository method of
defining a FlashCopy logical drive.
repositoryArray The array in which you want to build the
FlashCopy repository logical drive. The default
value is to build the FlashCopy repository logical
drive in the same array as the base logical drive.
freeCapacityArea The amount of storage space that you want to use
for the FlashCopy repository logical drive. Free
storage space is defined in units of bytes, KB, MB,
GB, or TB.
userLabel The name that you want to give to the FlashCopy
logical drive. If you do not choose a name for the
FlashCopy logical drive, the software creates a
default name by using the base logical drive name.
For example, with a base logical drive name of
Mars_Spirit_4:
v When the base logical drive does not have a
FlashCopy logical drive, the default FlashCopy
logical drive name is Mars_Spirit_4-1.
v When the base logical drive already has n-1
number of FlashCopy logical drives, the default
name is Mars_Spirit_4-n.
repositoryUserLabel
The name that you want to give to the FlashCopy
repository logical drive. If you do not choose a
name for the FlashCopy repository logical drive, the
software creates a default name by using the base
logical drive name. For example, if the base logical
drive name is Mars_Spirit_4 and does not have an
associated FlashCopy repository logical drive, the
default FlashCopy repository logical drive name is
Mars_Spirit_4-R1. If the base logical drive already
has n-1 number of FlashCopy repository logical
drives, the default name is Mars_Spirit_4-Rn.
warningThresholdPercent The percentage of the capacity that you will permit
the FlashCopy repository logical drive to get before
you receive a warning that the FlashCopy repository
logical drive is nearing full. The warning value is a
percentage of the total capacity of the FlashCopy
repository logical drive. The default value is 50,
which represents 50 percent of the total capacity.
(You can change this value later by using the set
flashcopyLogicalDrive command.)
This example shows the create flashcopyLogicalDrive command that includes user-defined parameters:
c:\...\...\client>smcli 123.45.67.89 -c create
flashcopyLogicalDrive baseLogicalDrive=\Mars_Spirit_4\
repositoryRAIDLevel=5 repositoryDriveCount=5
driveType=fibre userLabel=\Mars_Spirit_4_EnhFlashCopy1\
repositoryUserLabel=\Mars_Spirit_4rep1\
warningThresholdPercent=75 repositoryPercentOfBase=40
repositoryFullPolicy=failFlashCopy;
One technique for naming the FlashCopy logical drive and the FlashCopy repository logical drive is to
add a hyphenated suffix to the original base logical drive name. The suffix distinguishes between the
FlashCopy logical drive and the FlashCopy repository logical drive. For example, if you have a base
logical drive with a name of Engineering Data, the FlashCopy logical drive can have a name of
Engineering Data-S1, and the FlashCopy repository logical drive can have a name of Engineering
Data-R1.
If you do not choose a unique name for either the FlashCopy logical drive or the FlashCopy repository
logical drive, the controllers create a default name by using the base logical drive name. These examples
are FlashCopy logical drive names that the controllers might create:
v If the base logical drive name is aaa and does not have a FlashCopy logical drive, the default
FlashCopy logical drive name is aaa1.
v If the base logical drive already has n-1 number of FlashCopy logical drives, the default name is aaa-n.
v If the base logical drive name is aaa and does not have a FlashCopy repository logical drive, the
default FlashCopy repository logical drive name is aaa-R1
5-6 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
v If the base logical drive already has n-1 number of FlashCopy repository logical drives, the default
name is aaa-Rn.
In the examples from the previous section, the user-defined FlashCopy logical drive name was
Mars_Spirit_4_EnhFlashCopy1, and the user-defined FlashCopy repository logical drive name was
Mars_Spirit_4_rep1. The default name that was provided by the controller for the FlashCopy logical drive
was Mars_Spirit_4-1. The default name that was provided by the controller for the FlashCopy repository
logical drive was Mars_Spirit_4-R1.
When you change the warning threshold percent and the FlashCopy repository full policy, you can apply
the changes to one or several FlashCopy logical drives with this command. This example shows how to
use the set (FlashCopy) logicalDrive command to change these properties on more than one FlashCopy
logical drive:
c:\...\...\client>smcli 123.45.67.89 -c set logicalDrive
[\Mars_Spirit_4-1\ \Mars_Spirit_4-2\ \Mars_Spirit_4-3\
warningThresholdPercent=50
repositoryFullPolicy=failBaseWrites;
If you no longer want copy-on-write operations to run, you can use the stop flashcopy logicalDrive
command to stop the copy-on-write operations. When you stop a FlashCopy logical drive, the FlashCopy
logicalDrive and the FlashCopy repository logical drive are still defined for the base logical drive. Only
copy-on-write has stopped. This example shows how to stop a FlashCopy logical drive:
When you want to restart a copy-on-write operation, use the recreate flashcopy logicalDrive
command or the recreate flashcopy collection command. The recreate flashcopy logicalDrive
command starts a fresh copy-on-write operation by using an existing FlashCopy logical drive.
Note: The FlashCopy logical drive must be in either an Optimal state or a Disabled state.
When you restart a FlashCopy logical drive, these actions occur:
v All copy-on-write data previously on the FlashCopy repository logical drive is overwritten.
v FlashCopy logical drive parameters and FlashCopy repository logical drive parameters stay the same
as the previously disabled FlashCopy logical drive and the previously disabled FlashCopy repository
logical drive. You can also change the userLabel parameter, the warningThresholdPercent parameter,
and the repositoryFullPolicy parameter when you restart the FlashCopy logical drive.
v The original names for the FlashCopy repository logical drive are retained.
If you do not intend to use a FlashCopy logical drive again, you can delete the FlashCopy logical drive
by using the delete logicalDrive command. When you delete a FlashCopy logical drive, the associated
FlashCopy repository logical drive also is deleted.
5-8 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Chapter 6. Using the Enhanced FlashCopy Images Premium
Feature
Note: Enhanced FlashCopy premium feature is available only on DS3500 and DCS3700 Storage
subsystems. In this publication, the Enhanced FlashCopy premium feature and its associated functions
will always have the words Enhanced FlashCopy as prefix. Examples of this feature include:
v Enhanced FlashCopy image
v Enhanced FlashCopy groups
v Enhanced FlashCopy repository drive
The current FlashCopy premium feature and its features will have only the word FlashCopy as a prefix.
Examples of this feature include:
v FlashCopy logical drive
v FlashCopy repository drive
Controller firmware version 7.83 and later supports a new version of FlashCopy, called Enhanced
FlashCopy. Enhanced FlashCopy provides new ways of creating a large number of FlashCopies of a base
logical drive, with minimum performance degradation due the copy-on-write operations feature. In an
existing FlashCopy operation, a Copy-on-write operation will be performed for each FlashCopy of the
base logical drive. The higher the number of FlashCopies, the higher the number of copy-on-write
operations. In an Enhanced FlashCopy operation, only one copy-on-write operation will be performed
for a group of up to 32 FlashCopies of a base logical drive. Up to 32 Enhanced FlashCopy images of a
base logical drive can be grouped into an Enhanced FlashCopy group with an Enhanced FlashCopy
group repository drive.
An Enhanced FlashCopy image is a logical image of the content of an associated base logical drive
created at a specific moment. An Enhanced FlashCopy image can be thought of as a restore point. A host
cannot directly read from or write to the Enhanced FlashCopy image because the Enhanced FlashCopy
image is used to save only the transient data captured from the base logical drive.
You must create an Enhanced FlashCopy logical drive to enable host access to a complete copy of the
data contained in the Enhanced FlashCopy image. The Enhanced FlashCopy logical drive contains its
own repository, which is used to save any subsequent modifications made by the host to the base logical
drive without affecting the referenced Enhanced FlashCopy image.
Enhanced FlashCopy images are useful any time you need to be able to roll back to a known good data
set at a specific point in time. For example, before performing an operation on a logical drive that you
might want to reverse, you can create an Enhanced FlashCopy image to enable the reverse operation and
restore the entire logical drive to its previous state. An Enhanced FlashCopy image is created almost
instantaneously, and initially uses no disk space, because it stores only the incremental changes needed to
roll the logical drive back to the point-in-time when the Enhanced FlashCopy image was created.
You can create Enhanced FlashCopy images manually or automate the process with a schedule. With a
schedule, an Enhanced FlashCopy image is generated automatically, based on the date and time you
choose, and is displayed with its associated Enhanced FlashCopy group. You can create Enhanced
FlashCopy images for these storage objects:
v Standard logical drives
A standard logical drive has a fixed physical capacity that is entirely reserved for the data on the
logical drive.
v Thin logical drives
To create an Enhanced FlashCopy image, you must first create an Enhanced FlashCopy group and the
associated Enhanced FlashCopy repository logical drive. You can either use an existing repository logical
drive or create a repository logical drive by performing these actions:
v Identifying the array or disk pool in which you want to place the repository logical drive
v The capacity for the repository logical drive
You can delete any Enhanced FlashCopy image in an Enhanced FlashCopy group. When an Enhanced
FlashCopy image is deleted, it's definition is removed from the system, and the space occupied by the
Enhanced FlashCopy image in the repository is released and made available for reuse within the
Enhanced FlashCopy group. The Enhanced FlashCopy image can be deleted only in the order of creation,
with the oldest one deleted first.
An Enhanced FlashCopy group is a collection of Enhanced FlashCopy images of a single associated base
logical drive. An Enhanced FlashCopy image is always created within the context of an Enhanced
FlashCopy group, so the identity of the Enhanced FlashCopy group is a key component that must be
specified when creating an Enhanced FlashCopy image.
The purpose of an Enhanced FlashCopy group is to maintain a sequence of Enhanced FlashCopy images
of a given base logical drive without impacting performance. You can set up a schedule for an Enhanced
FlashCopy group to automatically create an Enhanced FlashCopy image at a specific time in the future or
on a regular basis.
Each Enhanced FlashCopy group has a strict ordering of Enhanced FlashCopy images based on the time
an Enhanced FlashCopy image was created. These terms describe the time relationship of Enhanced
FlashCopy images:
6-2 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
v Successor
An Enhanced FlashCopy image that is created after another Enhanced FlashCopy image has been
created, also called newest.
v Predecessor
An Enhanced FlashCopy image that is created before another Enhanced FlashCopy image, also called
oldest.
The terms newest and oldest are arguments used in the CLI commands.
An Enhanced FlashCopy group uses an Enhanced FlashCopy group repository logical drive to save all
data for the Enhanced FlashCopy images contained in the group. An Enhanced FlashCopy image
operation uses less disk space than a full physical copy because the data stored in the Enhanced
FlashCopy logical drive repository logical drive is only the data that has changed since the Enhanced
FlashCopy image has been taken.
An Enhanced FlashCopy group is created initially with one Enhanced FlashCopy group repository logical
drive, with a default capacity of 40% the capacity of the base logical drive. The Enhanced FlashCopy
group repository logical drive initially contains a small amount of data, which increases with subsequent
data updates. If needed, you can increase the size of the Enhanced FlashCopy logical drive repository
logical drive by combining unused repository logical drives to the Enhanced FlashCopy group repository
logical drive or by creating additional Enhanced FlashCopy group repository logical drives.
The only types of logical drives that can contain an Enhanced FlashCopy group are these:
v Standard logical drives
v Thin logical drives
Non standard logical drives, such as Enhanced FlashCopy logical drives, cannot be used for Enhanced
FlashCopy groups. The base logical drive can reside on either an array or a disk pool.
Note: Enhanced FlashCopy logical drives and Enhanced FlashCopy groups cannot coexist on the same
base logical drive.
Every Enhanced FlashCopy image is created in the context of exactly one Enhanced FlashCopy group. An
Enhanced FlashCopy group is a sequence of Enhanced FlashCopy images of a single associated base
logical drive. A given Enhanced FlashCopy group has exactly one Enhanced FlashCopy logical drive
repository logical drive that is used to save data for all of the Enhanced FlashCopy images that are part
of the Enhanced FlashCopy group. When a new Enhanced FlashCopy image is created in an Enhanced
FlashCopy group, the Enhanced FlashCopy images of all previously-created Enhanced FlashCopy images
in that Enhanced FlashCopy group become static and stop consuming additional repository space. The
newly-created Enhanced FlashCopy image begins consuming repository space during processing of
ensuing copy-on-write actions for the associated base logical drive.
The Enhanced FlashCopy group repository logical drive is a standard logical drive that can be expanded
to accommodate an increasing number of Enhanced FlashCopy images. The Enhanced FlashCopy group
You can create an Enhanced FlashCopy repository logical drive automatically using the default settings or
you can manually create an Enhanced FlashCopy repository logical drive by defining the settings for the
repository logical drive.
After the Enhanced FlashCopy group and the associated repository logical drive are created, any write
operation on the base logical drive necessitates that the affected content of the base logical drive be saved
to a different location before it is overwritten by the new data. The Enhanced FlashCopy image
copy-on-write mechanism performs this task, and saves the required data to the repository logical drive.
An index in the Enhanced FlashCopy logical drive repository logical drive. is then updated to reflect the
new location of the Enhanced FlashCopy image content for the affected logical block addressing (LBA)
range. An ensuing base logical drive write to an LBA range that has already been preserved by a
previous copy-on-write operation does not require an additional copy-on-write action, so the overhead of
the copy is not repeated in such cases.
As an Enhanced FlashCopy group attribute, users can choose the way in which Enhanced FlashCopy
logical drive repository full conditions are managed through one of these modes of operation when such
conditions arises:
v Auto-Purge Enhanced FlashCopy Images:
Automatically delete the oldest Enhanced FlashCopy images in the Enhanced FlashCopy group to free
up space that can be used to satisfy the copy-on-write operation capacity needs in the Enhanced
FlashCopy group repository.
v Fail Base Writes
Fail write requests to the base logical drive that triggered the Enhanced FlashCopy logical drive
repository access. In this case, the base logical drive, the Enhanced FlashCopy group and its Enhanced
FlashCopy images and Enhanced FlashCopy logical drives remain in their previous states.
Attention: AIX does not support the Fail writes to base logical drive option of the Enhanced
FlashCopy logical drive repository full policy. Selecting this option might cause data loss on the base
logical drive. If you are using AIX, ensure that the default option Fail FlashCopy logical drive is
selected. Ensure you monitor the capacity of the FlashCopy repository logical drive, as you cannot
access the FlashCopy if the repository logical drive reaches full capacity.
Each Enhanced FlashCopy group can be configured independently in this regard. Expanding an
Enhanced FlashCopy logical drive repository logical drive does not directly change the state of any
Enhanced FlashCopy in the Enhanced FlashCopy group. In particular, Enhanced FlashCopy images in the
purged state remain in that state even after a repository logical drive expansion creates additional free
space for the Enhanced FlashCopy group.
The Storage Manager GUI and CLI automatically provide a name (user label) every time a standard
logical drive is created for use as an Enhanced FlashCopy logical drive repository logical drive member.
The user label string consists of the prefix repos_ followed by a four-digit, zero-padded numeric suffix.
The numeric value has a minimum value of 1, and is selected using the smallest previously-unused
number among all existing logical drives. Users cannot modify or override the name that is automatically
provided by IBM DS Storage Manager software.
Note: IBM DS Storage Manager software always uses a lower-case "repos_" prefix when it creates
Enhanced FlashCopy repository logical drives. IBM DS Storage Manager software tests the logical drive
6-4 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
label for conformance to this pattern. The CLI only permits specification of an existing logical drive for
use as a Enhanced FlashCopy repository logical drive member if that logical drive user label conforms to
the pattern.
An Enhanced FlashCopy logical drive provides the host access to the data contained in an Enhanced
FlashCopy image. An Enhanced FlashCopy image cannot be directly read by a hosts because the
Enhanced FlashCopy image is only the changed data captured from the base logical drive. Therefore, it is
necessary to create a logical drive that a host can access that is a merging of the data from the base
logical drive and the Enhanced FlashCopy image.
The Enhanced FlashCopy logical drive can be designated as either read-only or read-write:
v A Read-Only Enhanced FlashCopy logical drive provides a host application with READ access to a
copy of the data contained in the Enhanced FlashCopy image, but without the ability to modify the
Enhanced FlashCopy image. A Read-Only Enhanced FlashCopy logical drive does not have an
associated Enhanced FlashCopy logical drive repository.
v A Read-Write Enhanced FlashCopy logical drive requires an associated Enhanced FlashCopy logical
drive repository to provide the host application with WRITE access to a copy of the data contained in
the Enhanced FlashCopy image.
An Enhanced FlashCopy logical drive that is designated as read-write must have its own Enhanced
FlashCopy logical drive repository logical drive to save any subsequent modifications made by the host
application to the base logical drive without affecting the referenced Enhanced FlashCopy image.
The Enhanced FlashCopy logical drive repository logical drive is allocated from the disk pool or array
from which the original Enhanced FlashCopy image is allocated. All I/O write operations to the
Enhanced FlashCopy image are redirected to the Enhanced FlashCopy logical drive repository that was
allocated for saving data modifications. The data of the original Enhanced FlashCopy image remains
unchanged.
When you delete an Enhanced FlashCopy logical drive, you can either delete the Enhanced FlashCopy
logical drive repository logical drive or retain it as an unmapped logical drive.
The controller firmware and the IBM DS Storage Manager software management software treat Enhanced
FlashCopy images, Enhanced FlashCopy groups, and Enhanced FlashCopy logical drives as distinct
entities relative to Enhanced FlashCopies:
v An Enhanced FlashCopy group has an association with a standard logical drive that is the base for the
Enhanced FlashCopy group.
v All Enhanced FlashCopy images within an Enhanced FlashCopy group have a direct association with
that Enhanced FlashCopy group.
v Every Enhanced FlashCopy logical drive of an Enhanced FlashCopy image has a direct association
with that Enhanced FlashCopy image. In addition, every Enhanced FlashCopy logical drive has a
persistent relationship to the base logical drive of the Enhanced FlashCopy image for which the
Enhanced FlashCopy logical drive was initially created. In other words, an Enhanced FlashCopy logical
drive is effectively bound to its base logical drive. Even if the Enhanced FlashCopy logical drive is in
a Stopped state, which detaches from a particular Enhanced FlashCopy image, the Enhanced
FlashCopy logical drive retains its association with the base logical drive, and can only be restarted on
top of an Enhanced FlashCopy image for that base logical drive.
v The Enhanced FlashCopy repository logical drives for an Enhanced FlashCopy group have an
association with the Enhanced FlashCopy group.
A consistency group is a container that holds several logical drives so that you can manage all of the
logical drives as one entity. A consistency group allows simultaneous Enhanced FlashCopy images of
several logical drives, thus ensuring consistent FlashCopies of a group of logical drives.
If you frequently want to perform the same Enhanced FlashCopy image operations on several logical
drives at the same point in time, you can create a consistency group to perform those operations. A
consistency group pools several logical drives together so that you can take an Enhanced FlashCopy of
all the logical drives at the same point in time. Any operation that you perform on the consistency group
is performed simultaneously on all of the logical drives in the consistency group. The FlashCopy image
action creates a synchronized Enhanced FlashCopy images of all the logical drives and is ideal for
applications that span several logical drives, for example, a database application that has the logs on one
logical drive and the database on another logical drive. Some of the Enhanced FlashCopy image
operations that you can perform on a consistency group include creating, scheduling, and rolling back.
Each logical drive that belongs to a consistency group is referred to as a member logical drive. When you
add a logical drive to a consistency group, the system automatically creates a new Enhanced FlashCopy
group that corresponds to this member logical drive for the Enhanced FlashCopy images that will be
created for this member logical drive. You can set up a schedule for a consistency group to automatically
create an Enhanced FlashCopy image of each member logical drive in the group at a specific time in the
future or on a regular basis.
You can use either of the following two methods to create a consistency group:
v Create the consistency group, and add the member logical drives in one step.
v Create the consistency group, and then add the member logical drives in a subsequent step.
Standard logical drives and thin logical drives are the only type of logical drives that can be members of
a consistency group. Non standard logical drives, such as FlashCopy logical drives, cannot be used for
consistency groups. The base logical drive can reside on either an array or a disk pool.
6-6 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Working With Enhanced FlashCopy Images Premium Feature
Creating an Enhanced FlashCopy Image on page 6-8
Starting, Stopping, and Resuming an Enhanced FlashCopy Image Rollback on page 6-18
Restarting a Consistency Group Enhanced FlashCopy Image Logical drive on page 6-15
To create a new Enhanced FlashCopy group use the create enhancedFlashCopyGroup command. This
command creates a new Enhanced FlashCopy group that is associated with a specific source logical drive.
You also create a relationship to a repository logical drive by one of these methods:
v Use an existing repository logical drive
v Create a new repository logical drive in an array
v Create a new repository logical drive in a disk pool
To create a new repository logical drive, you identify either an existing array or an existing disk pool and
define the size (capacity) for the repository logical drive. You define the size by entering either a
percentage of the base logical drive or a specific size that you want to reserve for the repository logical
drive.
This example shows a basic command in which a new Enhanced FlashCopy group is being created and
associated with an existing repository logical drive:
c:\...\smX\client>smcli 123.45.67.88 123.45.67.89
-c create enhancedFlashCopyGroup userLabel=\Data_Store_1\
sourcelogical drive=\"Cont_Dev_04\"
repositoryLogical drive=\"repos_1234\";
Refer to the Create Enhanced FlashCopy Group on page 3-66 section for more information.
To delete the Enhanced FlashCopy group and its associated repositories, use this command:
delete enhancedFlashCopyGroup
["enhancedFlashCopyGroupName"]
deleteRepositoryMembers=TRUE;
If you want to retain the repository logical drives, set the deleteRepositoryMembers parameter of the
above command to FALSE.
See the Deleting an Enhanced FlashCopy Image Group for more information.
The only parameters that you need to enter with this command are the names of the Enhanced
FlashCopy groups.
To create an Enhanced FlashCopy Image of Enhanced FlashCopy Group to enFCGName, use the following
command:
create enhancedFlashCopyImage
enhancedFlashCopyGroup="
enFCGName";
See the Create Enhanced FlashCopy Image on page 3-72 for more information.
6-8 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
v The base logical drive for an Enhanced FlashCopy group or one or more member logical drives of a
consistency group that contains this Enhanced FlashCopy image is a member of an asynchronous
mirror group.
v The logical drive or logical drives are currently in a synchronizing operation.
The Enhanced FlashCopy image creation operation completes as soon as the synchronization operation is
complete. To cancel the pending Enhanced FlashCopy image creation before the synchronization
operation completes, use one of these commands:
v stop EnhancedFlashCopyGroup [enhancedFlashCopyGroupName]pendingEnhancedFlashCopyImageCreation
for Enhanced FlashCopy groups
v stop consistencyGroup [enhancedFlashCopyConsistencyGroupName]
pendingEnhancedFlashCopyImageCreation for Enhanced FlashCopy consistency groups
When you cancel a pending Enhanced FlashCopy image creation for a specific Enhanced FlashCopy
group or Enhanced FlashCopy consistency group, only that group is disabled. All of the other groups
stay in operation.
The following table lists the parameters that you can use to set a schedule for creating an Enhanced
FlashCopy image:
Option Description
enableSchedule Use this parameter to turn on or to turn off the ability to
schedule a FlashCopy operation. To turn on FlashCopy
scheduling, set this parameter to TRUE. To turn off
FlashCopy scheduling, set this parameter to FALSE.
Use the enableSchedule parameter and the schedule parameter to schedule automatic creation of
Enhanced FlashCopy images. Using these parameters, you can schedule Enhanced FlashCopy images
daily, weekly, or monthly (by day or by date). The enableSchedule parameter turns on or turns off the
ability to schedule Enhanced FlashCopy images. When you enable scheduling, you use the schedule
parameter to define when you want the Enhanced FlashCopy images to occur.
This list explains how to use the options for the schedule parameter:
v immediate As soon as you enter the command, an Enhanced FlashCopy image is created, and a
copy-on-write operation begins.
v startDate A specific date on which you want to create an Enhanced FlashCopy image and perform a
copy-on-write operation. The format for entering the date is MM:DD:YY. If you do not provide a start
date, the current date is used. An example of this option is startDate=06:27:11.
v scheduleDay - A day of the week on which you want to create an Enhanced FlashCopy image. You can
enter these values: monday, tuesday, wednesday, thursday, friday, saturday, sundayand so on. An
example of this option is scheduleDay=wednesday.
v startTime The time of a day that you want to create an Enhanced FlashCopy image and start
performing a copy-on-write operation. The format for entering the time is HH:MM, where HH is the
hour and MM is the minute past the hour. Use a 24-hour clock. For example, 2:00 in the afternoon is
14:00. An example of this option is startTime=14:27.
v scheduleInterval An amount of time, in minutes, that you want to have as a minimum between
copy-on-write operation. You can possibly create a schedule in which you have overlapping
copy-on-write operations because of the duration a copy operation. You can make sure that you have
time between copy-on-write operations by using this option. The maximum value for the
scheduleInterval option is 1440 minutes. An example of this option is scheduleInterval=180.
v endDate A specific date on which you want to stop creating an Enhanced FlashCopy image and end
the copy-on-write operation. The format for entering the date is MM:DD:YY. An example of this option
is endDate=11:26:11. noEndDate is a value that can be specified for the endDate parameter to indicate
that the schedule will be enabled with no end date.
v timesPerDay The number of times that you want the schedule to run in a day. An example of this
option is timesPerDay=4.
If you also use the scheduleInterval option, the firmware chooses between the timesPerDay option and
the scheduleInterval option by selecting the lowest value of the two options. The firmware calculates an
integer value for the scheduleInterval option by dividing 1440 by the scheduleInterval option value
that you set. For example, 1440/180 = 8. The firmware then compares the timesPerDay integer value with
the calculated scheduleInterval integer value and uses the smaller value.
6-10 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
To remove a schedule, use the create EnhancedFlashCopyGroup command or the create
consistencyGroup command and set the enableSchedule parameter to FALSE. The enableSchedule
parameter set to FALSE turns off the schedule, not the creating of Enhanced FlashCopy images.
Syntax
The following command will create a schedule for creating Enhanced FlashCopy images for
enhancedFlashCopyGroupName Enhanced FlashCopy group two times a day, on Mondays and Fridays of
the week, starting with the first image at 2:00 AM and the second image 720 minutes after the first image;
the start date is May 20th, 2012 with no end date:
create enhancedFlashCopyGroup
userLabel="enhancedFlashCopyGroupName"
purceLogicalDrive="BaselogicaldriveName"
repositoryLogicalDrive="repos_0001"
repositoryFullPolicy= purgeEnhancedFlashCopyImages
rollbackPriority=highest
repositoryFullLimit=50
enableSchedule=TRUE
schedule startDate=05:20:12
ScheduleDay=(Monday,Friday) startTime=02:00
timesPerDay=2 scheduleInterval=720
endDate=noEndDate;
When an Enhanced FlashCopy image(s) is deleted from an Enhanced FlashCopy consistency group, the
system performs the following actions:
v Deletes the Enhanced FlashCopy images from the storage subsystem.
v Releases the repositorys reserve space for reuse within the an Enhanced FlashCopy consistency group.
v Moves any member logical drive, associated with the deleted Enhanced FlashCopy image(s), to a
Stopped state.
v Disables the member Enhanced FlashCopy logical drives associated with the deleted Enhanced
FlashCopy image(s).
Optionally you can choose to keep a number of Enhanced FlashCopy images with either of these
parameters:
v deleteCount This parameter deletes the oldest Enhanced FlashCopy image first and continues to
delete the Enhanced FlashCopy images in the order of creation, until reaching the number that you
enter. If the number that you enter is greater than the number of Enhanced FlashCopy images, then all
of the Enhanced FlashCopy images are deleted.
If you have an Enhanced FlashCopy logical drive associated with the to-be-deleted Enhanced FlashCopy
images, you can choose to either stop the deletion operation or continue with the deletion anyway. To
continue with the deletion whether the Enhanced FlashCopy images have associated Enhanced
FlashCopy logical drives or not, set the ignoreEnhancedFlashCopyVolume parameter to TRUE. To stop the
deletion when the Enhanced FlashCopy image has the associated Enhanced FlashCopy logical drive, set
the ignoreEnhancedFlashCopyVolume parameter to FALSE. The default is FALSE. This parameter applies only
if the Enhanced FlashCopy image is associated with an Enhanced FlashCopy logical drive.
The consistency group Enhanced FlashCopy logical drive can be designated as either read-only or
read-write. Read-write consistency group Enhanced FlashCopy logical drives require a repository for each
member logical drive that you select to save any subsequent modifications made by the host application
to the base logical drive without affecting the referenced Enhanced FlashCopy image. Each member
repository is created at the same time the consistency group Enhanced FlashCopy logical drive is created.
Note: A read-write Enhanced FlashCopy logical drive requires an overall repository. The overall
repository is created initially with one individual repository logical drive. However, the overall repository
can contain multiple repository logical drives in the future for expansion purposes.
Prerequisites
v The Enhanced FlashCopy premium feature must be enabled on the storage subsystem.
v The consistency group must contain at least one member logical drive before you can create a
consistency group Enhanced FlashCopy logical drive.
Guidelines
Keep these guidelines in mind when creating a consistency group Enhanced FlashCopy logical drive:
v There is a maximum of 512 Enhanced FlashCopy images for a consistency group for DS3500 and
DCS3700 controller subsystems.
v You cannot create an Enhanced FlashCopy logical drive of a failed logical drive.
v Enhanced FlashCopy logical drive repositories are fully resize-able. If you have the storage capacity
you can increase the size of the Enhanced FlashCopy repository to avoid a repository full message.
Conversely, if you find that the Enhanced FlashCopy logical drive repository is larger than you need,
you can reduce its size to free up space that is needed by other logical drives.
v If you attempt to create an Enhanced FlashCopy logical drive for an Enhanced FlashCopy image and
that Enhanced FlashCopy image is in a pending Enhanced FlashCopy image creation operation it is
due to the following conditions:
The base logical drive that contains this Enhanced FlashCopy image is a member of an
asynchronous mirror group AND
The base logical drive is currently in a synchronizing operation. The Enhanced FlashCopy image
creation will complete as soon as the synchronization operation is complete.
v The Enhanced FlashCopy logical drive repository must have the same T10PI and Quality of Service
(QoS) settings as the associated base logical drive. For example, if a base logical drive that is used for
6-12 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
an Enhanced FlashCopy logical drive is T10PI enabled, then each member logical drive in the
associated Enhanced FlashCopy logical drive repository must be T10PI enabled.
Example commands to create a consistency group Enhanced FlashCopy logical drive are as follows:
v To create consistency group Enhanced FlashCopy logical drive with read/write capability for Enhanced
FlashCopy consistency group CG_001 using the newest Enhanced FlashCopy image for all members of
the Enhanced FlashCopy consistency group:
create cgEnhancedFlashCopyLogicalDrive
userLabel="cgEnhFCLDName3"
cgEnhancedFlashCopyImageID="CG_001:newest"
v To create consistency group Enhanced FlashCopy logical drive with read only capability for Enhanced
FlashCopy consistency group CG_001 using the Enhanced FlashCopy image with the creation order 6
for all members of the Enhanced FlashCopy consistency group:
create cgEnhancedFlashCopyLogicalDrive
userLabel="cgEnhFCLDName3"
cgEnhancedFlashCopyImageID="CG_001:6" readOnly
Note: To determine the creation order of the consistency group Enhanced FlashCopy image in an
Enhanced FlashCopy consistency group, right click on the consistency group Enhanced FlashCopy
image and select Properties in the pull-down menu. When the properties window opens, look for the
value of the creation order field.
v To create consistency group Enhanced FlashCopy logical drive with read/write capability for Enhanced
FlashCopy consistency group CG_001 using the oldest Enhanced FlashCopy image for only member
logical drive 1 of array 0 and member logical drive 5 of disk pool Disk_Pool_1. Note that the "(" and
")" for the members field indicated that new repository logical drives will be created:
create cgEnhancedFlashCopyLogicalDrive
userLabel="cgEnhFCLDName4"
cgEnhancedFlashCopyImageID="CG_001:oldest"
members=("1:0" "5:Disk_Pool_1")
v To create the same thing as above, using the existing repository logical drives of Repos_0113 in array 0
for member logical drive 1 and Repos_0112 for member logical drive 5 in disk pool Disk_pool_1, use
the following command:
Note: The name of the existing repositories must be in double quotation marks '"' as shown
create cgEnhancedFlashCopyLogicalDrive
userLabel="cgEnhFCLDName4"
cgEnhancedFlashCopyImageID="CG_001:6"
members=("1":"repos_0113" "5":"repos_0112");
When you create an Enhanced FlashCopy image of a consistency group, the result is an Enhanced
FlashCopy image of every member logical drive of the consistency group. To create a consistency group
Enhanced FlashCopy image, use this command:
create cgEnhancedFlashCopyImage consistencyGroup="
consistencyGroupName"
When you enter this command you must give the consistency group Enhanced FlashCopy logical drive a
unique name and identify the consistency group Enhanced FlashCopy image to be associated with the
consistency group Enhanced FlashCopy logical drive.
Optionally you can choose the name of the repository logical drive associated with the Enhanced
FlashCopy logical drive and set warning limit for that repository logical drive.
To delete the Enhanced FlashCopy consistency group and its associated repositories, use this command:
delete consistencyGroup [consistencyGroupName] deleteRepositoryMembers=True;
To keep the repositories for later use, set the deleteRepositoryMembers parameter to False instead.
Optionally you can choose to keep a number of Enhanced FlashCopy images with these parameters:
v deleteCount This parameter deletes the oldest Enhanced FlashCopy image first and continues to
delete the oldest Enhanced FlashCopy images until reaching the number that you enter. If the number
that you enter is greater than the number of Enhanced FlashCopy images, then all of the Enhanced
FlashCopy images are deleted.
v retainCount This parameter keeps the most recent Enhanced FlashCopy images in the consistency
group.
If you have an Enhanced FlashCopy logical drive associated with the to-be-deleted Enhanced FlashCopy
images, you can choose to either stop the deletion operation or continue with the deletion anyway. To
continue with the deletion whether the Enhanced FlashCopy images have associated Enhanced
FlashCopy logical drives or not, set the ignoreEnhancedFlashCopyVolume parameter to TRUE. To stop the
deletion when the Enhanced FlashCopy image has the associated Enhanced FlashCopy logical drive, set
the ignoreEnhancedFlashCopyVolume parameter to FALSE. The default is FALSE. This parameter applies only
if the Enhanced FlashCopy image is associated with an Enhanced FlashCopy logical drive.
You create an Enhanced FlashCopy logical drive to provide host access to an Enhanced FlashCopy image
within an Enhanced FlashCopy group. A read-write Enhanced FlashCopy logical drive has its own
repository that is used to save any subsequent modifications made by the host application to the base
logical drive without affecting the referenced Enhanced FlashCopy image.
The Enhanced FlashCopy logical drive can be designated as either read-only or read-write.
v A read-only Enhanced FlashCopy logical drive provides a host application with READ access to a copy
of the data contained in the Enhanced FlashCopy image, but without the ability to modify the
Enhanced FlashCopy image. A read-only Enhanced FlashCopy logical drive does not have an
associated repository.
v A read-write Enhanced FlashCopy logical drive requires an associated repository to provide the host
application with WRITE access to a copy of the data contained in the Enhanced FlashCopy image.
6-14 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Prerequisites
The Enhanced FlashCopy premium feature must be enabled on the local storage subsystems.
Guidelines
Keep these guidelines in mind when creating an Enhanced FlashCopy logical drive:
v You cannot create an Enhanced FlashCopy logical drive of a Failed base logical drive.
v Enhanced FlashCopy repositories are fully resize-able. If you have the storage capacity you can
increase the size of the Enhanced FlashCopy repository to avoid a repository full message. Conversely,
if you find that the Enhanced FlashCopy repository is larger than you need, you can reduce its size to
free up space that is needed by other logical drives.
v If you create an Enhanced FlashCopy logical drive for an Enhanced FlashCopy image and that
Enhanced FlashCopy image creation operation remains in a Pending state it is due to the following
conditions:
The base logical drive that contains this Enhanced FlashCopy image is a member of an
asynchronous mirror group AND
The base logical drive is currently in a synchronizing operation. The Enhanced FlashCopy image
creation will complete as soon as the synchronization operation is complete.
v The Enhanced FlashCopy logical drive repository must have the same T10PI and Quality of Service
(QoS) settings as the associated base logical drive. For example, if a base logical drive that is used for
an Enhanced FlashCopy logical drive is T10PI enabled, then each repository logical drive in the overall
repository must be T10PI enabled.
To create a read-only Enhanced FlashCopy logical drive for the oldest enhanced FlashCopy image of the
Enhanced FlashCopy group SG_05 using the default Enhanced FlashCopy logical drive repository drive
settings, use this command:
create enhancedFlashCopyLogicalDrive userLabel="enhFlashCopyLDName"
enhancedFlashCopyImageID="SG_05:oldest" readOnly;
To create a read-write Enhanced FlashCopy logical drive for the newest enhanced FlashCopy image of the
Enhanced FlashCopy group SG_05 using the default Enhanced FlashCopy logical drive repository drive
settings, use this command:
create enhancedFlashCopyLogicalDrive userLabel="enhFlashCopyLDName"
enhancedFlashCopyImageID="SG_05:newest";
To restart an Enhanced FlashCopy logical drive that has entered a Stopped state, use this command:
resume cgEnhancedFlashCopyLogicalDrive ["
enhancedFlashCopyLogicalDriveName"]
cgEnhancedFlashCopyImage="enhancedFlashCopyImageName"
When you run this command, you must identify the Consistency Group Enhanced FlashCopy logical
drive and the consistency group Enhanced FlashCopy image used.
When you delete an Enhanced FlashCopy logical drive the system performs the following actions:
v Deletes all existing links with the Enhanced FlashCopy image.
v Deletes the associated repository that exists for the Enhanced FlashCopy group (if selected).
If you want to retain the repository members, set the deleteRepositoryMembers parameter to FALSE.
Typically, you use increase capacity when you receive a warning that the repository is becoming full. You
can increase the repository capacity by performing one of these tasks:
v Adding one or more existing repository logical drives
v Creating a new repository logical drive using free capacity that is available on an array or disk pool.
If any array or disk pool does not have free capacity, you can add unconfigured capacity in the form of
unused drives to an array or disk pool.
Prerequisites
You cannot increase the storage capacity of a repository logical drive if one of these conditions exists:
v The logical drive that you want to add does not have an Optimal status.
v Any logical drive in the array or disk pool that you want to add is in any state of modification.
v The array or disk pool does not have any free capacity.
v The array or disk pool does not have any unconfigured capacity.
v Eligible logical drives are not available.
Guidelines
v Each of the individual logical drives in the overall repository must have the same T10PI settings as the
associated base logical drive for the storage object. For example, if a base logical drive for a storage
object is T10PI enabled, then the associated overall repository must be T10PI enabled.
v Make sure that a base logical drive and each of the individual logical drives in the overall repository
have the same Quality of Service (QoS) attributes, specifically for the following characteristics:
RAID Level. A repository in a disk pool is considered to have a matching RAID Level for any base
logical drive on an array, regardless of the base logical drives actual RAID Level. However, a
repository on an array is considered to have a matching RAID Level only if that RAID Level is
identical to the RAID Level of the base logical drive.
Drive Type. A match requires that the base logical drive and the repository logical drive reside on
either an array or disk pool with identical drive type attributes.
v You cannot increase or decrease the repository capacity for an Enhanced FlashCopy logical drive that is
read-only because it does not have an associated repository. Only Enhanced FlashCopy logical drives
that are read-write require a repository
6-16 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
To increase the size of an Enhanced FlashCopy logical drive repository logical drive using existing
repository of repos_xxxx, use this command:
v set EnhancedFlashCopyLogicalDrive ["EnhancedFlashCopyLogicalDriveName"]
increaseRepositoryCapacity
repositorylogicaldrives=(repos_xxxx)
v To increase the size of an Enhanced FlashCopy group repository logical drive using existing repository
of repos_xxxx use this command:
set EnhancedFlashCopyGroup ["EnhancedFlashCopyGroupName"]
increaseRepositoryCapacity
repositorylogicaldrives=(repos_xxxx)
Note:
v repositoryLogicalDrive - Can be either the name of existing repository like repos_xxxx or the name of
the array or disk pool that the Enhanced FlashCopy group resides, and the capacity of the repository,
for example (arrayName capacity=00)
v repositoryFullLimit=percentValue - Repository capacity at which you will receive a warning that the
Enhanced FlashCopy repository logical drive is nearing full capacity.
If a repository logical drive has more capacity than is needed, you can reduce the capacity of the
repository logical drive by removing member logical drives from the end of its concatenated set. A
repository logical drive must always retain at least one member after such a reduction. The member
logical drives that are removed in such an operation are effectively detached from the repository logical
drive, thus reducing the repository logical drive capacity. The detached logical drives can then be reused
to provide additional capacity for the same or a different repository logical drive.
You can reduce the storage capacity of an existing repository logical drive for the following storage
objects:
v Enhanced FlashCopy group
v Enhanced FlashCopy logical drive
v Consistency group member logical drive
v Consistency group member Enhanced FlashCopy logical drive
Prerequisites
You cannot decrease the storage capacity of the overall repository if one of these conditions exists:
v The overall repository contains only one repository member logical drive.
v If there are one or more Enhanced FlashCopy images associated with the overall repository.
v If an Enhanced FlashCopy logical drive or a consistency group member Enhanced FlashCopy logical
drive is disabled.
Guidelines
v You can only remove repository member logical drives only in the reverse order that they were added.
v An overall repository must have at least one repository member logical drive.
v You cannot increase or decrease the repository capacity for an Enhanced FlashCopy logical drive that is
read-only because it does not have an associated repository. Only Enhanced FlashCopy logical drives
that are read-write require a repository logical drive.
v When you decrease capacity for an Enhanced FlashCopy logical drive or a consistency group member
Enhanced FlashCopy logical drive, the system automatically transitions the logical drive to a Disabled
state.
The Enhanced FlashCopy image rollback commands provide a way for you to manage the content that is
maintained by Enhanced FlashCopy groups and Enhanced FlashCopy consistency groups. An Enhanced
FlashCopy image rollback operation enables you to restore the contents of a base logical drive to a
point-in-time image that was captured when an Enhanced FlashCopy image was created. The base logical
drive is then immediately accessible for read/write operation using the rolled-back content after the
controller firmware accepts the rollback request. The read/write operation can take place while the
rolled-back content is being transferred to the base logical drive.
Note: The host will have immediate access to the new-rolled-back base logical drive, but the existing
base logical drive will not allow the host read-write access once the rollback is initiated. You can create
an Enhanced FlashCopy of the base logical drive just prior to initiating the rollback to preserve the
pre-rollback base logical drive for recovery purposes.
6-18 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Dynamic Logical Drive Expansion (DVE) to increase the capacity of a logical drive
Dynamic RAID Migration (DRM) to change the RAID level of an array.
Dynamic Segment Size (DSS) to change the segment size of a logical drive.
v You cannot start a rollback operation if the base logical drive is participating in a VolumeCopy.
v You cannot start a rollback operation if the base logical drive is a secondary logical drive in a remote
mirror. However, if the base logical drive is the primary logical drive in a remote mirror, you can start
a rollback operation. Additionally, you cannot perform a role reversal in a remote mirror if the primary
logical drive is participating in a rollback operation.
v A rollback operation fails if any of the used capacity in the associated Enhanced FlashCopy repository
logical drive has unreadable sectors.
Rollback operations require some level of system overhead, which can reduce overall system
performance. You can define the level of overhead the system devotes to a rollback operation using the
create EnhancedFlashCopyGroup command or the create consistencyGroup command. These commands
have a rollbackPriority parameter. Values for the rollbackPriority parameter range from highest
through lowest. The highest value means that the rollback operation has priority over all other host I/O.
The lowest value means that the rollback operation should be performed with minimal impact to host
I/O.
When you start an Enhanced FlashCopy image rollback, the contents of the base logical drive
immediately start to change to the contents of the Enhanced FlashCopy image. To start an Enhanced
FlashCopy image rollback use the start EnhancedFlashCopyImage rollback command or the start
cgEnhancedFlashCopyImagerollback command. These commands accepts the name of one or more
member logical drives. The start EnhancedFlashCopyImage rollback command works with specific
Enhanced FlashCopy images. The start cgEnhancedFlashCopyImagerollback command works with
specific member logical drives in the consistency group.
Attention: Possible loss of data access Stopping an Enhanced FlashCopy image rollback can leave the
base logical drive and the Enhanced FlashCopy image unusable.
Stopping an Enhanced FlashCopy image rollback leaves the base logical drive in an indeterminate state
with potentially invalid or inconsistent data that is typically unusable by a host system. The base logical
drive appears as failed in the storage management software. Stop an Enhanced FlashCopy image rollback
only in cases where recovery options exist for restoring the data in a base logical drive. If you must stop
an Enhanced FlashCopy image rollback use the stop EnhancedFlashCopyImage rollback command or the
stop cgEnhancedFlashCopyImage rollback command.
You can cancel an active rollback that is in progress (actively copying data), a pending rollback (in a
pending queue awaiting resources to start), or a rollback that has been paused due to an error.
After you cancel a rollback operation, you must take one of the following actions:
v Reinitialize the content of the base logical drive.
v Perform a new rollback operation to restore the base logical drive (using either the same Enhanced
FlashCopy image that was used in the Cancel Rollback operation or a different Enhanced FlashCopy
image to perform the new rollback operation).
In some cases a rollback operation might pause because of a condition or action of the controller. If this
occurs, you will see a status of Paused. After the controller is operating normally, you can resume an
Enhanced FlashCopy image rollback by using either the resume EnhancedFlashCopyImage rollback
command or the resume cgEnhancedFlashCopylogical drive command.
You can see the status of an Enhanced FlashCopy image rollback operation by running either the show
EnhancedFlashCopyImage command or the show cgEnhancedFlashCopyImage command. These commands
return one of these statuses during an Enhanced FlashCopy image rollback operation:
Table 6-1. FlashCopy Rollback Operation Status
Status Description
None No Enhanced FlashCopy image rollback operations are
running.
In Progress An Enhanced FlashCopy image rollback operation is
running.
6-20 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Chapter 7. Using the Enhanced Remote Mirroring Premium
Feature
The Enhanced Remote Mirroring premium feature provides for online, real-time replication of data
between storage subsystems over a remote distance. In the event of a disaster or a catastrophic failure on
one storage subsystem, you can promote the second storage subsystem to take over responsibility for
computing services. Enhanced Remote Mirroring is designed for extended storage environments in which
the storage subsystems that are used for Enhanced Remote Mirroring are maintained at separate sites.
Logical drives on one storage subsystem are mirrored to logical drives on another storage subsystem
across a fabric SAN. Data transfers can be synchronous or asynchronous. You choose the method when
you set up the remote-mirror pair. The data transfers occur at Fibre Channel speeds to maintain data on
the different storage subsystems. Because Enhanced Remote Mirroring is storage based, it does not
require any server overhead or application overhead.
Note: Enhanced Remote Mirroring is not supported in DS3000 storage subsystem configurations.
Table 7-1. Maximum Number of Defined Mirrors
Maximum Number of Defined
Controller Model Mirrors
DS3500 series 8 (16 with controller firmware 7.77
and later)
DS3950 64
DS4300 32
DS4400 64
DS4500 64
DS4700 64
DS4800 128
DS5020 64
The primary logical drive is the logical drive that accepts host I/O activity and stores application data.
When the mirror relationship is first created, data from the primary logical drive is copied in its entirety
to the secondary logical drive. This process is known as a full synchronization and is directed by the
controller owner of the primary logical drive. During a full synchronization, the primary logical drive
remains fully accessible for all normal I/O operations.
The controller owner of the primary logical drive initiates remote writes to the secondary logical drive to
keep the data on the two logical drives synchronized.
The secondary logical drive maintains a mirror (or copy) of the data on its associated primary logical
drive. The controller owner of the secondary logical drive receives remote writes from the controller
owner of the primary logical drive but will not accept host write requests. Hosts are able to read from the
secondary logical drive, which appears as read-only.
In the event of a disaster or a catastrophic failure at the primary site, you can perform a role reversal to
promote the secondary logical drive to a primary role. Hosts then are able to read from and write to the
newly promoted logical drive, and business operations can continue.
When you activate the Enhanced Remote Mirroring premium feature on the storage subsystem, you
create two mirror repository logical drives, one for each controller in the storage subsystem. An
individual mirror repository logical drive is not needed for each remote mirror.
When you create the mirror repository logical drives, you specify the location of the logical drives. You
can either use existing free capacity, or you can create an array for the logical drives from unconfigured
capacity and then specify the RAID level.
Because of the critical nature of the data being stored, do not use RAID 0 as the RAID level of mirror
repository logical drives. The required size of each logical drive is 128 MB, or 256 MB total for both
mirror repository logical drives of a dual-controller storage subsystem. In previous versions of the
Enhanced Remote Mirroring feature, the mirror repository logical drives required less disk storage space
and needed to be upgraded to use the maximum amount of mirror relationships.
Mirror Relationships
Before you create a mirror relationship, you must enable the Enhanced Remote Mirroring premium
feature on both the primary storage subsystem and the secondary storage subsystem. You must also
create a secondary logical drive on the secondary site if one does not already exist. The secondary logical
drive must be a standard logical drive of equal or greater capacity than the associated primary logical
drive.
7-2 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
When secondary logical drives are available, you can establish a mirror relationship in the storage
management software by identifying the primary logical drive and the storage subsystem that contains
the secondary logical drive.
When you first create the mirror relationship, a full synchronization automatically occurs, with data from
the primary logical drive copied in its entirety to the secondary logical drive.
Data Replication
The controllers manage data replication between the primary logical drive and the secondary logical
drive. This process is transparent to host machines and applications. This section describes how data is
replicated between the storage subsystems that are participating in Enhanced Remote Mirroring. This
section also describes the actions taken by the controller owner of the primary logical drive if a link
interruption occurs between storage subsystems.
Write Modes
When the controller owner of the primary logical drive receives a write request from a host, the controller
first logs information about the write to a mirror repository logical drive, and then writes the data to the
primary logical drive. The controller then initiates a remote write operation to copy the affected data
blocks to the secondary logical drive at the secondary storage subsystem.
The Enhanced Remote Mirroring feature provides two write mode options that affect when the I/O
completion indication is sent back to the host: Synchronous and Asynchronous.
Metro Mirror
Metro mirror provides the highest level security for full data recovery from the secondary storage
subsystem in the event of a disaster. Metro mirror does reduce host I/O performance. When this write
mode is selected, host write requests are written to the primary logical drive and then copied to the
secondary logical drive. After the host write request has been written to the primary logical drive and the
data has been successfully copied to the secondary logical drive, the controller removes the log record on
the mirror repository logical drive. The controller then sends an I/O completion indication back to the
host system. Metro mirror is selected as the default value and is the recommended write mode.
Global Copy
Global copy offers faster host I/O performance but does not guarantee that a copy operation has
successfully completed before processing the next write request. When you use Global copy, host write
requests are written to the primary logical drive. The controller then sends an I/O complete indication
back to the host system, without acknowledging that the data has been successfully copied to the
secondary (remote) storage subsystem.
When using Global copy, write requests are not guaranteed to be completed in the same order on the
secondary logical drive as they are on the primary logical drive. If the order of write requests is not
retained, data on the secondary logical drive might become inconsistent with the data on the primary
logical drive. This event could jeopardize any attempt to recover data if a disaster occurs on the primary
storage subsystem.
Global Mirror
When multiple mirror relationships exist on a single storage subsystem and have been configured to use
Global copy and to preserve consistent write order, they are considered to be an interdependent group
that is in the Global mirror. The data on the secondary, remote storage subsystem cannot be considered
fully synchronized until all of the remote mirrors that are in the Global mirror are synchronized.
In this case, the remote write operation cannot be completed to the secondary logical drive, and the
primary logical drive and the secondary logical drive are no longer correctly mirrored. The primary
controller transitions the mirrored pair into an Unsynchronized state and sends an I/O completion to the
primary host. The primary host can continue to write to the primary logical drive, but remote writes do
not take place.
When communication is restored between the controller owner of the primary logical drive and the
controller owner of the secondary logical drive, a resynchronization takes place. This resynchronization
happens automatically, or it must be started manually, depending on which write mode you chose when
setting up the mirror relationship. During the resynchronization, only the blocks of data that have
changed on the primary logical drive during the link interruption are copied to the secondary logical
drive. After the resynchronization starts, the mirrored pair transitions from an Unsynchronized status to a
Synchronization in Progress status.
The primary controller also marks the mirrored pair as unsynchronized when a logical drive error on the
secondary side prevents the remote write from completing. For example, an offline secondary logical
drive or a failed secondary logical drive can cause the remote mirror to become unsynchronized. When
the logical drive error is corrected (the secondary logical drive is placed online or recovered to an
Optimal status), then synchronization is required. The mirrored pair then transitions to a Synchronization
in Progress status.
Resynchronization
Data replication between the primary logical drive and the secondary logical drive in a mirror
relationship is managed by the controllers and is transparent to host machines and applications. When
the controller owner of the primary logical drive receives a write request from a host, the controller first
logs information about the write to a mirror repository logical drive. The controller then writes the data
to the primary logical drive. The controller then initiates a write operation to copy the affected data to the
secondary logical drive on the remote storage subsystem.
If a link interruption or a logical drive error prevents communication with the secondary storage
subsystem, the controller owner of the primary logical drive transitions the mirrored pair into an
Unsynchronized status. The controller owner then sends an I/O completion to the host sending the write
request. The host can continue to issue write requests to the primary logical drive, but remote writes to
the secondary logical drive do not take place.
When connectivity is restored between the controller owner of the primary logical drive and the
controller owner of the secondary logical drive, the logical drives must be resynchronized by copying the
blocks of data that changed during the interruption to the secondary logical drive. Only the blocks of
data that have changed on the primary logical drive during the link interruption are copied to the
secondary logical drive.
Attention: Possible loss of data access Any communication disruptions between the primary storage
subsystem and the secondary storage subsystem while resynchronization is underway could result in a
mix of new data and old data on the secondary logical drive. This condition would render the data
unusable in a disaster recovery situation.
7-4 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Creating a Remote Mirror Pair
Before you create any mirror relationships, logical drives must exist at both the primary site and the
secondary site. The logical drive that resides on the local storage subsystem is the primary logical drive.
Similarly, the logical drive that resides on the remote storage subsystem is the secondary logical drive. If
neither the primary logical drive or the secondary logical drive exist, you must create these logical drives.
When you create the secondary logical drive, you must consider these items:
v The secondary logical drive must be of equal or greater size than the primary logical drive.
v The RAID level of the secondary logical drive does not have to be the same as the primary logical
drive.
Performance Considerations
Consider these performance issues when you create mirror relationships:
v The controller owner of a primary logical drive performs a full synchronization in the background
while processing local I/O writes to the primary logical drive and associated remote writes to the
secondary logical drive. Because the full synchronization diverts controller processing resources from
I/O writes, full synchronization can have a performance impact to the host application.
v To reduce the performance impact, you can set the synchronization priority level to determine how the
controller owner will prioritize the full synchronization relative to other I/O activity. To set the
synchronization priority level, consider these guidelines:
A full synchronization at the lowest synchronization priority level takes approximately eight times
as long as a full synchronization at the highest synchronization priority level.
A full synchronization at the low synchronization priority level takes approximately six times as
long as a full synchronization at the highest synchronization priority level.
A full synchronization at the medium synchronization priority level takes approximately
three-and-a-half times as long as a full synchronization at the highest synchronization priority level.
A full synchronization at the high synchronization priority level takes approximately twice as long
as a full synchronization at the highest synchronization priority level.
v When the mirrored logical drive pair is in a Synchronization in Progress state, all host write data is
copied to the remote system. Both controller I/O bandwidth and I/O latency can affect host write
performance. Host read performance is not affected by the mirroring relationship.
v The time that it takes for data to be copied from the primary logical drive to the secondary logical
drive might impact overall performance. This impact is primarily caused by the delay and system
resource required for copying data to the remote mirror. Some delay might also occur because of the
limit to the number of simultaneous writes.
The free capacity that you select for the mirror repository logical drive must have a total of 256 MB of
capacity available. Two mirror repository logical drives are created on this capacity, one for each
controller. If you enter a value for the repository storage space that is too small for the mirror repository
logical drives, the firmware returns an error message that gives the amount of space needed for the
mirror repository logical drives. The command does not try to activate the Enhanced Remote Mirroring
feature. You can re-enter the command using the value from the error message for the repository storage
space value.
The RAID level that you choose for the mirror repository logical drive has these constraints:
v RAID 0 You cannot use RAID 0.
v RAID 1 The number of drives must be an even number. If you select an odd number of drives, the
controller firmware returns an error.
v RAID 3 or RAID 5 You must have a minimum of three disk drives in the array.
v RAID 6 You must have a minimum of five disk drives in the array.
The activate storageSubsystem feature=remoteMirror command provides three methods for defining
the disk drives for your mirror repository logical drive:
v You define each disk drive for the mirror repository logical drive by its enclosure ID and its slot ID.
v You define an array in which the mirror repository logical drive resides. You can optionally define the
capacity of the mirror repository logical drive.
v You define the number of disk drives, but not specific disk drives, for the mirror repository logical
drive.
Activating the Enhanced Remote Mirroring Feature with User-Assigned Disk Drives
Activating the Enhanced Remote Mirroring feature by assigning the disk drives provides flexibility in
defining your configuration by letting you choose from the available disk drives in your storage
subsystem. Choosing the disk drives for your remote mirror automatically creates a new array. You can
specify which disk drives to use and the RAID level for the new array.
This example shows a command in which you assign the disk drives:
7-6 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
c:\...\...\client>smcli 123.45.67.89 -c activate
storageSubsystem feature=remoteMirror repositoryRAIDLevel=5
repositoryDrives=(1,1 1,2 1,3 1,4 1,5);
The command in this example creates a new mirror repository logical drive consisting of five disk drives
that forms a new array. The new array has a RAID level of 5.
With this version of the activate storageSubsystem feature=remoteMirror command, you choose an
existing array in which to place the mirror repository logical drive. The storage management software
then determines which disk drives to use. You can also define how much space to assign to the mirror
repository logical drive. Because you are using an existing array, the RAID level for the mirror repository
logical drive defaults to the RAID level of the array in which you place it. You cannot define the RAID
level for the mirror repository logical drive.
This example shows a command in which the software assigns the disk drives:
c:\...\...\client>smcli 123.45.67.89 -c activate storageSubsystem
feature=remoteMirror repositoryArray=2 freeCapacityArea=2;
The command in this example creates a new mirror repository logical drive in array 2 using the second
free capacity area.
With this version of the activate storageSubsystem feature=remoteMirror command, you must specify
the number of disk drives and the RAID level that you want for the mirror repository logical drive. This
version of the command creates a new array. For this command to work, you must have disk drives in
the storage subsystem that are not assigned to an array.
activate storageSubsystem feature=remoteMirror
repositoryRAIDLevel=(1 | 3 | 5 | 6)
repositoryDriveCount=numberOfDrives
[driveType=(fibre | SATA | SAS |)]
[enclosureLossProtect=(TRUE | FALSE)]
This example shows a command in which you specify the number of disk drives:
c:\...\...\client>smcli 123.45.67.89 -c activate storageSubsystem f
eature=remoteMirror repositoryRAIDLevel=5 repositoryDriveCount=5
driveType=fibre;
The command in this example creates a new mirror repository logical drive by using five
softwareselected disk drives for the mirror repository logical drive. The mirror repository logical drive
has a RAID level of 5. The type of drive for the mirror repository logical drive is Fibre Channel.
where logicalDriveName is the name of the logical drive that you want to use for the primary logical
drive, and StorageSubsystemName is the remote storage subsystem that contains possible candidates for the
secondary logical drive. Enclose both the logical drive name and the storage subsystem name in double
quotation marks ( ).
Note: You can use the optional parameters as needed to help define your configuration.
The command in this example creates a remote mirror in which the primary logical drive is named
Jan_04_Account on the local storage subsystem. The secondary logical drive is named Jan_04_Account_B
on the remote storage subsystem that is named Tabor. The names used in this example are similar, but
that is not a requirement for the logical drive names in a remote-mirror pair. In this example, the remote
storage subsystem has a password that you must enter when making any change to the storage
subsystem configuration. Creating a remote-mirror pair is a significant change to a storage subsystem
configuration. Setting the write mode to synchronous and the synchronization priority to highest means
that host write requests are written to the primary logical drive and then immediately copied to the
secondary logical drive. These actions help to make sure that the data on the secondary logical drive is as
7-8 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
accurate a copy of the data on the primary logical drive as possible. The highest synchronization priority
does, however, use more system resources, which can reduce system performance.
After you have created a remote mirror, you can see the progress of data synchronization between the
primary logical drive and the secondary logical drive by running the show remoteMirror
synchronizationProgress command. This command shows the progress as a percentage of data
synchronization that has completed.
You can apply the changes to one or several remote mirror pairs by using this command. Use the
primary logical drive name to identify the remote mirror pairs for which you are changing the properties.
When a mirror relationship is in a suspended state, the primary logical drive does not make any attempt
to contact the secondary logical drive. Any writes to the primary logical drive are persistently logged in
the mirror repository logical drives. After the mirror relationship resumes, any data that is written to the
primary logical drive is automatically written to the secondary logical drive. Only the modified data
blocks on the primary logical drive are written to the secondary logical drive. Full synchronization is not
required.
The writeConsistency parameter defines whether the logical drives identified in this command are in a
write-consistency group or are separate. For the logical drives in a writeconsistency group, set this
parameter to TRUE. For the logical drives that are not in a write-consistency group, set this parameter to
FALSE.
The mirror relationship remains suspended until you use the resume remoteMirror command to restart
synchronization activities. This command restarts data transfers between a primary logical drive and a
secondary logical drive in a mirror relationship after the mirror has been suspended or unsynchronized.
The writeConsistency parameter in this command operates the same as in the previous command.
When you run this command, use the name of the primary logical drive of the remote mirror pair.
To re-establish the link between a primary logical drive and a secondary logical drive, use the create
remoteMirror command.
7-10 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Deleting a Primary Logical Drive or a Secondary Logical Drive
Use the delete logicalDrive command to remove a primary logical drive or a secondary logical drive
from a storage subsystem. Deleting a logical drive in a mirror relationship removes the mirror
relationship and completely deletes the logical drive from the storage subsystem. You cannot redefine the
mirror relationship until you create a new logical drive or choose an alternate logical drive to replace the
deleted logical drive.
Attention: Possible loss of data access Deleting a primary logical drive or a secondary logical drive
permanently removes the data from the storage subsystem.
When you run the Enhanced Remote Mirroring feature with other premium features, you must consider
the requirements of the other premium features to help make sure that you set up a stable storage
subsystem configuration.
In addition to running with the premium features, you can also run the Enhanced Remote Mirroring
feature while running Dynamic Logical Drive Expansion (DVE).
Storage Partitioning
Storage Partitioning is a premium feature that lets hosts share access to logical drives in a storage
subsystem. You create a storage partition when you define any of these logical components in a storage
subsystem:
v A host
v A host group
v A logical drive-to-LUN mapping
The logical drive-to-LUN mapping lets you define which host group or host has access to a particular
logical drive in the storage subsystem.
The logical drive for which the point-in-time image is created is known as the base logical drive and
must be a standard logical drive in the storage subsystem. The FlashCopy repository logical drive stores
information about all data that changed since the FlashCopy was created.
In this version of the storage management software, you can create FlashCopy logical drives based on the
primary logical drive or secondary logical drive of a remote mirror.
VolumeCopy
The VolumeCopy premium feature copies data from one logical drive (the source logical drive) to another
logical drive (the target logical drive) within a single storage subsystem. You can use this feature to
perform these functions:
v Copy data from arrays that use smaller-capacity disk drives to arrays that use larger-capacity disk
drives
v Back up data
v Restore FlashCopy logical drive data to the base logical drive.
You can use a primary logical drive in a remote mirror as a source logical drive or a target logical drive
in a VolumeCopy. You cannot use a secondary logical drive as a source logical drive or a target logical
drive.
Note: If you start a role reversal during a copy-in-progress, the copy fails and cannot be restarted.
This modification operation is considered to be dynamic because you can continually access data on
arrays, logical drives, and disk drives throughout the entire operation.
A DVE operation can be performed on a primary logical drive or a secondary logical drive of a mirror
relationship.
Note: Although the storage management software indicates that the logical drive has increased capacity,
its usable capacity is the size of the smaller of the primary logical drive or the secondary logical drive.
7-12 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Asynchronous Enhanced Remote Mirroring Utility
This section describes the host utility to achieve periodic consistency with Asynchronous Enhanced
Remote Mirroring configurations. This section also describes how to run the Asynchronous Enhanced
Remote Mirroring utility.
The Asynchronous Enhanced Remote Mirroring utility enables you to bring a collection of asynchronous
remote logical drives into a mutually consistent and recoverable state. You can choose to run the utility
based on application demands, link state and speed, and other factors that are relevant to your
environment.
Note: The Asynchronous Enhanced Remote Mirroring utility does not check to make sure that
concurrently running instances of the utility are not trying to process the same logical drives and mirrors.
If you choose to simultaneously run more than one instance of the Asynchronous Enhanced Remote
Mirroring utility, you must make sure that the configuration files that you choose to run do not list the
same logical drives and mirrors.
where configuration_file is the file that you provide as input. The configuration file specifies the Enhanced
Remote Mirroring logical drives that you want to synchronize by using the utility. When you create the
configuration file, use these conditions to define the logical drives in the file:
v All the primary logical drives in a logical drive set must belong to the same storage subsystem.
v The maximum number of logical drive sets that you can specify in the file is four.
v The maximum number of mirrored pairs that you can specify as part of a consistency group is eight.
The optional parameter, -d, lets you specify a file to which you can send information regarding how the
utility runs. In this example, the file name is debug_file. The debug file contains trace information that can
be reviewed by an IBM Technical Support representative to determine how well the Asynchronous
Enhanced Remote Mirroring utility has run.
Note: Depending on the location of the configuration file and the debug file, you must specify the
complete path with the file name.
To run the Asynchronous Enhanced Remote Mirroring utility, you must enter the asyncRVMUtil command
from the command line. Because UNIX operating systems are case sensitive, you must type the command
exactly as shown. On Windows operating systems, you can type the command in all uppercase, in all
lowercase, or in mixed case.
Note: To use the Asynchronous Enhanced Remote Mirroring utility, you must be managing the storage
subsystem by using the command line interface, not the graphical user interface of DS Storage Manager.
Configuration Utility
The configuration file is an ASCII flat text file that provides the information for the Enhanced Remote
Mirroring synchronization used by the Asynchronous Enhanced Remote Mirroring utility. The file defines
the mirror logical drive sets to be synchronized. All of the mirror logical drives in the logical drive sets
defined in the configuration file are run collectively to create a recoverable image. If any one of the
mirrors in the logical drive set fails, the operation is stopped for this logical drive set and carried on to
the next logical drive set that is listed in the configuration file.
7-14 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
logSpec ::= "Log" "{" {logAttribute} "}"
logAttribute ::= fileSpec
fileSpec ::= "file" "=" fileName
LogicalDriveSetSpec ::= "LogicalDriveSet" LogicalDriveSetName
"{" {LogicalDriveSetAttribute} "}"
LogicalDriveSetAttribute ::= timeoutSpec | mirrorSpec
timeoutSpec ::= "OptimalWaitTimeLimit" "=" integer
mirrorSpec ::= "Mirror" "{" {mirrorAttribute} "}"
mirrorAttribute ::= primarySpec | secondarySpec |
FlashCopySpec
primarySpec ::= "Primary" "=" LogicalDriveSpec
secondarySpec ::= "Secondary" "=" LogicalDriveSpec
FlashCopySpec ::= "Copy" "=" logicalDriveSpec
logicalDriveSpec ::= storageSubsystemName"."logicalDriveUserLabel
In this syntax, items enclosed in double quotation marks ( ) are terminal symbols. Items separated by a
vertical bar (|) are alternative values (enter one or the other, but not both). Items enclosed in curly braces
({ }) are optional (you can use the item zero or more times).
Note: Names and labels can be any characters that are defined as appropriate for your operating system.
The maximum length for a name or label is 30 characters. If the name or label contains special characters
(as defined by the operating system) or period characters, you must enclose the name or label in double
quotation marks ( ). You can, optionally, enclose the name or label in double quotation marks at any
time.
Important: In the Asynchronous Enhanced Remote Mirroring utility configuration file, you must specify
the primary logical drive, the secondary logical drive, and the copy (FlashCopy ) logical drive. The utility
does not make sure that the secondary logical drive is correct for the Enhanced Remote Mirroring
relationship. The utility also does not make sure that the FlashCopy logical drive is actually a FlashCopy
for the secondary logical drive. You must make sure that these logical drives are correct. If the logical drives
This example shows a configuration file for the Asynchronous Enhanced Remote Mirroring utility.
Log{ file="d:\rvm-consistency.log" }
LogicalDriveSet "set1" {
optimalWaitTimeLimit = 15
Mirror {
Primary = LosAngelesSubsystem.PayrollLogicalDrive
Secondary = NewYorkSubsystem.PayrollLogicalDrive
Copy = NewYorkSubsystem.PayrollLogicalDriveImage
}
Mirror {
Primary = LosAngelesSubsystem.PayrollLogicalDrive
Secondary = BostonSubsystem.PayrollLogicalDrive
Copy = BostonSubsystem.PayrollLogicalDriveImage
}
}
LogicalDriveSet "set2" {
Mirror {
Primary = BostonSubsystem.HRLogicalDrive
Secondary = LosAngelesSubsystem.HRLogicalDrive
Copy = LosAngelesSubsystem.HRLogicalDriveImage
}
}
7-16 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Chapter 8. Using the VolumeCopy Premium Feature
The VolumeCopy premium feature lets you copy data from one logical drive (the source) to another
logical drive (the target) in a single storage subsystem. You can use this feature to perform these tasks:
v Back up data
v Copy data from arrays that use smaller-capacity disk drives to arrays using greater-capacity disk drives
v Restore FlashCopy logical drive data to the associated base logical drive
Tip: Because of this restriction, IBM strongly recommends using a FlashCopy version of the logical drive
as the source for the VolumeCopy, rather than using the original logical drive as the source. If you use
the FlashCopy as the source for the VolumeCopy operation, then I/O operations to the original logical
drive can continue.
While a VolumeCopy is In Progress, the same controller must own both the source logical drive and the
target logical drive. If one controller does not own both the source logical drive and the target logical
drive before creating the VolumeCopy, ownership of the target logical drive is automatically transferred
to the controller that owns the source logical drive. When the VolumeCopy is finished or stopped,
ownership of the target logical drive is restored to its preferred controller. If ownership of the source
logical drive changes while a VolumeCopy is running, ownership of the target logical drive also changes.
After the VolumeCopy completes, the source logical drive becomes available to host applications for write
requests. The target logical drive automatically becomes read only to hosts, and write requests to the
target logical drive are rejected.
Attention: Possible loss of data access A VolumeCopy overwrites data on the target logical drive.
Before you start a new operation, make sure that you no longer need the old data, or you have backed
up the old data on the target logical drive.
While the VolumeCopy has a status of In Progress, Pending, or Failed, the controllers reject read and
write requests to the target logical drive. After the VolumeCopy operation is finished, the target logical
drive automatically becomes read only to the hosts, and write requests to the target logical drive are
rejected. You can change the Read-Only attribute after the VolumeCopy has completed or has been
stopped. (For more information about the Read-Only attribute, see Viewing VolumeCopy Properties on
page 8-6.)
The following logical drives are not valid target logical drives:
v The base logical drive of an active FlashCopy logical drive
v A FlashCopy logical drive
v A mirror repository logical drive
v A FlashCopy repository logical drive
v A secondary logical drive in a remote-mirror pair
v A failed logical drive
v A missing logical drive
v A logical drive with a status of Degraded
v A logical drive that is currently in a modification operation
v A logical drive that is holding a SCSI-2 reservation or a persistent reservation
v A logical drive that is a source logical drive or a target logical drive in another VolumeCopy that has a
status of In Progress, Pending, or Failed
To determine which logical drives have reservations, run the show (logicalDrive) reservations
command. To remove a reservation, run the clear (logicalDrive) reservations command.
8-2 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Storage Subsystem Performance
During a VolumeCopy operation, the resources of the storage subsystem might be diverted from
processing I/O activity to completing a VolumeCopy, which might affect the overall performance of the
storage subsystem.
When you create a new VolumeCopy, you define the copy priority to determine how much controller
processing time is allocated for a VolumeCopy compared with I/O activity.
Copy priority has five relative settings ranging from highest to lowest. The highest priority rate supports
the VolumeCopy, but I/O activity might be affected. The lowest priority rate supports I/O activity, but
the VolumeCopy takes longer. You define the copy priority when you create the VolumeCopy pair. You
can redefine the copy priority later by using the set volumeCopy command. You can also redefine the
VolumeCopy priority when you recopy a logical drive.
Restrictions
These restrictions apply to the source logical drive, the target logical drive, and the storage subsystem:
v While a VolumeCopy operation has a status of In Progress, Pending, or Failed, the source logical drive
is available for read activity only. After the VolumeCopy finishes, read activity from and write activity
to the source logical drive is permitted.
v A logical drive can be selected as a target logical drive for only one VolumeCopy at a time.
v The maximum allowable number of VolumeCopies per storage subsystem depends upon the storage
subsystem configuration.
v A logical drive that is reserved by the host cannot be selected as a source logical drive or as a target
logical drive.
v A logical drive with a status of Failed cannot be used as a source logical drive or as a target logical
drive.
v A logical drive with a status of Degraded cannot be used as a target logical drive.
v You cannot select a logical drive that is participating in a modification operation as a source logical
drive or as a target logical drive. Modification operations include Dynamic Capacity Expansion (DCE),
Dynamic RAID Level Migration (DRM), Dynamic Segment Sizing (DSS), Dynamic Logical Drive
Expansion (DVE), and defragmenting an array.
VolumeCopy Commands
The following table lists the VolumeCopy commands and briefly describes what the commands do.
Table 8-1. VolumeCopy Commands
Command Description
create volumeCopy Creates a VolumeCopy and starts the
VolumeCopy operation.
disable storageSubsystem feature Turns off the current VolumeCopy operation.
volumeCopy
enable storageSubsystem feature Activates the VolumeCopy premium feature.
Creating a VolumeCopy
Before you create a VolumeCopy, make sure that a suitable target logical drive exists on the storage
subsystem, or create a new target logical drive specifically for the VolumeCopy. The target logical drive
that you use must have a capacity equal to or greater than the source logical drive.
You can have a maximum of eight VolumeCopies with a status of In Progress at one time. Any
VolumeCopy greater than eight has a status of Pending until one of the VolumeCopies with a status of In
Progress has completed the VolumeCopy process.
- where the file parameter is the complete file path and file name of a valid Feature Key file. Enclose the
file path and file name in double quotation marks ( ). Valid file names for Feature Key files usually end
with a .key extension.
8-4 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
source logical drive candidates and the target logical drive candidates. You can use the show volumeCopy
sourceCandidates command and the show volumeCopy targetCandidates command only after you have
enabled the VolumeCopy premium feature.
Creating a VolumeCopy
Attention: Possible loss of data access A VolumeCopy overwrites data on the target logical drive.
Make sure that you no longer need the data or have backed up the data on the target logical drive before
you start a VolumeCopy operation.
When you create a VolumeCopy, you must define which logical drives that you want to use for the
source logical drive and the target logical drive. You define the source logical drive and the target logical
drive by the name of each logical drive. You can also define the copy priority and choose whether you
want the target logical drive to be read only after the data is copied from the source logical drive.
Important: Setting the targetReadOnlyEnabled attribute to false breaks the one-to-one relationship
between the source and target VolumeCopy logical drives. Therefore, any data that are written to the
target VolumeCopy logical drive will not be copied to the source VolumeCopy logical drive. In addition,
these data will be lost if you recopy of the source VolumeCopy logical drive to the target VolumeCopy
logical drive.
Before you run the create volumeCopy command, perform these actions:
v Stop all I/O activity to the source logical drive and the target logical drive.
v Dismount any file systems on the source logical drive and the target logical drive, if applicable.
The command in this example copies the data from the source logical drive named Jaba_Hut to the target
logical drive named Obi_1. Setting the copy priority to medium provides a compromise between how
quickly the data is copied from the source logical drive to the target logical drive and the amount of
processing resources that are required for data transfers to other logical drives in the storage subsystem.
Setting the targetReadOnlyEnabled parameter to TRUE means that write requests cannot be made to the
target logical drive, making sure that the data on the target logical drive stays unaltered.
After the VolumeCopy operation is completed, the target logical drive automatically becomes read only to
hosts. Any write requests to the target logical drive are rejected, unless you disable the Read-Only
attribute by using the set volumeCopy command.
To view the progress of a VolumeCopy, use the show logicalDrive actionProgress command. This
command returns information about the logical drive action, the percentage completed, and the time
remaining until the VolumeCopy is complete.
If a logical drive is participating in more than one VolumeCopy (it can be a source logical drive for one
VolumeCopy operation and a target logical drive for another VolumeCopy operation), the details are
repeated for each associated copy pair.
The command in this example is requesting information about the source logical drive JabaHut. If you
wanted information about all of the logical drives, you would use the allLogicalDrives parameter. You
can also request information about a specific target logical drive.
Copy priority has five relative settings ranging from highest to lowest. The highest priority supports the
VolumeCopy, but I/O activity might be affected. The lowest priority supports I/O activity, but the
VolumeCopy takes longer. You can change the copy priority at these times:
v Before the VolumeCopy operation starts
v While the VolumeCopy operation has a status of In Progress
v After the VolumeCopy operation has completed when re-creating a VolumeCopy operation by using
the recopy volumeCopy command
When you create a VolumeCopy pair and after the original VolumeCopy has completed, the target logical
drive is automatically defined as read-only to the hosts. The read-only status of the target logical drive
helps to make sure that the copied data on the target logical drive is not corrupted by additional writes
to the target logical drive after the VolumeCopy is created. You want to maintain the read-only status
when you are performing these tasks:
v Using the target logical drive for backup purposes
v Copying data from one array to a larger array for greater accessibility
8-6 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
v Planning to use the data on the target logical drive to copy back to the base logical drive in case of a
disabled FlashCopy logical drive or failed FlashCopy logical drive
At other times, you might want to write additional data to the target logical drive. You can use the set
volumeCopy command to reset the read/write permission for the target logical drive.
Note: If you have set the VolumeCopy parameters to enable host writes to the target logical drive, the
read request and the write request to the target logical drive are rejected while the VolumeCopy
operation has a status of In Progress, Pending, or Failed.
Important: Setting the targetReadOnlyEnabled attribute to false breaks the one-to-one relationship
between the source and target VolumeCopy logical drives. Therefore, any data that are written to the
target VolumeCopy logical drive will not be copied to the source VolumeCopy logical drive. In addition,
these data will be lost if you recopy of the source VolumeCopy logical drive to the target VolumeCopy
logical drive.
Note: You can use the parameters as needed to help define your configuration.
When you use the recopy volumeCopy command to make a backup, you cannot write to the source logical
drive while the recopy operation is running. The recopy operation might take a long time.
Restriction: Because of this restriction, IBM strongly recommends using a FlashCopy version of the
logical drive as the source for the VolumeCopy, rather than using the original logical drive as the source.
If you use the FlashCopy as the source for the VolumeCopy operation, then I/O operations to the original
logical drive can continue.
When you run the recopy volumeCopy command, the data on the source logical drive is copied in its
entirety to the target logical drive.
Attention: Possible loss of data access The recopy volumeCopy command overwrites existing data on
the target logical drive and makes the target logical drive read-only to hosts. The recopy volumeCopy
command fails all of the FlashCopy logical drives that are associated with the target logical drive, if any
exist.
You can also reset the copy priority by using the recopy volumeCopy command if you want to change the
copy priority for the recopy operation. The higher priorities allocate storage subsystem resources to the
VolumeCopy at the expense of storage subsystem performance.
Note: You can use the optional parameters as needed to help define your configuration.
The command in this example copies data from the source logical drive that is associated with the target
logical drive Obi_1 to the target logical drive again. The copy priority is set to the highest value to
complete the VolumeCopy as quickly as possible. The underlying consideration for using this command
is that you have already created the VolumeCopy pair, which has already created one VolumeCopy. By
using this command, you are copying the data from the source logical drive to the target logical drive
with the assumption that the data on the source logical drive has changed since the previous copy was
made.
This example shows you how to use the command in a script file:
recopy volumeCopy target [Obi_1] copyPriority=highest;
Stopping a VolumeCopy
The stop volumeCopy command lets you stop a VolumeCopy that has a status of In Progress, Pending, or
Failed. After you have stopped a VolumeCopy, you can use the recopy volumeCopy command to create a
new VolumeCopy by using the original VolumeCopy pair. After you stop a VolumeCopy operation, all of
the mapped hosts will have write access to the source logical drive.
Important: If the VolumeCopy has a status of In Progress, you must stop the VolumeCopy before you
can remove the VolumeCopy pair from the storage subsystem configuration.
8-8 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
This example shows how to use the command in a script file:
remove volumeCopy target [Obi_1];
When you are running the VolumeCopy feature with other premium features, you must consider the
requirements of other premium features to help make sure that you set up a stable storage subsystem
configuration.
In addition to the premium features, you also can run the VolumeCopy feature while running Dynamic
Logical Drive Expansion (DVE).
Storage Partitioning
Storage Partitioning is a premium feature that lets hosts share access to logical drives in a storage
subsystem. You create a storage partition when you define any of these logical components in a storage
subsystem:
v A host
v A host group
v A logical drive-to-LUN mapping
The logical drive-to-LUN mapping lets you define which host group or host has access to a particular
logical drive in the storage subsystem.
After you create a VolumeCopy, the target logical drive automatically becomes read only to hosts to make
sure that the data is preserved. Hosts that have been mapped to a target logical drive do not have write
access to the logical drive, and any attempt to write to the read-only target logical drive results in a host
I/O error.
If you want hosts to have write access to the data on the target logical drive, use the set volumeCopy
command to disable the Read-Only attribute for the target logical drive.
The logical drive for which the point-in-time image is created is known as the base logical drive and
must be a standard logical drive in the storage subsystem. The FlashCopy repository logical drive stores
information about all of the data that changed since the FlashCopy was created.
Tip: You can select a FlashCopy logical drive as the source logical drive for a VolumeCopy. This selection
is a good use of this feature, because it performs complete backups without significant impact to the
storage subsystem availability. Some I/O processing resources are lost to the copy operation.
Important: If you choose the base logical drive of a FlashCopy logical drive as your target logical drive,
you must disable all of the FlashCopy logical drives that are associated with the base logical drive before
you can select it as a target logical drive.
You can use the FlashCopy Logical Drive premium feature with the VolumeCopy premium feature to
back up data on the same storage subsystem and to restore the data on the FlashCopy logical drive back
to its original base logical drive.
When you create a remote mirror, a remote mirror pair is created, which consists of a primary logical
drive at the primary storage subsystem and a secondary logical drive at a remote storage subsystem.
The primary logical drive is the logical drive that accepts host I/O and stores data. When the mirror
relationship is initially created, data from the primary logical drive is copied in its entirety to the
secondary logical drive. This process is known as a full synchronization and is directed by the controller
owner of the primary logical drive. During a full synchronization, the primary logical drive remains fully
accessible for all normal I/O activity.
The controller owner of the primary logical drive starts remote writes to the secondary logical drive to
keep the data on the two logical drives synchronized. Whenever the data on the primary logical drive
and the secondary logical drive becomes unsynchronized, the controller owner of the primary logical
drive starts a resynchronization, where only the data that changed during the interruption is copied.
The secondary logical drive maintains a mirror of the data on its associated primary logical drive. The
controller owner of the secondary logical drive receives remote writes from the controller owner of the
primary logical drive but does not accept host write requests.
The secondary logical drive stays available to host applications as read-only while mirroring is underway.
In the event of a disaster or a catastrophic failure at the primary site, you can perform a role reversal to
promote the secondary logical drive to a primary role. Hosts are then able to access the newly promoted
logical drive, and business operations can continue.
You can select a primary logical drive that is participating in a remote mirror pair to be used as the
source logical drive or a target logical drive for a VolumeCopy. A secondary logical drive that is
participating in a remote-mirror pair cannot be selected as a source logical drive or a target logical drive.
Role Reversals
A role reversal is the act of promoting the secondary logical drive to be the primary logical drive of the
remote mirror pair, and demoting the primary logical drive to be the secondary logical drive.
In the event of a disaster at the storage subsystem that contains the primary logical drive, you can fail
over to the secondary site by performing a role reversal to promote the secondary logical drive to the
primary logical drive role. This action lets hosts continue to access data, and business operations can
continue.
Trying a role reversal in which the original primary logical drive is the source logical drive for an active
VolumeCopy (the status is In Progress or Pending) causes the VolumeCopy to fail. The failure occurs
when the original primary logical drive becomes the new secondary logical drive. You cannot restart the
VolumeCopy until you return the roles of the logical drives back to their original state; that is, the logical
drive that was originally the primary logical drive is set once again to be the primary logical drive.
8-10 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
If the primary storage subsystem is recovered but is unreachable due to a link failure, a forced promotion
of the secondary logical drive will result in both the primary logical drive and the secondary logical drive
viewing themselves in the primary logical drive role (dual-primary condition). If this condition occurs,
the VolumeCopy in which the primary logical drive is participating is unaffected by the role change.
You can perform a role reversal by using the set remoteMirror command. (For information about the set
remoteMirror command, see Set Remote Mirror on page 3-206.)
v To change a secondary logical drive to a primary logical drive, use this command, which promotes the
selected secondary logical drive to become the primary logical drive of the remote mirror pair. Use this
command after a catastrophic failure has occurred.
set remoteMirror role=primary
v To change a primary logical drive to a secondary logical drive, use this command, which demotes the
selected primary logical drive to become the secondary logical drive. Use this command after a
catastrophic failure has occurred.
set remoteMirror role=secondary
The organization is not a rigid approach, and you can use the commands as appropriate for your storage
subsystem. The commands listed in this chapter do not cover the entire array of commands you can use
for maintenance. Other commands, particularly the set commands, can provide diagnostic or
maintenance capabilities.
Routine Maintenance
Routine maintenance involves those tasks that you might perform periodically to make sure that the
storage subsystem is running as well as possible or to detect conditions before they become problems.
A media scan runs on all of the logical drives in the storage subsystem that have these conditions:
v Has Optimal status
v Has no modification operations in progress
v Has media scan enabled
Errors that are detected during a scan of a user logical drive are reported to the Major Event Log (MEL)
and handled as follows:
v Unrecovered media error The disk drive could not read the requested data on its first try or on any
subsequent retries. The result of this action is that for logical drives with redundancy protection, the
data is reconstructed, rewritten to the disk drive, and verified, and the error is reported to the Event
Log. For logical drives without redundancy protection, the error is not corrected, but it is reported to
the Event Log.
v Recovered media error The disk drive could not read the requested data on its first attempt. The
result of this action is that the data is rewritten to the disk drive and verified. The error is reported to
the Event Log.
v Redundancy mismatches Redundancy errors are found, and a media error is forced on the block
stripe so that it is found when the disk drive is scanned again. If redundancy is repaired, this forced
media error is removed. The result of this action is that the first 10 redundancy mismatches found on a
logical drive are reported to the Event Log.
v Unfixable error The data could not be read, and parity information or redundancy information
could not be used to regenerate it. For example, redundancy information cannot be used to reconstruct
data on a degraded logical drive. The result of this action is that the error is reported to the Event Log.
The set logicalDrive command enables a media scan for the logical drive. The command takes this
form:
set (allLogicalDrives | logicalDrive [logicalDriveName] | logicalDrives
[logicalDriveName1 ... LogicalDriveNameN] | logicalDrive <wwID>)
mediaScanEnabled=(TRUE | FALSE)
The set storageSubsystem command defines how frequently a media scan is run on a storage subsystem.
The command takes this form:
set storageSubsystem mediaScanRate=(disabled | 1-30)
The mediaScanRate values define the number of days over which the media scan runs. Valid values are
disabled, which turns off the media scan; or 1 day to 30 days, where 1 day is the fastest scan rate, and 30
days is the slowest. A value other than what is shown will not allow the media scan to function.
Before you can run a redundancy check, you must enable redundancy checking by using the set
logicalDrive command. The command takes this form:
Resetting a Controller
Important: When you reset a controller, the controller is no longer available for I/O operations until the
reset is complete. If a host is using logical drives that are owned by the controller being reset, the I/O
that is directed to the controller is rejected. Before resetting the controller, either make sure that the
logical drives that are owned by the controller are not in use, or make sure that a multi-path driver is
installed on all of the hosts that are using these logical drives.
Resetting a controller is the same as rebooting the controller processors. To reset a controller, use this
command:
reset controller [(a | b)]
9-2 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Resetting the Battery Age
After you have replaced the batteries in the storage subsystem, you must reset the age of the battery. You
can reset either the batteries for an entire storage subsystem or a battery in a specific controller. To reset
the age of the batteries to zero days, use this command:
reset storageSubystem batteryInstallDate [controller=(a | b)]
Note: The DS3950, DS4800 (models 82, 84, and 88), DS5020, DS5100, and DS5300 controller modules do
not support this command. The batteries in the DS3950, DS4800 (models 82, 84, and 88), DS5020, DS5100,
and DS5300 controller modules do not require that you reset the battery age after you have replaced the
batteries.
To turn off the indicator light after locating the disk drive, use this command:
stop drive locate
Relocating an Array
Array relocation describes the action of moving disk drives within the same storage subsystem. This is a
supported capability; however, any relocation of storage subsystem components must be completed
under the guidance of an IBM Technical Support representative.
This section describes the commands that you use to remove a set of disk drives and then reinstall them
into a different storage subsystem.
There are two methods you can use to move arrays: hot array relocation and cold array relocation.
Note: For more detailed information about relocating arrays, see one of the following documents:
v DS3000: IBM System Storage DS3000 Installation, User's and Maintenance Guide
v DS4000 / DS5000: IBM System Storage DS4000/DS5000 Hard Drive and Storage Expansion Enclosure
Installation and Migration Guide
v Hot array relocation lets you add or move storage without reconfiguring the storage subsystem and, in
some cases, without rebooting. During hot array relocation, the storage subsystem power is not turned
off.
v Cold array relocation requires that the power to the source storage subsystem and the destination
storage subsystem be turned off before moving the arrays from one storage subsystem to another. Then
the power to the storage subsystems can be turned on.
To ensure that any array being moved to a different destination storage subsystem is correctly recognized
and managed by the new storage subsystem, use hot array relocation whenever possible.
Attention: Possible loss of data access You must move a single array at a time, and it must go into a
storage subsystem with the same level of controller firmware.
Relocating an array from one storage subsystem to another includes these procedures:
1. Verifying the status of the storage subsystems
2. Ensuring that both storage subsystems have the latest controller firmware versions installed
3. Locating the drives in the array
4. Placing the array offline
5. Removing drives from the storage subsystem
6. Replacing an array into the new storage subsystem
Attention: Check firmware versions Ensure that both existing and new storage subsystems have the
latest controller firmware versions installed.
v See the IBM Disk Support website to find the latest firmware versions for your storage subsystems:
www.ibm.com/systems/support/storage/disk
v Also check the following documentation for more information:
DS3000: IBM System Storage DS3000 Installation, User's and Maintenance Guide
DS4000 / DS5000: IBM System Storage DS4000/DS5000 Hard Drive and Storage Expansion Enclosure
Installation and Migration Guide
To perform these steps, you must be familiar with the following CLI commands. The command syntax is
provided to assist in your use of these new commands.
Note: Array relocation commands are supported with the following controller firmware only:
v DS5000: 07.30.xx.xx
v DS4000: 07.1x.xx.xx
v DS3000: Not supported.
9-4 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Use the following command to place a specific storage subsystem into an exported state so that its disk
drives may be removed.
start array [user-label] export
At this point you are allowed to remove the disk drives that comprise the array, and physically reinstall
them into a different storage subsystem.
Use the following command to logically move a specific storage subsystem from an exported state to the
complete state.
start array [user-label] import
Performance Tuning
Over time, as a storage subsystem exchanges data between the hosts and the disk drives, its performance
can degrade. You can monitor the performance of a storage subsystem and make adjustments to the
operational settings on the storage subsystem to help improve performance.
where filename is the name of the file in which you want to save the performance statistics. You can use
any file name that your operating system can support. The default file type is .csv. The performance
information is saved as a comma-delimited file.
Before you use the save storageSubsystem performanceStats command, run the set session
performanceMonitorInterval command and the set session performanceMonitorIterations command to
specify how often statistics are collected.
RAID 6 is supported in DS4000 and DS5000 storage products only, with controller firmware version
7.1x.xx.xx or higher.
where arrayNumber is the number of the array for which you want to change the RAID level.
where segmentSizeValue is the new segment size that you want to set. Valid segment size values are 8, 16,
32, 64, 128, 256, and 512. You can identify the logical drive by name or by WWID. (For usage information,
see Set Logical Drive Attributes on page 3-190.)
9-6 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
The set storageSubsystem command lets you change settings for these items:
v The cache block size
v The cache flush start percentage
v The cache flush stop percentage
The set logicalDrive command lets you change settings for these items:
v The cache flush modifier
v The cache without batteries enabled or disabled
v The mirror cache enabled or disabled
v The read cache enabled or disabled
v The write cache enabled or disabled
v The read ahead multiplier
v The redundancy check enabled or disabled
Defragmenting an Array
When you defragment an array, you consolidate the free capacity in the array into one contiguous area.
Defragmentation does not change the way in which the data is stored on the logical drives. As an
example, consider an array with five logical drives. If you delete logical drive 1 and logical drive 3, your
array is configured as follows:
space, logical drive 2, space, logical drive 4, logical drive 5, original unused space
When you defragment this array, the space (free capacity) is consolidated into one contiguous location
after the logical drives. After being defragmented, the array appears as follows:
Note: If you need to defragment the data stored in the logical drive, you must use the appropriate
defragmenting tool for the installed operating system.
storageSu bsystemProfile.txt
Major Event Log
A detailed list of errors that occur on the storage
subsystem. The list is stored in reserved areas on the
disk drives in the storage subsystem. The list records
configuration events and failures with storage
subsystem components.
majorEventLog.txt
Read link status
A detailed list of errors that have been detected in the
traffic flow between the devices on the Fibre Channel
loop. A file of historical read link status data might
also be included in the archive.
readLinkStatus.csv
Switch-on-a-chip (SOC) error
statistics Information from the loop-switch ports that are
connected to Fibre Channel devices.
socStatistics.csv
NVSRAM
A controller file that specifies the default settings for
the controllers.
NVSRAMdata.txt
Performance statistics
A detailed description of how a storage subsystem is
performing. Collected data includes the I/O activity of
specific controllers or logical drives, the transfer rate of
the controller, the current I/Os per second, and the
maximum I/Os per second.
performanceStatistics.csv
Persistent reservations and
persistent registrations A detailed list of logical drives on the storage
subsystem and persistent reservations and persistent
registrations.
persistentRegistrations.txt
Object bundle
A detailed description of the status of the storage
subsystem and its components, which was valid at the
time that the file was generated. The object bundle file
is a binary file and does not contain human-readable
information.
objectBundle
Drive diagnostic data
A detailed list of log sense data from all of the disk
drives in the storage subsystem.
driveDiagnosticData.txt
9-8 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Table 9-2. Support Data for the Storage Subsystem (continued)
Type of Data Description and File Name
Recovery profile
A detailed description of the latest recovery profile
record and historical data.
recoveryProfile.csv
Unreadable sectors
A detailed list of all of the unreadable sectors that
have been logged to the storage subsystem.
badBlocksData.txt
State capture data
A detailed description of the current state of the
storage subsystem.
stateCaptureData.dmp
Storage subsystem
A detailed listing of the hardware components and the
software components that comprise the storage
subsystem configuration.
storageSubsystemConfiguration.cfg
Diagnosing a Controller
The diagnose controller command provides these tests that help you make sure that a controller is
functioning correctly:
v The read test
v The write test
v The data-loopback test
The read test initiates a read command as it would be sent over an I/O data path. The read test compares
data with a known, specific data pattern, and the read test checks for data integrity and errors. If the read
command is unsuccessful or the data compared is not correct, the controller is considered to be in error
and is placed offline.
The write test initiates a write command as it would be sent over an I/O data path to the diagnostics
region on a specified disk drive. This diagnostics region is then read and compared to a specific data
pattern. If the write fails or the data compared is not correct, the controller is considered to be in error,
and it is failed and placed offline.
Run the data-loopback test only on controllers that have connections between the controller and the disk
drives. The test passes data through each controller disk drive-side channel, the minihub, out onto the
loop, and back again. Enough data is transferred to determine error conditions on the channel. If the test
fails on any channel, this status is saved so that it can be returned if all of the other tests pass.
For best results, run all three tests after you first install the storage subsystem and any time that you that
have made changes to the storage subsystem or the components that are connected to the storage
subsystem (such as hubs, switches, and host adapters).
The test results contain a generic, overall status message and a set of specific test results. Each test result
contains these items:
v Test (read, write, or data loopback)
v Port (read or write)
v Level (internal or external)
v Status (pass or fail)
Events are written to the Event Log when the diagnostics are started and when testing is completed.
These events help you to evaluate whether diagnostics testing was successful or failed and the reason for
the failure.
Error counts are calculated from the current baseline. The baseline describes the error count values for
each type of device in the Fibre Channel loop, either when the controller goes through its start-of-day
sequence or when you reset the baseline. The baseline indicates the difference in error counts from the
time the baseline was established to the time you request the read link status data.
The script command set provides two commands for running RLS diagnostics:
v reset storageSubsystem RLSBaseline Resets the RLS baseline for all devices by setting all of the
counts to 0.
v save storageSubsystem RLSCounts Saves the RLS counters to a file that you can review later. The
default file name is readLinkStatus.csv.
Run the reset storageSubsystem RLSBaseline command before you run the save storageSubsystem
RLSBaseline command.
The following table lists the type of data contained by the file that is generated by the save
storageSubsystem RLSBaseline command.
Table 9-3. RLS Baseline Data for the Storage Subsystem
Type of Data Description
Devices
A list of all devices on the Fibre Channel loop.
9-10 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Table 9-3. RLS Baseline Data for the Storage Subsystem (continued)
Type of Data Description
Baseline time The date and time when the baseline was set.
Elapsed time The time that has elapsed from when the baseline time was
set to when the read link status was gathered.
Invalid transmission
word (ITW) The total number of ITW errors that were detected on the
Fibre Channel loop from the baseline time to the current date
and time. ITW might also be referred to as the Received Bad
Character Count.
The way that you interpret the RLS results is based on the concept that the device immediately following
the problematic component will have the largest number of invalid transition word (ITW) error counts.
The process is to obtain the ITW count for every component and device on the loop, analyze the data in
loop order, and identify any large increases in the ITW counts.
Important:
The current error counting standard for when to calculate the ITW error count is not well defined.
Different vendor devices calculate at different rates. Analysis of the data must take this discrepancy into
consideration.
9-12 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Collecting Switch-on-a-Chip Error Statistics
Switch-on-a-chip (SOC) error statistics provide information about the loop-switch ports that are connected
to the Fibre Channel devices in a storage subsystem. (RLS counts provide information about the Fibre
Channel devices.) Reporting SOC error statistics is available only on storage subsystems that have SOC
loop-switch devices that are incorporated into the controller disk drive channel or the ESM circuitry. SOC
devices are integrated circuits that join together Fibre Channel devices in arbitrated loop topologies. SOC
devices automatically collect statistical information for each SOC port that is connected to a controller
port, an ESM port, a disk drive port, or an expansion connector. An IBM Technical Support representative
can use the statistical information with RLS counts to identify problems with Fibre Channel devices that
are attached to the loop.
The method for collecting error statistics starts by establishing a baseline for the SOC error statistics. The
baseline consists of SOC error statistics that are established at a set time for each SOC device on the loop.
The baseline is set by clearing the error counters in each SOC device. You can set a device baseline by
performing one of these actions:
v Turning on the power to the device or resetting the device
v Running the reset storageSubsystem SOCBaseline command
In addition, each controller also initializes the SOC error counters in all of the expansion drawers that are
attached to the controller following a cold boot (power-on or hot insertion). If you add an expansion
drawer while the power is turned on to the storage subsystem, a new baseline is established for any
device on the expansion drawer.
After you have established the baseline for the SOC devices, you run the storage subsystem for a
predetermined amount of time (for example, two hours). At the end of the run time, you collect the SOC
error statistics by saving the information to a file. To save the information, run the save
storageSubsystem SOCCounts file filename command. The default name of the file that contains the SOC
error statistics is socStatistics.csv. You can use any file name that has the .csv extension.
Analyzing the SOC error statistics is beyond the scope of normal storage subsystem management. After
you have collected the SOC error statistics in a file, send the file to an IBM Technical Support
representative.
Recovery Operations
Recovery operations include repairing the storage subsystem and returning it to an operational state. This
might involve replacing a failed CRU, a failed controller, or a disk drive or restoring data or the storage
subsystem to operation. For information about when it is appropriate to replace a CRU, see Routine
Maintenance on page 9-1.
Placing a controller online sets it to the Optimal state and makes it active and available for I/O
operations. Placing a controller offline makes it unavailable for I/O operations and moves its arrays to
the other controller if failover protection is enabled.
Taking a controller offline can seriously impact data integrity and storage subsystem operation.
v If you do not use write cache mirroring, data in the cache of the controller you place offline is lost.
v If you take a controller offline and you have controller failover protection through a host multi-path
driver, the other controller in the pair takes over. Arrays and their associated logical drives that were
assigned to the offline controller are automatically reassigned to the remaining controller. If you do not
have a multi-path driver installed on the application host and you take a controller offline while the
application is using associated logical drives, application errors will occur.
Attention: Possible loss of data access Placing a controller offline can cause loss of data.
Use Service mode to replace CRUs, such as a controller. Placing a controller in Service mode makes it
unavailable for I/O operations and moves its arrays to the second controller without affecting the
preferred path of the array. This action might significantly reduce performance. The arrays are
automatically transferred back to the preferred controller when it is placed back online.
If you change a controller to Service mode while an application is using the associated logical drives on
the controller, the change causes I/O errors unless a multi-path driver is installed on the host. Before you
place a controller in Service mode, make sure that the logical drives are not in use, or a multi-path driver
is installed on all of the hosts that are using these logical drives.
In addition, if you do not have a multi-path driver, you must make appropriate operating system-specific
modifications to make sure that the arrays moved are accessed on the new path when you change to
Service mode.
Important: Place a controller in Service mode only under the direction of an IBM Technical Support
representative.
Initializing a Drive
Attention: Possible loss of data access When you initialize a disk drive, all data on the disk drive is
lost.
You must initialize a disk drive when you have moved a disk drive that was previously part of a
multidisk array from one storage subsystem to another. If you do not move the entire set of disk drives,
9-14 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
the array information and the logical drive information on the disk drives that you move are incomplete.
Each disk drive that you move contains only part of the information that is defined for the logical drive
and the array. To be able to reuse the disk drives to create a new array and logical drive, you must delete
all of the old information from the disk drives by initializing the disk drive.
When you initialize a disk drive, all of the old array information and logical drive information are
deleted, and the disk drive is returned to an unassigned state. Returning a disk drive to an unassigned
state adds unconfigured capacity to a storage subsystem. You can use this capacity to create additional
arrays and logical drives.
where enclosureID and slotID are the identifiers for the disk drive.
Reconstructing a Drive
If two or more of the disk drives in a array have failed, the logical drive shows a status of Failed. All of
the logical drives in the array are no longer operating. To return the array to an Optimal status, you must
replace the failed disk drives. Then, you must reconstruct the data on the new disk drives. The data that
you reconstruct is the data as it would appear on the failed disk drives.
Important: You can use this command only when the disk drive is assigned to a RAID 1, RAID 3, RAID
5, or RAID 6 array.
where enclosureID and slotID are the identifiers for the disk drive.
A logical drive is automatically initialized when you first create it. If the logical drive starts showing
failures, you might be required to re-initialize the logical drive to correct the failure condition.
Important: If you run this command without a multi-path driver on the hosts, stop I/O activity to the
logical drives to prevent application errors.
Important: You cannot run this command if all of the logical drives are currently owned by their
preferred controller, or the storage subsystem does not have defined logical drives.
Under some host operating systems, you must reconfigure the multi-path host driver. You might also
need to make operating system modifications to recognize the new I/O path to the logical drive.
Replacing CRUs
The DS3950, DS3000, DS4000, DS5000, and DS5020 controller module components, such as the controller
CRUs, the power-fan CRUs, and the interconnect-battery CRUs, have a Service Action Allowed (SAA)
indicator light. This indicator light is a blue LED. The Service Action Allowed indicator light helps to
make sure that you do not remove a CRU before it is safe to do so.
Attention: Possible loss of data access Never remove a component that has a Service Action
Required indicator light on unless the Service Action Allowed (SAA) indicator light is on.
If a component fails and must be replaced, the Service Action Required indicator light on that CRU
comes on to indicate that service action is required, provided no data availability dependencies or other
conditions exist that dictate the CRU should not be removed. The Service Action Allowed indicator light
automatically comes on or goes off when conditions change. In most cases, the Service Action Allowed
indicator light comes on steadily when the Service Action Required indicator light comes on for the CRU.
If the interconnect-battery CRU must be replaced, the Service Action Allowed indicator light does not
come on automatically. Before the Service Action Allowed indicator light on the interconnect-battery CRU
can come on, you must place controller CRU in slot B into Service mode. This action routes all control
and I/O activity through one controller to help make sure that data access is maintained while the
interconnect-battery CRU is removed. The Service Action Allowed indicator light comes on after the new
CRU has been installed.
The ability to remove a CRU depends on the data availability dependencies of the controller module or
the controller module. The Service Action Allowed indicator light does not come on if removing a CRU
jeopardizes data on the expansion drawers or current I/O activity. An example of limiting when you can
remove a CRU is when one controller CRU has a Service Action Required indicator light on. You cannot
remove the other controller CRU (the Service Action Allowed indicator light does not come on), because
doing so would jeopardize the data either on the expansion drawers or transitioning through the
controllers.
A less obvious example, as in the DS4800 storage subsystem, is when the power supply for the controller
CRU in slot A has failed, and the controller CRU in slot B has failed. Removing the controller CRU in slot
B before replacing the failed power-fan CRU causes the controller CRU in slot A to lose power, which
results in a loss of data access. This action occurs because power distribution from each power-fan CRU
is through the controller CRU that is physically connected to that power-fan CRU.
9-16 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
v The power-fan CRU has both its Service Action Required indicator light and its Service Action Allowed
indicator light on.
v The controller CRU in slot B has only its Service Action Required indicator light on, but its Service
Action Allowed indicator light is off.
v After the failed power-fan CRU has been replaced, the Service Action Allowed indicator light comes on
for the controller CRU in slot B.
For more information about the Service Action Not Allowed indicator, please see the IBM System Storage
DSxxxx Storage Subsystem Installation, User's and Maintenance Guide for your storage subsystem product.
SUMMARY------------------------------
Number of controllers: 2
Number of arrays: 5
RAID 6: Enabled
VolumeCopy: Disabled
Number of copies used: 0
Number of copies allowed: 0
Number of drives: 32
Mixed drive types: Enabled
Current drive type(s): Fibre (5), Fibre/FDE (21), Serial ATA (SATA) (6)
Total hot spare drives: 2
Standby: 2
In use: 0
Access logical drive: LUN 31,31,31 (see Mappings section for details)
Default host OS: Windows 2000/Server 2003/Server 2008 Non-Clustered
(Host OS index 2)
Current configuration
Firmware version: 07.50.00.00
NVSRAM version: N1818D53R1050V03
EMW version: 10.50.G5.02
AMW version: 10.50.G5.02
Pending configuration
Staged firmware download supported: Yes
Firmware version: None
NVSRAM version: None
Transferred on: None
Controller enclosure audible alarm: Disabled
CONTROLLERS------------------------------
Number of controllers: 2
Status: Online
Current configuration
Firmware version: 07.50.00.00
Appware version: 07.50.00.00
Bootware version: 07.50.00.00
NVSRAM version: N1818D53R1050V03
Pending configuration
Firmware version: None
Appware version: None
Bootware version: None
NVSRAM version: None
10-2 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Transferred on: None
Current ID (ALPA)
On drive channel 1: 125/0x1
Replacement part number: memSpyTesting_9
Model name: 7000-88
Board ID: 7091
Submodel ID: 93
Product ID: 1818
Revision: 0730
Replacement part number: memSpyTesting_9
Part number: 32847-10
Serial number: SF74700554
Vendor: IBM
Date of manufacture: January 24, 2008
Data Cache
Total present: 8192 MB
Total used: 8192 MB
Data Cache Module
Status: Optimal
Location: Controller A, Slot 1
Capacity: 1,024 MB
Replacement Part number: Not Available
Manufacturer Part Number: M3 93T2953EZ3-CD5
Part Number: Not Available
Serial number: 1426196510
Manufacturer: Samsung
Date of manufacture: October 29, 2007
Data Cache Module
Status: Optimal
Location: Controller A, Slot 2
Capacity: 1,024 MB
Replacement Part number: Not Available
Manufacturer Part Number: M3 93T2953EZ3-CD5
Part Number: Not Available
Serial number: 1426196542
Manufacturer: Samsung
Date of manufacture: October 29, 2007
Data Cache Module
Status: Optimal
Location: Controller A, Slot 3
Capacity: 1,024 MB
Replacement Part number: Not Available
Manufacturer Part Number: M3 93T2953EZ3-CD5
Part Number: Not Available
Serial number: 1426196568
Manufacturer: Samsung
Date of manufacture: October 29, 2007
Data Cache Module
Status: Optimal
Location: Controller A, Slot 4
Capacity: 1,024 MB
Replacement Part number: Not Available
Manufacturer Part Number: M3 93T2953EZ3-CD5
Part Number: Not Available
Serial number: 1426196524
Manufacturer: Samsung
Date of manufacture: October 29, 2007
Data Cache Module
Status: Optimal
Location: Controller A, Slot 5
Capacity: 1,024 MB
Replacement Part number: Not Available
Manufacturer Part Number: M3 93T2953EZ3-CD5
Part Number: Not Available
Serial number: 1426196503
Manufacturer: Samsung
Date of manufacture: October 29, 2007
10-4 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Number of ports: 4
Board ID: 0801
Replacement part number: Not Available
Part number: PN L2-25023-02
Serial number: SN SF84300044
Vendor: VN LSI
Date of manufacture: November 1, 2008
Host Interface Board
Status: Optimal
Location: Slot 1
Type: Fibre channel
Number of ports: 4
Board ID: 0801
Replacement part number: Not Available
Part number: PN L2-25023-02
Serial number: SN SF84300041
Vendor: VN LSI
Date of manufacture: November 1, 2008
Date/Time: Tue Jan 27 15:19:38 EST 2009
Ethernet port: 1
Link status: Up
MAC address: 00:a0:b8:29:ed:8a
Negotiation mode: Auto-negotiate
Port speed: 10 Mbps
Duplex mode: Half duplex
IPv4 settings: Enabled
Network configuration: Static
IP address: 192.168.70.70
Subnet mask: 255.255.255.0
Gateway: 0.0.0.0
IPv6 settings: Enabled
Auto-configuration: Stateless
Local IP address: FE80:0000:0000:0000:02A0:B8FF:FE29:ED8A
Ethernet port: 2
Link status: Failed
MAC address: 00:a0:b8:29:ed:8b
Negotiation mode: Auto-negotiate
Port speed: Unknown
Duplex mode: Half duplex
IPv4 settings: Enabled
Network configuration: Static
IP address: 192.168.129.101
Subnet mask: 255.255.255.0
Gateway: 0.0.0.0
IPv6 settings: Enabled
Auto-configuration: Static
Local IP address: FE80:0000:0000:0000:0000:0000:0000:0000
10-6 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Channel: 1
Current ID: Not applicable/0xFFFFFFFF
Preferred ID: 125/0x1
NL-Port ID: 0x010200
Maximum data rate: 8 Gbps
Current data rate: 4 Gbps
Data rate control: Auto
Link status: Up
Topology: Fabric Attach
World-wide port identifier: 20:1e:00:a0:b8:29:ed:8a
World-wide node identifier: 20:0e:00:a0:b8:29:ed:8a
Part type: PM8032 revision 5
Status: Online
Current configuration
Firmware version: 07.50.00.00
Appware version: 07.50.00.00
Bootware version: 07.50.00.00
NVSRAM version: N1818D53R1050V03
Pending configuration
Firmware version: None
Appware version: None
Bootware version: None
NVSRAM version: None
Transferred on: None
Current ID (ALPA)
On drive channel 1: 124/0x2
Replacement part number: Not Available
Model name: 7000-88
Board ID: 7091
Submodel ID: 93
Product ID: 1818
10-8 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Revision: 0730
Replacement part number:
Part number: 32847-10
Serial number: SF74600024
Vendor: IBM
Date of manufacture: January 23, 2008
Data Cache
Total present: 8192 MB
Total used: 8192 MB
Data Cache Module
Status: Optimal
Location: Controller B, Slot 9
Capacity: 1,024 MB
Replacement Part number: Not Available
Manufacturer Part Number: M3 93T2953EZ3-CD5
Part Number: Not Available
Serial number: 1127652678
Manufacturer: Samsung
Date of manufacture: December 31, 2007
Data Cache Module
Status: Optimal
Location: Controller B, Slot 10
Capacity: 1,024 MB
Replacement Part number: Not Available
Manufacturer Part Number: M3 93T2953CZ3-CD5
Part Number: Not Available
Serial number: 4076997590
Manufacturer: Samsung
Date of manufacture: January 29, 2007
Data Cache Module
Status: Optimal
Location: Controller B, Slot 11
Capacity: 1,024 MB
Replacement Part number: Not Available
Manufacturer Part Number: M3 93T2953CZ3-CD5
Part Number: Not Available
Serial number: 4076997577
Manufacturer: Samsung
Date of manufacture: January 29, 2007
Data Cache Module
Status: Optimal
Location: Controller B, Slot 12
Capacity: 1,024 MB
Replacement Part number: Not Available
Manufacturer Part Number: M3 93T2953CZ3-CD5
Part Number: Not Available
Serial number: 4076997790
Manufacturer: Samsung
Date of manufacture: January 29, 2007
Data Cache Module
Status: Optimal
Location: Controller B, Slot 13
Capacity: 1,024 MB
Replacement Part number: Not Available
Manufacturer Part Number: M3 93T2953CZ3-CD5
Part Number: Not Available
Serial number: 4076997641
Manufacturer: Samsung
Date of manufacture: January 29, 2007
Data Cache Module
Status: Optimal
Location: Controller B, Slot 14
Capacity: 1,024 MB
Replacement Part number: Not Available
Manufacturer Part Number: M3 93T2953CZ3-CD5
Part Number: Not Available
Serial number: 4110514102
10-10 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Status: Optimal
Location: Slot 4
Type: Fibre channel
Number of ports: 4
Board ID: 0801
Replacement part number: Not Available
Part number: PN L2-25023-02
Serial number: SN SF84300014
Vendor: VN LSI
Date of manufacture: November 1, 2008
Date/Time: Tue Jan 27 15:19:47 EST 2009
Ethernet port: 1
Link status: Up
MAC address: 00:a0:b8:29:ec:e6
Negotiation mode: Auto-negotiate
Port speed: 10 Mbps
Duplex mode: Half duplex
IPv4 settings: Enabled
Network configuration: Static
IP address: 192.168.70.71
Subnet mask: 255.255.255.0
Gateway: 0.0.0.0
IPv6 settings: Enabled
Auto-configuration: Stateless
Local IP address: FE80:0000:0000:0000:02A0:B8FF:FE29:ECE6
Ethernet port: 2
Link status: Failed
MAC address: 00:a0:b8:29:ec:e7
Negotiation mode: Auto-negotiate
Port speed: Unknown
Duplex mode: Half duplex
IPv4 settings: Enabled
Network configuration: Static
IP address: 192.168.129.102
Subnet mask: 255.255.255.0
Gateway: 0.0.0.0
IPv6 settings: Enabled
Auto-configuration: Stateless
Local IP address: FE80:0000:0000:0000:02A0:B8FF:FE29:ECE7
10-12 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
World-wide port identifier: 20:1f:00:a0:b8:29:ed:8a
World-wide node identifier: 20:0e:00:a0:b8:29:ed:8a
Part type: PM8032 revision 5
ARRAYS------------------------------
Number of arrays: 5
Name: 1
Status: Optimal
Capacity 1.064 TB
RAID level: 6
10-14 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Enclosure Slot
2 3
2 4
2 5
2 6
2 7
2 12
4 2
4 4
4 7
4 8
Name: FC_R3
Status: Optimal
Capacity 836.688 GB
RAID level: 3
Security Capable: No
Secure: No
Enclosure Slot
4 9
4 12
4 14
4 16
Name: FDE_R6
Status: Optimal
Capacity 817.381 GB
RAID level: 6
Enclosure Slot
2 1
2 2
2 13
2 15
2 16
4 5
4 6
4 3
Name: Sata_Raid6
Status: Optimal
Capacity 2.727 TB
RAID level: 6
Security Capable: No
Secure: No
Enclosure Slot
2 8
2 9
2 10
2 11
4 1
4 13
10-16 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Name: Secure_R1
Status: Optimal
Capacity 278.897 GB
RAID level: 1
Enclosure Slot
4 15 [mirrored pair with drive at enclosure 4, slot 10]
4 10 [mirrored pair with drive at enclosure 4, slot 15]
SUMMARY
DETAILS
Capacity: 400.0 GB
Logical Drive ID: 60:0a:0b:80:00:29:ed:8a:00:00:cd:50:49:41:11:ff
Subsystem ID (SSID): 6
Associated array: FC_R3
RAID level: 3
Capacity: 278.0 GB
Logical Drive ID: 60:0a:0b:80:00:33:98:48:00:00:c9:73:49:41:0a:a1
Subsystem ID (SSID): 8
Associated array: Secure_R1
RAID level: 1
Secure: Yes
10-18 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Logical Drive status: Optimal
Capacity: 410.0 GB
Logical Drive ID: 60:0a:0b:80:00:29:ec:e6:00:00:df:13:49:41:13:4f
Subsystem ID (SSID): 5
Associated array: FDE_R6
RAID level: 6
Secure: Yes
Capacity: 1,000.0 GB
Logical Drive ID: 60:0a:0b:80:00:29:ed:8a:00:00:cc:90:49:3f:f7:b5
Subsystem ID (SSID): 0
Associated array: Sata_Raid6
RAID level: 6
Secure: No
Capacity: 1,000.0 GB
Logical Drive ID: 60:0a:0b:80:00:29:ec:e6:00:00:dd:b1:49:3f:f9:87
Subsystem ID (SSID): 1
Associated array: Sata_Raid6
RAID level: 6
Secure: No
Capacity: 510.0 GB
Logical Drive ID: 60:0a:0b:80:00:29:ec:e6:00:00:de:a0:49:40:e6:2d
Subsystem ID (SSID): 3
Associated array: 1
RAID level: 6
Secure: Yes
10-20 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Read cache: Enabled
Write cache: Enabled
Write cache without batteries: Disabled
Write cache with mirroring: Enabled
Flush write cache after (in seconds): 10.00
Dynamic cache read prefetch: Enabled
DRIVES------------------------------
SUMMARY
Number of drives: 32
Current drive types: Fibre (5), Fibre/FDE (21), Serial ATA (SATA) (6)
BASIC:
DRIVE CHANNELS:
10-22 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
4, 16 4 7
Standby: 2
In use: 0
DETAILS
Drive at Enclosure 2, Slot 1
Status: Optimal
Mode: Assigned
Raw capacity: 136.732 GB
Usable capacity: 136.232 GB
World-wide identifier: 20:00:00:1d:38:1d:1d:73:00:00:00:00:00:00:00:00
Associated array: FDE_R6
Port Channel ID
0 3 0/0xEF
1 8 0/0xEF
Status: Optimal
Mode: Assigned
Raw capacity: 136.732 GB
Usable capacity: 136.232 GB
World-wide identifier: 20:00:00:1d:38:1d:1d:e1:00:00:00:00:00:00:00:00
Associated array: FDE_R6
Port Channel ID
0 8 1/0xE8
1 3 1/0xE8
Status: Optimal
Mode: Assigned
Raw capacity: 136.732 GB
Usable capacity: 136.232 GB
World-wide identifier: 20:00:00:1d:38:1d:1d:7c:00:00:00:00:00:00:00:00
Associated array: 1
Port Channel ID
0 3 2/0xE4
1 8 2/0xE4
Status: Optimal
Mode: Assigned
Raw capacity: 136.732 GB
Usable capacity: 136.232 GB
World-wide identifier: 20:00:00:1d:38:1d:1d:5c:00:00:00:00:00:00:00:00
Associated array: 1
Port Channel ID
0 8 5/0xE0
1 3 5/0xE0
10-24 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Vendor: IBM-SSG
Date of manufacture: October 16, 2008
Status: Optimal
Mode: Assigned
Raw capacity: 279.397 GB
Usable capacity: 278.897 GB
World-wide identifier: 20:00:00:1d:38:1b:16:1d:00:00:00:00:00:00:00:00
Associated array: 1
Port Channel ID
0 3 6/0xDC
1 8 6/0xDC
Status: Optimal
Mode: Assigned
Raw capacity: 698.638 GB
Usable capacity: 698.138 GB
World-wide identifier: 20:00:00:a0:b8:41:47:0e:00:00:00:00:00:00:00:00
Associated array: Sata_Raid6
Port Channel ID
0 8 7/0xT10PI
1 3 7/0xT10PI
Security Capable: No
Secure: No
Read/write accessible: Yes
Security key identifier: Not Applicable
ATA Translator
Product ID: BR-2401-3.0
Vendor: SLI
Status: Optimal
Mode: Assigned
Raw capacity: 698.638 GB
Usable capacity: 698.138 GB
World-wide identifier: 20:00:00:a0:b8:41:27:26:00:00:00:00:00:00:00:00
Associated array: Sata_Raid6
Port Channel ID
0 3 8/0xD9
1 8 8/0xD9
Security Capable: No
Secure: No
Read/write accessible: Yes
Security key identifier: Not Applicable
ATA Translator
Product ID: BR-2401-3.0
Vendor: SLI
Firmware Version: LP1158
Location: Individual Drive Canister
Status: Optimal
Mode: Assigned
Raw capacity: 136.732 GB
Usable capacity: 136.232 GB
World-wide identifier: 20:00:00:1d:38:1d:1e:18:00:00:00:00:00:00:00:00
Associated array: 1
Port Channel ID
0 4 7/0xT10PI
1 7 7/0xT10PI
10-26 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Serial number: 3QN080DY00009903RDMQ
Vendor: IBM-SSG
Date of manufacture: October 16, 2008
Status: Optimal
Mode: Assigned
Raw capacity: 279.397 GB
Usable capacity: 278.897 GB
World-wide identifier: 50:00:cc:a0:08:02:58:0c:00:00:00:00:00:00:00:00
Associated array: FC_R3
Port Channel ID
0 7 8/0xD9
1 4 8/0xD9
Security Capable: No
Secure: No
Read/write accessible: Yes
Security key identifier: Not Applicable
DRIVE CHANNELS----------------------------
SUMMARY
DETAILS
DRIVE CHANNEL 1
Port: 8, 7
Status: Optimal
Max. Rate: 4 Gbps
Current Rate: 2 Gbps
Rate Control: Auto
Controller A link status: Up
Controller B link status: Up
DRIVE COUNTS
Controller A
Controller B
DRIVE CHANNEL 2
Port: 6, 5
Status: Optimal
Max. Rate: 4 Gbps
Current Rate: 4 Gbps
Rate Control: Auto
Controller A link status: Up
Controller B link status: Up
DRIVE COUNTS
Controller A
Controller B
DRIVE CHANNEL 3
Port: 4, 3, Out
Status: Optimal
Max. Rate: 4 Gbps
Current Rate: 4 Gbps
Rate Control: Auto
Controller A link status: Up
10-28 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Controller B link status: Up
DRIVE COUNTS
Controller A
Controller B
DRIVE CHANNEL 4
Port: 2, 1, Out
Status: Optimal
Max. Rate: 4 Gbps
Current Rate: 4 Gbps
Rate Control: Auto
Controller A link status: Up
Controller B link status: Up
DRIVE COUNTS
Controller A
Controller B
DRIVE CHANNEL 5
Port: 1, 2
Status: Optimal
Max. Rate: 4 Gbps
Current Rate: 2 Gbps
Rate Control: Auto
Controller A link status: Up
Controller B link status: Up
DRIVE COUNTS
Controller A
Controller B
DRIVE CHANNEL 6
Port: 3, 4
Status: Optimal
Max. Rate: 4 Gbps
Current Rate: 4 Gbps
Rate Control: Auto
Controller A link status: Up
Controller B link status: Up
DRIVE COUNTS
Controller A
10-30 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Total I/O count: 330848
Controller B
DRIVE CHANNEL 7
Port: 5, 6, Out
Status: Optimal
Max. Rate: 4 Gbps
Current Rate: 4 Gbps
Rate Control: Auto
Controller A link status: Up
Controller B link status: Up
DRIVE COUNTS
Controller A
Controller B
DRIVE CHANNEL 8
Port: 7, 8, Out
Status: Optimal
Max. Rate: 4 Gbps
Current Rate: 4 Gbps
Rate Control: Auto
Controller A link status: Up
Controller B link status: Up
DRIVE COUNTS
Controller A
Controller B
ENCLOSURES------------------------------
Drive Enclosure 2 Overall Component Information
10-32 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Product ID: EXP5000
Part number: PN 39M5570
Serial number: SN 1T54721521
Vendor: IBM
Date of manufacture: December 1, 2005
SFPs Detected: 2
Fans Detected: 2
10-34 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Serial number: SN 1T53023041
Vendor: VN ENGENIO
SFPs Detected: 2
Fans Detected: 2
10-36 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Temperature sensor status: Optimal
Location: ESM Canister A (left)
Batteries Detected: 2
SFPs Detected: 8
10-38 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
SFP status: Optimal
Attached to: Host-side of controller A
Location: Channel 1
Supported data rate(s): 1 Gbps, 2 Gbps, 4 Gbps
Link length: Intermediate
Connector: LC
Transmitter type: Shortwave Laser w/o OFC
Transmission media: TM Multi-mode 62.5m(M6)
IEEE company ID: 00 17 6a
Revision: Not Available
Part number: AFBR-57R5AQZ
Serial number: A2065050D5
Vendor: AVAGO
Date of manufacture: December 14, 2006
Fans Detected: 4
TOPOLOGY DEFINITIONS
STORAGE SUBSYSTEM
Default type: Windows 2000/Server 2003/Server 2008
Non-Clustered
Default Group
Host: Right
Host type: Windows 2000/Server 2003/Server 2008
Non-Clustered
Host port identifier: 21:00:00:e0:8b:95:c7:1e
Alias: QLogic_1
Host type: Windows 2000/Server 2003/Server 2008
Non-Clustered
Host port identifier: 21:01:00:e0:8b:b5:c7:1e
Alias: QLogic_2
Host type: Windows 2000/Server 2003/Server 2008
Non-Clustered
Host port identifier: 10:00:00:05:1e:56:67:98
Alias: Brocade1
Host: Left
Host type: Windows 2000/Server 2003/Server 2008
Non-Clustered
Host port identifier: 21:00:00:e0:8b:83:fd:cc
Alias: Qlogic1
Host type: Windows 2000/Server 2003/Server 2008
Non-Clustered
Host port identifier: 21:01:00:e0:8b:a3:fd:cc
Alias: Qlogic2
10-40 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
HOST TYPE ADT STATUS
ASSOCIATED INDEX
AIX Disabled 6
AIX-ADT/AVT Enabled 4
DEFAULT Disabled 0
HP-UX Enabled 7
HPXTPGS Disabled 17
Irix Disabled 10
LNXCLVMWARE Disabled 13
Linux Enabled 5
Mac OS X Enabled 1
Attention: Incorrectly setting the NVSRAM can severely affect the performance and the availability of
the subsystems. You should only modify the NVSRAM settings according to the latest information
documented for your configuration in DS4000 publications, readmes, or by your IBM support
representative.
Controller "a":
Region 226:
0000: 4942 4d20 2020 2020 3138 3138 2020 2020 IBM.....1818....
0010: 2020 2020 2020 2020 3037 3330 0000 0000 ........0730....
0020: 0000 0000 0000 0000 0000 0000 0000 0000 ................
0030: 0000 0008 5600 0000 0000 0000 0000 0000 ....V...........
Region 232:
0000: 0000 0000 0000 0000 0000 0000 0000 0000 ................
0010: 5500 0000 0000 0000 0000 0000 0000 0000 U...............
Region 233:
Region 234:
0000: 1020 3040 5060 0000 0000 0000 0000 0000 ..0.P...........
0010: 1121 3141 5161 0000 0000 0000 0000 0000 ..1AQa..........
0020: 1222 3242 5262 0000 0000 0000 0000 0000 ..2BRb..........
0030: 1323 3343 5363 0000 0000 0000 0000 0000 ..3CSc..........
0040: 1424 3444 5464 0000 0000 0000 0000 0000 ..4DTd..........
0050: 0000 0000 0000 0000 0000 0000 0000 0000 ................
0060: 0000 0000 0000 0000 0000 0000 0000 0000 ................
0070: 0000 0000 0000 0000 0000 0000 0000 0000 ................
Region 236:
0000: 0000 0000 0000 0000 0000 0000 0000 0000 ................
0010: 0000 0000 0000 0000 0000 0000 0000 0000 ................
0020: 0000 0000 0000 0000 0000 0000 0000 0000 ................
0030: 0000 0000 0000 0000 0000 0000 0000 0000 ................
0040: 0000 0000 0000 0000 0000 0000 0000 0000 ................
0050: 0000 0000 0000 0000 0000 0000 0000 0000 ................
0060: 0000 0000 0000 0000 0000 0000 0000 0000 ................
0070: 0000 0000 0000 0000 0000 0000 0000 0000 ................
Region 237:
0000: 0000 0000 0000 0000 007d 0000 0000 0000 ................
0010: 0000 0000 007d 0d0e 0f00 0000 0000 0000 ................
Region 238:
0000: 0000 ca32 0000 0000 0050 0600 0000 0000 ...2.....P......
0010: 0000 0000 0000 0000 f001 0000 8480 0000 ................
0020: 0000 0000 0000 0000 cc8c 008a 0029 fe00 ................
0030: 80be 9f45 7300 2000 0f00 1400 0000 0000 ...Es...........
Region 240:
0000: 0c12 4453 3530 3030 5f41 7f7f 7f7f 7f33 ..DS5000.A.....3
0010: 3030 5f41 ab04 c0a8 8032 0104 ffff ff00 00.......2......
0020: fc01 83b5 04c0 a846 32bf 04ff ffff 00fd .......F2.......
0030: 0183 a005 726f 6269 6eac 04c0 a801 0103 .....robin......
0040: 04c0 a846 01fb 0180 a109 616e 6f6e 796d ...F......anonym
0050: 6f75 73a2 0870 6173 7377 6f72 64ff 0000 ous..password...
0060: 0000 0000 0000 0000 0000 0000 0000 0000 ................
0070: 0000 0000 0000 0000 0000 0000 0000 0000 ................
0080: 0000 0000 0000 0000 0000 0000 0000 0000 ................
0090: 0000 0000 0000 0000 0000 0000 0000 0000 ................
00a0: 0000 0000 0000 0000 0000 0000 0000 0000 ................
00b0: 0000 0000 0000 0000 0000 0000 0000 0000 ................
00c0: 0000 0000 0000 0000 0000 0000 0000 0000 ................
00d0: 0000 0000 0000 0000 0000 0000 0000 0000 ................
00e0: 0000 0000 0000 0000 0000 0000 0000 0000 ................
00f0: 0000 0000 0000 0000 0000 0000 0000 0000 ................
Region 241:
0000: 0000 ca32 0000 0000 0050 0600 0000 0000 ...2.....P......
0010: 0000 0000 0000 0000 f001 0000 8480 0000 ................
0020: 0000 0000 0000 0000 cc8c 008a 0029 fe00 ................
0030: 80be 9f45 7300 2000 0f00 1400 0000 0000 ...Es...........
0040: 4465 6661 756c 7400 0000 0000 0000 0000 Default.........
0050: 0000 0000 0000 0000 0000 0000 0000 0000 ................
0060: 0000 0000 0000 0000 0000 0000 0000 0000 ................
0070: 0000 0000 0000 0000 0000 0000 0000 0000 ................
0080: 0000 0000 0000 0000 0000 0000 0000 0000 ................
0090: 0000 0000 0000 0000 0000 0000 0000 0000 ................
10-42 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Region 242:
0000: 4445 4641 554c 5400 0000 0000 0000 0000 DEFAULT.........
0010: 0020 0000 0100 0001 0000 0000 0000 0000 ................
0020: 0001 0100 0000 0008 0100 0000 0000 0000 ................
0030: 0000 0000 0000 0000 0000 0000 0000 0000 ................
Region 242:
0000: 4d61 6320 4f53 2058 0000 0000 0000 0000 Mac.OS.X........
0010: 017f 0000 0100 0001 0001 0000 0000 0000 ................
0020: 0000 0100 0100 0008 0100 0000 0000 0000 ................
0030: 0000 0000 0000 0000 0000 0000 0000 0000 ................
Region 242:
0000: 5732 4b4e 4554 4e43 4c00 0000 0000 0000 W2KNETNCL.......
0010: 0020 0000 0100 0001 0000 0000 0000 0000 ................
0020: 0001 0100 0000 0008 0100 0000 0000 0000 ................
0030: 0000 0000 0000 0000 0000 0000 0000 0000 ................
Region 242:
0000: 5732 4b4e 4554 434c 0000 0000 0000 0000 W2KNETCL........
0010: 0020 0000 0100 0001 0001 0001 0000 0000 ................
0020: 0001 0100 0000 0008 0100 0000 0000 0000 ................
0030: 0000 0000 0000 0000 0000 0000 0000 0000 ................
Region 242:
0000: 4149 582d 4144 542f 4156 5400 0000 0000 AIX.ADT.AVT.....
0010: 0100 0000 0100 0001 0100 0000 0001 0000 ................
0020: 0000 0100 0100 0008 0100 0000 0000 0000 ................
0030: 0000 0000 0000 0000 0000 0000 0000 0000 ................
Region 242:
0000: 4c4e 5800 0000 0000 0000 0000 0000 0000 LNX.............
0010: 017f 0000 0100 0001 0001 0000 0000 0000 ................
0020: 0000 0100 0100 0008 0100 0000 0000 0000 ................
0030: 0000 0000 0000 0000 0000 0000 0000 0000 ................
Region 242:
0000: 4149 5800 0000 0000 0000 0000 0000 0000 AIX.............
0010: 0100 0000 0100 0001 0100 0000 0001 0000 ................
0020: 0000 0100 0000 0008 0100 0000 0000 0000 ................
0030: 0000 0000 0000 0000 0000 0000 0000 0000 ................
Region 242:
0000: 4850 5800 0000 0000 0000 0000 0000 0000 HPX.............
0010: 017f 0000 0100 0001 0101 0001 0101 0001 ................
0020: 0100 0000 0100 001c 0100 0000 0000 0000 ................
0030: 0000 0000 0000 0000 0000 0000 0000 0000 ................
Region 242:
0000: 534f 4c00 0000 0000 0000 0000 0000 0000 SOL.............
0010: 0120 0000 0100 0001 0001 0000 0000 0000 ................
0020: 0000 0000 0000 0008 0100 0000 0000 0000 ................
0030: 0000 0000 0000 0000 0000 0000 0000 0000 ................
Region 242:
0000: 5732 4b4e 4554 4e43 4c44 4d50 0000 0000 W2KNETNCLDMP....
0010: 0020 0000 0100 0001 0000 0100 0000 0000 ................
0020: 0000 0100 0180 0008 0100 0000 0000 0000 ................
0030: 0000 0000 0000 0000 0000 0000 0000 0000 ................
Region 242:
0000: 4952 5800 0000 0000 0000 0000 0000 0000 IRX.............
0010: 007f 0000 0100 2001 0000 0000 0000 0000 ................
0020: 0000 0100 0000 0008 0100 0000 0000 0000 ................
0030: 0000 0000 0000 0000 0000 0000 0000 0000 ................
Region 242:
Region 242:
0000: 4942 4d20 5453 2053 414e 2056 4345 0000 IBM.TS.SAN.VCE..
0010: 0000 0000 0100 0000 0000 0001 0000 0000 ................
0020: 0000 0100 0100 0008 0100 0000 0000 0000 ................
0030: 0000 0000 0000 0000 0000 0000 0000 0000 ................
Region 242:
0000: 4c4e 5843 4c56 4d57 4152 4500 0000 0000 LNXCLVMWARE.....
0010: 017f 0000 0100 0001 0001 0001 0000 0000 ................
0020: 0000 0100 0000 0008 0100 0000 0000 0000 ................
0030: 0000 0000 0000 0000 0000 0000 0000 0000 ................
Region 242:
0000: 534f 4c41 5654 0000 0000 0000 0000 0000 SOLAVT..........
0010: 0120 0000 0100 0001 0001 0100 0000 0000 ................
0020: 0000 0001 0180 0000 0100 0000 0000 0000 ................
0030: 0000 0000 0000 0000 0000 0000 0000 0000 ................
Region 242:
0000: 5732 4b4e 4554 434c 444d 5000 0000 0000 W2KNETCLDMP.....
0010: 0020 0000 0100 0001 0001 0101 0000 0000 ................
0020: 0000 0101 0180 0008 0100 0000 0000 0000 ................
0030: 0000 0000 0000 0000 0000 0000 0000 0000 ................
Region 242:
0000: 0075 6e6e 616d 6564 2031 3600 0000 0000 .unnamed.16.....
0010: 0000 0000 0000 0000 0000 0000 0000 0000 ................
0020: 0000 0000 0000 0000 0000 0000 0000 0000 ................
0030: 0000 0000 0000 0000 0000 0000 0000 0000 ................
Region 242:
0000: 4850 5854 5047 5300 0000 0000 0000 0000 HPXTPGS.........
0010: 017f 0000 0100 0001 0101 0001 0101 0000 ................
0020: 0001 0000 0000 0008 0200 0000 0000 0000 ................
0030: 0000 0000 0000 0000 0000 0000 0000 0000 ................
Region 242:
0000: 0075 6e6e 616d 6564 2031 3800 0000 0000 .unnamed.18.....
0010: 0000 0000 0000 0000 0000 0000 0000 0000 ................
0020: 0000 0000 0000 0000 0000 0000 0000 0000 ................
0030: 0000 0000 0000 0000 0000 0000 0000 0000 ................
Region 242:
0000: 0075 6e6e 616d 6564 2031 3900 0000 0000 .unnamed.19.....
0010: 0000 0000 0000 0000 0000 0000 0000 0000 ................
0020: 0000 0000 0000 0000 0000 0000 0000 0000 ................
0030: 0000 0000 0000 0000 0000 0000 0000 0000 ................
Region 242:
0000: 0075 6e6e 616d 6564 2032 3000 0000 0000 .unnamed.20.....
0010: 0000 0000 0000 0000 0000 0000 0000 0000 ................
0020: 0000 0000 0000 0000 0000 0000 0000 0000 ................
0030: 0000 0000 0000 0000 0000 0000 0000 0000 ................
Region 242:
0000: 0075 6e6e 616d 6564 2032 3100 0000 0000 .unnamed.21.....
0010: 0000 0000 0000 0000 0000 0000 0000 0000 ................
0020: 0000 0000 0000 0000 0000 0000 0000 0000 ................
0030: 0000 0000 0000 0000 0000 0000 0000 0000 ................
Region 242:
0000: 0075 6e6e 616d 6564 2032 3200 0000 0000 .unnamed.22.....
10-44 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
0010: 0000 0000 0000 0000 0000 0000 0000 0000 ................
0020: 0000 0000 0000 0000 0000 0000 0000 0000 ................
0030: 0000 0000 0000 0000 0000 0000 0000 0000 ................
Region 242:
0000: 0075 6e6e 616d 6564 2032 3300 0000 0000 .unnamed.23.....
0010: 0000 0000 0000 0000 0000 0000 0000 0000 ................
0020: 0000 0000 0000 0000 0000 0000 0000 0000 ................
0030: 0000 0000 0000 0000 0000 0000 0000 0000 ................
Region 242:
0000: 0075 6e6e 616d 6564 2032 3400 0000 0000 .unnamed.24.....
0010: 0000 0000 0000 0000 0000 0000 0000 0000 ................
0020: 0000 0000 0000 0000 0000 0000 0000 0000 ................
0030: 0000 0000 0000 0000 0000 0000 0000 0000 ................
Region 242:
0000: 0075 6e6e 616d 6564 2032 3500 0000 0000 .unnamed.25.....
0010: 0000 0000 0000 0000 0000 0000 0000 0000 ................
0020: 0000 0000 0000 0000 0000 0000 0000 0000 ................
0030: 0000 0000 0000 0000 0000 0000 0000 0000 ................
Region 242:
0000: 0075 6e6e 616d 6564 2032 3600 0000 0000 .unnamed.26.....
0010: 0000 0000 0000 0000 0000 0000 0000 0000 ................
0020: 0000 0000 0000 0000 0000 0000 0000 0000 ................
0030: 0000 0000 0000 0000 0000 0000 0000 0000 ................
Region 242:
0000: 0075 6e6e 616d 6564 2032 3700 0000 0000 .unnamed.27.....
0010: 0000 0000 0000 0000 0000 0000 0000 0000 ................
0020: 0000 0000 0000 0000 0000 0000 0000 0000 ................
0030: 0000 0000 0000 0000 0000 0000 0000 0000 ................
Region 242:
0000: 0075 6e6e 616d 6564 2032 3800 0000 0000 .unnamed.28.....
0010: 0000 0000 0000 0000 0000 0000 0000 0000 ................
0020: 0000 0000 0000 0000 0000 0000 0000 0000 ................
0030: 0000 0000 0000 0000 0000 0000 0000 0000 ................
Region 242:
0000: 0075 6e6e 616d 6564 2032 3900 0000 0000 .unnamed.29.....
0010: 0000 0000 0000 0000 0000 0000 0000 0000 ................
0020: 0000 0000 0000 0000 0000 0000 0000 0000 ................
0030: 0000 0000 0000 0000 0000 0000 0000 0000 ................
Region 242:
0000: 0075 6e6e 616d 6564 2033 3000 0000 0000 .unnamed.30.....
0010: 0000 0000 0000 0000 0000 0000 0000 0000 ................
0020: 0000 0000 0000 0000 0000 0000 0000 0000 ................
0030: 0000 0000 0000 0000 0000 0000 0000 0000 ................
Region 242:
0000: 0075 6e6e 616d 6564 2033 3100 0000 0000 .unnamed.31.....
0010: 0000 0000 0000 0000 0000 0000 0000 0000 ................
0020: 0000 0000 0000 0000 0000 0000 0000 0000 ................
0030: 0000 0000 0000 0000 0000 0000 0000 0000 ................
Show Drive
The show drive command returns information about the disk drives in a storage subsystem.
DRIVES------------------------------
SUMMARY
Number of drives: 32
BASIC:
10-46 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
JG01
7, 16 Optimal 279.397 GB Fibre 4 Gbps HUS1545300FC
JG01
DRIVE CHANNELS:
Standby: 5
In use: 0
DETAILS
Drive at Enclosure 5, Slot 1
Mode: Assigned
Raw capacity: 419.187 GB
Usable capacity: 418.687 GB
World-wide identifier: 50:00:cc:a0:08:02:93:00:00:00:00:00:00:00:00:00
Associated array: Mix_R5
Port Channel ID
0 5 0/0xEF
1 3 0/0xEF
Security Capable: No
Secure: No
Read/write accessible: Yes
Security key identifier: Not Applicable
Status: Optimal
Mode: Assigned
Raw capacity: 136.732 GB
Usable capacity: 136.232 GB
World-wide identifier: 20:00:00:1d:38:1d:1d:74:00:00:00:00:00:00:00:00
Associated array: FDE_R0
Port Channel ID
0 3 1/0xE8
1 5 1/0xE8
Status: Optimal
Mode: Assigned
Raw capacity: 698.638 GB
Usable capacity: 698.138 GB
10-48 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
World-wide identifier: 20:00:00:a0:b8:41:20:c8:00:00:00:00:00:00:00:00
Associated array: Sata_R1
Port Channel ID
0 5 8/0xD9
1 3 8/0xD9
Security Capable: No
Secure: No
Read/write accessible: Yes
Security key identifier: Not Applicable
ATA Translator
Product ID: BR-2401-3.0
Vendor: SLI
Firmware Version: LP1158
Location: Individual Drive Canister
SUMMARY
DETAILS
DRIVE CHANNEL 1
Port: 8, 7
Status: Optimal
Max. Rate: 4 Gbps
Current Rate: 4 Gbps
Rate Control: Auto
Controller A link status: Up
Controller B link status: Up
DRIVE COUNTS
Controller A
Controller B
DRIVE CHANNEL 2
Port: 6, 5
Status: Optimal
Max. Rate: 4 Gbps
Current Rate: 4 Gbps
Rate Control: Auto
Controller A link status: Up
Controller B link status: Up
DRIVE COUNTS
Controller A
Controller B
DRIVE CHANNEL 3
Port: 4, 3, Out
Status: Optimal
Max. Rate: 4 Gbps
Current Rate: 4 Gbps
10-50 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Rate Control: Auto
Controller A link status: Up
Controller B link status: Up
DRIVE COUNTS
Controller A
Controller B
DRIVE CHANNEL 4
Port: 2, 1, Out
Status: Optimal
Max. Rate: 4 Gbps
Current Rate: 4 Gbps
Rate Control: Auto
Controller A link status: Up
Controller B link status: Up
DRIVE COUNTS
Controller A
Controller B
DRIVE CHANNEL 5
Port: 1, 2, Out
Status: Optimal
Max. Rate: 4 Gbps
Current Rate: 4 Gbps
Rate Control: Auto
Controller A link status: Up
Controller B link status: Up
DRIVE COUNTS
Controller A
Controller B
DRIVE CHANNEL 6
Port: 3, 4, Out
Status: Optimal
Max. Rate: 4 Gbps
Current Rate: 4 Gbps
Rate Control: Auto
Controller A link status: Up
Controller B link status: Up
DRIVE COUNTS
10-52 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Controller A
Controller B
DRIVE CHANNEL 7
Port: 5, 6
Status: Optimal
Max. Rate: 4 Gbps
Current Rate: 4 Gbps
Rate Control: Auto
Controller A link status: Up
Controller B link status: Up
DRIVE COUNTS
Controller A
Controller B
DRIVE CHANNEL 8
Port: 7, 8
Status: Optimal
Max. Rate: 4 Gbps
Current Rate: 4 Gbps
Rate Control: Auto
Controller A link status: Up
Controller B link status: Up
Controller A
Controller B
SUMMARY
DETAILS
10-54 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Capacity: 500.0 GB
Logical Drive ID: 60:0a:0b:80:00:29:ee:02:00:00:c8:64:49:41:0a:7a
Subsystem ID (SSID): 6
Associated array: FC_R3
RAID level: 3
Secure: No
Capacity: 550.0 GB
Logical Drive ID: 60:0a:0b:80:00:33:98:48:00:00:c9:76:49:41:0c:4c
Subsystem ID (SSID): 7
Associated array: FC_R3
RAID level: 3
Secure: No
Capacity: 440.0 GB
Logical Drive ID: 60:0a:0b:80:00:29:ee:02:00:00:c8:5b:49:41:06:db
Subsystem ID (SSID): 2
Associated array: FDE_R6
RAID level: 6
Secure: Yes
Capacity: 500.0 GB
Logical Drive ID: 60:0a:0b:80:00:33:98:48:00:00:c9:70:49:41:09:a6
Subsystem ID (SSID): 3
Associated array: Mix_R5
RAID level: 5
Secure: No
10-56 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Read cache: Enabled
Write cache: Enabled
Write cache without batteries: Disabled
Write cache with mirroring: Enabled
Flush write cache after (in seconds): 10.00
Dynamic cache read prefetch: Enabled
Capacity: 520.0 GB
Logical Drive ID: 60:0a:0b:80:00:29:ee:02:00:00:c8:5e:49:41:09:04
Subsystem ID (SSID): 4
Associated array: Mix_R5
RAID level: 5
Secure: No
Capacity: 500.0 GB
Logical Drive ID: 60:0a:0b:80:00:29:ee:02:00:00:c8:53:49:40:03:e2
Subsystem ID (SSID): 0
Associated array: Sata_R1
RAID level: 1
Secure: No
Capacity: 190.0 GB
Logical Drive ID: 60:0a:0b:80:00:33:98:48:00:00:c9:93:49:42:37:1f
Subsystem ID (SSID): 8
Associated array: Sata_R1
RAID level: 1
Secure: No
10-58 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Number of flashcopy logical drives: 0
By using the save storageSubsystem configuration command, you can create a file that you can use to
copy an existing configuration from one storage subsystem to other storage subsystems. You can also use
this file to restore an existing configuration that has become corrupted. You also can copy an existing file
to serve as a pattern from which you create a new script file by modifying portions of the original file.
The default file extension is .scr.
You can create a new script file by using a text editor, such as Microsoft Notepad. The maximum line
length is 256 characters. The command syntax must conform to the usage guidelines that are described in
Chapter 2, About the Script Commands, on page 2-1 and the command formatting rules that are listed
in Formatting Rules for Script Commands on page 3-2. When you create a new script file, you can use
any file name and extension that will run on the host operating system.
This example shows how to run a script file from the command line.
c:\...\...\client>smcli 123.45.67.89 -f scriptfile.scr;
This example shows blank lines between the lines beginning with Show, Create, //Note, and create. The
blank lines are included in this example only for clarity. Each command is actually written on one line in
the script file; however, the size of this page has caused the command text to wrap. You might want to
include blank lines in your script files to separate blocks of commands or make a comment that stands
out. To include a comment, enter two forward slashes (//), which causes the script engine to treat the line
as a comment.
The line beginning with //Create is a comment that explains that the purpose of this script file is to
create a new logical drive by using the create logicalDrive command on an existing array.
The line beginning //Note: is a comment in the script file that explains that the size of the last logical
drive created that uses all of the available capacity because the capacity parameter is not used.
The command in this example creates a new logical drive in array 1. The logical drive has a RAID level
of 5. The logical drive name (user label) is 7. (Note the double quotation marks around the 7. The double
quotation marks define that the information in the double quotation marks is a label.) The new logical
drive is assigned to the controller in slot A in the controller module. The segment size is set to 16. The
logical drive has a read ahead multiplier value of 256. The capacity of the logical drive is 2 GB.
The general form of the command shows the optional parameters in a different sequence than the
optional parameters in the example command. You can enter optional parameters in any sequence. You
must enter the required parameters in the sequence shown in the command descriptions.
The line showing Setting additional attributes for logical drive 7 is another example of using
the show string command. The reason for placing this command here is to tell the user that the create
logicalDrive command ran successfully and that properties that could not be set by the create
logicalDrive command are now set.
The set logicalDrive parameters are shown on separate lines. You do not need to use separate lines for
each parameter. You can enter more than one parameter with the set logicalDrive command by leaving
a space between the parameters, as in this example:
set logicalDrive[7] cacheFlushModifier=10 cacheWithoutBatteryEnabled=false
modificationPriority=high;
By using separate lines, you can see more clearly the parameters that you are setting and the values to
which you are setting the parameters. Blocking the parameters in this manner makes it easier to either
edit the file or copy specific parameter settings for use in another script file.
11-2 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
show Setting additional attributes for logical drive 7//Configuration settings
that cannot be set during logical drive creation
set logicalDrive [7] cacheFlushModifier=10;
set logicalDrive [7] cacheWithoutBatteryEnabled=false;
set logicalDrive [7] mirrorEnabled=true;
set logicalDrive [7] readCacheEnabled=true;
set logicalDrive [7] writeCacheEnabled=true;
set logicalDrive [7] mediaScanEnabled=false;
set logicalDrive [7] redundantCheckEnabled=false;
set logicalDrive [7] modificationPriority=high;
The command in this example, like the create logicalDrive command in the previous example, creates a
new logical drive. The significant difference between these two examples is that this example shows how
you can define specific disk drives to include in the logical drive. Use the show storageSubsystem
profile command to find out what disk drives are available in a storage subsystem.
Deprecated Commands
Table 12-1. Deprecated Commands
Deprecated Command New Command
Removed.
accept storageSubsystem pendingTopology
(allHosts | host [user-label] | hosts
[user-label])
The requirement to set the host type has
create hostPort been removed. The hostType parameter is
used with the create host command.
12-2 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Table 12-1. Deprecated Commands (continued)
Deprecated Command New Command
show storageSubsystem
preferredLogicalDriveOwners show storageSubsystem profile
12-4 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Table 12-1. Deprecated Commands (continued)
Deprecated Command New Command
capacity=logicalDriveCapacity capacity=logicalDriveCapacity
raidLevel=(0 | 1 | 3 | 5) userLabel= owner=(a | b)
logicalDriveName owner=(a | b) cacheReadPrefetch=(TRUE | FALSE)
usageHint=usageHintSpec segmentSize= segmentSize=segmentSizeValue
segmentSizeValue readAheadMultiplier=
multiplierValue In the create RAID logicalDrive
commands, the new commands use fewer
optional attributevalue pairs.
12-6 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Table 12-1. Deprecated Commands (continued)
Deprecated Command New Command
12-8 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Table 12-1. Deprecated Commands (continued)
Deprecated Command New Command
Deprecated Parameters
Table 12-2. Deprecated Parameters
Old Syntax New Syntax
array Removed (partly)
availability Removed from the set array command.
bootp Removed.
clearEventLog clear storageSubsystem eventLog
copyEntry VolumeCopy
database Removed
disableFlashcopy stop flashcopy
disableFlashcopy stop flashcopy
Drive-channel identifier Removed
enforceSoftLimit Removed
featureKey feature
filesystem Removed
gatewayIPAddress IPv4GatewayIP
hostType Removed from the create host port
command and the set host port
command.
id[] logicalDrive<>
increaseVolCapacity set logicalDrive addCapacity
incrementalCapacity addCapacity
ipAddress IPv4Address or IPv6Address
logicalDriveLabel Removed
logicalDriveReservations show LogicalDrive reservations or
reservations
mapping lunMapping
modePage Removed
multimedia Removed
on error set session errorAction
performanceMonitor interval performanceMonitorInterval
performanceMonitor iterations performanceMonitorIterations
priority copyPriority
-r The -r terminal made a distinction
between inband storage management
and out-of-bandstorage management.
the -r terminal is no longer required.
12-10 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Appendix. Additional Documentation
The following tables present an overview of the IBM System Storage DS Storage Manager, storage
subsystem, and storage expansion enclosure product libraries, and other related documents. Each table
lists documents that are included in the libraries and what common tasks they address.
The following table lists the DS3000 storage subsystem documents and the common user tasks addressed
by each document.
The following table lists the DS4000 storage subsystem documents and the common user tasks addressed
by each document.
The following table lists the DS3000, DS4000, and DS5000 storage expansion enclosure documents and the
common user tasks addressed by each document.
The following table lists other DS3000 and DS4000-related documents and the common user tasks
addressed by each document.
A-2 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Title User Tasks
Planning Hardware Software Configuration Operation and Diagnosis and
Installation Installation Administration Maintenance
IBM TotalStorage
Hardware
U
Maintenance Manual
The following table lists the DS5100 and DS5300 storage subsystem documents and the common user
tasks addressed by each document.
A-4 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Notices
This information was developed for products and services offered in the U.S.A.
IBM may not offer the products, services, or features discussed in this document in other countries.
Consult your local IBM representative for information on the products and services currently available in
your area. Any reference to an IBM product, program, or service is not intended to state or imply that
only that IBM product, program, or service may be used. Any functionally equivalent product, program,
or service that does not infringe any IBM intellectual property right may be used instead. However, it is
the user's responsibility to evaluate and verify the operation of any non-IBM product, program, or
service.
IBM may have patents or pending patent applications covering subject matter described in this
document. The furnishing of this document does not grant you any license to these patents. You can send
license inquiries, in writing, to:
For license inquiries regarding double-byte (DBCS) information, contact the IBM Intellectual Property
Department in your country or send inquiries, in writing, to:
The following paragraph does not apply to the United Kingdom or any other country where such
provisions are inconsistent with local law: INTERNATIONAL BUSINESS MACHINES CORPORATION
PROVIDES THIS PUBLICATIONS "AS IS" WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESS
OR IMPLIED, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
NON-INFRINGEMENT, MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE. Some
states do not allow disclaimer of express or implied warranties in certain transactions, therefore, this
statement may not apply to you.
This information could include technical inaccuracies or typographical errors. Changes are periodically
made to the information herein; these changes will be incorporated in new editions of the publications.
IBM may make improvements or changes (or both) in the product(s) or program(s) (or both), described in
this publication at any time without notice.
Any references in this information to non-IBM websites are provided for convenience only and do not in
any manner serve as an endorsement of those websites. The materials at those websites are not part of
the materials for this IBM product and use of those websites is at your own risk.
Information concerning non-IBM products was obtained from the suppliers of those products, their
published announcements or other publicly available sources. IBM has not tested those products and
cannot confirm the accuracy of performance, compatibility or any other claims related to non-IBM
products. Questions on the capabilities of non-IBM products should be addressed to the suppliers of
those products.
Some software may differ from its retail version (if available), and may not include user manuals or all
program functionality.
Trademarks
IBM, the IBM logo, and ibm.com are trademarks or registered trademarks of International Business
Machines Corporation in the United States, other countries, or both. If these and other IBM trademarked
terms are marked on their first occurrence in this information with a trademark symbol ( or ), these
symbols indicate U.S. registered or common law trademarks owned by IBM at the time this information
was published. Such trademarks may also be registered or common law trademarks in other countries. A
current list of IBM trademarks is available on the Web at Copyright and trademark information at
http://www.ibm.com/legal/copytrade.shtml.
Adobe and PostScript are either registered trademarks or trademarks of Adobe Systems Incorporated in
the United States and/or other countries.
Cell Broadband Engine is a trademark of Sony Computer Entertainment, Inc., in the United States, other
countries, or both and is used under license therefrom.
Intel, Intel Xeon, Itanium, and Pentium are trademarks or registered trademarks of Intel Corporation or
its subsidiaries in the United States and other countries.
Java and all Java-based trademarks are trademarks of Sun Microsystems, Inc., in the United States, other
countries, or both.
Linux is a registered trademark of Linus Torvalds in the United States, other countries, or both.
Microsoft, Windows, and Windows NT are trademarks of Microsoft Corporation in the United States,
other countries, or both.
UNIX is a registered trademark of The Open Group in the United States and other countries.
Other company, product, or service names may be trademarks or service marks of others.
Important notes
Processor speed indicates the internal clock speed of the microprocessor; other factors also affect
application performance.
CD or DVD drive speed is the variable read rate. Actual speeds vary and are often less than the possible
maximum.
When referring to processor storage, real and virtual storage, or channel volume, KB stands for 1024
bytes, MB stands for 1 048 576 bytes, and GB stands for 1 073 741 824 bytes.
When referring to hard disk drive capacity or communications volume, MB stands for 1 000 000 bytes,
and GB stands for 1 000 000 000 bytes. Total user-accessible capacity can vary depending on operating
environments.
Maximum internal hard disk drive capacities assume the replacement of any standard hard disk drives
and population of all hard disk drive bays with the largest currently supported drives that are available
from IBM.
B-2 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Maximum memory might require replacement of the standard memory with an optional memory
module.
IBM makes no representation or warranties regarding non-IBM products and services that are
ServerProven, including but not limited to the implied warranties of merchantability and fitness for a
particular purpose. These products are offered and warranted solely by third parties.
IBM makes no representations or warranties with respect to non-IBM products. Support (if any) for the
non-IBM products is provided by the third party, not IBM.
Some software might differ from its retail version (if available) and might not include user manuals or all
program functionality.
Documentation format
The publications for this product are in Adobe Portable Document Format (PDF) and should be
compliant with accessibility standards. If you experience difficulties when you use the PDF files and want
to request a Web-based format or accessible PDF document for a publication, direct your mail to the
following address:
Information Development
IBM Corporation
205/A015
3039 E. Cornwallis Road
P.O. Box 12195
Research Triangle Park, North Carolina 27709-2195
U.S.A.
In the request, be sure to include the publication part number and title.
When you send information to IBM, you grant IBM a nonexclusive right to use or distribute the
information in any way it believes appropriate without incurring any obligation to you.
Notices B-3
B-4 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Index
A Display Support Bundle Collection
Schedule 3-117
Resume Consistency Group Enhanced
FlashCopy Logical Drive 3-144
Activate Host Port 3-38 documentation Resume Enhanced FlashCopy Image
Activate iSCSI Initiator 3-38 websites xvii Rollback 3-145
Add Member to Consistency documentation, Storage Subsystem, Resume Enhanced FlashCopy Logical
Group 3-39 Storage Subsystem library A-1 Drive 3-146
address drivers xvii Resume FlashCopy Rollback 3-147
of the IBM director of licensing B-1 DS3000 software/firmware support xv Revive Enhanced FlashCopy
AIX host DS4000 software/firmware support xv Group 3-149
support xviii DS5000 software/firmware support xv Revive Enhanced FlashCopy Logical
Drive 3-149
C E
Clear Storage Subsystem Diagnostic Data Enable Disk Pool Security 3-123 S
Capture 3-48 Save Storage Subsystem Diagnostic Data
Clear Storage Subsystem Recovery Capture 3-155
Mode 3-50
Configure Automatic Support Bundle F Schedule Support Bundle Collection
Configuration 3-159
Collection 3-50 fire suppression xix
services offered in the U.S.A. B-1
Convert FlashCopy Logical Drive to Set Consistency Group Attributes 3-163
Enhanced FlashCopy Group 3-50 Set Consistency Group Enhanced
Create Consistency Group 3-54 H FlashCopy Logical Drive 3-164
Create Consistency Group Enhanced hardware service and support xviii Set Disk Pool 3-168
FlashCopy Image 3-58 Set Disk Pool (Modify Disk Pool) 3-170
Create Consistency Group Enhanced Set Enhanced FlashCopy Group
FlashCopy Logical Drive 3-59
Create Consistency Group Enhanced I Attributes 3-177
Set Enhanced FlashCopy Group Media
FlashCopy Logical Drive IBM
Scan 3-178
Mapping 3-57, 3-61 director of licensing address B-1
Set Enhanced FlashCopy Group
Create Disk Pool 3-61 Increase Logical Drive Capacity on a Disk
Repository Logical Drive
Create Enhanced FlashCopy Group 3-66 Pool 3-126
Capacity 3-183
Create Enhanced FlashCopy Image 3-72 Initialize Thin Logical Drive 3-127
Set Enhanced FlashCopy Group
Create Enhanced FlashCopy Logical Intel and AMD-based host
Schedule 3-179
Drive 3-72 support xviii
Set Enhanced FlashCopy Logical Drive
Create Logical Drive on Disk Pool 3-93 Media Scan 3-182
Create Read-Only Enhanced FlashCopy Set Enhanced FlashCopy Logical Drive
Logical Drive 3-95 L Repository Logical Drive
Linux host Capacity 3-182
support xviii Set Logical Drive Attributes 3-195
D Set Logical Drive Attributes for a Disk
Delete Consistency Group 3-102 Pool 3-200
Delete Consistency Group Enhanced N Set Logical Drive Mapping 3-204
Set Read Only Enhanced FlashCopy
FlashCopy Image 3-103 notes, important B-2
Delete Consistency Group Enhanced Logical Drive to a Read/Write Logical
notices
FlashCopy Logical Drive 3-103 Drive 3-205
general B-1
Delete Disk Pool 3-104 Set Thin Logical Drive Attributes 3-216
Delete Enhanced FlashCopy Show Consistency Group Enhanced
Group 3-105 FlashCopy Image 3-221
Delete Enhanced FlashCopy P Show Disk Pool 3-225
Image 3-106 products, developed B-1 Show Enhanced FlashCopy Group 3-228
Delete Enhanced FlashCopy Logical Show Enhanced FlashCopy Image 3-230
Drive 3-107 Show Enhanced FlashCopy Logical
Delete FlashCopy Logical Drive 3-108 R Drives 3-231
Show Storage Subsystem DBM
Delete Logical Drive on a Disk Remove Member Logical Drive from
Pool 3-111 Database 3-242
Consistency Group 3-138
device drivers Show Storage Subsystem Diagnostic Data
Rename Enhanced FlashCopy Logical
downloading latest versions xvii Capture 3-242
Drive 3-139
Disable FlashCopy 3-115 Show Storage Subsystem Features 3-243
resources
Display Automatic Support Bundle Show Storage Subsystem Profile 3-243
websites xvii
Collection Configuration 3-117 Show Thin Logical Drive 3-245
T
trademarks B-2
W
Web sites
AIX xviii
SAN support xviii
websites
Fix central xviii
IBM publications center xviii
IBM System Storage product
information xviii
interoperability matrix xviii
list xvii
premium feature activation xvii
SSIC xvii
switch support xviii
System p xviii
System x xviii
X-2 IBM System Storage DS3000, DS4000, and DS5000: Command Line Interface and Script Commands Programming Guide
Printed in USA
GA32-0961-03