Netezza System Admin Guide
Netezza System Admin Guide
Netezza System Admin Guide
Document Number: 20282-14 Rev. 1 Software Release: 6.0.x Revised: October 14, 2010
Netezza Corporation Corporate Headquarters 26 Forest St., Marlborough, Massachusetts 01752 tel 508.382.8200 fax 508.382.8300 www.netezza.com
The specifications and information regarding the products described in this manual are subject to change without notice. All statements, information, and recommendations in this manual are believed to be accurate. Netezza makes no representations or warranties of any kind, express or implied, including, without limitation, those of merchantability, fitness for a particular purpose, and non infringement, regarding this manual or the products' use or performance. In no event will Netezza be liable for indirect, incidental, consequential, special, or economic damages (including lost business profits, business interruption, loss or damage of data, and the like) arising out of the use or inability to use this manual or the products, regardless of the form of action, whether in contract, tort (including negligence), breach of warranty, or otherwise, even if Netezza has been advised of the possibility of such damages. Netezza, the Netezza logo, the circle-N logo, TwinFin, Skimmer, Snippet Blades, S-Blades, NPS, Snippet, Snippet Processing Unit, SPU, Snippet Processing Array, SPA, Performance Server, Netezza Performance Server, Asymmetric Massively Parallel Processing, AMPP, Intelligent Query Streaming and other marks are trademarks or registered trademarks of Netezza Corporation in the United States and/or other countries. All rights reserved. Red Hat is a trademark or registered trademark of Red Hat, Inc. in the United States and/or other countries. Linux is a trademark or registered trademark of Linus Torvalds in the United States and/or other countries. D-CC, D-C++, Diab+, FastJ, pSOS+, SingleStep, Tornado, VxWorks, Wind River, and the Wind River logo are trademarks, registered trademarks, or service marks of Wind River Systems, Inc. Tornado patent pending. APC and the APC logo are trademarks or registered trademarks of American Power Conversion Corporation. All document files and software of the above named third-party suppliers are provided "as is" and may contain deficiencies. Netezza and its suppliers disclaim all warranties of any kind, express or implied, including, without limitation, those of merchantability, fitness for a particular purpose, and non infringement. In no event will Netezza or its suppliers be liable for indirect, incidental, consequential, special, or economic damages (including lost business profits, business interruption, loss or damage of data, and the like), or the use or inability to use the above-named third-party products, even if Netezza or its suppliers have been advised of the possibility of such damages. All other trademarks mentioned in this document are the property of their respective owners. Document Number: 20282-14 Software Release Number: 6.0.x Netezza System Administrators Guide Copyright 2001-2010 Netezza Corporation. All rights reserved. PostgreSQL Portions of this publication were derived from PostgreSQL documentation. For those portions of the documentation that were derived originally from PostgreSQL documentation, and only for those portions, the following applies: PostgreSQL is copyright 1996-2001 by the PostgreSQL global development group and is distributed under the terms of the license of the University of California below. Postgres95 is copyright 1994-5 by the Regents of the University of California. Permission to use, copy, modify, and distribute this documentation for any purpose, without fee, and without a written agreement is hereby granted, provided that the above copyright notice and this paragraph and the following two paragraphs appear in all copies. In no event shall the University of California be liable to any party for direct, indirect, special, incidental, or consequential damages, including lost profits, arising out of the use of this documentation, even if the University of California has been advised of the possibility of such damage. The University of California specifically disclaims any warranties, including, but not limited to, the implied warranties of merchantability and fitness for a particular purpose. The documentation provided hereunder is on an "as-is" basis, and the University of California has no obligations to provide maintenance, support, updates, enhancements, or modifications. ICU Library The Netezza implementation of the ICU library is an adaptation of an open source library Copyright (c) 1995-2003 International Business Machines Corporation and others. ICU License - ICU 1.8.1 and later COPYRIGHT AND PERMISSION NOTICE Copyright (c) 1995-2003 International Business Machines Corporation and others All rights reserved. Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, provided that the above copyright notice(s) and this permission notice appear in all copies of the Software and that both the above copyright notice(s) and this permission notice appear in supporting documentation. THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT OF THIRD PARTY RIGHTS. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR HOLDERS INCLUDED IN THIS NOTICE BE LIABLE FOR ANY CLAIM, OR ANY SPECIAL INDIRECT OR CONSEQUENTIAL DAMAGES, OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. Except as contained in this notice, the name of a copyright holder shall not be used in advertising or otherwise to promote the sale, use or other dealings in this Software without prior written authorization of the copyright holder. ODBC Driver The Netezza implementation of the ODBC driver is an adaptation of an open source driver, Copyright 2000, 2001, Great Bridge LLC. The source code for this driver and the object code of any Netezza software that links with it are available upon request to [email protected]
Botan License Copyright (C) 1999-2008 Jack Lloyd 2001 Peter J Jones 2004-2007 Justin Karneges 2005 Matthew Gregan 2005-2006 Matt Johnston 2006 Luca Piccarreta 2007 Yves Jerschow 2007-2008 FlexSecure GmbH 2007-2008 Technische Universitat Darmstadt 2007-2008 Falko Strenzke 2007-2008 Martin Doering 2007 Manuel Hartl 2007 Christoph Ludwig 2007 Patrick Sona All rights reserved. Redistribution and use in source and binary forms, for any use, with or without modification, of Botan (http://botan.randombit.net/license.html) is permitted provided that the following conditions are met: 1. Redistributions of source code must retain the above copyright notice, this list of conditions, and the following disclaimer. 2. Redistributions in binary form must reproduce the above copyright notice, this list of conditions, and the following disclaimer in the documentation and/ or other materials provided with the distribution. THIS SOFTWARE IS PROVIDED BY THE AUTHOR(S) "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE, ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR(S) OR CONTRIBUTOR(S) BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITYOF SUCH DAMAGE. Regulatory Notices Install the NPS system in a restricted-access location. Ensure that only those trained to operate or service the equipment have physical access to it. Install each AC power outlet near the NPS rack that plugs into it, and keep it freely accessible. Provide approved 30A circuit breakers on all power sources. Product may be powered by redundant power sources. Disconnect ALL power sources before servicing. High leakage current. Earth connection essential before connecting supply. Courant de fuite lev. Raccordement la terre indispensable avant le raccordement au rseau. FCC - Industry Canada Statement This equipment has been tested and found to comply with the limits for a Class A digital device, pursuant to part 15 of the FCC rules. These limits are designed to provide reasonable protection against harmful interference when the equipment is operated in a commercial environment. This equipment generates, uses, and can radiate radio-frequency energy and, if not installed and used in accordance with the instruction manual, may cause harmful interference to radio communications. Operation of this equipment in a residential area is likely to cause harmful interference, in which case users will be required to correct the interference at their own expense. This Class A digital apparatus meets all requirements of the Canadian Interference-Causing Equipment Regulations. Cet appareil numrique de la classe A respecte toutes les exigences du Rglement sur le matriel brouilleur du Canada. WEEE Netezza Corporation is committed to meeting the requirements of the European Union (EU) Waste Electrical and Electronic Equipment (WEEE) Directive. This Directive requires producers of electrical and electronic equipment to finance the takeback, for reuse or recycling, of their products placed on the EU market after August 13, 2005. CE Statement (Europe) This product complies with the European Low Voltage Directive 73/23/EEC and EMC Directive 89/336/EEC as amended by European Directive 93/68/EEC. Warning: This is a class A product. In a domestic environment this product may cause radio interference in which case the user may be required to take adequate measures. VCCI Statement
VCCI A
Contents
Preface 1 Administration Overview
Administrators Roles . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1-1 Administration Tasks . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1-1 Initial System Setup and Information . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1-2 Netezza Software Directories . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1-3 Managing the External Network Connections . . . . . . . . . . . . . . . . . . . . . . . . . . . 1-5 Managing Domain Name Service (DNS) Updates . . . . . . . . . . . . . . . . . . . . . . . . 1-5 Setting up Remote Access . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1-7 Administration Interfaces . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1-7 Other Netezza Documentation. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1-8
vi
Identifying the Active and Standby Nodes . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4-5 Monitoring the Cluster and Resource Group Status . . . . . . . . . . . . . . . . . . . . . . . 4-6 nps Resource Group. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4-7 Failover Criteria . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4-8 Relocate to the Standby Node. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4-9 Safe Manual Control of the Hosts (And Heartbeat) . . . . . . . . . . . . . . . . . . . . . . . 4-9 Transition to Maintenance (Non-Heartbeat) Mode . . . . . . . . . . . . . . . . . . . . . . . 4-10 Transitioning from Maintenance to Clustering Mode . . . . . . . . . . . . . . . . . . . . . 4-11 Cluster Manager Events . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4-12 Logging and Messages . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4-13 DRBD Administration. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4-13 Monitoring DRBD Status . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4-14 Sample DRBD Status Output . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4-15 Split-Brain . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4-15 Administration Reference and Troubleshooting . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4-16 IP Address Requirements . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4-17 Forcing Heartbeat to Shutdown . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4-17 Shutting Down Heartbeat on Both Nodes without Causing Relocate . . . . . . . . . . 4-17 Restarting Heartbeat after Maintenance Network Issues . . . . . . . . . . . . . . . . . . 4-17 Resolving Configuration Problems . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4-18 Fixed a Problem, but crm_mon Still Shows Failed Items . . . . . . . . . . . . . . . . . . 4-18 Output From crm_mon Does Not Show the nps Resource Group . . . . . . . . . . . . . 4-18 Linux Users and Groups Required for HA . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4-19 Checking for User Sessions and Activity. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4-19
vii
Displaying Hardware Issues . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 5-10 Managing Hosts. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 5-11 Managing SPUs. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 5-11 Managing Disks . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 5-13 Managing Data Slices . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 5-15 Displaying Data Slice Issues . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 5-16 Monitor Data Slice Status. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 5-16 Regenerate a Data Slice . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 5-17 Rebalance Data Slices . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 5-18 Mirroring Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 5-19 Handling Transactions during Failover and Regeneration . . . . . . . . . . . . . . . . . . 5-20 Automatic Query and Load Continuation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 5-21 Power Procedures . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 5-22 TwinFin PDU and Circuit Breakers Overview. . . . . . . . . . . . . . . . . . . . . . . . . . . 5-22 Powering On the Netezza TwinFin System . . . . . . . . . . . . . . . . . . . . . . . . . . . . 5-23 Powering Off the Netezza TwinFin System . . . . . . . . . . . . . . . . . . . . . . . . . . . . 5-24
viii
Client Manager . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 6-13 Database Operating System . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 6-13 Event Manager . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 6-14 Flow Communications Retransmit . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 6-14 Flow Communications Receive . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 6-15 Host Statistics Generator . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 6-15 Load Manager . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 6-15 Postgres . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 6-16 Session Manager . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 6-16 SPU Cores Manager . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 6-16 Startup Server . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 6-16 Statistics Server . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 6-17 System Manager . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 6-17 The nzDbosSpill File . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 6-17 System Configuration . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 6-17 Display Configuration Information . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 6-18 Changing the System Registry. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 6-18
ix
Specifying Disk Space Threshold Notification. . . . . . . . . . . . . . . . . . . . . . . . . . 7-22 Specifying Runaway Query Notification . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7-24 Monitoring the System State. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7-25 Monitoring for Disk Predictive Failure Errors. . . . . . . . . . . . . . . . . . . . . . . . . . . 7-25 Monitoring for ECC Errors . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7-26 Monitoring Regeneration Errors . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7-27 Monitoring Disk Errors . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7-28 Monitoring Hardware Temperature. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7-29 Monitoring System Temperature . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7-30 Query History Events . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7-31 Monitoring SPU Cores . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7-34 Monitoring Voltage Faults . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7-35 Event Types Reference. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7-36 Transaction Limits Event . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7-36 FPGA QDR Failure Event . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7-36 Network Interface State Change Event . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7-36 S-Blade CPU Core Events . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7-37 Displaying Alerts . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7-37
Privileges by Object . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 8-13 Indirect Object Privileges . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 8-15 Always Available Functions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 8-16 Creating an Administrative User Group . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 8-16 Logon Authentication . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 8-17 Local Authentication . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 8-17 LDAP Authentication . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 8-17 Commands Related to Authentication Methods. . . . . . . . . . . . . . . . . . . . . . . . . 8-19 Passwords and Logons . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 8-20 Netezza Client Encryption and Security . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 8-21 Configuring the SSL Certificate . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 8-21 Configuring the Netezza Host Authentication for Clients . . . . . . . . . . . . . . . . . . 8-22 Commands Related to Netezza Client Connection Methods . . . . . . . . . . . . . . . . 8-25 Setting User and Group Limits . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 8-25 Specifying User Rowset Limits . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 8-27 Specifying Query Timeout Limits. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 8-27 Specifying Session Timeout . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 8-28 Specifying Session Priority . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 8-28 Logging Netezza SQL Information . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 8-29 Logging Netezza SQL Information on the Server . . . . . . . . . . . . . . . . . . . . . . . . 8-29 Logging Netezza SQL Information on the Client . . . . . . . . . . . . . . . . . . . . . . . . 8-29 Group Public Views . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 8-29
xi
Avoiding Data Skew . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 9-9 Specifying Distribution Keys . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 9-10 Viewing Data Skew . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 9-10 Using Clustered Base Tables . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 9-11 Organizing Keys and Zone Maps . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 9-13 Selecting Organizing Keys . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 9-13 Reorganizing the Table Data . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 9-14 Updating Database Statistics . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 9-14 Maintaining Table Statistics Automatically. . . . . . . . . . . . . . . . . . . . . . . . . . . . 9-16 Running the GENERATE STATISTICS Command . . . . . . . . . . . . . . . . . . . . . . . 9-16 Just in Time Statistics . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 9-17 Zone Maps . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 9-18 Grooming Tables . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 9-19 GROOM and the nzreclaim Command . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 9-19 Groom and Backup Synchronization . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 9-20 Managing Sessions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 9-21 Using the nzsession Command . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 9-21 Running Transactions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 9-22 Transaction Control and Monitoring . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 9-22 Transactions Per System . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 9-23 Transaction Concurrency and Isolation. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 9-23 Concurrent Transaction Serialization and Queueing, Implicit Transactions. . . . . . 9-24 Concurrent Transaction Serialization and Queueing, Explicit Transactions . . . . . . 9-24 Netezza Optimizer and Query Plans. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 9-25 Execution Plans . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 9-26 Displaying Plan Types . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 9-26 Analyzing Query Performance . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 9-27 Viewing Query Status and History . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 9-27
xii
Compressed Unload and Reload . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 10-5 Filesystem Connector for Backup and Recovery . . . . . . . . . . . . . . . . . . . . . . . . 10-6 Third-Party Backup and Recovery Solutions Support . . . . . . . . . . . . . . . . . . . . . 10-7 Host Backup and Restore . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 10-7 Using the nzhostbackup command . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 10-8 Using the nzhostrestore command. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 10-8 Using the nzbackup Command . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 10-10 The nzbackup Command Syntax . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 10-10 Specifying Backup Privileges . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 10-13 nzbackup Examples . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 10-14 Backup Archive Directory . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 10-16 Incremental Backups . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 10-16 Backup History Report . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 10-18 Backing Up and Restoring Users, Groups, and Permissions . . . . . . . . . . . . . . . 10-19 Using the nzrestore Command . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 10-21 The nzrestore Command Syntax . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 10-22 Specifying Restore Privileges . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 10-25 nzrestore Examples . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 10-26 Maintaining Database Statistics . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 10-27 Restoring Tables . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 10-27 Understanding Incremental Restoration . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 10-28 Using the Veritas NetBackup Connector. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 10-31 Installing the Veritas NetBackup License . . . . . . . . . . . . . . . . . . . . . . . . . . . . 10-31 Configuring NetBackup for a Netezza Client . . . . . . . . . . . . . . . . . . . . . . . . . . 10-32 Integrating Veritas NetBackup to Netezza . . . . . . . . . . . . . . . . . . . . . . . . . . . 10-33 Procedures for Backing Up and Restoring Using Veritas NetBackup . . . . . . . . . 10-38 Using the IBM Tivoli Storage Manager Connector . . . . . . . . . . . . . . . . . . . . . . . . . 10-40 About the Tivoli Backup Integration. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 10-41 Configuring the Netezza Host . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 10-41 Configuring the Tivoli Storage Manager Server . . . . . . . . . . . . . . . . . . . . . . . . 10-45 Special Considerations for Large Databases . . . . . . . . . . . . . . . . . . . . . . . . . . 10-51 Running nzbackup and nzrestore with the TSM Connector . . . . . . . . . . . . . . . . 10-53 Host Backup and Restore to the TSM Server . . . . . . . . . . . . . . . . . . . . . . . . . 10-53 Backing up and Restoring Data Using the TSM Interfaces . . . . . . . . . . . . . . . . 10-54 Troubleshooting. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 10-56
xiii
xiv
$hist_state_change_$SCHEMA_VERSION . . . . . . . . . . . . . . . . . . . . . . . . . . . 11-31 $hist_table_access_$SCHEMA_VERSION . . . . . . . . . . . . . . . . . . . . . . . . . . . 11-32 $hist_column_access_$SCHEMA_VERSION. . . . . . . . . . . . . . . . . . . . . . . . . . 11-33 $hist_plan_prolog_$SCHEMA_VERSION . . . . . . . . . . . . . . . . . . . . . . . . . . . . 11-34 $hist_plan_epilog_$SCHEMA_VERSION . . . . . . . . . . . . . . . . . . . . . . . . . . . . 11-36 History Table Helper Functions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 11-36 FORMAT_QUERY_STATUS () . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 11-37 FORMAT_PLAN_STATUS () . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 11-37 FORMAT_TABLE_ACCESS() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 11-37 FORMAT_COLUMN_ACCESS() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 11-38 Example Usage . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 11-38
xv
Host CPU Table. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 13-3 Host File System Table . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 13-4 Host Interface Table . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 13-4 Host Management Channel Table . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 13-6 Host Network Table . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 13-7 Host Table . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 13-8 Hardware Management Channel Table . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 13-9 Per Table Per Data Slice Table . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 13-10 Query Table . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 13-10 Query History Table . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 13-11 SPU Partition Table . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 13-12 SPU Table . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 13-13 System Group . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 13-13 Table Table. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 13-14 Displaying System Statistics . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 13-15 The nzstats Command . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 13-15 To display table types and fields . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 13-15 To display a specific table . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 13-15
xvi
Configuring the MantraVM Monitoring Interfaces . . . . . . . . . . . . . . . . . . . . . . . 14-7 Displaying the MantraVM Monitoring Interfaces . . . . . . . . . . . . . . . . . . . . . . . . 14-8 Accessing the Mantra Web Interface . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 14-8 Troubleshooting. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 14-9 Double-Byte Character Support . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 14-9 Event Throttling. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 14-9 /nz Partition is Full . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 14-9 Mantra Inactivity Timeout. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 14-10
xvii
Inputs . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . A-18 Description . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . A-18 Usage. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . A-19 nzhistcreatedb . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . A-19 Syntax . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . A-19 Inputs . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . A-19 Outputs . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . A-20 Description . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . A-21 Usage. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . A-21 nzhostbackup . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . A-21 Syntax . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . A-22 Inputs . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . A-22 Description . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . A-22 Usage. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . A-23 nzhostrestore . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . A-23 Syntax . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . A-24 Inputs . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . A-24 Options . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . A-24 Description . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . A-25 Usage. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . A-25 nzhw . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . A-25 Syntax . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . A-26 Inputs . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . A-26 Options . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . A-29 Description . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . A-29 Usage. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . A-30 nzload . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . A-31 nzpassword . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . A-31 Syntax . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . A-31 Inputs . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . A-32 Options . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . A-32 Description . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . A-33 Usage. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . A-33 nzreclaim . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . A-34 Syntax . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . A-34 Inputs . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . A-34 Options . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . A-34
xviii
Description . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . A-35 Usage. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . A-35 nzrestore . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . A-36 nzrev . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . A-36 Syntax . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . A-36 Inputs . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . A-36 Description . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . A-36 Usage. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . A-37 nzsession . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . A-37 Syntax . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . A-37 Inputs . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . A-37 Options. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . A-39 Description . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . A-40 Usage. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . A-42 nzstart . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . A-42 Syntax . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . A-43 Inputs . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . A-43 Description . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . A-43 Usage. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . A-44 nzstate . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . A-44 Syntax . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . A-44 Inputs . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . A-44 Options. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . A-45 Description . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . A-45 Usage. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . A-46 nzstats . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . A-46 Syntax . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . A-46 Inputs . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . A-46 Options. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . A-47 Description . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . A-48 Usage. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . A-49 nzstop . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . A-49 Syntax Description. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . A-49 Inputs . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . A-50 Options. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . A-50 Description . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . A-50 Usage. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . A-50
xix
nzsystem . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . A-51 Syntax . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . A-51 Inputs . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . A-51 Options . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . A-52 Description . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . A-52 Usage. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . A-53 Customer Service Troubleshooting Commands . . . . . . . . . . . . . . . . . . . . . . . . . . . . A-54 nzconvertsyscase . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . A-55 nzdumpschema . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . A-57 nzinitsystem . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . A-58 Syntax . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . A-58 nzlogmerge . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . A-59 Syntax . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . A-59
xx
xxi
xxii
Tables
Table 2-1: Table 2-2: Table 2-3: Table 2-4: Table 2-5: Table 3-1: Table 3-2: Table 3-3: Table 3-4: Table 3-5: Table 3-6: Table 3-7: Table 4-1: Table 4-2: Table 4-3: Table 5-1: Table 5-2: Table 5-3: Table 5-4: Table 5-5: Table 5-6: Table 6-1: Table 6-2: Table 6-3: Table 6-4: Table 6-5: Table 7-1: Table 7-2: Table 7-3: Table 7-4: Table 7-5: Table 7-6: Table 7-7: Supported Netezza CLI Client Operating Systems . . . . . . . . . . . . . . . 2-2 Sample UNIX CD Mount Commands . . . . . . . . . . . . . . . . . . . . . . . . 2-3 Environment Variables . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2-5 Directory Structure. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2-10 Netezza Port Numbers for Database Access . . . . . . . . . . . . . . . . . . 2-13 Command Line Summary . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3-2 CLI Command Locations. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3-4 nzsql Command Options . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3-7 nzsql Internal Slash Commands . . . . . . . . . . . . . . . . . . . . . . . . . . 3-10 Color Indicators . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3-13 Main Menu Commands. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3-14 Automatic Refresh . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3-17 HA Tasks and Commands (Old Design and New Design) . . . . . . . . . . 4-2 Cluster Management Scripts . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4-5 HA IP Addresses . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4-17 Key Netezza Hardware Components to Monitor . . . . . . . . . . . . . . . . . 5-1 Hardware Description Types . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 5-3 Hardware Roles . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 5-5 Hardware States . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 5-7 Data Slice Status . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 5-17 System States and Transactions . . . . . . . . . . . . . . . . . . . . . . . . . . 5-20 Netezza Software Revision Numbering . . . . . . . . . . . . . . . . . . . . . . . 6-2 Common System States . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 6-3 System States Reference . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 6-4 Netezza Processes . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 6-8 Error Categories . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 6-11 Template Event Rules . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7-2 Netezza Template Event Rules . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7-3 Event Types. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7-8 Event Argument Expression Syntax . . . . . . . . . . . . . . . . . . . . . . . . 7-13 Notification Substitution Tags . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7-14 Notification Syntax. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7-15 System State Changes . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7-19
xxiii
Table 7-8: Table 7-9: Table 7-10: Table 7-11: Table 7-12: Table 7-13: Table 7-14: Table 7-15: Table 7-16: Table 7-17: Table 7-18: Table 7-19: Table 7-20: Table 7-21: Table 7-22: Table 7-23: Table 8-1: Table 8-2: Table 8-3: Table 8-4: Table 8-5: Table 8-6: Table 8-7: Table 8-8: Table 8-9: Table 8-10: Table 9-1: Table 9-2: Table 9-3: Table 9-4: Table 9-5: Table 9-6: Table 9-7: Table 9-8: Table 9-9: Table 10-1: Table 10-2:
Hardware Service Requested Event Rule . . . . . . . . . . . . . . . . . . . . 7-20 Hardware Restarted Event Rule . . . . . . . . . . . . . . . . . . . . . . . . . . . 7-21 Disk Space Event Rules . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7-22 Threshold and States . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7-23 Runaway Query Event Rule . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7-24 SCSI Predictive Failure Event Rule . . . . . . . . . . . . . . . . . . . . . . . . 7-25 ECC Error Event Rule . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7-26 Regen Fault Event Rule . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7-27 SCSI Disk Error Event Rule . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7-28 Thermal Fault Event Rule . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7-30 Sys Heat Threshold Event Rule . . . . . . . . . . . . . . . . . . . . . . . . . . . 7-30 histCaptureEvent Rule . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7-31 histLoadEvent Rule . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7-33 SPU Core Event Rule . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7-34 Voltage Fault Event Rule . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7-35 Transaction Limit Event Rule . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7-36 Administrator Privileges . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 8-9 Object Privileges . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 8-10 Netezza SQL Commands for Displaying Privileges . . . . . . . . . . . . . . 8-13 Privileges by Object . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 8-14 Indirect Object Privileges . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 8-15 Authentication-Related Commands . . . . . . . . . . . . . . . . . . . . . . . . 8-19 Client Connection-Related Commands . . . . . . . . . . . . . . . . . . . . . . 8-25 User and Group Settings. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 8-26 Public Views . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 8-30 System Views . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 8-31 Data Type Disk Usage . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 9-2 compressedTableRatio Command Arguments . . . . . . . . . . . . . . . . . . 9-5 Table Skew . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 9-10 Database Information . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 9-14 Generate Statistics Syntax . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 9-15 Automatic Statistics. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 9-16 The 32nd read/write Transaction Queueing. . . . . . . . . . . . . . . . . . . 9-25 The _v_qrystat View . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 9-28 The _v_qryhist View . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 9-28 Choosing a Backup and Restore Method. . . . . . . . . . . . . . . . . . . . . 10-2 Backup/Restore Commands and Content . . . . . . . . . . . . . . . . . . . . 10-2
xxiv
Table 10-3: Table 10-4: Table 10-5: Table 10-6: Table 10-7: Table 10-8: Table 10-9: Table 10-10: Table 10-11: Table 10-12: Table 11-1: Table 11-2: Table 11-3: Table 11-4: Table 11-5: Table 11-6: Table 11-7: Table 11-8: Table 11-9: Table 11-10: Table 11-11: Table 11-12: Table 11-13: Table 11-14: Table 11-15: Table 11-16: Table 11-17: Table 11-18: Table 11-19: Table 11-20: Table 11-21: Table 11-22: Table 11-23: Table 12-1: Table 12-2: Table 12-3: Table 12-4:
Retaining Specials . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 10-5 The nzbackup Command Options . . . . . . . . . . . . . . . . . . . . . . . . 10-10 Environment Settings . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 10-13 Backup History Source . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 10-19 Backup and Restore Behavior . . . . . . . . . . . . . . . . . . . . . . . . . . . 10-20 The nzrestore Command Options . . . . . . . . . . . . . . . . . . . . . . . . . 10-22 Environment Settings . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 10-25 Backup History Target . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 10-29 Restore History Source . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 10-31 NetBackup Policy Settings . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 10-32 History Loader Settings and Behavior. . . . . . . . . . . . . . . . . . . . . . . 11-8 _v_querystatus. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 11-15 _v_planstatus . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 11-16 $v_hist_queries View . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 11-18 $v_hist_incomplete_queries View . . . . . . . . . . . . . . . . . . . . . . . . 11-19 $v_hist_table_access_stats View . . . . . . . . . . . . . . . . . . . . . . . . . 11-19 $v_hist_column_access_stats View . . . . . . . . . . . . . . . . . . . . . . . 11-20 $v_hist_log_events View . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 11-20 $hist_version. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 11-21 $hist_nps_$SCHEMA_VERSION . . . . . . . . . . . . . . . . . . . . . . . . . 11-22 $hist_log_entry_$SCHEMA_VERSION . . . . . . . . . . . . . . . . . . . . . 11-22 $hist_failed_authentication_$SCHEMA_VERSION. . . . . . . . . . . . . 11-23 $hist_session_prolog_$SCHEMA_VERSION . . . . . . . . . . . . . . . . . 11-24 $hist_session_epilog_$SCHEMA_VERSION . . . . . . . . . . . . . . . . . 11-26 $hist_query_prolog_$SCHEMA_VERSION. . . . . . . . . . . . . . . . . . . 11-27 $hist_query_epilog_$SCHEMA_VERSION. . . . . . . . . . . . . . . . . . . 11-28 $hist_query_overflow_$SCHEMA_VERSION . . . . . . . . . . . . . . . . . 11-29 $hist_service_$SCHEMA_VERSION . . . . . . . . . . . . . . . . . . . . . . . 11-30 $hist_state_change_$SCHEMA_VERSION . . . . . . . . . . . . . . . . . . 11-31 $hist_table_access_$SCHEMA_VERSION. . . . . . . . . . . . . . . . . . . 11-32 $hist_column_access_$SCHEMA_VERSION . . . . . . . . . . . . . . . . . 11-33 $hist_plan_prolog_$SCHEMA_VERSION . . . . . . . . . . . . . . . . . . . 11-34 $hist_plan_epilog_$SCHEMA_VERSION . . . . . . . . . . . . . . . . . . . 11-36 Workload Management Feature Summary . . . . . . . . . . . . . . . . . . . . 12-2 Short Query Bias Registry Settings. . . . . . . . . . . . . . . . . . . . . . . . . 12-5 Sample Resource Sharing Groups . . . . . . . . . . . . . . . . . . . . . . . . . 12-7 Assigning Resources to Active RSGs . . . . . . . . . . . . . . . . . . . . . . . 12-8
xxv
Table 12-5: Table 12-6: Table 12-7: Table 12-8: Table 12-9: Table 13-1: Table 13-2: Table 13-3: Table 13-4: Table 13-5: Table 13-6: Table 13-7: Table 13-8: Table 13-9: Table 13-10: Table 13-11: Table 13-12: Table 13-13: Table 13-14: Table 13-15: Table 13-16: Table 13-17: Table A-1: Table A-2: Table A-3: Table A-4: Table A-5: Table A-6: Table A-7: Table A-8: Table A-9: Table A-10: Table A-11: Table A-12: Table A-13: Table A-14: Table A-15:
Guaranteed Resource Allocation Settings . . . . . . . . . . . . . . . . . . . 12-13 GRA Compliance Registry Settings . . . . . . . . . . . . . . . . . . . . . . . 12-14 GRA Report Settings . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 12-15 Netezza Priorities. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 12-20 Gate Keeper Registry Settings . . . . . . . . . . . . . . . . . . . . . . . . . . . 12-22 Netezza Groups and Tables. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 13-1 Database Table . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 13-2 DBMS Group . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 13-3 Host CPU Table . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 13-3 Host File System Table. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 13-4 Host Interfaces Table . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 13-4 Host Management Channel Table . . . . . . . . . . . . . . . . . . . . . . . . . 13-6 Host Network Table . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 13-7 Host Table . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 13-8 Hardware Management Channel Table . . . . . . . . . . . . . . . . . . . . . . 13-9 Per Table Data Slice Table . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 13-10 Query Table . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 13-10 Query History Table . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 13-11 SPU Partition Table . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 13-12 SPU Table . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 13-13 System Group . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 13-13 Table Table . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 13-14 Command Line Summary . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . A-1 Administrator Privileges . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . A-4 Object Privileges . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . A-5 nzds Input Options. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . A-9 nzds Options . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . A-11 nzevent Input Options . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . A-13 nzevent Options. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . A-13 nzhistcleanupdb Input Options . . . . . . . . . . . . . . . . . . . . . . . . . . . A-18 nzhistcreatedb Input Options . . . . . . . . . . . . . . . . . . . . . . . . . . . . A-19 nzhistcreatedb Output Messages . . . . . . . . . . . . . . . . . . . . . . . . . . A-20 nzhostbackup Input Options . . . . . . . . . . . . . . . . . . . . . . . . . . . . . A-22 nzhostrestore Input Options . . . . . . . . . . . . . . . . . . . . . . . . . . . . . A-24 nzhostrestore Options. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . A-24 nzhw Input Options . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . A-26 nzhw Options . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . A-29
xxvi
Table A-16: Table A-17: Table A-18: Table A-19: Table A-20: Table A-21: Table A-22: Table A-23: Table A-24: Table A-25: Table A-26: Table A-27: Table A-28: Table A-29: Table A-30: Table A-31: Table A-32: Table A-33: Table A-34: Table A-35: Table A-36: Table A-37: Table C-1: Table C-2: Table D-1: Table D-2: Table D-3: Table D-4:
nzpassword Input Options. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . A-32 nzpassword Options . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . A-32 nzreclaim Input Options . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . A-34 nzreclaim Options . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . A-34 nzrev input Options . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . A-36 nzsession Input Options . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . A-37 nzsession Options . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . A-39 Session Information . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . A-41 nzstart Inputs . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . A-43 nzstate Inputs . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . A-44 nzstate Options . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . A-45 nzstats Inputs . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . A-46 nzstats Options . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . A-47 nzstop Inputs . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . A-50 nzstop Options. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . A-50 nzsystem Inputs. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . A-51 nzsystem Options. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . A-52 Diagnostic Commands . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . A-54 nzconvertsyscase Input Options. . . . . . . . . . . . . . . . . . . . . . . . . . . A-56 nzdumpschema Inputs . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . A-57 nzinitsystem Options . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . A-58 nzlogmerge Options . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . A-59 User Views . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . C-1 System Views . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . C-3 Startup Configuration Options . . . . . . . . . . . . . . . . . . . . . . . . . . . . . D-1 System Manager Configuration Options . . . . . . . . . . . . . . . . . . . . . . D-3 Host Processes . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . D-5 SPU Configuration Options . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . D-10
xxvii
xxviii
Figures
Figure 3-1: Figure 3-2: Figure 3-3: Figure 3-4: Figure 3-5: Figure 3-6: Figure 3-7: Figure 3-8: Figure 3-9: Figure 3-10: Figure 3-11: Figure 5-1: Figure 5-2: Figure 5-3: Figure 5-4: Figure 5-5: Figure 5-6: Figure 5-7: Figure 7-1: Figure 9-1: Figure 9-2: Figure 9-3: Figure 10-1: Figure 10-2: Figure 10-3: Figure 11-1: Figure 11-2: Figure 12-1: Figure 12-2: Figure 12-3: Figure 12-4: Figure 12-5: Figure 12-6: Sample Run Command Window. . . . . . . . . . . . . . . . . . . . . . . . . . . 3-11 Login Dialog Box . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3-12 Netezza Revision Warning Window. . . . . . . . . . . . . . . . . . . . . . . . . 3-12 NzAdmin Main System Window . . . . . . . . . . . . . . . . . . . . . . . . . . . 3-13 NzAdmin Hyperlink Support . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3-15 Preferences Dialog Box. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3-16 Connection Error window . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3-18 Navigation Pane. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3-19 Status Pane. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3-20 System Summary Page . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3-20 NzPortal Performance Report . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3-22 Sample nzhw show Output . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 5-3 Netezza TwinFin System Components and Locations . . . . . . . . . . . . . 5-5 SPUs, Disks, Data Slices, and Data Partitions. . . . . . . . . . . . . . . . . . 5-8 Balanced and Unbalanced Disk Topologies. . . . . . . . . . . . . . . . . . . . 5-9 Disk Mirroring and Failure Recovery. . . . . . . . . . . . . . . . . . . . . . . . 5-20 TwinFin 6 (and larger) PDUs and Circuit Breakers. . . . . . . . . . . . . . 5-22 TwinFin 3 PDUs and Circuit Breakers . . . . . . . . . . . . . . . . . . . . . . 5-23 Alerts Window . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7-37 Record Distribution Window . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 9-9 Table Skew Window . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 9-11 Organizing Tables with CBTs . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 9-12 Database Backups Timeline . . . . . . . . . . . . . . . . . . . . . . . . . . . . 10-17 Activity Monitor . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 10-37 Viewing a Failed Entry . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 10-38 Query History Staging and Loading Areas . . . . . . . . . . . . . . . . . . . . 11-7 The Query History Configuration Dialog . . . . . . . . . . . . . . . . . . . . 11-14 SQB Queuing and Priority . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 12-4 GRA Usage Sharing . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 12-7 Impacts of the Admin User on GRA . . . . . . . . . . . . . . . . . . . . . . . 12-10 Multiple Jobs in a Group Share the Groups Resources . . . . . . . . . 12-11 GRA and Priority . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 12-12 Resource Allocation Performance Window . . . . . . . . . . . . . . . . . . 12-17
xxix
Figure 12-7: Figure 12-8: Figure 12-9: Figure 12-10: Figure 12-11: Figure 14-1:
Resource Allocation Performance History Window . . . . . . . . . . . . . 12-18 Resource Allocation Performance Graph. . . . . . . . . . . . . . . . . . . . 12-19 Using PQE to Control Job Concurrency by Runtime and Priority . . . 12-21 Gate Keeper Default Normal Work Queue . . . . . . . . . . . . . . . . . . . 12-23 Gate Keeper Time-Based Normal Queues and Registry Settings . . . 12-24 Mantra and MantraVM Service . . . . . . . . . . . . . . . . . . . . . . . . . . . 14-1
xxx
Preface
The Netezza data warehouse appliance is a high performance, integrated database appliance that provides unparalleled performance, extensive scaling, high reliability, and ease of use. The Netezza appliance uses a unique architecture that combines current trends in processor, network, and software technologies to deliver a very high performance system for large enterprise customers.
xxxi
xxxii
CHAPTER 1
Administration Overview
Whats in this chapter
Administrators Roles Administration Tasks Initial System Setup and Information Administration Interfaces Other Netezza Documentation
This chapter provides an introduction and overview to the tasks involved in administering a Netezza data warehouse appliance.
Administrators Roles
Netezza administration tasks typically fall into two categories: System administration managing the hardware, configuration settings, system status, access, disk space, usage, upgrades, and other tasks Database administration managing the user databases and their content, loading data, backing up data, restoring data, controlling access to data and permissions In some customer environments, one person could be both the system and database administrator to perform the tasks when needed. In other environments, multiple people may share these responsibilities, or they may own specific tasks or responsibilities. You can develop the administrative model that works best for your environment. In addition to the administrator roles, there are also database user roles. A database user is someone who has access to one or more databases and has permission to run queries on the data stored within those databases. In general, database users have access permissions to one or more user databases, and they have permission to perform certain types of tasks as well as to create or manage certain types of objects (tables, synonyms, and so forth) within those databases.
Administration Tasks
The administration tasks generally fall into these categories: Deploying and installing Netezza clients Managing the Netezza appliance
1-1
Managing system notifications and events Managing Netezza users and groups Database management Loading data (described in the Netezza Data Loading Guide) Database backup and restore Query history Workload management This guide describes these tasks and how to perform them using the various Netezza administration UIs.
1-2
20282-14
Rev.1
Netezza Support and Sales representatives will work with you to install and initially configure the Netezza in your customer environment. Typically, the initial rollout consists of installing the system in your data center, and then performing some configuration steps to set the systems hostname and IP address to connect the system to your network and make it accessible to users. They will also work with you to perform initial studies of the system usage and query performance, and may advocate other configuration settings or administration ideas to improve the performance of and access to the Netezza for your users.
data.<ver>/base Contains system tables, catalog information and subdirectories for the databases. Each database you create has its own subdirectory whose name matches the databases object ID value. For example, base/1/ is the system database, base/2/ is the master_db database, and base/nnn is an end-user database, where nnn is the object ID of the database. data.<ver>/cache Contains copies of compiled code that was dynamically generated on the host, cross-compiled to run on the SPUs, then downloaded to the SPUs for execution. The copies are saved to eliminate extra steps and overhead when running similar queries.
20282-14
Rev.1
1-3
data.<ver>/config Contains configuration files such as callHome.txt, sendMail.cfg, and system.cfg files. The callHome.txt is the callhome attachment file; sendMail.cfg contains the configuration parameters for the sendmail program; system.cfg is the systems configuration registry, which allows you to control and tune the system. Other files may exist in this directory if the Netezza system uses options such as LDAP authentication and other applications. data.<ver>/plans Contains copies of the most recent execution plans for reference. The system stores the execution plan (for each query) in a separate file with a .pln extension, and includes the following information: The original SQL that was submitted. The plan itself, describing how the various tables and columns are to be accessed, when joins, sorts, and aggregations are performed, and so on. If the system was able to reuse a cached (already compiled) version of the code. The system also generates a separate C program (.cpp file) to process each snippet of each plan. The system compares this code against files in /nz/data/cache to determine whether the compilation step can be skipped. The kit Directory The kit directory contains the following subdirectories:
kit.<rev>/ Top level directory for the release <rev> (for example, kit.2.0). kit.<rev>/bin/ All user-level CLI programs. kit.<rev>/bin/adm Internal CLI programs. kit.<rev>/log/<pgm name>/ Component log files, one subdirectory per component containing a file per day of log information up to seven days. The information in the logs includes when the process started, when the process exited or completed, and any error conditions. kit.<rev>/ sbin Internal host and utility programs not intended to be run directly by users. These programs are not specifically prefixed (for example, clientmgr). kit.<rev>/share/ Postgres-specific files. kit.<rev>/sys/ System configuration files, startup.cfg and some subdirectories (init, include, strings). kit.<rev>/sys/init/ Files used for system initialization.
1-4
20282-14
Rev.1
20282-14
Rev.1
1-5
To change the DNS information: 1. Log in to either host as root. 2. Enter the following command:
[root@nzhost1 ~]# service nzresolv update
Note: If you use the service command to edit the DNS information, you must use vi as the text editor tool, as shown in these examples. However, if you prefer to use a different text editor, you can set the $EDITOR environment variable and use the /etc/init.d/ nzresolve update command to edit the files using your editor of choice. 3. A text editor opens with the systems DNS information:
# !!! All lines starting '# !!!' will be removed. # !!! search yourcompany.com nameserver 1.2.3.4 nameserver 1.2.5.6
4. You can enter, delete, or change the information as required. When you finish,you can save your changes and exit (or exit without saving the changes). For example, type one of the following commands: :wq to save the changes. :q to exit the file. :q! to exit without saving any changes you made in the file. Use caution before changing the DNS information; incorrect changes can impact the operation of the Netezza system. Review any changes with the DNS administrator at your site to ensure that the changes are correct.
Overwriting DNS Information with a Text File information from an existing text file: 1. Log in to either host as root.
2. Create a text file with your DNS information. Your text file should have a format similar to the following:
search yourcompany.com nameserver 1.2.3.4 nameserver 1.2.5.6
3. Enter the following command, where file is the fully qualified pathname to the text file:
[root@nzhost1 ~]# service nzresolv update file
Appending DNS Information from the Command Prompt To change the DNS information by entering the information from the command prompt: 1. Log in to either host as root. 2. Enter the following command (note the dash character at the end of the command):
[root@nzhost1 ~]# service nzresolv update -
1-6
20282-14
Rev.1
Administration Interfaces
The command prompt proceeds to a new line where you can enter the DNS information. Enter the complete DNS information, because the text that you type replaces the existing information in the resolv.conf file. 3. After you finish typing the DNS information, type one of the following commands: Control-D to save the information that you entered and exit the editor. Control-C to exit without saving any changes.
Administration Interfaces
Netezza offers several ways or interfaces that allow you to perform the various system and database management tasks: Netezza commands (nz* commands) are installed in the /nz/kit/bin directory on the Netezza host. For many of the nz* commands, you must be able to log on to the Netezza system to access and run those commands. In most cases, users log in as the default nz user account, but you may have created other Linux user accounts on your system. Some commands require you to specify a database user account, password, and database to ensure that you have permissions to perform the task. The Netezza CLI client kits package a subset of the nz* commands that can be run from Windows and UNIX client systems. The client commands may also require you to specify a database user account, password, and database to ensure that you have database administrative and object permissions to perform the task. SQL commands. The SQL commands support administration tasks and queries within a SQL database session. You can run the SQL commands from the Netezza nzsql command interpreter or through SQL APIs such as ODBC, JDBC, and the OLE DB Provider. You must have a database user account to run the SQL commands with appropriate permissions for the queries and tasks that you perform.
20282-14
Rev.1
1-7
NzAdmin tool. NzAdmin is a Netezza interface that runs on Windows client workstations to manage Netezza systems. Web Admin. Web Admin is a Web browser client that users can access on the Netezza system or a compatible Linux server to manage their Netezza systems via common Web browser applications. NzPortal. NzPortal is a Web browser client that provides detailed monitoring capabilities for your Netezza systems. You can use NzPortal to answer questions about system usage, workload, capacity planning, and overall query performance. The nz* commands are installed and available on the Netezza system, but it is more common for users to install Netezza client applications on client workstations. Netezza supports a variety of Windows and UNIX client operating systems. Chapter 2, Installing the Netezza Client Software, describes the Netezza clients and how to install them. Chapter 3, Using the Netezza Administration Interfaces, describes how to get started using the administration interfaces. The client interfaces provide you with different ways to perform similar tasks. While most users tend to use the nz* commands or SQL commands to perform tasks, you can use any combination of the client interfaces, depending upon the task or your workstation environment, or interface preferences.
1-8
20282-14
Rev.1
CHAPTER 2
Installing the Netezza Client Software
Whats in this chapter
Client Software Packages Installing the Netezza CLI Client on a UNIX System Installing the Netezza Tools on a Windows Client Installing the Web Admin Interface Installing the NzPortal Interface Clients and Unicode Characters Client Timeout Controls Netezza Port Numbers Creating Encrypted Passwords Using Stored Passwords
In most cases, the only applications that Netezza administrators or users need to install are the client applications to access the Netezza system. Netezza provides client software that runs on a variety of systems such as Windows, Linux, Solaris, AIX, and HP-UX systems. For a description of the client applications, see Administration Interfaces on page 1-7. This chapter describes how to install the Netezza CLI clients, NzAdmin tool, and Web Admin interface. Note: This chapter does not describe how to install the Netezza system software or how to upgrade the Netezza host software. Typically, Netezza Support works with you for any situations that might require software reinstallations, and the steps to upgrade a Netezza system are described in the Netezza Software Upgrade Guide. If your users or their business reporting applications access the Netezza system through ODBC, JDBC, or OLE-DB Provider APIs, see the Netezza ODBC, JDBC and OLE DB Installation and Configuration Guide for detailed instructions on the installation and setup of these data connectivity clients.
2-1
The Netezza Linux/HP Clients CD contains the interface software such as the CLI and the ODBC/JDBC drivers for Linux/HP clients. The Netezza Windows Client and Web Admin CD contains the interface software such as NzAdmin, some nz* commands, the ODBC/JDBC drivers, and the OLE-DB Provider. It also includes the Web Admin software. Table 2-1 lists the supported operating systems and revisions for the Netezza CLI clients. Table 2-1: Supported Netezza CLI Client Operating Systems OS Linux Windows AIX Solaris HP-UX Revisions Red Hat EL AS 4.0, 5.2, 5.3 (32-bit) SuSE Enterprise Server 8 & 9 (32-bit) 2000 (32-bit only), and the 32- and 64-bit versions of 2003, 2008, XP, Vista 5.1, 5.2, 5.3 with 5.0.2.1 C++ runtime libraries 2.7, 2.8, 2.9, 2.10 11i versions 1.6 and 2 (B.11.22 and B.11.23) Hardware Platform and Notes Intel (32-bit) AMD (32- and 64-bit) nzsql is not currently supported on Windows clients. PowerPC (32 and 64-bit) SPARC Platforms (32- and 64bit) Itanium (32- and 64-bit)
Note: The Netezza client kits are designed to run on the vendors proprietary hardware architecture. For example, the AIX, HP-UX, and Solaris clients are intended for each vendor's proprietary RISC architecture. The Linux client is intended for RedHat or SUSE on the 32-bit Intel architecture (not the IBM mainframe zSeries or any of the other platforms on which Linux runs).
2-2
20282-14
Rev.1
3. Depending upon the auto-mounter settings, you may need to mount the CD drive. For example, on Linux the command is similar to:
mount /media/cdrom or mount /media/cdrecorder
Table 2-2 describes other common mount commands for the supported UNIX clients. If you encounter any problems mounting or accessing the CD drive on your client system, refer to your operating system documentation or command man pages. Table 2-2: Sample UNIX CD Mount Commands Platform Solaris HP-UX Command mount -o ro -F hsfs /dev/dsk/c0t1d0s2 /tmp/cdrom To mount the CD:
pfs_mountd & pfsd & pfs_mount /dev/dsk/c0t0d0 /cdrom
Export the library path, where the pathname is the location of the nz files. Note that the location of the Netezza client files is /usr/local/nz or the location you choose to install them.
export SHLIB_PATH=/<path_to_installdir>/bin/lib
AIX
5. You can run the setup command at the top level of the CD, which checks the client OS and then determines the correct client files to install. You can also navigate to the correct operating system subdirectory on the CD and run the unpack command as follows:
./unpack
Note: On some UNIX systems such as Red Hat 5.3, the auto-mounter settings may not provide execute permissions by default. If the unpack command returns a permission denied error, you can copy the installation files from the CD to a local directory and run the unpack command from that local directory. You can also disable auto-mount and mount the CDROM manually as described in Table 2-2, then execute the scripts. Note: For installations on Linux, be sure to use the unpack in the linux directory, not the linux64 directory (which contains only the executable for the 64-bit ODBC driver). 6. The unpack program checks the client system to ensure that it supports the CLI package and prompts you for an installation location. The default is /usr/local/nz for Linux, but you can install the CLI tools to any location on the client. The program prompts you to create the directory if it does not exist. Sample command output follows:
-----------------------------------------------------------------Netezza Performance Server -- NPS Linux Client 5.0 Copyright 2002-2009 Netezza Corporation. All rights reserved. -----------------------------------------------------------------Validating package checksum ... ok
20282-14
Rev.1
2-3
Where should the NPS Linux Client be unpacked? [/usr/local/nz] Directory '/usr/local/nz' does not exist; create it (y/n)? [y] Enter 0% 25% 50% 75% 100% ||||||||||||||||||||||||||||||||||||||||||||||||||| Unpacking complete.
After the installation completes, the Netezza CLI commands will be installed to the specified destination directory.
Installation Requirements
The installation package requires a computer system running a supported Windows operating system (Windows 2000, 2003, XP (32- and 64-bit), VISTA (32-bit), and 2008 (32and 64-bit) and that has either a CD-ROM drive or a network connection. Note: If you will be using or viewing object names that use UTF-8 encoded characters, your Windows client systems require the Microsoft universal font to display the characters within the NzAdmin tool. The Arial Unicode MS font is installed by default on Windows XP systems, but you may need to run a manual installation for other Windows platforms such as 2003, 2000 or others. For more information, see the Microsoft support article at http://office.microsoft.com/en-us/help/hp052558401033.aspx.
2-4
20282-14
Rev.1
3. Double-click or run nzsetup.exe. This is a standard installation program that consists of a series of steps in which you select and enter information used to configure the installation. You can cancel the installation at any time. The installation program displays a license agreement, which you must accept to install the client tools. It also allows you to specify the following information: Destination folder You can use the default installation folder or specify an alternative location. The default folder is C:\Program Files\Netezza Tools. If you choose a different folder, the installation program creates the folder if one does not exist. Setup type Select the type of installation: typical, minimal, or custom. Typical Installs the nzadmin program, the help file, the documentation, and the console utilities, including the loader. Minimal Installs the nzadmin program and help files. Custom Displays a screen where you can select to install any combination of the administration application, console applications, or documentation. After you complete the selections and review the installation options, the client installer creates the Netezza Tools folder, which has several subfolders. You cannot change the subfolder names or locations. Bin Executables and support files Doc Copies of the Netezza product documentation and an Acrobat Index to search the doc set Help Application help files jre Java runtime environment files for the Netezza tools sys Application string files Uninstall Netezza Tools Files to remove Netezza tools from the client system The installation program displays a dialog when it completes, and on some systems, it could prompt you to reboot the system before you use the application. The installation program adds the Netezza commands to the Windows Start > Programs menu. The program group is Netezza and it has the suboptions Netezza Administrator and Documentation. The Netezza Administrator command starts the NzAdmin tool. The Documentation command lists the PDFs of the installed documentation. Note: To use the commands in the bin directory, you must open a Windows command line prompt (a DOS prompt).
Environment Variables
Table 2-3 lists the operating system environment variables that the installation tool adds for the Netezza console applications. Table 2-3: Environment Variables Variable PATH Operation append Setting <installation directory>\bin
20282-14
Rev.1
2-5
Table 2-3: Environment Variables Variable NZ_DIR Operation set Setting Installation directory (for example C:\Program Files\ Netezza Tools)
2-6
20282-14
Rev.1
Creates an SSL site certificate, which is used when connecting to the Web Admin server through secure sockets layer (SSL) protocols. The installation script takes a conservative approach when installing the RPM set and libpq.so library file. It does not alter or overwrite RPM packages or other files that exist on the target system. Therefore, the script looks for any of the packages on the system, and, if they exist, it skips that RPM or file, and moves on to the next.
For systems with a DVD/CD-RW drive, use the command: [root@nzhost1 ~]# mount /media/cdrecorder 4. Run the unpack command to add the software files to the system:
[root@nzhost1 ~]# ./unpack
The unpack script installs the software files for the Web Admin interface. Sample command output follows:
---------------------------------------------------------------------Netezza Performance Server -- NPS Web Admin 6.0 Copyright 2002-2010 Netezza Corporation. All rights reserved. ---------------------------------------------------------------------Validating package checksum ... ok Directory '/usr/local/nzWebAdmin' does not exist; create it (y/n)? [y] Enter ********************************************************************* Unpacking WebAdmin files into: /usr/local/nzWebAdmin ********************************************************************* 0% 25% 50% 75% 100% ||||||||||||||||||||||||||||||||||||||||||||||||||| Installing web services RPMs ... Preparing... #################################### 1:apr ####################################### Preparing... #################################### 1:apr-util ###################################### Preparing... #################################### package curl-7.15.5-2.el5.i386 is already installed Preparing... #################################### 1:distcache ###################################### Preparing... #################################### package expat-1.95.8-8.2.1.i386 is already installed
20282-14
Rev.1
2-7
Preparing... #################################### 1:freetype ###################################### Preparing... #################################### 1:gmp ####################################### [Output abbreviated for documentation...] 1:postgresql-libs ###################################### Preparing... #################################### 1:unixODBC #######################################
********************************************************************** Previous odbc configuration moved to /etc/odbcinst.ini.30724 ********************************************************************** Running ldconfig... Starting httpd: Unpacking complete.
OK
The unpacking process automatically starts the Web Admin server. If you need to stop the Web Admin server at any time, log in as root or a superuser account and use the following command:
service httpd stop
To start the Web Admin server, log in as root or a superuser account and use the following command:
service httpd start
2-8
20282-14
Rev.1
The existing directory /usr/local/nzWebAdmin has been copied to /usr/local/nzWebAdmin.old.16894 The Apache web server is currently running. Would you like to stop it for installation (y/n)? [y] Enter Stopping httpd: [ 0% 25% 50% 75% 100% ||||||||||||||||||||||||||||||||||||||||||||||||||| WARNING: The existing directory /etc/httpd has been moved to /etc/httpd.old.16894 There is an existing rpm installation of httpd. Remove (y/n)? [y] Enter There is an existing rpm installation of mod_ssl. Remove (y/n)? [y] Enter There is an existing rpm installation of php-gd. Remove (y/n)? [y] Enter There is an existing rpm installation of php-mbstring. Remove (y/n)? [y] Enter There is an existing rpm installation of php. Remove (y/n)? [y] Enter Installing web services RPMs ... Preparing... #################################### Repackaging... 1:apr ####################################### Upgrading... 1:apr ######################################## [Output abbreviated for documentation...] Preparing... #################################### 1:postgresql-libs ###################################### Preparing... #################################### 1:unixODBC #######################################
OK
********************************************************************** Previous odbc configuration moved to /etc/odbcinst.ini.16894 ********************************************************************** Running ldconfig... Starting httpd: Unpacking complete.
OK
20282-14
Rev.1
2-9
The installation script also copies the software and help files to the default web server directory (/var/www/html) so that the server can access them.This directory hierarchy must be maintained for the Web Admin interface and online help to operate properly. Table 2-4 lists the directory structure. Table 2-4: Directory Structure Directory /usr/local/nzWebAdmin/Admin /usr/local/nzWebAdmin/lib /usr/local/nzWebAdmin/RPMs/ /var/www/error /var/www/html Contents Web Admin software libpq.so file LAS4 and RHEL5 subdirectories that contain packages for the Linux operating system Contains error message files for the web server
html files php files inc files (PHP include files)
/var/www/icons
Image files
2-10
20282-14
Rev.1
2. Insert the Netezza NzPortal CD into your systems CD drive. Note: If you have downloaded the NzPortal package (nzportal.package.tar.z) to a directory such as /tmp on your Linux system, change to that directory and use a command such as tar -xzf nzportal.package.tar.z to untar the package. Proceed to Step 5. 3. Depending upon the auto-mounter settings, you may need to mount the CD drive. For example, on Linux the command is similar to:
mount /media/cdrom
or
mount /media/cdrecorder
4. Change to the CD directory that you used in Step 3. 5. Unpack the NzPortal files to install them as follows. There are several prompts in the unpack script; this output uses Enter to show that the user accepted the defaults.
[root@nzhost cdrecorder]# ./unpack ------------------------------------------------------------------------Netezza Performance Server -- NzPortal 6.0.B1 Copyright 2002-2010 Netezza Corporation. All rights reserved. ------------------------------------------------------------------------Validating package checksum ... ok Where should the NzPortal be unpacked? [/usr/local/nzportal] Enter Directory '/usr/local/nzportal' does not exist; create it (y/n)? [y] Enter ************************************************************************* NOTICE - Using pre-installed Apache, Version 2.0 ************************************************************************* ************************************************************************* NOTICE - This installation will copy files to the existing Document Root: /usr/local/nzWebAdmin/Admin ************************************************************************* The Apache web server is currently running. Do you want to stop it for installation (y/n)? [y] Enter Stopping httpd: Deleting exsiting users... 0% 25% 50% 75% 100% ||||||||||||||||||||||||||||||||||||||||||||||||||| cp: cannot stat `/usr/local/nzportal/libnzpq.so': No such file or directory ************************************************************ Moving files to the Apache Document Root: /usr/local/nzWebAdmin/Admin ************************************************************ Shutting down kernel logger: Shutting down system logger: Starting system logger: [ [ [ OK OK OK ] ] ]
OK
20282-14
Rev.1
2-11
Starting kernel logger: Starting nzSoapService server: Starting httpd: Unpacking complete.
[ [ [
OK OK OK
] ] ]
The unpacking process automatically starts the NzPortal server. If you need to stop the Web services at any time, log in as root or a superuser account and use the following commands:
service httpd stop service nzportal_service stop
To start the services, log in as root or a superuser account and use the following commands:
service httpd start service nzportal_service start
For details about the NzPortal interface and how to access it, see NzPortal Interface on page 3-21.
2-12
20282-14
Rev.1
2. In a DOS command prompt window, change the code page to UTF-8 by entering the following command:
chcp 65001
As an alternative to these DOS setup steps, the input/output from the DOS clients can be piped from/to nzconvert and converted to a native code page, such as 932 for Japanese. On a Windows system, the fonts that you use for your display must meet these following Microsoft requirements as outlined on the Support site at http://support.microsoft.com/ default.aspx?scid=kb;EN-US;Q247815.
20282-14
Rev.1
2-13
On older Netezza systems with HP hosts, the HP Insight Manager and Integrated Lights Out (iLO) server administration use the following ports: 22, 80, 443, 2381, and 17988. Note: Netezza personnel, if granted access for remote service, use port 22 for SSH, and ports 20 and 21 for FTP.
Where: The user name is the Netezza database users name in the Netezza system catalog. If you do not specify the user name on the command line, the nzpassword command uses the environment variable NZ_USER. The password is the Netezza database users password in the Netezza system catalog or the password specified in the environment variable NZ_PASSWORD. If you do not supply a password on the command line or in the environment variable, the system prompts you for a password. The hostname is the Netezza host. If you do not specify the hostname on the command line, the nzpassword command uses the environment variable NZ_HOST. You can create encrypted passwords for any number of user name/host pairs. When you use the nzpassword add command to cache the password, note that quotation marks are not required around the user name or password values. You should only qualify the user name or password with a surrounding set of single-quote double-quote pairs (for example, '"Bob"') in cases where the value is case-sensitive. If you specify quoted or unquoted names or passwords in nzpassword or other nz commands, you must use the same quoting style in all cases.
2-14
20282-14
Rev.1
If you qualify a case-insensitive user name with quotes (for example '"netezza"'), the command may still complete successfully, but this is not recommended and not guaranteed to work in all command cases. After you type the nzpassword command, the system sends the encrypted password to the Netezza host where it is compared against the user name/password in the system catalog. If the information matches, the Netezza stores the encrypted information in a local password cache, and displays no additional message. On Linux and Solaris, the password cache is the file .nzpassword in the users home directory. Note that the system creates this file without access permissions to other users, and refuses to honor a password cache whose permission allows other users access. On Windows, the password cache is stored in the registry. If the information does not match, the Netezza displays a message indicating that the authentication request failed. The Netezza also logs all verification attempts. If the database administrator changed a user password in the system catalog, the existing nzpasswords are invalid.
20282-14
Rev.1
2-15
client commands will prompt for a password, which can cause automated scripts to hang. Also, if you use an older client to add a cached password to or delete a cached password from an AES-256 format file, you could corrupt the AES-256 password file and lose the cached passwords. If you typically run multiple releases of Netezza clients, you should use the Blowfish format for your cached passwords.
2-16
20282-14
Rev.1
CHAPTER 3
Using the Netezza Administration Interfaces
Whats in this chapter
Netezza CLI Overview SQL Command Overview NzAdmin Tool Overview Web Admin Overview NzPortal Interface
This chapter provides a high-level description of the Netezza administration interfaces, such as the command line interface, NzAdmin, Web Admin interface, NzPortal, and the SQL commands. This chapter describes how to access and use these interfaces. Note: In general, the Netezza CLI commands are used most often to perform the various administration tasks. Many of the tasks can also be performed using SQL commands or the interactive interfaces. Throughout this guide, the primary task descriptions use the CLI commands and reference other ways to perform the same task.
3-1
Summary of Commands
Table 3-1 describes the nz* commands you can use to monitor and manage the Netezza system. These commands reside in the /nz/kit/bin directory on the Netezza host. Many of these commands are also installed with the Netezza client kits and can be run from a remote client workstation. Table 3-1: Command Line Summary Command nzbackup Description Backs up an existing database. For more information For command syntax, see nzbackup on page A-6. For more information, see Using the nzbackup Command on page 10-10.
nzcontents
For command syntax, see nzcontents on Displays the revision and build number of all page A-7. For more information, see Software Revision Levels on page 6-1. the executables, plus the checksum of Netezza binaries. Converts character encodings for loading with the nzload command or external tables. Manages and displays information about the data slices on the system. Displays and manages event rules. For command syntax, see nzconvert on page A-7. For more information, refer to the Netezza Database Users Guide.
nzconvert
nzds
nzevent
For command syntax, see nzevent on page A-12. For more information, see Chapter 7, Managing Event Rules.
nzhistcleanupdb
Deletes old history For command syntax, see nzhistcleanupdb information from a his- on page A-17. For more information, refer to tory database. Chapter 11, Query History Collection and Reporting. Creates a history database with all its tables, views, and objects for history collection and reporting. Backs up the host information, including users and groups. Restores the host information. For command syntax, see nzhistcreatedb on page A-19. For more information, refer to Chapter 11, Query History Collection and Reporting. For command syntax, see nzhistcreatedb on page A-19. For command syntax, see nzhostrestore on page A-23.
nzhistcreatedb
nzhostbackup
nzhostrestore
3-2
20282-14
Rev.1
Table 3-1: Command Line Summary Command nzload Description Loads data into database files. For more information For command syntax, see nzload on page A-31. For more information, see Loading Data into the Netezza Appliance on page 10-1. For command syntax, see nzpassword on page A-31. For more information, see Creating Encrypted Passwords on page 2-14.
nzpassword
nzreclaim
Uses the SQL GROOM For command syntax, see nzreclaim on page A-34. For more information, see GroomTABLE command to reclaim disk space from ing Tables on page 9-19. user tables, and also to reorganize the tables. Restores the contents of a database backup. Displays the current software revision for any Netezza software release. For command syntax, see nzrestore on page A-36. For more information, see Using the nzrestore Command on page 10-21. For command syntax, see nzrev on page A-36. For more information, see Software Revision Levels on page 6-1.
nzrestore
nzrev
nzsession
Shows a list of current For command syntax, see nzsession on system sessions (load, page A-37. For more information, see Managing Sessions on page 9-21. client, and sql). Supports filtering by session type or user, allows you to abort sessions, and change the current job list for a queued session job. Invokes the SQL command interpreter. For usage information, see Chapter 9, Managing User Content on the Netezza Appliance. For command syntax, see the Netezza Database Users Guide. For command syntax, see nzstart on page A-42. For more information, see Managing the System State on page 6-6. For command syntax, see nzstate on page A-44. For more information, see Displaying the Current System State on page 6-3.
nzsql
nzstart
nzstate
Displays the current system state or waits for a specific system state to occur before returning.
20282-14
Rev.1
3-3
Table 3-1: Command Line Summary Command nzstats Description Displays system level statistics. Stops the system. For more information For command syntax, see nzstats on page A-46. For more information, see Displaying Netezza Statistics on page 13-1. For command syntax, see nzstop on page A-49. For more information, see Managing the System State on page 6-6. For command syntax, see nzsystem on page A-51. For more information, see Managing the System State on page 6-6.
nzstop
nzsystem
Command Locations
Table 3-2 lists the default location of the Netezza CLI commands and whether they are available in the various UNIX or Windows client kits. Remember to add the appropriate bin directory to your search path to simplify command invocation. Table 3-2: CLI Command Locations /nz/kit/ bin C:\Program Files\Netezza Tools\Bin HPUX Client AIX Client Windows Client
Default Location
Platform nzbackup nzhistcleanupdb nzhistcreatedb nzhostbackup nzhostrestore nzrestore nzstart nzstop nzwebstart nzwebstop nzcontents nzsql
3-4
20282-14
Rev.1
Table 3-2: CLI Command Locations /nz/kit/ bin C:\Program Files\Netezza Tools\Bin HPUX Client AIX Client Windows Client
Default Location
Platform nzreclaim nzconvert nzds nzevent nzhw nzload nzpassword nzrev nzsession nzstate nzstats nzsystem
20282-14
Rev.1
3-5
While some of the nz* commands can operate and display information without additional access requirements, some commands and operations require that you specify a Netezza database user account and password. The account may also require appropriate access and administrative permissions to display information or process a command. Several examples follow. To display the state of a Netezza system using a Windows client command:
C:\Program Files\Netezza Tools\Bin>nzstate show -host mynps -u user -pw passwd System state is 'Online'.
To display the valid Netezza system states using a Windows client command:
C:\Program Files\Netezza Tools\Bin>nzstate listStates State Symbol -----------initialized paused pausedNow offline offlineNow online stopped down Description -----------------------------------------------------------used by a system component when first starting already running queries will complete but new ones are queued like paused, except running queries are aborted no queries are queued, only maintenance is allowed like offline, except user jobs are stopped immediately system is running normally system software is not running system was not able to initialize successfully
Note: In this example, note that you did not have to specify a host, user, or password. The command simply displayed information that was already available on the local Windows client. To back up a Netezza database (you must run the command while logged in to the Netezza system, as this is not supported from a client):
[nz@npshost ~]$ nzbackup -dir /home/user/backups -u user -pw password -db db1 Backup of database db1 to backupset 20090116125409 completed successfully.
The syntax is single-quote, backslash, single-quote, identifier, backslash, single-quote, single-quote. This syntax protects the quotes so that the identifier remains quoted in the Netezza system.
3-6
20282-14
Rev.1
nzsql Command
The nzsql command is a SQL command interpreter. You can use it on the Netezza host or on UNIX client systems to create database objects, run queries, and manage the database. Note: The nzsql command is not yet available on Windows client systems. To invoke the nzsql command, enter:
nzsql [options] [security options] [dbname [user] [password]]
Table 3-3 describes the nzsql command options. For detailed information about the command options and how to use the command, see the Netezza Database Users Guide. Table 3-3: nzsql Command Options Argument -a -A -c <query> -d <dbname> Description Echoes all input from a script. Specifies unaligned table output mode (-P format=unaligned). Runs only a single query (or slash command) and exits. Specifies the database name to which to connect.
If you do not specify -d, the nzsql command uses the environ-
the nzsql command prompts you for a database name. -e -E -f <file name> -F <string> Echoes queries sent to the backend. Displays queries that internal commands generate. Executes queries from a file, then exits. Sets the field separator (default: | (-P fieldsep=).
20282-14
Rev.1
3-7
Table 3-3: nzsql Command Options Argument -h -H -host <host> -l -n -o <file name> -P var[=arg] -port <port> -pw <password> Description Displays this help. Specifies the HTML table output mode (-P format=html). Specifies the database server host. Lists available databases, then exits. Disables readline. Required when nzsql is used with an input method such as Japanese, Chinese, or Korean Sends query output to file name (or |pipe). Sets printing option var to arg. Specifies the database server port (default: hardwired). Specifies the database user password.
If you do not specify -pw, the nzsql command uses the environ-
the nzsql command prompts you for a password. -q -R <string> -s -S -t -time -T text -u <user name> Runs quietly (no messages, only query output). Sets the record separator (default: newline) (-P recordsep=). Specifies single step mode (confirm each query). Specifies single line mode (newline terminates query). Prints rows only (-P tuples_only). Prints the time taken by queries. Sets HTML table tag options (width, border) (-P tableattr=). Specifies the database user name.
If you do not specify -u, the nzsql command uses the environ-
the nzsql command prompts you for a user name. -V -v name=val -x -X Shows the version information and exits. Sets the nzsql variable name to value. Turns on expanded table output (-P expanded). Does not read startup file (~/.nzsqlrc).
3-8
20282-14
Rev.1
Table 3-3: nzsql Command Options Argument -securityLevel Description Specifies the security level that you want to use for the session. The argument has four values:
preferredUnsecured This is the default value. Specify this
option when you would prefer an unsecured connection, but you will accept a secured connection if the Netezza system requires one.
preferredSecured Specify this option when you want a
secured connection to the Netezza system, but you will accept an unsecured connection if the Netezza system is configured to use only unsecured connections.
onlyUnsecured Specify this option when you want an unse-
cured connection to the Netezza system. If the Netezza system requires a secured connection, the connection will be rejected.
onlySecured Specify this option when you want a secured
connection to the Netezza system. If the Netezza system accepts only unsecured connections, or if you are attempting to connect to a Netezza system that is running a release prior to 4.5, the connection will be rejected. -caCertFile Specifies the pathname of the root CA certificate file on the client system. This argument is used by Netezza clients who use peer authentication to verify the Netezza host system. The default value is NULL which skips the peer authentication process.
Within the nzsql command interpreter, you can enter the following commands for help or to execute a command: \h Help for SQL commands. \? Internal slash commands. See Table 3-4. \g or terminate with semicolon Execute a query. \q Quit.
You do not have to supply a value; simply defining it is sufficient. You can also toggle batch processing with a SQL script. For example:
\set ON_ERROR_STOP \unset ON_ERROR_STOP
20282-14
Rev.1
3-9
You can use the $HOME/.nzsqlrc file to store values, such as the ON_ERROR_STOP, and have it apply to all future nzsql sessions and all scripts.
3-10
20282-14
Rev.1
Figure 3-1: Sample Run Command Window If you run the nzadmin.exe in a command window, you can optionally enter the following login information on the command line to bypass the login dialog: -host or /host and the name of the Netezza host or its IP address -user or /user and a valid Netezza database user name -pw or /pw and a valid password for the Netezza user. The NzAdmin tool also can use cached passwords on your client system. To specify using a cached password, use the -pw option without a password string. You can enter these arguments in any order, but you must separate them with spaces or commas. You can mix the - and / command forms. If you enter all three arguments, NzAdmin bypasses the login dialog and connects you to the host you have specified. If there is an error, NzAdmin displays the login dialog with the host and user fields completed and you must enter the password. If you specify only one or two arguments, NzAdmin displays the login dialog. You must complete the remaining fields. If you duplicate arguments, that is, specify -host red and -host blue, NzAdmin displays a warning message and uses the first one (host red). Note: The NzAdmin tool and Web Admin accept delimited (quoted) user names in their respective login dialogs. You can also delimit user names passed when invoking the NzAdmin tool in a command window.
Logging In to NzAdmin
Unless otherwise specified on the command line, the NzAdmin login dialog box requires three arguments: host, user name, and password. When you enter the password, the NzAdmin tool allows you to save the encrypted password on the local system. When you login again, you only need enter the host and user name. The drop down list in the host field displays the previous host addresses or names you have used in the past.
20282-14
Rev.1
3-11
Figure 3-3: Netezza Revision Warning Window You can suppress subsequent warning messages for version incompatibility by selecting Dont warn me about this again and clicking OK.
3-12
20282-14
Rev.1
Figure 3-4: NzAdmin Main System Window In the main hardware view, NzAdmin displays an image of the Netezza system, which could be one or more racks for z-series systems or one or more SPAs for Netezza TwinFin systems. As you move the cursor over the image, NzAdmin displays information such as hardware IDs and other details and the mouse cursor changes to the hyperlink hand. Clicking the image allows you to drill down to more information about the component. In the status bar at the bottom of the window, the NzAdmin tool displays your user name and the duration of the NzAdmin session. If the host system is not in the online state, the status bar displays the message The host is not online. You can access commands through the menu bar, the toolbar, or by right-clicking objects.
20282-14
Rev.1
3-13
Table 3-5: Color Indicators Status Red Description Failed. The component is down or failed. It can also indicate that a component is likely to fail, which is the case if two fans on the same SPA are down. Missing. A component is missing and no state is available.
Empty
File > System State File > Reconnect File > Exit View > Toolbar View > Status Bar View > System Objects
3-14
20282-14
Rev.1
Table 3-6: Main Menu Commands Command Tools > Table Storage Description Table Storage Displays table and materialized view storage usage by database or by user.
Tools > Query History Configuration Query History Configuration Displays a window that you can use to create and alter query history configurations, as well as to set the current configuration. Tools > Default Settings Tools > Options Default Settings Displays the materialized view refresh threshold. Preferences Displays the Preferences dialog box that you can use to set the object naming preference and whether you want auto refresh. Displays the online Netezza System Administrators Guide. Displays the NzAdmin and Netezza revision numbers and copyright text.
20282-14
Rev.1
3-15
As you move the cursor over the SPA image, the NzAdmin tool displays the slot number, hardware ID, role, and state of each SPU, and the mouse cursor changes to the hyperlink hand. Clicking the SPU displays the SPU status window and positions the tree control to the corresponding entry.
Administration Commands
You can access system and database administration commands from both the tree view and the status pane of NzAdmin. In either case, a popup or context menu supports the commands related to the components displayed. To activate a pop-up context menu, right-click a component in a list. The Options hyperlink menu is located in the top bar of the window.
Figure 3-6: Preferences Dialog Box If you enable auto refresh, the NzAdmin tool displays a refresh icon in the right corner of the status bar. The system stores the refresh state and time interval, and maintains this information across NzAdmin sessions. Therefore, if you set automatic refresh, it remains in effect until you change it.
3-16
20282-14
Rev.1
To reduce communication with the server, the NzAdmin tool refreshes data based on the item you select in the left pane. Table 3-7 lists the items and corresponding data retrieved on refresh. Table 3-7: Automatic Refresh Selected Item Server (system view) SPA Units SPA ID n SPU units Event rules Individual statistic such as DBMS Group Server (database view) Databases Database <name> Tables Views Sequences Synonyms Functions Aggregates Procedures Users Groups Sessions Data Retrieved All topology and hardware state information.
Event rules. Specific statistic information. All databases and their associated objects, users, groups, and session information. All database information and associated objects. Specific database, table, and view information. Table information. View information. Sequences information. Synonyms information. User-defined functions information. User-defined aggregates information. Stored procedure information. User information. Group information. Session information.
If the NzAdmin tool is already communicating with the backend server, such as processing a user command or performing a manual refresh, it does not execute an auto refresh.
20282-14
Rev.1
3-17
Figure 3-7: Connection Error window If you click Reconnect, the NzAdmin tool attempts to establish a connection to the server. If you click Exit, NzAdmin terminates your session.
3-18
20282-14
Rev.1
Navigation Pane
The navigation page is on the left side of the page and contains the main list of site links. This page is fixed and, with a few exceptions, is present on all pages within the site. Most links are grouped within system and database commands.
20282-14
Rev.1
3-19
Status Pane
The status pane is at the top of the page, and contains database status and system state, time of last status update, host revision number, hostname or address, and user name and authentication setting.
Figure 3-9: Status Pane The status area also includes a search box, which you can use to search through system tables. Depending on the search string you enter, the system finds the following items: If the search string is numeric, the system searches for hardware identifiers or IP addresses, such as a SPU or SPA. If the search string is alphanumeric, the system searches for databases, tables, views, sequences, synonyms, functions, aggregates, procedures, and user or group names. The alphanumeric search uses the SQL like operator, therefore you can augment the search string with SQL pattern characters. For example, the search string cust% finds all occurrences of the customer table throughout all the databases in the system.
3-20
20282-14
Rev.1
NzPortal Interface
Drilldown Links
The Web Admin interface lets you drill down for more detailed information on system, hardware, and database objects. Many pages contain drilldown links, in text or graphical form. For example: In the Hardware View page, you can click on the rack image to drill down to a specific SPA. In the SPA Status page, you can click on a SPU within the SPA image to drill down to detailed information on a SPU. In the Table List page, you can click on a table name to drill down to table properties.
Action Buttons
At the top of many Web Admin pages, there are action links that provide additional navigation based on the current pages content. For example, from the Table Properties page you can select to view the table record distribution or statistics, or truncate or drop the table.
Online Help
The Web Admin interface provides you with two types of help: Task-oriented help Available when you click Help Contents in the navigation pane. Context-sensitive help Available when you click the question icon on each page.
NzPortal Interface
NzPortal provides detailed monitoring capabilities for your Netezza systems. You can use NzPortal to answer questions about system usage, workload, capacity planning, and overall query performance. You can use NzPortal to examine the current workload of a Netezza system as well as to filter and explore historical queries and activity. The NzPortal application uses both active monitoring queries and query history data to summarize the system activity. You must enable the query history capabilities on the Netezza system(s) that you monitor to take advantage of the history analysis. Figure 3-11 on page 3-22 shows a portion of a sample NzPortal window.
20282-14
Rev.1
3-21
Figure 3-11: NzPortal Performance Report The Performance charts display the throughput history over time, which can help you to identify the most busy and least busy hours for your system, and well as help you to evaluate the overall scope of the activity during those times. This can help you to plan for such activities as maintenance windows during the least used times, as well as help you to identify the busiest times when high activity may cause users to report delays or performance issues. NzPortal can monitor multiple Netezza systems simultaneously. The Netezza systems must be running Netezza Release 4.6 or later. The supported Netezza system models that can be monitored include TwinFin and later systems, Skimmer systems, 10000-series systems, 8000z-series systems, and 5000-series systems. For details about the NzPortal interface and its windows and capabilities, refer to the online help which is accessible from the NzPortal interface.
You could also use the full URL of the NzPortal interface, which is:
http://hostname/com.netezza.portal.Portal/index.html
3-22
20282-14
Rev.1
NzPortal Interface
The NzPortal main window appears. The NzPortal views and main window are greyed out until you log in. From this window you can only login to the NzPortal interface, as well as display help and the NzPortal version information. 2. Click Login. The Login dialog appears. 3. Enter your NzPortal user account and password, then click Login.
20282-14
Rev.1
3-23
3-24
20282-14
Rev.1
CHAPTER 4
Managing Netezza HA Systems
Whats in this chapter
Linux-HA and DRBD Overview Differences with the Previous Netezza HA Solution Linux-HA Administration DRBD Administration Administration Reference and Troubleshooting
The Netezza high availability (HA) solution uses Linux-HA and Distributed Replicated Block Device (DRBD) as the foundation for cluster management and data mirroring. The Linux-HA and DRBD applications are commonly used, established, open source projects for creating HA clusters in various environments. They are supported by a large and active community for improvements and fixes, and they also offer the flexibility for Netezza to add corrections or improvements on a faster basis, without waiting for updates from third-party vendors. All the TwinFin models are HA systems, which means that they have two host servers for managing Netezza operations. The host server (often referred to as host within the documentation) is a Linux server that runs the Netezza software and utilities. This chapter describes some high-level concepts and basic administration tasks for the Netezza HA environment.
4-1
The Netezza implementation uses DRBD in a synchronous mode, which is a tightly coupled mirroring system. When a block is written, the active host does not record the write as complete until both the active and the standby hosts successfully write the block. The active host must receive an acknowledgement from the standby host that it also has completed the write. Synchronous mirroring (DRBD protocol C) is most often used in HA environments that want the highest possible assurance of no lost transactions should the active node fail over to the standby node. Heartbeat typically controls the DRBD services, but commands are available to manually manage the services. For details about DRBD and its terms and operations, see the documentation available at http://www.drbd.org.
Some additional points of differences between the solutions: All Linux-HA and DRBD logging information is written to /var/log/messages on each host. For more information about the log files, see Logging and Messages on page 4-13. In the new cluster environment, pingd has replaced netchecker (the Network Failure Daemon). pingd is a built-in part of the Linux-HA suite. The cluster manager HA solution also required a storage array (the MSA500) as a quorum disk to hold the shared data. A storage array is not used in the new Linux-HA/DRBD solution, as DRBD automatically mirrors the data in the /nz and /export/home partitions from the primary host to the secondary host. Note: The /nzdata and /shrres file systems on the MSA500 are deprecated.
4-2
20282-14
Rev.1
Linux-HA Administration
In some customer environments that used the previous cluster manager solution, it was possible to have only the active host running while the secondary was powered off. If problems occurred on the active host, the Netezza administrator onsite would power off the active host and power on the standby. In the new Linux-HA DRBD solution, both HA hosts must be operational at all times. DRBD ensures that the data saved on both hosts is synchronized, and when Heartbeat detects problems on the active host, the software automatically fails over to the standby with no manual intervention.
Linux-HA Administration
When you start a Netezza HA system, Heartbeat automatically starts on both hosts. It can take a few minutes for Heartbeat to start all the members of the nps resource group. You can use the crm_mon command from either host to observe the status, as described in Monitoring the Cluster and Resource Group Status on page 4-6.
Heartbeat Configuration
Heartbeat uses the /etc/ha.d/ha.cf configuration file first to load its configuration. The file contains low-level information about fencing mechanisms, timing parameters, and whether the configuration is v1 (old-style) or v2 (CIB). Netezza uses the v2 implementation. Do not modify the file unless directed to in Netezza documentation or by Netezza Support.
CIB
The majority of the Heartbeat configuration is stored in the Cluster Information Base (CIB). The CIB is located on disk at /var/lib/heartbeat/crm/cib.xml. Heartbeat synchronizes it automatically between the two Netezza hosts. NEVER manually edit the CIB file! You must use cibadmin (or crm_resource) to modify the Heartbeat configuration. Wrapper scripts like heartbeat_admin.sh will update the file in a safe way.
Note: It is possible to get into a situation where Heartbeat will not start properly due to a manual CIB modificationalthough the CIB cannot be safely modified without Heartbeat being started (that is, cibadmin cannot run). In this situation, you can run /nzlocal/scripts/ heartbeat_config.sh to reset the CIB and /etc/ha.d/ha.cf to factory-default status. After doing this, it is necessary to run /nzlocal/scripts/heartbeat_admin.sh --enable-nps to complete the CIB configuration.
20282-14
Rev.1
4-3
the default active host and so HA1 is often synonymous with the active host. The names HA1 and HA2 are still used to refer to the host servers regardless of their active/standby role. In TwinFin and later system designs, host1/HA1 is configured by default to be the active host. You can run cluster management commands from either the active or the standby host. The nz* commands must be run on the active host, but the commands run the same regardless of whether host 1 or host 2 is the active host. The Netezza software operation is not affected by the host that it runs on; the operation is identical when either host 1 or host 2 is the active host. However, when host 1 is the active host, certain system-level operations such as S-Blade restarts and reboots often complete more quickly than when host 2/HA2 is the active host. An S-Blade reboot can take one to two minutes longer to complete when host 2 is the active host. Certain tasks such as manufacturing and system configuration scripts can require host 1 to be the active host, and they will display an error if run on host 2 as the active host. The documentation for these commands indicates whether they require host 1 to be the active host, or if special steps are required when host 2 is the active host.
4-4
20282-14
Rev.1
Linux-HA Administration
Note: Table 4-2 lists the common commands. Note that these commands are listed here for reference, but they are described in detail in the Netezza System Configuration Guide for your model type. Refer to that guide if you need to perform any of these procedures. Table 4-2: Cluster Management Scripts Type Initial installation scripts Scripts heartbeat_config.sh: Sets up Heartbeat for the first time heartbeat_admin.sh --enable-nps: Adds Netezza services to cluster control after initial installation heartbeat_admin.sh --change-hostname heartbeat_admin.sh --change-fabric-ip heartbeat_admin.sh --change-wall-ip heartbeat_admin.sh --migrate
Hostname change Fabric IP change Wall IP change Manual migrate (relocate) Linux-HA status and troubleshooting commands:
crm_mon: Monitor cluster status crm_verify: Sanity check configuration, and print status
Note: The following is a list of other Linux-HA commands available. This list is also provided as a reference, but it is highly recommended that you do not use any of these commands unless directed to by Netezza documentation or by Netezza Support. Linux-HA configuration commands: cibadmin: Main interface to modify configuration crm_resource: Shortcut interface for modifying configuration crm_attribute: Shortcut interface for modifying configuration crm_diff: Diff and patch two different CIBs Linux-HA administration commands: crmadmin: Low-level query and control crm_failcount: Query and reset failcount crm_standby: Mark a node as standby, usually for maintenance
20282-14
Rev.1
4-5
The command output displays a message about how it was invoked, and then displays the hostname where the nps resource group is running. This is the active host. You can obtain more information about the state of the cluster and which host is active using the crm_mon command. Refer to the sample output shown in the next section, Monitoring the Cluster and Resource Group Status on page 4-6. Note: If the nps resource group is unable to start, or if it has been manually stopped (such as by crm_resource -r nps -p target_role -v stopped), neither host is considered to be active. If this is the case, crm_resource -r nps -W will not return a hostname.
Sample output follows. This command refreshes its display every five seconds, but you can specify a different refresh rate (for example, -i10 is a ten-second refresh rate). Press Control-C to exit the command.
[root@nzhost1 ~]# crm_mon -i5 ============ Last updated: Wed Sep 30 13:42:39 2009 Current DC: nzhost1 (key) 2 Nodes configured. 3 Resources configured. ============ Node: nzhost1 (key): online Node: nzhost2 (key): online Resource Group: nps drbd_exphome_device (heartbeat:drbddisk): Started drbd_nz_device (heartbeat:drbddisk): Started exphome_filesystem (heartbeat::ocf:Filesystem): nz_filesystem (heartbeat::ocf:Filesystem): fabric_ip (heartbeat::ocf:IPaddr): Started wall_ip (heartbeat::ocf:IPaddr): Started nz_dnsmasq (lsb:nz_dnsmasq): Started nzhost1 mantravm (lsb:mantravm): Started nzhost1 nzinit (lsb:nzinit): Started nzhost1 fencing_route_to_ha1 (stonith:apcmaster): Started fencing_route_to_ha2 (stonith:apcmaster): Started
nzhost2 nzhost1
The host running the nps resource group is considered the active host. Every member of the nps resource group will start on the same host. The output above shows that they are all running on nzhost1, which means that nzhost1 is the active host. Note: If the nps resource group is unable to start, or if it has been manually stopped (such as by crm_resource -r nps -p target_role -v stopped), neither host is considered to be active. If this is the case, crm_mon will either show individual resources in the nps group as stopped, or it will not show the nps resource group at all.
4-6
20282-14
Rev.1
Linux-HA Administration
Although the crm_resource output shows that the MantraVM service is started, this is a general status for Heartbeat monitoring. For details on the MantraVM status, use the service mantravm status command which is described in Displaying the Status of the MantraVM Service on page 14-4. Note: The crm_mon output also shows the name of the Current DC. The Designated Coordinator (DC) host is not an indication of the active host. The DC is an automatically assigned role that Linux-HA uses to identify a node that acts as a coordinator when the cluster is in a healthy state. This is a Linux-HA implementation detail and does not impact Netezza. Each host is capable of recognizing and recovering from failure, regardless of which one is the DC. For more information about the DC and Linux-HA implementation details, see http://www.linux-ha.org/DesignatedCoordinator. The resources under the nps resource group are as follows: The DRBD devices:
drbd_exphome_device (heartbeat:drbddisk): drbd_nz_device (heartbeat:drbddisk): Started nzhost1 Started nzhost1
The Netezza daemon which performs necessary prerequisite work and then starts the Netezza software:
nzinit (lsb:nzinit): Started nzhost1
The fence routes for internal Heartbeat use are not part of the nps resource group. If these services are started, it means that failovers are possible:
fencing_route_to_ha1 fencing_route_to_ha2 (stonith:apcmaster): (stonith:apcmaster): Started nzhost2 Started nzhost1
20282-14
Rev.1
4-7
fabric_ip wall_ip nz_dnsmasq mantravm nzinit The order of the members of the group matters; group members are started sequentially from first to last. They are stopped sequentially in reverse order, from last to first. Heartbeat blocks on each members startup and will not attempt to start the next group member until the previous member has started successfully. If any member of the resource group is unable to start (returns an error or times out), Heartbeat performs a failover to the standby node. Note: The mantravm resource is not a blocking resource; that is, if the MantraVM service does not start when the nps resource group is starting, the nps resource group does not wait for the MantraVM to start.
Failover Criteria
During a failover or resource migration, the nps resource group is stopped on the active host and started on the standby host. The standby host then becomes the active host. It is important to differentiate between a resource failover and a resource migration (or relocation). A failover is an automated event which is performed by the cluster manager without human intervention when it detects a failure case. A resource migration occurs when an administrator intentionally moves the resources to the standby. A failover can be triggered by any of the following events: BOTH maintenance network links to the active host are lost. ALL fabric network links to the active host are lost. A user manually stops Heartbeat on the active host. The active host is cleanly shut down, such as if someone issued the command shutdown -h on that host. The active host is uncleanly shut down, such as during a power failure to the system (both power supplies fail). If any member of the nps resource group cannot start properly when the resource group is initially started. If any one of the following members of the nps resource group fails after the resource group was successfully started: drbd_exphome_device or drbd_nz_device: These correspond to low-level DRBD devices that serve the shared filesystems. If these devices fail, the shared data would not be accessible on that host. exphome_filesystem or nz_filesystem: These are the actual mounts for the DRBD devices. nz_dnsmasq: The DNS daemon for the Netezza system. Note: If any of these resource group members experiences a failure, Heartbeat first tries to restart or repair the process locally. The failover is triggered only if that repair or restart pro-
4-8
20282-14
Rev.1
Linux-HA Administration
cess does not work. Other resources in the group not listed above are not monitored for failover detection. The following common situations DO NOT trigger a failover: Any of the failover criteria occurring on the STANDBY host while the active host is healthy. Note: Heartbeat may decide to fence (forcibly power cycle) the standby host when it detects certain failures to try to restore the standby host to a state of good health. A single maintenance network link to the active host is lost. Losing some (but not all) of the fabric network links to the active host. Network connectivity from the Netezza host (either active or standby) to the customer's network is lost. One or both network connections serving the DRBD network fail. The MantraVM service fails. If the MantraVM service should fail for any reason, it will not cause a failover of the nps resource group to the standby host.
The command blocks until the nps resource group stops completely. To monitor the status, use the crm_mon -i5 command. You can run the command on either host, although on the active host you need to run it from a different terminal window.
20282-14
Rev.1
4-9
This command blocks until it completes successfully. It is important to wait and let the command complete. You can check /var/log/messages for status messages, or you can monitor progress on a separate terminal session using either of the following commands: tail -f /var/log/messages crm_mon -i5 3. Stop Heartbeat on the active Netezza host:
[root@nzhost1 ~]# service heartbeat stop Stopping High-Availability services: [ OK ]
In some rare cases, the Heartbeat cannot be stopped using this process. In these cases you can force Heartbeat to stop as described in Forcing Heartbeat to Shutdown on page 4-17.
4. As root, make sure that there are no open nz sessions or any open files in the /nz and/ or /export/home shared directories. For details, see Checking for User Sessions and Activity on page 4-19.
[root@nzhost1 ~]# lsof /nz /export/home
5. Run the following script in /nzlocal/scripts to make the Netezza system ready for nonclustered operations. The command prompts you for a confirmation to continue, shown as Enter in the output.
[root@nzhost1 ~]# /nzlocal/scripts/nz.non-heartbeat.sh --------------------------------------------------------------Thu Jan 7 15:13:27 EST 2010 File systems and eth2 on this host are okay. Going on. File systems and eth2 on other host are okay. Going on. This script will configure Host 1 or 2 to own the shared disks and own the fabric.
4-10
20282-14
Rev.1
Linux-HA Administration
When complete, this script will have: mounted /export/home and /nz aliased 10.0.0.1 on eth2 run the rackenable script appropriate for this host based on the last octet of eth2 being 2 for rack 1 or 3 for rack 2 To proceed, please hit enter. Otherwise, abort this. Enter Okay, we are proceeding. Thu Jan 7 15:13:29 EST 2010 Filesystem 1K-blocks Used Available Use% Mounted on /dev/sda6 16253924 935980 14478952 7% / /dev/sda10 8123168 435272 7268604 6% /tmp /dev/sda9 8123168 998808 6705068 13% /usr /dev/sda8 8123168 211916 7491960 3% /var /dev/sda7 8123168 500392 7203484 7% /opt /dev/sda3 312925264 535788 296237324 1% /nzscratch /dev/sda1 1019208 40192 926408 5% /boot none 8704000 2228 8701772 1% /dev/shm /dev/sda12 4061540 73940 3777956 2% /usr/local /dev/drbd0 16387068 175972 15378660 2% /export/home /dev/drbd1 309510044 5447740 288340020 2% /nz Done mounting file systems eth2:0 Link encap:Ethernet HWaddr 00:07:43:05:8E:26 inet addr:10.0.0.1 Bcast:10.0.15.255 Mask:255.255.240.0 UP BROADCAST RUNNING MULTICAST MTU:9000 Metric:1 Interrupt:122 Memory:c1fff000-c1ffffff Done enabling IP alias Running nz_dnsmasq: nz_dnsmasq started. Ready to use NPS in non-cluster environment [ OK ]
20282-14
Rev.1
4-11
[root@nzhost1 ~]# /nzlocal/scripts/nz.heartbeat.sh --------------------------------------------------------------Thu Jan 7 15:14:32 EST 2010 This script will configure Host 1 or 2 to run in a cluster When complete, this script will have: unmounted /export/home and /nz Disabling IP alias 10.0.0.1 from eth2 To proceed, please hit enter. Otherwise, abort this. Enter Okay, we are proceeding. Thu Jan 7 15:14:33 EST 2010 Filesystem 1K-blocks Used Available Use% Mounted on /dev/sda6 16253924 935980 14478952 7% / /dev/sda10 8123168 435272 7268604 6% /tmp /dev/sda9 8123168 998808 6705068 13% /usr /dev/sda8 8123168 211928 7491948 3% /var /dev/sda7 8123168 500544 7203332 7% /opt /dev/sda3 312925264 535788 296237324 1% /nzscratch /dev/sda1 1019208 40192 926408 5% /boot none 8704000 2228 8701772 1% /dev/shm /dev/sda12 4061540 73940 3777956 2% /usr/local Done unmounting file systems eth2:0 Link encap:Ethernet HWaddr 00:07:43:05:8E:26 UP BROADCAST RUNNING MULTICAST MTU:9000 Metric:1 Interrupt:122 Memory:c1fff000-c1ffffff Done disabling IP alias Shutting down dnsmasq: nz_dnsmasq stopped. Ready to use NPS in a cluster environment
OK
Note: If the command reports errors that it is unable to unmount /nz or /export/home, you must manually make sure that both partitions are mounted before running the command again. The script may have unmounted one of the partitions, even if the script failed. Otherwise the script may not run. 5. As root, start the cluster on the first node, which will become the active node:
[root@nzhost1 ~] service heartbeat start Starting High-Availability services: [ OK ]
6. As root, start the cluster on the second node, which will become the standby node:
[root@nzhost2 ~] service heartbeat start Starting High-Availability services: [ OK ]
4-12
20282-14
Rev.1
DRBD Administration
Node fencing actions (STONITH actions) To configure the Cluster Manager: 1. Log into the active host as the root user. 2. Using a text editor, edit the /nzlocal/maillist file as follows. Add the lines shown in bold below.
# #Email notification list for the cluster manager problems # #Enter email addresses of mail recipients under the TO entry, one to a line # #Enter email address of from email address (if a non-default is desired) #under the FROM entry # TO: [email protected] [email protected] FROM: [email protected]
Note: For the TO email addresses, specify one or more email addresses for the users who wish to receive email about cluster manager events. For the FROM email address, specify the email address that you want to use as the sender of the event email. 3. Save and close the maillist file. 4. Log in as root to the standby host and repeat steps 2 and 3 on the standby host. Note: The /nzlocal/maillist files should be identical on both hosts in the cluster. 5. After you configure the maillist files, test the event mail by shutting down or rebooting either host in the cluster. Your specified TO addresses should receive email about the event.
DRBD Administration
DRBD provides replicated storage of the data in managed partitions (that is, /nz and / export/home). When a write occurs to one of these locations, the write action is performed at both the local node and the peer standby node. Both perform the same write to keep the data in synchronization. The peer responds to the active node when finished, and if the local write operation is also successfully finished, the active node reports the write as complete.
20282-14
Rev.1
4-13
Read operations are always performed by the local node. The DRBD software can be started, stopped, and monitored using the following command (as root):
/sbin/service drbd start/stop/status
While you can use the status command as needed, you should only stop and start the DRBD processes during routine maintenance procedures or when directed by Netezza Support. As a best practice, do not stop the DRBD processes on a healthy, active Netezza HA host to avoid the risk of split-brain. For more information, see Split-Brain.
In the sample output, note that the states of DRBD are one of the following: Primary/Secondary the healthy state for DRBD. One device is Primary and one is Secondary. Secondary/Secondary DRBD is in a holding pattern. This usually occurs at boot time or when the nps resource group is stopped. Primary/Unknown One node is available and healthy, the other node is either down or the cable is not connected. Secondary/Unknown This is a rare case where one node is in standby, the other is either down or the cable is not connected, and DRBD cannot declare a node as the primary/active node. If the other host also shows this status, the problem is most likely in the connection between the hosts. Contact Netezza Support for assistance in troubleshooting this case. The common Connection State values include the following:
4-14
20282-14
Rev.1
DRBD Administration
Connected the normal and operating state; the host is communicating with its peer. WFConnection the host is waiting for its peer node connection; usually seen when other node is rebooting. Standalone the node is functioning alone due to a lack of network connection with its peer and will not try to reconnect. If the cluster is in this state, it means that data is not being replicated. Manual intervention is required to fix this problem. The common State values include the following: Primary the primary image; local on active host. Secondary the mirror image, which receives updates from the primary; local on standby host. Unknown always on other host; state of image is unknown. The common Disk State values include the following: UpToDate the data on the image is current. DUnknown this is an unknown data state; usually results from a broken connection.
The DRBD status when the current node is active and the standby node is down:
m:res 0:r1 1:r0 cs WFConnection WFConnection st Primary/Unknown Primary/Unknown ds UpToDate/DUnknown UpToDate/DUnknown p C C mounted /export/home /nz fstype ext3 ext3
Split-Brain
Split-brain is an error state that occurs when the images of data on each Netezza host are different. It typically occurs when synchronization is disabled and users change data independently on each Netezza host. As a result, the two Netezza host images are different, and it becomes difficult to resolve what the latest, correct image should be. Split-brain does not occur if clustering is enabled. The fencing controls prevent users from changing the replicated data on the standby node. It is highly recommended that you allow DRBD management to be controlled by Heartbeat to avoid the split-brain problems.
However, if a split-brain problem should occur, the following message appears in the /var/ log/messages file:
20282-14
Rev.1
4-15
While DRBD does have automatic correction processes to resolve split-brain situations, the Netezza implementation disables the automatic correction. Manual intervention is required, which is the best way to ensure that as many of the data changes are restored as possible. To detect and repair split-brain, work with Netezza Support to follow this procedure: 1. Look for Split in /var/log/messages, usually on the host that you are trying to make the primary/active host. Let DRBD detect this condition. 2. Because split-brain results from running both images as primary Netezza hosts without synchronization, check the Netezza logs on both hosts. For example, check the pg.log files on both hosts to see when/if updates have occurred. If there is an overlap in times, both images have different information. 3. Identify which host image, if either, is the correct image. In some cases, neither host image may be fully correct. You must choose the image that is the more correct. The host that has the image which you decide is correct is the survivor, and the other host is the victim. 4. Perform the following procedure: a. Log in to the victim host as root and run these commands: Note: As a best practice, perform these steps for one resource at a time; that is, perform all the commands in steps b. and c. for r0 and then repeat them all for r1. There is an all option, but use it carefully. The individual resource commands usually work more effectively. drbdadm secondary resource where resource can be r0, r1 or all drbdadm disconnect resource where resource can be r0, r1 or all drbdadm -- --discard-my-data connect resource where resource can be r0, r1 or all b. Log in to the survivor host as root and run this command: drbdadm connect resource where resource can be r0, r1 or all Note: The connect command may display an error that instructs you to run drbdadm disconnect first. 5. You can check the status of the fix using drbdadm primary resource and the service drbd status command. Make sure that you run drbdadm secondary resource before you start Heartbeat.
4-16
20282-14
Rev.1
IP Address Requirements
Table 4-3 is an example block of the eight IP addresses that are recommended for a customer to reserve for an HA system: Table 4-3: HA IP Addresses Entity HA1 HA1 Host Management MantraVM Management Floating IP HA2 HA2 Host Management Reserved Reserved Sample IP Address 172.16.103.209 172.16.103.210 172.16.103.211 172.16.103.212 172.16.103.213 172.16.103.214 172.16.103.215 172.16.103.216
In the IP addressing scheme, note that there are two host IPs, two host management IPs, and the floating IP, which is HA1 + 3.
You need to run this command twice. Then, try to stop Heartbeat again using service heartbeat stop. Note that this process is not guaranteed to stop all of the resources that Heartbeat manages, such as /nz mount, drbd devices, nzbootpd, and so on.
20282-14
Rev.1
4-17
You can specify one or more V characters. The more Vs that you specify, the more verbose the output. Specify at least four or five Vs as a best practice, and increase the number as needed. You can specify up to 12 Vs, but that large a number is not recommended. Sample output follows:
[root@ nzhost1 ha.d]# crm_verify -LVVV crm_verify[18488]: 2008/11/18_00:02:03 info: main: =#=#=#=#= Getting XML =#=#=#=#= crm_verify[18488]: 2008/11/18_00:02:03 info: main: Reading XML from: live cluster crm_verify[18488]: 2008/11/18_00:02:03 notice: main: Required feature set: 1.1 crm_verify[18488]: 2008/11/18_00:02:03 notice: cluster_option: Using default value '60s' for cluster option 'cluster-delay' crm_verify[18488]: 2008/11/18_00:02:03 notice: cluster_option: Using default value '-1' for cluster option 'pe-error-series-max' crm_verify[18488]: 2008/11/18_00:02:03 notice: cluster_option: Using default value '-1' for cluster option 'pe-warn-series-max' crm_verify[18488]: 2008/11/18_00:02:03 notice: cluster_option: Using default value '-1' for cluster option 'pe-input-series-max' crm_verify[18488]: 2008/11/18_00:02:03 notice: cluster_option: Using default value 'true' for cluster option 'startup-fencing' crm_verify[18488]: 2008/11/18_00:02:03 info: determine_online_status: Node nzhost1 is online crm_verify[18488]: 2008/11/18_00:02:03 info: determine_online_status: Node nzhost2 is online
For example, if the fencing route to ha1 is listed as failed on host1, use the following command:
crm_resource -r fencing_route_to_ha1 -C -H host1
Output From crm_mon Does Not Show the nps Resource Group
If the log messages indicate that the nps resource group cannot run anywhere, the cause is that Heartbeat tried to run the resource group on both HA1 and HA2, but it failed in both cases. Search in /var/log/messages on each host to find this first failure. Search from the bottom of the log for the message cannot run anywhere and then scan upward in the log to find the service failures. You must fix the problem(s) that caused a service to fail to start before you can successfully start the cluster. After you fix the failure case, you must restart Heartbeat following the instructions in Transitioning from Maintenance to Clustering Mode on page 4-11.
4-18
20282-14
Rev.1
The sample output shows three sessions: the last entry is the session created to generate the results for the nzsession command. The first two entries are user activity, and you should wait for those sessions to complete or stop them prior before you use the nz.heartbeat.sh or nz.non-heartbeat.sh commands. To check for connections to the /export/home and /nz directory: 1. As the nz user on the active host, stop the Netezza software:
[nz@nzhost1 ~]$ /nz/kit/bin/nzstop
2. Log out of the nz account and return to the root account; then use the lsof command to list any open files that reside in /nz or /export/home. Sample output follows:
[root@nzhost1 ~]# lsof /nz /export/home COMMAND PID USER FD TYPE DEVICE SIZE bash 2913 nz cwd DIR 8,5 4096 indexall. 4493 nz cwd DIR 8,5 4096 less 7399 nz cwd DIR 8,5 4096 lsof 13205 nz cwd DIR 8,5 4096 grep 13206 nz cwd DIR 8,5 4096 tail 22819 nz 3r REG 8,5 146995 NODE 1497025 1497025 1497025 1497025 1497025 1497188 NAME /export/home/nz /export/home/nz /export/home/nz /export/home/nz /export/home/nz /export/home/nz/fpga_135.log
20282-14
Rev.1
4-19
This example shows that there are several open files in /export/home. If necessary, you could close the open files using a command such as kill and supplying the process ID (PID) shown in the second column. Use caution with the kill command; if you are not familiar with Linux system commands, contact Support or your Linux system administrator for assistance.
4-20
20282-14
Rev.1
CHAPTER 5
Managing the Netezza Hardware
Whats in this chapter
Netezza Hardware Components Hardware Management Tasks Managing Data Slices Power Procedures
This chapter describes administration tasks for hardware components of the Netezza appliance. Most of the administration tasks focus on obtaining status and information about the operation of the appliance, and in becoming familiar with the hardware states. This chapter also describes tasks to perform should a hardware component fail.
SPAs contain the SPUs and associated disk storage which drive the query processing on the Netezza appliance. Skimmer systems have one host server and thus are not HA configurations.
5-1
Table 5-1: Key Netezza Hardware Components to Monitor Component Snippet Processing Units (SPUs) Description SPUs provide the CPU, memory, and Netezza FPGA processing power for the queries that run on the system. Comments/Management Focus Tasks include monitoring the status of each SPU. Should a SPU fail, the disks that it owns are redirected to other SPUs for processing ownership. Tasks include monitoring the health and status of the disk hardware. Should a disk fail, tasks include regenerating the disk to a spare and replacing the disk. Tasks include monitoring the mirroring status of the data slices and also the space consumption of the data slice.
Disks
Disks are the storage media for the user databases and tables managed by the Netezza appliance.
Data slices
Data slices are virtual partitions on the disks; they contain user databases and tables, and their content is mirrored to ensure HA access to the data in the event of a disk failure. These components control the thermal cooling for the racks and components such as SPAs and disk enclosures.
Tasks include monitoring the status of the fans and blowers, and should a component fail, replacing the component to ensure proper cooling of the hardware. Tasks include monitoring the status of the power supplies, and should a component fail, replacing the component to ensure redundant power to the hardware.
Power supplies
These components provide electrical power to the various hardware components of the system.
The Netezza appliance uses SNMP events (described in Chapter 7, Managing Event Rules) and status indicators to send notifications of any hardware failures. Most hardware components are redundant; thus, a failure typically means that the remaining hardware components will assume the work of the component that failed. The system may or may not be operating in a degraded state, depending upon the component that failed. Never run the system in a degraded state for a long period of time. It is imperative to replace a failed component in a timely manner so that the system returns to an optimal topology and best performance. Netezza Support and Field Service will work with you to replace failed components to ensure that the system returns to full service as quickly as possible. Most of the system components require Field Service support to replace. Components such as disks can be replaced by customer administrators.
5-2
20282-14
Rev.1
Figure 5-1 shows some sample output and highlights several important fields that describe status and aspects of the hardware. Hardware Type Hardware ID
Description HW ID ------------- ----Rack 1001 SPA 1002 SPU 1003 DiskEnclosure 1004 Fan 1005 Fan 1006 Fan 1007 Fan 1008 PowerSupply 1009 PowerSupply 1010 Disk 1011 Disk 1012 Disk 1013 ...
Location Role State --------------------------- ------ -----rack1 Active None spa1 Active None spa1.spu7 Active Online spa1.diskEncl4 Active Ok spa1.diskEncl4.fan1 Active Ok spa1.diskEncl4.fan2 Active Ok spa1.diskEncl4.fan3 Active Ok spa1.diskEncl4.fan4 Active Ok spa1.diskEncl4.pwr1 Active Ok spa1.diskEncl4.pwr2 Active Ok spa1.diskEncl4.disk1 Active Ok spa1.diskEncl4.disk2 Active Ok spa1.diskEncl4.disk3 Active Ok
Hardware Types
Each hardware component of the Netezza system has a type that identifies the hardware component. Table 5-2 describes the hardware types. You see these types when you run the nzhw command or display hardware using the NzAdmin or Web Admin UIs. Table 5-2: Hardware Description Types Description Rack SPA SPU SFI Fan MM Comments A hardware rack for the Netezza system Snippet processing array (SPA) Snippet processing unit (SPU) Switch fabric interface (SFI), which is a component of Netezza z-series systems. (Not present in TwinFin systems.) A thermal cooling device for the system A management device for the associated unit (SPU chassis, disk enclosure). In the TwinFin family of systems, these devices include the AMM and ESM components. A power supply for an enclosure (SPU chassis or disk). A storage disk, used to store the user databases and tables
PowerSupply Disk
20282-14
Rev.1
5-3
Table 5-2: Hardware Description Types Description DiskEnclosure Comments A chassis that contains the disk devices.
Hardware IDs
Each hardware component has a unique hardware identifier (ID) which is in the form of an integer, such as 1000, 1001, 1014, and so on. You can use the hardware ID to perform operations on a specific hardware component, or to uniquely identify which component in command output or other informational displays. To display information about the component with the hardware ID 1001:
[nz@nzhost ~]$ nzhw show -id 1011 Description HW ID Location Role State ----------- ----- -------------------- ------ ----Disk 1011 spa1.diskEncl4.disk1 Active Ok
Hardware Location
Netezza uses two formats to describe the position of a hardware component within a rack. The logical location is a string in a dot format that describes the position of a hardware component within the Netezza rack. For example, the nzhw output shown in Figure 5-1 on page 5-3 shows the logical location for components; a Disk component description follows:
Disk 1011 spa1.diskEncl1.disk1 Active Ok
In this example, the location of the disk is in SPA 1, disk enclosure one, disk position one. The physical location is a text string that describes the location of a component. You can display the physical location of a component using the nzhw locate command. For example, to display the physical location of disk ID 1011:
[nz@nzhost ~]$ nzhw locate -id 1011 Turned locator LED 'ON' for Disk: Logical Name:'spa1.diskEncl4.disk1' Physical Location:'1st Rack, 4th DiskEnclosure, Disk in Row 1/Column 1'
As shown in the command output, the nzhw locate command also lights the locator LED for components such as SPUs, disks, and disk enclosures. For hardware components that do not have LEDs, the command displays the physical location string. Figure 5-2 shows a TwinFin 12 system with a closer view of the storage arrays and SPU chassis components and locations.
5-4
20282-14
Rev.1
Enclosure1 Disk Array 1 Enclosure2 Enclosure3 Disk Array 2 Host 1 Host 2 KVM Enclosure4
Each disk array has four disk enclosures; each enclosure has 12 disks, numbered as follows: 1 5 9 2 6 10 3 7 11 4 8 12
SPU Chassis 1
SPU1 occupies slots 1 and 2; SPU3 occupies slots 3 and 4, up to SPU 11 which occupies slots 11 and 12.
SPU Chassis 2
Figure 5-2: Netezza TwinFin System Components and Locations For detailed information about the locations of various components in the front and back of the system racks, see the Netezza Site Preparation and Specifications guide.
Hardware Roles
Each hardware component of the Netezza system has a hardware role, which represents how the hardware is being used. Table 5-3 describes the hardware roles. You see these roles when you run the nzhw command or display hardware status using the NzAdmin or Web Admin UIs. Table 5-3: Hardware Roles Role None Description The None role indicates that the hardware is initialized, but it has yet to be discovered by the Netezza system. This usually occurs during system startup before any of the SPUs have sent their discovery information. The hardware component is an active system participant. Failing over this device could impact the Netezza system. Comments All active SPUs must be discovered before the system can transition from the Discovery state to the Initializing state.
Active
20282-14
Rev.1
5-5
The hardware is transitioning from spare to Transitional state active. In TwinFin systems, this is the role when a disk is involved in a regeneration. It is not yet active, so it cannot participate in queries. The hardware has failed. It cannot be used Monitor your supply of spare disks. Do not operate without as a spare. After maintenance has been performed, you must activate the hardware spare disks. using the nzhw command before it can become a spare and used in the system. The hardware is not available for any system operations. You must activate the hardware using the nzhw command before it can become a spare and used in the system. This role is specific to disks. If the disk has a UUID that does not match the host UUID, then it is considered mismatched. You must activate the hardware using the nzhw command before it can become a spare and used in the system. To use the SPU as a spare, activate it, otherwise, remove it from the system. To delete it from the system catalog, use the nzhw delete command.
Failed
Inactive
Mismatched
Spare
The hardware is not used in the current Normal system state. After a running Netezza system, but it is available new disk is added to the systo become active in the event of a failover. tem, its role is set to Spare.
Incompatible The hardware is incompatible with the sys- Some examples are disks that tem. It should be removed and replaced are smaller in capacity than with compatible hardware. the smallest disk in use, or blade cards which are not Netezza SPUs.
Hardware States
The state of a hardware component represents the power status of the hardware. Each hardware component has a state. Table 5-4 describes the hardware states for all components except a SPU. Note: SPU states are the system states, which are described in Table 6-3 on page 6-4. You see these states when you run the nzhw command or display hardware status using the NzAdmin or Web Admin UIs.
5-6
20282-14
Rev.1
Table 5-4: Hardware States State None Description The None state indicates that the hardware is initialized, but it has yet to be discovered by the Netezza system. This usually occurs during system startup before any of the SPUs have sent their discovery information. Comments All active SPUs must be discovered before the system can transition from the Discovery state to the Initializing state. If any active SPUs are still in the Booting state, there could be an issue with the hardware startup.
Ok
The Netezza system has received the dis- Normal state covery information for this device, and it is working properly. The device has been turned off.
The system is running normally. It can service requests. The system manager has detected a new device in a slot that was previously occupied but not deleted. This typically occurs when a disk or SPU has been removed and replaced with a spare without deleting the old device. The old device is considered absent because the system manager cannot find it within the system.
Unreachable
The system manager cannot communicate The device may have been with a previously discovered device. failed or physically removed from the system.
20282-14
Rev.1
5-7
tem using a distribution key. An optimal distribution is one where each data slice has approximately the same amount of each user table as any other. The Netezza system distributes the user data to all of the data slices in the system using a hashing algorithm. A data partition is a logical representation of a data slice that is managed by a specific SPU. That is, each SPU owns one or more data partitions, which contains the user data that the SPU is responsible for processing during queries. For TwinFin systems, each SPU typically owns 8 data partitions, although one SPU has only 6 partitions. SPUs could own more than 8 data partitions; if a SPU fails, its data partitions are reassigned in pairs to the other active SPUs in the system. Figure 5-3 shows a conceptual overview of SPUs, disks, data slices, and data partitions in a TwinFin system. In the figure, the SPU owns 8 data partitions which are numbered from 0 to 7. For SPU ID 1003, its first data partition (0) points to data slice ID 9, which is stored on disk 1070. Each data partition points to a data slice. As an example, assume that disk 1014 fails and its contents are regenerated to a spare disk ID 1024 (as described in Mirroring Overview on page 5-19). In this situation, the SPU 1003s data partition 7, which previously pointed to data slice 16 on disk 1014, has been updated to point to data slice 16 on the new disk 1024.
SPU 1003 0 1 2 3 4 5 6 7 9 1070 10 1071 11 1032 12 1033 13 1051 14 1052 15 1013 16 1014 Disks
SPU 1164 0 1 2 3 4 5 6 7 55 1134 56 1135 57 1153 58 1154 59 1096 60 1097 61 1115 62 1116 Disks
Figure 5-3: SPUs, Disks, Data Slices, and Data Partitions If a SPU fails, the system moves all its data slices to new SPUs for management. The system moves them in pairs (the pair of disks that contain the primary and mirror data slices of each other). In this situation, some SPUs will have 10 data partitions (numbered 0 9).
5-8
20282-14
Rev.1
Unbalanced Topology
The system manager can detect and respond to disk topology issues. For example, if an SBlade has more disks in the odd-numbered enclosures of its array, the system manager reports the problem as an overloaded SAS bus. You can use the nzds rebalance command to reconfigure the topology so that half of the disks are in the odd-numbered enclosures and half in the even-numbered. (The rebalance process requires the system to transition to the pausing now state to accomplish the topology update.) When the Netezza system restarts, the restart process checks for topology issues such as overloaded SAS buses or SPAs that have S-Blades with uneven shares of dataslices. (Each S-Blade should have no more than two more dataslices than any of its active peers in the same chassis.) If the system detects a spare S-Blade for instance, it will reconfigure the dataslice topology to evenly distribute the workload among the S-Blades.
20282-14
Rev.1
5-9
Callhome Feature
An important part of the Netezza systems availability and reliability is the callhome feature. Callhome enables the system to identify a failed component and to send a message to Netezza Support, where your problem will be analyzed and a replacement part sent to you if needed. The callhome feature is implemented as part of the Netezza event manager. The event manager monitors system operation (events). When the event manager receives an event, it compares the event to a set of user-defined event rules. The event manager uses the match criteria portion of the event rule to determine which events generate a notification to the user. The callhome feature uses a file named callHome.txt which resides in the /nz/data/config directory. The callHome.txt file defines important information about the Netezza system such as primary and secondary administrator contact information, as well as system information such as location, model number, and serial number. Typically, the Netezza installation team member will edit this file for you when the Netezza system is installed onsite, but you can review and/or edit the file as needed to ensure that the contact information is current. For more information about configuring callhome, see Adding an Event Rule on page 7-7.
5-10
20282-14
Rev.1
The disks should be replaced to ensure that the system has spares and an optimal topology. You can also use the NzAdmin and Web Admin interfaces to obtain visibility to hardware issues and failures.
Managing Hosts
In general, there are very few management tasks relating to the Netezza hosts. In most cases, the tasks are best practices for the optimal operation of the host. For example: Do not change or customize the kernel or operating system files unless directed to do so by Netezza Support or Netezza customer documentation. Changes to the kernel or operating system files could impact the performance of the host. Do not install third-party software on the Netezza host without consulting Netezza Support. While management agents or other applications may be of interest, it is important to work with Support to ensure that third-party applications do not interfere with the host processing. During Netezza software upgrades, host and kernel software revisions are verified to ensure that the host software is operating with the latest required levels. The upgrade processes may display messages informing you to update the host software to obtain the latest performance and security features. On TwinFin systems, Netezza uses DRBD replication only on the /nz and /export/home partitions. As new data is written to the Netezza /nz partition and the /export/home partition on the primary Netezza system, the DRBD software automatically makes the same changes to the /nz and /export/home partition of the standby Netezza system. Use caution when saving files to the host disks; in general, it is not recommended that you store Netezza database backups on the host disks, nor use the host disks to store large files that could grow and fill the host disks over time. Be sure to clean up and remove any temporary files that you create on the host disks to keep the disk space as available as possible for Netezza software and database use. If the active host fails, the Netezza HA software typically fails over to the standby host to keep the Netezza operations running. Netezza Support will work with you to schedule field service to replace the failed host.
Managing SPUs
Snippet Processing Units (SPUs) are hardware components that serve as the query processing engines of the Netezza appliance. Each SPU has CPUs and FPGAs as well as memory and I/O to process queries and query results. Each SPU has associated disks that it owns to store the portions of the user databases and tables that the SPU processes during queries. The basic SPU management tasks are as follows: Monitor status and overall health Activate a spare SPU Deactivate a spare SPU Failover a SPU Locate a SPU in the Netezza rack
20282-14
Rev.1
5-11
Reset (power cycle) a SPU Delete a failed, inactive, or incompatible SPU Replace a failed SPU The following sections describe how to perform these tasks. You can use the nzhw command to activate, deactivate, failover, locate, and reset a SPU, or delete SPU information from the system catalog. For more information about the nzhw command syntax and options, see nzhw on page A-25. To indicate which SPU you want to control, you can refer to the SPU using its hardware ID. You can use the nzhw command to display the IDs, as well as obtain the information from management UIs such as NzAdmin or Web Admin.
Activate a SPU
You can use the nzhw command to activate a SPU that is inactive or failed. To activate a SPU:
nzhw activate -u admin -pw password -host nzhost -id 1004
Deactivate a SPU
You can use the nzhw command to make a spare SPU unavailable to the system. If the specified SPU is active, the command displays an error.
5-12
20282-14
Rev.1
Failover a SPU
You can use the nzhw command to initiate a SPU failover. To failover a SPU, enter:
nzhw failover -u admin -pw password -host nzhost -id 1004
Locate a SPU
You can use the nzhw command to turn on or off a SPUs LED and display the physical location of the SPU. The default is on. To locate a SPU, enter:
nzhw locate -u admin -pw password -host nzhost -id 1082 Turned locator LED 'ON' for SPU: Logical Name:'spa1.spu11' Physical Location:'1st Rack, 1st SPA, SPU in 11th slot'
Reset a SPU
You can use the nzhw command to power cycle a SPU (a hard reset). To reset a SPU, enter:
nzhw reset -u admin -pw password -id 1006
Managing Disks
The disks on the system store the user databases and tables that are being managed and queried by the Netezza appliance. The basic disk management tasks are as follows: Monitor status and overall health Activate a inactive, failed, or mismatched disk Deactivate a spare disk Failover a disk
20282-14
Rev.1
5-13
Locate a disk in the Netezza rack Delete a failed, inactive, mismatched, or incompatible disk Replace a failed disk The following sections describe how to perform these tasks. You can use the nzhw command to activate, deactivate, failover, and locate a disk, or delete disk information from the system catalog. For more information about the nzhw command syntax and options, see nzhw on page A-25. To indicate which disk you want to control, you can refer to the disk using its hardware ID. You can use the nzhw command to display the IDs, as well as obtain the information from management UIs such as NzAdmin or Web Admin.
----------- ----- -------------------- ------ ----- -------------------- --------- -----------------------------Disk BC1D 1011 spa1.diskEncl4.disk1 Active Ok 931.51 GiB; Model ST31000640SS 9QJ3ARET00009909FJXQ
Activate a Disk
You can use the nzhw command to make an inactive, failed, or mismatched disk available to the system as a spare. To activate a disk:
nzhw activate -u admin -pw password -host nzhost -id 1004
5-14
20282-14
Rev.1
Deactivate a Disk
You can use the nzhw command to make a spare disk unavailable to the system. To deactivate a disk:
nzhw deactivate -u admin -pw password -host nzhost -id 5004
Failover a Disk
You can use the nzhw command to initiate a failover. You cannot fail over a disk the system is at least in the initialized state. To failover a disk, enter:
nzhw failover -u admin -pw password -host nzhost -id 1004
Locate a Disk
You can use the nzhw command to turn on or off a disks LED. The default is on. The command also displays the physical location of the disk. To turn on a disks LED, enter:
nzhw locate -u admin -pw password -host nzhost -id 1004 Turned locator LED 'ON' for Disk: Logical Name:'spa1.diskEncl4.disk1' Physical Location:'1st Rack, 4th DiskEnclosure, Disk in Row 1/Column 1'
20282-14
Rev.1
5-15
The basic data slice management tasks are as follows: Monitor status, space consumption, and overall health Rebalance data slices to the available SPUs Regenerate (or regen) a data slice after a disk failure The following sections describe how to perform these tasks. You can use the nzds command to manage data slices and perform these tasks. For more information about the nzds command syntax and options, see nzds on page A-8. To indicate which data slice you want to control, you can refer to the data slice using its data slice ID. You can use the nzds command to display the IDs, as well as obtain the information from management UIs such as NzAdmin or Web Admin.
You can also use the NzAdmin and Web Admin interfaces to obtain visibility to hardware issues and failures.
5-16
20282-14
Rev.1
To show detailed information about the data slices that are being regenerated:
[nz@TT48-0001 ~]$ nzds show -regenstatus -detail Data Slice Spu Spu Location Source Storage Location Destination Storage Location Source Destination Start Time
% Done
---------- ---- ---------------------- -------------------------------------- -------------------------------------------- ----------- ------1 1003 rack1.spa1.spu7.dpart0 1011 rack1.spa1.diskEncl1.disk1.ppart1 1015 rack1.spa1.diskEncl1.disk5.ppart3 0.00 2 1003 rack1.spa1.spu7.dpart1 1011 rack1.spa1.diskEncl1.disk1.ppart3 1015 rack1.spa1.diskEncl1.disk5.ppart1 0.00 9 1003 rack1.spa1.spu7.dpart7 1013 rack1.spa1.diskEncl1.disk3.ppart3 1020 rack1.spa1.diskEncl1.disk10.ppart1 0.00 10 1003 rack1.spa1.spu7.dpart6 1013 rack1.spa1.diskEncl1.disk3.ppart1 1020 rack1.spa1.diskEncl1.disk10.ppart3 0.00
The status of a data slice shows the health of the data slice. Table 5-5 describes the status values for a data slice. You see these states when you run the nzds command or display data slices using the NzAdmin or Web Admin UIs. Table 5-5: Data Slice Status State Healthy Repairing Degraded Description The data slice is operating normally and has both a primary and mirror partition. The data slice is in the process of being regenerated to a spare disk due to a disk failure. The data slice has no mirror and therefore is in a degraded state.
20282-14
Rev.1
5-17
regenerating. The data slice IDs which reside on the same source disk will both be regenerated to the same spare disk. For more information about regeneration, see Mirroring Overview on page 5-19. To regenerate the data slices (ID 11 and 17) affected by the failing disk and regenerate them on spare disk ID 1024:
nzds regen -u admin -pw password -ds "11,17" -dest 1024
Note: On a TwinFin system, regeneration can take several hours to complete. If the system is idle and has no other activity except the regen, or if the user data partitions are not very full, the regeneration takes less time to complete. You can review the status of the regeneration using the nzds show -regenStatus command. During the regeneration, note that user query performance can be impacted while the system is busy processing the regeneration. Likewise, user query activity can increase the time required for the regeneration. To check the status of regeneration:
nzds show -regenStatus Data Slice Spu Source Destination Start Time % Done ---------- ---- ------ ----------- ----------- ------1 1003 1011 1015 0.00 2 1003 1011 1015 0.00 9 1003 1013 1020 0.00 10 1003 1013 1020 0.00
A regeneration setup failure could occur if the system manager cannot remove the failed disk from the RAID array, or if it cannot add the spare disk to the RAID array. If a regeneration failure occurs, or if a spare disk is not available for the regeneration, the system continues processing jobs. The data slices that lost their mirror continue to operate in an unmirrored or Degraded state; however, you should replace your spare disks as soon as possible and ensure that all data slices are mirrored. If an unmirrored disk should fail, the system will be brought to a down state.
5-18
20282-14
Rev.1
You can use the nzds command to rebalance the data slice topology. The system also performs the rebalance check each time the system is restarted, or after a SPU failover or a disk regeneration setup failure. To rebalance the data slices:
nzds rebalance -u admin -pw password
If a rebalance is not required, the command displays a message that a rebalance is not necessary and exits without performing the step.
Mirroring Overview
Mirroring increases the reliability and the availability of the user databases and tables in your system. Mirroring maintains one redundant and consistent copy of all data stored on each of your primary data slices. The Netezza mirroring design partitions each disk so that it has two sets of user data: The first set is the primary data slice of data to be managed by the SPU that owns the disk/data slice. The second is the mirror partition, which is a backup, identical copy of another disks primary data slice. Mirroring handles the following tasks: Replicating data modifications on the primary disk partition to the corresponding mirror partition. Supporting failover, which means that when a disk fails to respond, automatically switching to the mirrored copy of the data. Regenerating the primary partition of a failed disk to a spare disk by using the copy on the mirror, and regenerating the mirror partition of a failed disk to a spare disk using the primary data. Each Netezza system contains a number of spare disks. When the system detects that a disk has failed, and thus it can no longer respond to queries on the data in its primary data slice, the system begins to use the secondary or mirror partition to process the query results. Query processing continues, although one disk is now responding to query results from both its primary data slice and its mirror partition, and thus may be a query performance bottleneck for a short while. In the background, the Netezza system starts a regeneration process to recreate the failed disk onto a spare disk. The system copies the data for the primary and mirror partitions from the available sources onto the spare disk. After the regen process completes, the Netezza system handles the query responsibilities for its primary until the system has completed its data slice regeneration to a spare disk. Figure 5-5 highlights this mirroring allocation on TwinFin systems: The disk holding data slice 4 fails. Disk 3 starts responding to requests for both its own primary data slice and its mirror of the primary data slice from disk 4. The system begins a data slice regeneration to copy the primary and mirror data to the spare disk, making it a copy of disk 4 while the system continues to process queries.
20282-14
Rev.1
5-19
SPU
1 3 5
Data slice 1 has a primary location on disk 1011 and a secondary/mirror location on disk 1030. Data slice 2 has a primary location on disk 1030 and a mirror location on disk 1011.
If the disk holding data slice 4 fails, the disk regeneration process copies the primary and mirror partitions from disk 3 to a spare disk.
Waits for the transaction to finish. Returns an error. Aborts only those transactions that Queues the transaction. cannot be restarted.
5-20
20282-14
Rev.1
Table 5-6: System States and Transactions System State Pause(ing) Active Transactions New Transactions
The following examples provide specific instances of how the system handles failovers that happen before, during, or after data is returned. If the pause -now occurs immediately after a BEGIN command completes, before data is returned, the transaction is restarted when the system returns to an online state. If a statement such as the following completes and then the system transitions, the transaction can restart because data has not been modified and the reboot does not interrupt a transaction.
BEGIN; SELECT * FROM emp;
If a statement such as the following completes, but the system goes transitions before the commit to disk, the transaction is aborted.
BEGIN; INSERT INTO emp2 FROM emp;
A statement such as the following can be restarted if it has not returned data, in this case a single number that represents the number of rows in a table. This sample includes an implicit BEGIN command.
SELECT count(*) FROM small_lineitem;
If a statement such as the following begins to return rows before the system transitions, the statement will be aborted.
INSERT INTO emp2 SELECT * FROM externaltable;
Note that this transaction, and others that would normally be aborted, would be restarted if the nzload -allowReplay option applied to the associated table. Note: There is a retry count for each transaction. If the system transitions to pause -now more than the number of retries allowed, the transaction is aborted.
20282-14
Rev.1
5-21
Power Procedures
This section describes how to power on a Netezza TwinFin system as well as how to poweroff the system. Typically, you would only need to power off the system if you are moving the system physically within the data center, or in the event of possible maintenance or emergency conditions within the data center. The instructions to power on or off a Netezza Skimmer system are available in the Netezza Site Preparation Guide for Skimmer Systems. Note: To power cycle a Netezza system, you must have physical access to the system to press power switches and to connect or disconnect cables. Netezza systems have keyboard/ video/mouse (KVM) units which allow you to enter administrative commands on the hosts.
Figure 5-6: TwinFin 6 (and larger) PDUs and Circuit Breakers To close the circuit breakers (power up the PDUs), press in each of the 9 breaker pins until they engage. Be sure to close the 9 pins on both main PDUs in each rack of the system. To open the circuit breakers (power off the PDUs), pull out each of the 9 breaker pins on the left and the right PDU in the rack. If it becomes difficult to pull out the breaker pins using your fingers, you could use a tool such as a pair of needle-nose pliers to gently pull out the pins. On the TwinFin3 models, the main input power distribution units (PDUs) are located on the right and left sides of the rack, as shown in Figure 5-7.
5-22
20282-14
Rev.1
Power Procedures
OFF
ON
Figure 5-7: TwinFin 3 PDUs and Circuit Breakers At the top of each PDU is a pair of breaker rocker switches. (Note that the labels on the switches are upside down when you view the PDUs.) To close the circuit breakers (power up the PDUs), you push the On toggle of the rocker switch in. Make sure that you push in all four rocker switches, two on each PDU. To open the circuit breakers (power off the PDUs), you must use a tool such as a small flathead screwdriver; insert the tool into the hole labelled OFF and gently press until the rocker toggle pops out. Make sure that you open all four of the rocker toggles, two on each PDU.
20282-14
Rev.1
OFF
ON
OFF
ON
5-23
4. Log in as root to one of the hosts and confirm that the Netezza software has started as follows: a. Run the crm_mon command to obtain the cluster status:
[root@nzhost1 ~]# crm_mon -i5 ============ Last updated: Tue Jun 2 11:46:43 2009 Current DC: nzhost1 (key) 2 Nodes configured. 3 Resources configured. ============ Node: nzhost1 (key): online Node: nzhost2 (key): online Resource Group: nps drbd_exphome_device (heartbeat:drbddisk): Started nzhost1 drbd_nz_device (heartbeat:drbddisk): Started nzhost1 exphome_filesystem (heartbeat::ocf:Filesystem): Started nzhost1 nz_filesystem (heartbeat::ocf:Filesystem): Started nzhost1 fabric_ip (heartbeat::ocf:IPaddr): Started nzhost1 wall_ip (heartbeat::ocf:IPaddr): Started nzhost1 nz_dnsmasq (lsb:nz_dnsmasq): Started nzhost1 nzinit (lsb:nzinit): Started nzhost1 fencing_route_to_ha1 (stonith:apcmaster): Started nzhost2 fencing_route_to_ha2 (stonith:apcmaster): Started nzhost1
b. Identify the active host in the cluster, which is the host where the nps resource group is running:
[root@nzhost1 ~]# crm_resource -r nps -W crm_resource[5377]: 2009/06/01_10:13:12 info: Invoked: crm_resource -r nps -W resource nps is running on: nzhost1
2. Log in as root to the standby host (nzhost2 in this example) and run the following command to stop heartbeat:
[root@nzhost2 ~]# service heartbeat stop
5-24
20282-14
Rev.1
Power Procedures
3. Log in as root to the active host (nzhost1 in this example) and run the following command to stop heartbeat:
[root@nzhost1 ~]# service heartbeat stop
4. As root on the standby host (nzhost2 in this example) , run the following command to shut down the host:
[root@nzhost2 ~]# shutdown -h now
5. As root on the active host, run the following command to shut down the host:
[root@nzhost1 ~]# shutdown -h now
6. Wait until you see the power lights on both hosts shut off. 7. Do one of the following steps depending upon which TwinFin model you have: For a TwinFin 6, 12, or larger model, pull out the 9 breaker pins on both the left and right lower PDUs as shown in Figure 5-6 on page 5-22. (Repeat these steps for each rack of the system.) For a TwinFin 3 model, use a small tool such as a pocket screwdriver to open the two breaker switches on both the left and right PDUs as shown in Figure 5-7 on page 5-23. 8. Disconnect the main input power cables (two per rack) from the data center power drops. (As a best practice, do not disconnect the power cords from the plug/connector on the PDUs in the rack; instead, disconnect them from the power drops outside the TwinFin rack.)
20282-14
Rev.1
5-25
5-26
20282-14
Rev.1
CHAPTER 6
Managing the Netezza Server
Whats in this chapter
Software Revision Levels System States Managing the System State System Errors System Logs System Configuration
This chapter describes how to manage the Netezza server and processes. The Netezza software that runs on the appliance can be stopped and started for maintenance tasks, so this chapter describes the meaning and impact of system states. This chapter also describes log files and where to find operational and error messages for troubleshooting activities. Although the system is configured for typical use in most customer environments, you can also tailor software operations to meet the special needs of your environment and users using configuration settings.
When you enter the nzrev -rev command, Netezza returns the entire revision number string, including all fields (such as variant and patch level, which in this example are both zero).
nzrev -rev 6.0.0-0.B-1.P-0.Bld-12478
6-1
From a client system, you can use the nzsystem showRev -host host -u user -pw password command to display the revision information.
Revision Stamp Build Stamp CheckSum ------------------------ --------------------------------- -------------Directory 6.0.0-0.B-1.P-0.Bld-12478 2010-04-15.12478.dev.cm.12478 1821... ab685... 3a52... 6.0.0-0.B-1.P-0.Bld-12478 2010-04-15.12478.dev.cm.12478 d3f2...
Table 6-1 describes the components of the Revision Stamp fields. Table 6-1: Netezza Software Revision Numbering Major Numeric Incremented for major releases. Minor Numeric Incremented for minor releases. Subminor Numeric Incremented for service packs. -Variant Numeric Usually 0. Used very rarely. .Stage Alphanumeric Indicates a stage of a release. D (development), A (alpha), and B (beta) are internal, F (final) is for released software. The sample output shows D-1. .Patch (P-n) Alphanumeric Incremented for fix releases. Note that all patches are cumulative and apply to a specific, existing release. .Build (Bld-n) Alphanumeric Incremented serially for every production build. Note that the prefix cm denotes a production build.
System States
The Netezza system state is the current operational state of the appliance. In most cases, the system is online and operating normally. There may be times when you need to stop the system to perform maintenance tasks or as part of a larger procedure. You can manage the Netezza system state using the nzstate command. It can display as well as wait for a specific state to occur. For more information about the nzstate command syntax and options, see nzstate on page A-44.
6-2
20282-14
Rev.1
System States
Table 6-2 lists the common system states and how they are invoked and exited. Table 6-2: Common System States States Online Description Select this state to make the Netezza fully operational. This is the most common system state. In this state, the system is ready to process or is processing user queries. Invoked The system enters this state when you use the nzsystem restart or resume command, or after you boot the system. Exited The system exits the online state when you use the nzsystem stop, offline, pause, or restart commands.
Note: You can also use the nzsystem restart command to quickly stop and start all server software. You can only use the nzsystem restart command on a running Netezza that is in a non-stopped state.
Offline
Select this state to interrupt the Netezza. The system enters this state when you use the nzsystem In this state, the system completes any running queries, but displays errors for any offline command. queued and new queries. Select this state when you expect a brief The system enters the paused state when you use the nzsysinterruption of server availability. In this tem pause command. state, the system completes any running queries, but prevents queued or new queries from starting. Except for the delay while in the paused state, users should not notice any interruption in service. The system enters the down state if there is insufficient hardware for the system to function even in failover mode. For more information about the cause of the Down state, use the nzstate -reason command. Not user invokeable.
The system exits this state when you use the nzsystem resume or stop command. The system exits the paused state when you use the nzsystem resume or stop command, or if there is a hardware failure on an active SPU. You must repair the system hardware and then use the nzsystem resume command. The system exits the stopped state when you use the nzstart command.
Paused
Down
Stopped Select this state for planned tasks such as installation of new software. In this state, the system waits for currently running queries to complete, prevents queued or new queries from starting, and then shuts down all Netezza software.
The system enters the stopped state when you use the nzsystem stop or the nzstop command. Note that if you use the nzstop command, the system aborts all running queries.
Note: When you specify the nzsystem pause, offline, restart, and stop commands, the system allows already running queries to finish unless you use the -now switch, which immediately aborts all running queries. For more information about the nzsystem command, see nzsystem on page A-51.
20282-14
Rev.1
6-3
Discovered
Going Offline (Now) The system is in an interim state going to offline now. Going Pre-Online Going to Maintain Initialized Initializing Maintain Missing Offline (Now) The system manager has detected a new, unknown SPU in a slot that was previously occupied but not deleted. This state is similar to offline, except that the system stops user jobs immediately during the transition to offline. For more information, see Table 5-4 on page 5-7. The system is running normally. It can service requests. The system is paused. You cannot run user jobs. This state is similar to paused, except that the system stops user jobs immediately during the transition to paused. For more information, see Table 5-4 on page 5-7. The system uses this state during the initial startup sequence. The system is initializing. You cannot execute queries or transactions in this state. The system is in an interim state, going to pre-online.
6-4
20282-14
Rev.1
System States
Table 6-3: System States Reference State Pausing Description The system is transitioning from online to paused. During this state no new queries or transactions are queued, although the system allows current transactions to complete, unless you have specified the nzsystem pause -now command. The system is attempting to pause due to a hardware failure, or the administrator entered the nzsystem pause -now command. The system has completed initialization. The system goes to the resume state. The system is waiting for all its components (SPUs, SFIs, and host processes) to reach the online state before changing the system state to online. The system is not running. Note that commands assume this state when they attempt to connect to a system and get no response. The SPUs can never be in this state. This state is similar to stopped, except that the system stops user jobs immediately during the transition to stopped. The system is transitioning from online to stopped. The system is attempting to stop, or the administrator entered the nzsystem stop -now command. The system manager cannot communicate with the SPU because it has failed or it has been physically removed from the system.
Stopped
To wait for the online state or else timeout after 10 seconds, enter:
nzstate waitfor -u admin -pw password -host nzhost -type online -timeout 10
20282-14
Rev.1
6-5
Do some maintenance.
nzsystem resume nzstate waitfor -u admin -pw password -host nzhost -type online -timeout 120
Run a query.
Note: You must run nzstart on the host and be logged on as the user nz. You cannot run it remotely from Netezza client systems.
6-6
20282-14
Rev.1
Note: You must run nzstop on the host and be logged on as the user nz. You cannot run it remotely. To stop the system, enter:
nzstop
To stop the system or exit after attempting for five minutes (300 seconds), enter:
nzstop -timeout 300
Enter y to continue. The transition completes quickly on an idle system, but it can take much longer if the system is busy processing active queries and transactions. When the transition completes, the system enters the paused state, which you can confirm with the nzstate command as follows:
[nz@nzhost ~]$ nzstate System state is 'Paused'.
You can use the -now option to force a transition to the paused state, which causes the system to abort any active queries and transactions. As a best practice, you should use the nzsession show -activeTxn command to display a list of the current active transactions before you force the system to terminate them.
The command usually completes very quickly; you can confirm that the system has returned to the online state using the following command:
[nz@nzhost ~]$ nzstate System state is 'Online'.
20282-14
Rev.1
6-7
Enter y to continue. The transition completes quickly on an idle system, but it can take much longer if the system is busy processing active queries and transactions. When the transition completes, the system enters the offline state, which you can confirm with the nzstate command as follows:
[nz@nzhost ~]$ nzstate System state is 'Offline'.
You can use the -now option to force a transition to the offline state, which causes the system to abort any active queries and transactions. As a best practice, you should use the nzsession show -activeTxn command to display a list of the current active transactions before you force the system to terminate them.
commands.
Launches an instance of the backupsvr or restoresvr to handle each client
instance. bootsvr
Informs TFTP client (the SPUs and SFIs) of the location of their initial
6-8
20282-14
Rev.1
process(es).
Dynamically generates C code to process the query, and cross-compiles
dbosEvent
so on) and sends the final results back to the clients postgres, backup, or restore process. eventmgr
Processes events and event rules. When an event occurs, such as the sys-
tem changes state, a hardware component fails or is restarted, the eventmgr checks to see if any action needs to be taken based on the event and if so, performs the action. The action could be sending an email message or executing an external program.
For more information about event rules, see Chapter 7, Managing Event
Rules. loadmgr
Handles incoming connections from the nzload command. Launches an instance of the loadsvr to handle each instance of the
invokes the internal VACUUM command on system catalogs to remove unneeded rows from system tables and compact disk space to enable faster system table scanning.
During system operation, the nzvacuumcat program monitors the amount
of host disk space used by system tables in each database. It perfoms this check every 60 seconds. If the system catalog disk space for a particular database grows over a threshold amount (128 KB), the nzvacuumcat program initiates a system table vacuum (VACUUM) on that database.
The VACUUM command works on system tables only after obtaining an
exclusive lock on all system catalog tables. If it is unable to lock the system catalog tables, it quits and retries. Only when the VACUUM command succeeds does the nzvacuumcat program change the size of the database.
While the VACUUM command is working, the system prevents any new
SQL or system table activity to start. This window of time is usually about 1 to 2 seconds, but can be longer if significant amounts of system catalog updates/deletes have occurred since the last VACUUM operation.
20282-14
Rev.1
6-9
executing. Note that two default postgres jobs are associated with the sysmgr and the sessionmgr processes. postmaster
Accepts connection requests from clients (nzsql, ODBC, and so on). Launches one postgres process per connection to service the client.
sessionmgr Keeps the session table current with the state of the different sessions that are running the system.
For more information, see Session Manager on page 6-16.
startupsvr
Launches and then monitors all of the other processes. If any system pro-
cess should die, the startupsvr follows a set of predefined rules, and either restarts the failed process or restarts the entire system.
Controlled by /nz/kit/sys/startup.cfg
statsmgr
Handles requests for statistics from the nzstats command. For more information, see Statistics Server on page 6-17.
statsSvr
statistics.
Note that the nzstats command communicates with the sysmgr to obtain
6-10
20282-14
Rev.1
System Errors
When you power up (or reset) the hardware, each SPU loads an image from its flash memory and executes it. This image is then responsible for running diagnostics on the SPU, registering the SPU with the host, and downloading runtime images for the SPUs CPU and the FPGA disk controller. The system downloads these images from the host through TFTP.
System Errors
During system operation different types of errors can occur. Table 6-5 describes some of those errors. Table 6-5: Error Categories Category User error Component failure Environment failure Recoverable internal error Nonrecover -able internal error Description An error on the part of the user, usually due to incorrect or invalid input. Example Invalid user name, invalid SQL syntax.
A hardware or software system compo- SPU/SFI failure; host process nent failure. crashes. A request of an environment facility fails. This is often due to resource or access problems. A file is locked; a buffer is full.
A detected internal programming error Unknown case value or msg that is not severe enough to abort the type; file close fails. program. A detected internal programming error Core, memory corruption, assert or corrupt internal state that requires fails. the program to abort.
The Netezza system can take the following actions when an error occurs: Display an error message Presents an error message string to the users that describes the error. Generally the system performs this action whenever a user request is not fulfilled. Try again During intermittent or temporary failures, keep trying until the error condition disappears. The retries are often needed when resources are limited, congested, or locked. Fail over Switches to an alternate or spare component, because an active component has failed. Failover is a system-level recovery mechanism and can be triggered by a system monitor or an error detected by software trying to use the component. Log the error Adds an entry to a component log. A log entry contains a date and time, a severity level, and an error/event description. Send an event notification Sends notification through e-mail or by running a command. The decision whether to send an event notification is based on a set of userconfigurable event rules.
20282-14
Rev.1
6-11
Abort the program Terminates the program, because it cannot continue due to an irreparably damaged internal state or because continuing would corrupt user data. Software asserts that detect internal programming mistakes often fall into this category, because it is difficult to determine that it is safe to continue. Clean up resources Frees or releases resources that are no longer needed. Software components are responsible for their own resource cleanup. In many cases, resources are freed locally as part of each specific error handler. In severe cases, a program cleanup handler runs just before the program exits and frees/releases any resources that are still held.
System Logs
All major software components that run on the host have an associated log. Log files have the following characteristics: Each log consists of a set of files stored in a component-specific directory. For managers, there is one log per manager. For servers, there is one log per session, and their log files have pid and/or date (<pid>.<yyyy-mm-dd>) identifiers. Each file contains one day of entries, for a default maximum of seven days. Each file contains entries that have a timestamp (date and time), an entry severity type, and a message. The system rotates log files, that is, for all the major components there are the current log and the archived log files. For all Netezza components (except postgres) The system creates a new log file at midnight if there is constant activity for that component. If, however you load data on Monday and then do not load again until Friday, the system creates a new log file dated the previous day from the new activity, in this case, Thursday. Although the size of the log files is unlimited, every 30 days the system removes all log files that have not been accessed. For postgres logs By default, the system checks the size of the log file daily and rotates it to an archive file if it is greater than 1 GB in size. The system keeps 28 days (four weeks) of archived log files. (Netezza Support can help you to customize these settings if needed.) To view the logs, log onto the host as user nz. To enable SQL logging, see Logging Netezza SQL Information on page 8-29. For more information about these processes, see Overview of the Netezza System Processing on page 6-8.
Log file
/nz/kit/log/backupsvr/backupsvr.log Current backup log /nz/kit/log/restoresvr/restoresvr.log Current restore log
6-12
20282-14
Rev.1
System Logs
Output
2004-05-13 08:03:12.791696 EDT Info: NZ-00022: --- program 'bnrmgr' (5006) starting on host romeo-8400 ... ---
Bootserver Manager
The bootsvr log file records the initiation of all SPUs on the system, usually when the system is restarted by the nzstart command and also all stopping and restarting of the bootsvr process.
Log file
/nz/kit/log/bootsvr/bootsvr.log Current log /nz/kit/log/bootsvr/bootsvr.YYYY-MM-DD.log Archived log
Output
2004-05-13 08:07:31.548940 EDT Info: Number of boots currently in progress= 12
Client Manager
The clientmgr log file records all connection requests to the database server and also all stopping and starting of the clientmgr process.
Log file
/nz/kit/log/clientmgr/clientmgr.log Current log /nz/kit/log/clientmgr/clientmgr.YYYY-MM-DD.log Archived log
Output
2004-05-13 14:09:31.486544 EDT Info: admin: login successful
Log file
/nz/kit/log/dbos/dbosDispatch.log Current log /nz/kit/log/dbos/dbosDispatch.YYYY-MM-DD.log Archived log
Output
2004-05-13 14:08:57.230602 EDT Info: plan queued: plan ID = 848, Q ID = 3, cli ID = 220, cli SID = 10497, cli UID = 5604, cli PID = 28173
20282-14
Rev.1
6-13
Plan ID The plan number queued or started. This number relates to the corresponding execution plan in the nz/data/plans directory. The system increments it for each new portion of SQL processed and resets it to 1 when you restart the system. Q ID The queue to which this plan has been assigned. cli ID The ID of the client process. cli SID The ID related to the ID returned from the nzsession. cli UID The unique ID of the dbos client. Every time a client connects it receives a unique number. cli PID The process ID of the calling process running on the Netezza host. Tx ID The unique transaction identifier.
Event Manager
The eventmgr log file records system events and the stopping and starting of the eventmgr process.
Log file
/nz/kit/log/eventmgr/eventmgr.log Current log /nz/kit/log/eventmgr/eventmgr.YYYY-MM-DD.log Archived log
Output
2004-05-06 06:00:29.147609 GMT: Info: invoking mail notifier, cmd = '/nz/kit.1.2.2/ sbin/ sendMail -dst "[email protected],[email protected]" -msg "NPS system went from online to pausing at 04-May-06, 06:00:29 GMT." -bodyText "NPS system went from online to pausing at 04-May-06, 06:00:29 GMT.\n\nEvent:\neventType: sysStateChanged\neventTimestamp: 04-May-06, 06:00:29 GMT\neventArgs: previousState=online, currentState=pausing\n\n"' 04-May-06 06:00:41 GMT: Info: received & processing event type = sysStateChanged, event args = 'previousState=pausing, currentState=paused' Event type The event that triggered the notification. Event args The argument being processed. Notifier cmd The type of notification. In this case because mail was sent, the sendMail command ran. -dst The destination address. -msg The mail header. -BodyText The body of the mail.
Log file
/nz/kit/log/fcommrtx/fcommrtx.log Current log
6-14
20282-14
Rev.1
System Logs
Output
2006-03-02 13:40:33.554519 EST Info: NZ-00023: --- program 'fcommrtx' (21713) exiting on host 'nps23170' ... 2006-03-02 13:41:12.665290 EST Info: NZ-00022: --- program 'fcommrtx' (5209) starting on host 'nps23174' ... 2006-03-02 13:47:35.595067 EST Info: NZ-00023: --- program 'fcommrtx' (5209) exiting on host 'nps23174' ...
Log file
/nz/kit/log/fcommrtx/fcommrx.log Current log /nz/kit/log/fcommrtx/fcommrx.2006-03-01.log Archived log
Output
2006-03-02 13:40:33.550352 EST Info: NZ-00023: --- program 'fcommrx' (21712) exiting on host 'nps23170' ...
Log file
/nz/kit/log/hostStatsGen/hostStatsGen.log Current log /nz/kit/log/hostStatsGen/hostStatsGen.YYYY-MM-DD.log Archived log
Output
2004-05-13 08:01:21.831314 EDT Info: NZ-00022: --- log file 'hostStatsGen' (13524) starting on host victor ...
Load Manager
The loadmgr log file records details of load requests, and the stopping and starting of the loadmgr.
Log file
/nz/kit/log/loadmgr/loadmgr.log Current log /nz/kit/log/loadmgr/loadmgr.YYYY-MM-DD.log Archived log
Output
2004-05-13 14:45:07.454286 EDT Info: NZ-00022: --- log file 'loadmgr' (12225) starting on host victor ...
20282-14
Rev.1
6-15
Postgres
The postgres log file is the main database log file. It contains information about database activities.
Log file
/nz/kit/log/postgres/pg.log Current log /nz/kit/log/postgres/pg.log.n Archived log
Output
2006-03-23 14:50:09.075458 EST [2672] DEBUG: connection: host=[local] user=admin database=dev
Session Manager
The sessionmgr log file records details about the starting and stopping of the sessionmgr process, and any errors associated with this process.
Log file
/nz/kit/log/sessionmgr/sessionmgr.log Current log /nz/kit/log/sessionmgr/sessionmgr.YYYY-MM-DD.log Archived log
Output
2004-05-13 14:11:38.736245 EDT Info: NZ-00023: --- program 'sessionmgr' (4928) exiting on host romeo-8400 ... ---
Log file
/nz/kit/log/spucores/
Startup Server
The startupsvr log file records the start up of the Netezza processes and any errors encountered with this process.
Log file
/nz/kit/log/startupsvr/startupsvr.log Current log /nz/kit/log/startupsvr/startupsvr.YYYY-MM-DD.log Archived log
Output
2004-05-13 15:47:08.934277 EDT Info: NZ-00022: --- program 'startupsvr' (23124) starting on host romeo-8400 ... ---
6-16
20282-14
Rev.1
System Configuration
Statistics Server
The statssvr log file records the details of starting and stopping the statsSvr and any associated errors.
Log file
/nz/kit/log/statsSvr/statsSvr.log Current log /nz/kit/log/statsSvr/statsSvr.YYYY-MM-DD.log Archived log
Output
2004-05-13 08:03:12.715148 EDT Info: NZ-00022: --- program 'statsSvr' (5000) starting on host romeo-8400 ... ---
System Manager
The sysmgr log file records details of stopping and starting the sysmgr process, and details of system initialization and system state status.
Log file
/nz/kit/log/sysmgr/ sysmgr.log
Output
2004-05-06 22:40:52.485191 EDT Info: NZ-01500: system state change from 'Initializing' to 'Going Pre-Online'
System Configuration
The system configuration file, system.cfg, contains configuration settings that the Netezza system uses for system startup, system management, host processes, and SPUs. The system configuration file is also known as the system registry. Entries in the system.cfg file allow you to control and tune the system.
20282-14
Rev.1
6-17
As a best practice, you should not change or customize the system registry unless directed to by Netezza Support or by a documented Netezza procedure. The registry contains numerous entries, some of which are documented for use or for reference. Most settings are internal and used only under direction from Netezza Support. Incorrect changes to the registry can cause performance impacts to the Netezza system. Many of the settings are documented in Appendix D, System Configuration File Settings. You can display the system configuration file settings using the nzsystem showRegistry command. For more information, see nzsystem on page A-51. Note: A default of zero in many cases indicates a compiled default not the actual value zero. Text (yes/no) and numbers indicate actual values.
The output from the command is very long; only a small portion is shown in the example.
6-18
20282-14
Rev.1
CHAPTER 7
Managing Event Rules
Whats in this chapter
Template Event Rules Managing Event Rules Template Event Reference
The Netezza event manager monitors the health, status, and activity of the Netezza system operation and can take action when a specific event occurs. Event monitoring is a proactive way to manage the system without continuous human observation. You can configure the event manager to continually watch for specific conditions such as machine state changes, hardware restarts, faults, or failures. In addition, the event manager can watch for conditions such as reaching a certain percentage of full disk space, queries that have been running for longer than expected, and other Netezza system behaviors. This chapter describes how to administer the Netezza system using event rules that you create and manage.
7-1
Table 7-1 lists the predefined template event rules. Table 7-1: Template Event Rules Template Event Rule Name Disk80PercentFull Description Notifies you when a disks space is more than 80 percent full. Specifying Disk Space Threshold Notification on page 7-22. Notifies you when a disks space is more than 90 percent full. Specifying Disk Space Threshold Notification on page 7-22. Notifies you when the system detects an error correcting code (ECC) error. For more information, see Monitoring for ECC Errors on page 7-26. Notifies you when a hardware component successfully reboots. For more information, see Hardware Restarted on page 7-21 Notifies you of the failure of a hardware component. Notifies you if there is a problem that prevents the current query history collection from writing files to the staging area. Notifies you if there is a problem that prevents the loading of the query history files in the staging area to the target query history database. Notifies you when the system goes from the online state to another state. For more information, see Specifying System State Changes on page 7-19. Notifies you when the system cannot set up a data slice regeneration. Notifies you when a query exceeds its duration limit. For more information, see Specifying Runaway Query Notification on page 7-24. Notifies you when the system manager detects that one or both disks in a mirrored pair have failed, or when an FPGA error occurs. Notifies you when a disks SCSI SMART threshold is exceeded. Notifies you when the system detects that a SPU process has restarted and resulted in a core file. For more information, see Monitoring SPU Cores on page 7-34.
Disk90PercentFull
EccError
HardwareRestarted
HardwareServiceRequested HistCaptureEvent
HistLoadEvent
HostNoLongerOnline
SCSIDiskError
SCSIPredictiveFailure SpuCore
7-2
20282-14
Rev.1
Table 7-1: Template Event Rules Template Event Rule Name SystemHeatThresholdExceeded Description When any three boards in an SPA reach the red temperature threshold, the event runs a command to shut down the SPAs, SFIs, and RPCs. For more information, see Monitoring System Temperature on page 7-30. Enabled by default for z-series systems only. Notifies you when the system is online. For more information, see Specifying System State Changes on page 7-19. Notifies you when the system is stuck in the Pausing Now state for more than the timeout specified by the sysmgr.pausingStateTimeout (420 seconds). For more information, see Specifying System State Changes on page 7-19. Notifies you when the temperature of a hardware component has exceeded its operating thresholds. For more information, see Monitoring Hardware Temperature on page 7-29. Notifies you when the voltage of a hardware component has exceeded its operating thresholds. For more information, see Monitoring Voltage Faults on page 7-35.
SystemOnline
SystemStuckInState
ThermalFault
VoltageFault
Note: Netezza may add new event types to monitor conditions on the system. These event types may not be available as templates, which means you must manually add a rule to enable them. For a description of additional TwinFin event types that could assist you with monitoring and managing the system, see Event Types Reference on page 7-36. The action to take for an event often depends on the type of event (its impact on the system operations or performance). Table 7-2 lists some of the predefined template events and their corresponding impacts and actions. Table 7-2: Netezza Template Event Rules Template Name Disk80PercentFull Disk90PercentFull Type hwDiskFull (Notice) Notify Admins, DBAs Severity Impact Moder- Full disk preate to vents some Serious operations. Action Reclaim space or remove unwanted databases or older data. For more information, see Specifying Disk Space Threshold Notification on page 7-22.
20282-14
Rev.1
7-3
Table 7-2: Netezza Template Event Rules Template Name EccError Type eccError (Notice) Notify Admins, NPS Severity Impact Moderate No impact. Records correctable memory errors. Any query or data load in progress is lost. Action Ignore if occasional, replace when occurs often. For more information, see Monitoring for ECC Errors on page 7-26. Investigate whether the cause is hardware, software. Check for SPU cores. For more information, see Hardware Restarted on page 7-21. Contact Netezza. For more information, see Hardware Service Requested on page 7-20.
HardwareRestarted
hwRestarted (Notice)
Admins, NPS
Moderate
HardwareServiceRequested
hwServiceRequested (Warning)
Admins, NPS
Moder- Any query or ate to work in Serious progress is lost. Disk failures initiate a regeneration. Moder- Query history ate to is unable to Serious save captured history data in the staging area; query history will stop collecting new data. Moder- Query history ate to is unable to Serious load history data into the database; new history data will not be available in reports until it can be loaded. Varies Availability status.
HistCaptureEvent
histCaptureEvent
Admins, NPS
The size of the staging area has reached the configured size threshold, or there is no available disk space in /nz/ data. Either increase the size threshold or free up disk space by deleting old files.
HistLoadEvent
histLoadEvent
Admins, NPS
The history configuration may have changed, the history database may have been deleted, or there may be some kind of session connection error.
HostNoLongerOnline SystemOnline
sysStateChanged (Information)
Depends on the current state. For more information, see Specifying System State Changes on page 7-19.
7-4
20282-14
Rev.1
Table 7-2: Netezza Template Event Rules Template Name SystemStuckInState Type Notify Severity Impact Moderate A system is stuck in the pausing now state. May prevent user data from being regenerated. Can consume resources needed for operations. Action Contact Support. See Monitoring the System State on page 7-25.
RegenFault
Critical
Contact Netezza Support. For more information, see Monitoring Regeneration Errors on page 7-27. Determine whether to allow to run, manage workload. For more information, see Specifying Runaway Query Notification on page 7-24. Schedule disk replacement as soon as possible. See Monitoring Disk Errors on page 7-28. Schedule disk replacement as soon as possible. See Monitoring for Disk Predictive Failure Errors on page 7-25. The system created a SPU core file. See Monitoring SPU Cores on page 7-34. Before powering on machine, check the SPA that caused this event to occur. For more information, see Monitoring System Temperature on page 7-30 Contact Netezza Support. For more information, see Monitoring Hardware Temperature on page 7-29. For more information, see Monitoring Voltage Faults on page 7-35.
RunAwayQuery
runawayQuery (Notice)
Admins, DBAs
Moderate
SCSIDiskError
scsiDiskError
Admins, NPS
SCSIPredictiveFailure
scsiPredictiveFailure
Admins, NPS
SpuCore
spuCore
Moderate Critical
SystemHeatThresholdExceeded
sysHeatThreshold
ThermalFault
Serious Can drastically reduce disk life expectancy if ignored. Serious May indicate power supply issues.
VoltageFault
hwVoltageFault
Admins, NPS
20282-14
Rev.1
7-5
When you copy a template event rule, which is disabled by default, your new rule is likewise disabled by default. You must enable it using the -on yes argument. In addition, if the template rule sends email notifications, you must specify a destination email address.
When you copy an existing user-defined event rule, note that your new rule will be enabled automatically if the existing rule is enabled. If the existing rule is disabled, your new rule is disabled by default. You must enable it using the -on yes argument. You must specify a unique name for your new rule; it cannot match the name of the existing user-defined rule.
Generating an Event
You can use the nzevent generate command to trigger an event for the event manager. If the event matches a current event rule, the system takes the action defined by the event rule. You might generate events for the following cases: To simulate a system event to test an event rule. To add new events, because the system is not generating events for conditions for which you would like notification.
7-6
20282-14
Rev.1
If the event that you want to generate has a restriction, specify the arguments that would trigger the restriction using the -eventArgs option. For example, if a runaway query event has a restriction that the duration of the query must be greater than 30 seconds, use a command similar to the following to ensure that a generated event is triggered:
nzevent generate -eventtype runawayquery -eventArgs 'duration=50'
In this example, the duration meets the event criteria (greater than 30) and the event is triggered. If you do not specify a value for a restriction argument in the -eventArgs string, the command uses default values for the arguments. In this example, duration has a default of 0, so the event would not be triggered since it did not meet the event criteria. To generate a event for a system state change:
nzevent generate -eventType sysStateChanged -eventArgs 'previousState=online, currentState=paused'
Note: If you are creating event rules on a Windows client system, use double quotes instead of single quotes to specify strings.
20282-14
Rev.1
7-7
To add an event rule that sends a message to a pager using the pageOffice.sh script when the system state changes to any state other than online, enter:
nzevent add -name SendMessageToPager -u admin -pw password -on yes -eventType sysStateChanged -eventArgsExpr '$previousState == online && $currentState != online' -notifyType runCmd -dst '$NZ_KIT_DIR/ usr/pageOffice.sh' -msg 'NPS system $HOST went from $previousState to $currentState at $eventTimestamp.' -bodyText '$notifyMsg\n\nEvent:\n$eventDetail\nEvent Rule:\n$eventRuleDetail'
previousState, currentState, <any system state>, <Event Source> eventSource hwType, hwId, spaId, spaSlot, devSerial, devHwRev, devFwRev, eventSource
spu, <SPU HW ID>, <SPA ID>,
<SPA Slot>, <SPU/SFI Serial>, <Hardware Revision>, <Firmware Revision>, <Event Source>
sfi, <SFI HW ID>, <SPA ID>, <SPA
<SPA Slot>
ps, <POWER SUPPLY HW ID>,
7-8
20282-14
Rev.1
Table 7-3: Event Types Event Type hwRestarted Tag Name hwType, hwId, spaId, spaSlot, devSerial, devHwRev, devFwRev Possible Values
spu, <SPU HW ID>, <SPA ID>,
<SPA Slot>
ps, <POWER SUPPLY HW ID>,
<SPA ID>, <SPA Slot> hwDiskFull hwType, hwId, spaId, spaSlot, partition, threshold,value spu, <SPU HW ID>, <Spa Id>,<SPA Slot>, <partition #>, <threshold>, <value>
For more information, see Specifying Disk Space Threshold Notification on page 7-22. runawayQuery sessionId, planId, duration <Session Id>, <Plan Id>, <seconds>
For more information, see Specifying Runaway Query Notification on page 7-24. custom1 or custom2 User-specified rule. Use with the nzevent generate command. For more information, see Creating a Custom Event Rule on page 7-18. hwType, hwId, spaId, spaSlot, attrId, attrName, curThreshold, npsThreshold, mfgThreshold, devSerial, diskSerial, diskModel, diskMfg spu, <SPU HW ID>, <SPA ID>, <SPA Slot>, <Attr ID>, <Attr Name>, <Current Threshold>, <NPS Threshold>, <Mfg Threshold>, <SPU/SFI Serial>, <Disk Serial>, <Disk Model>, <Disk Manufacturer>
smartThreshold (Used only on zseries systems such as the 10000-series, 8000z-series, and 5200-series systems.) eccError
hwType, hwId, spaId, spaSlot, errType, errCode, devSerial, devHwRev, devFwRev hwId, partition, sector, dataSliceId, tableId, lock, devSerial, diskSerial, diskModel, diskMfg
spu, <SPU HW ID>, <SPA ID>, <SPA Slot>, <Err Type>, <Err Code>, <SPU/ SFI Serial>, <Hardware Revision>, <Firmware Revision> <RegenSource HW Id>, <Partition>, <Sector>, <DataSlice>, <Table>, <Block>, <SPU/SFI Serial>, <Disk Serial>, <Disk Model>, <Disk Manufacturer>
regenError (Used only on z-series systems such as the 10000-series, 8000z-series, and 5200-series systems.)
20282-14
Rev.1
7-9
Table 7-3: Event Types Event Type diskError (Used only on z-series systems such as the 10000-series, 8000z-series, and 5200-series systems.) hwHeatThreshold (Used only on zseries systems such as the 10000-series, 8000z-series, and 5200-series systems.) sysHeatThreshold Tag Name hwType, hwId, spaId, spaSlot, errType, errCode,oper, retries, partition, lba, tableId, dataSliceId,block, fpgaEngineId, devSerial, diskSerial, diskModel, diskMfg hwType, hwId, spaId, spaSlot, devSerial, errType, errCode, errString Possible Values spu, <SPU HW ID>, <SPA ID>, <SPA Slot>, <Err Type>, <Err Code>, <Oper>, <Retries>, <Partition>, <LBA>, <Table>, <DataSlice>, <Block>, <FPGA Engine Id>, <SPU/ SFI Serial>, <Disk Serial>, <Disk Model>, <Disk Manufacturer> spu, <SPU HW ID>, <SPA ID>, <SPA Slot>, <Serial Number>, <Err Type>, <Err Code>, <Err String> sfi, <SPU HW ID>, <SPA ID>, <SPA Slot>, <Serial Number>, <Err Type>, <Err Code>, <Err String>
For more information, see Monitoring System Temperature on page 7-30. fwMismatch (Used hwId, hwType, spaId, spaSlot, devSerial, devHonly on z-series wRev, devFwRev systems such as the 10000-series, 8000z-series, and 5200-series systems.) systemStuckInState duration, currentState, expectedState spu, <SPU HW ID>, <SPA ID>, <SPA Slot>, <SPU/SFI Serial>, <Hardware Revision>, <Firmware Revision>
For more information, see Specifying System State Changes on page 7-19. histCaptureEvent configName, histType, storageLimit, loadMinThreshold, loadMaxThreshold, diskFullThreshold, loadInterval, nps, database, capturedSize, stagedSize, storageSize, dirName, errCode, errString <Config Name>, <query/audit>, <Storage Limit>, <Min Threshold>, <Max Threshold>, <Disk Full Threshold>, <Load Interval>, <Target NPS>, <Target DB Name>, <Captured Size MB>, <Staged Size MB>, <Storage(total) Size MB>, <Dir Name>, <Err Code>, <Err String>
7-10
20282-14
Rev.1
Table 7-3: Event Types Event Type histLoadEvent Tag Name configName, histType, storageLimit, loadMinThreshold, loadMaxThreshold, diskFullThreshold, loadInterval, nps, database, batchSize, stagedSize, dirName, errCode, errString hwType, hwId, label, location, curVolt, errString, eventSource Possible Values <Config Name>, <query/audit>, <Storage Limit>, <Min Threshold>, <Max Threshold>, <Disk Full Threshold>, <Load Interval>, <Target NPS>, <Target DB Name>, <Batch Size MB>, <Staged Size MB>, <Dir Name>, <Err Code>, <Err String>
SPU, <SPU HW ID>, <Label
hwVoltageFault
<Label String>, <Location String>, <Current Voltage>, <Err String>, <Event Source> spuCore regenFault hwId, location, errString, eventSource hwIdSpu, hwIdSrc, locationSrc, hwIdTgt, locationTgt, errString, devSerial, eventSource hwType, hwId, location, errString, devSerial, eventSource <HW ID>, <Location String>, <Err String>, <Event Source> <SPU HW ID>, <Source Disk HW ID>, <Source Disk Location>, <Target Disk HW ID>, <Target Disk Location>,<Error String>, <SPU Serial>, <Event Source>
spu, <SPU HW ID>, <Location
hwServiceRequested
20282-14
Rev.1
7-11
Table 7-3: Event Types Event Type scsiDiskError Tag Name spuHwId, diskHwId, location, errType, errCode,oper, dataPartition, lba, tableId, dataSliceId,devSerial, fpgaBoardSerial, diskSerial, diskModel, diskMfg, eventSource spuHwId, diskHwId, scsiAsc, scsiAscq,fru, location, devSerial, diskSerial, diskModel, diskMfg, eventSource hwType, hwId, label, location, devSerial, errString, curVal, eventSource Possible Values <SPU HW ID>, <Location String>, <Err Type>, <Err Code>, <Oper>, <Data Partition>, <LBA>, <Table>, <DataSlice>, <Block>, <SPU Serial>, <FPGA Board Serial>, <Disk Serial>, <Disk Model>, <Disk Manufacturer>, <Event Source> <SPU HW ID>, <Disk HW ID>, <SCSI ASC>, <SCSI ASCQ>,<Fru>, <Location String>, <SPU Serial>, <Disk Serial>, <Disk Model>, <Disk Manufacturer>, <Event Source> spu, <SPU HW ID>, <Label String>, <Location String>, <SPU Serial>, <Error String>, <Current Value>, <Event Source> Disk Enclosure, <Encl HW ID>, <Label String>, <Location String>, <Error String>, <Current Value>, <Event Source>
scsiPredictiveFailure
hwThermalFault
For more information, see Monitoring Hardware Temperature on page 7-29. transactionLimitEvent fpgaQdrFailure CurNumTX hwId, location, fpgaType, fpgaStrap, qdrSize, devSerial hwType, hwId, location, interfaceName, prevState, currState hwId, location, initialNumCore, lastNumCore, curNumCore <Current Number of Transactions> <SPU HW ID>, <Location String>, <FPGA Type>, <FPGA Strap>, <QDR Size>, <DAC Serial Number> <HW TYPE>, <HW ID>, <Location String>, <interface name>, <previous state>, <current state> <SPU HW ID>, <Location String>, <Number of CPU cores of SPU on initialization>, <Last Number of Online CPU cores of SPU>, <Current Number of Online CPU Cores of SPU>
nwIfChanged
numCpuCoreChanged
7-12
20282-14
Rev.1
For example, to receive an e-mail message when the system is not online, it is not enough to create an event rule for a sysStateChanged event. Because the sysStateChange event recognizes every state transition, you could be notified whenever the state changes at all, such as from online to paused. You can add an event args expression to further qualify the event for notification. If you specify an expression, the system substitutes the event arguments into the expression before evaluating it. The system uses the result in conjunction with the event type to determine a match. So, to send an e-mail message when the system is no longer online, you would use the expression: $previousState == online && $currentState!=online. The system gets the value of previousState and currentState from the actual argument values of a sysStateChanged event. You can specify an event using equality expressions, wildcard expressions, compound AND expressions, or OR expressions. Table 7-4 describes these expressions. Table 7-4: Event Argument Expression Syntax Expression EqualityExpr WildcardExpr Syntax <string> == <string> <string> != <string> <string> ~ <string> <string> !~ <string> EqualityExpr && EqualityExpr EqualityExpr || EqualityExpr Example $hwType == spu $hwType != spu '$errString ~ *spu*' '$errString !~ *ascq*' '$previousState == online && $currentState != online '$threshold == 80 || $threshold == 85
AndExpr OrExpr
20282-14
Rev.1
7-13
7-14
20282-14
Rev.1
Table 7-5: Notification Substitution Tags Source Environment Tag NZ_HOST NZ_DIR Description The host environment variable. The nz directory. For more information about these directories, see Directory Structure on page 2-10. The nz bin directory. The nz data directory. The nz kit directory. The nz log directory. The nz sbin directory. The nz system directory. The nz temp directory.
If you specify the email or runCmd arguments, you must enter the destination and the subject header. You can use all the following arguments with either command, except the -ccDst argument, which you cannot use with the runCmd. Table 7-6 lists the syntax of the message. Table 7-6: Notification Syntax Argument -dst Description Your e-mail address Example -dst [email protected],[email protected] You can specify multiple recipients. -msg NPS system $HOST went from $previousState to $currentState at $eventTimestamp. This message substitutes the hostname for $HOST, the previous system state for $previousState, the current system state for $currentState, and the date and time the event occurred for $eventTimeStamp.
-msg
-bodyText
Optional body of the e-mail -bodyText '$notifyMsg\n\nEvent:\n$eventDemessage tail\nEvent Rule:\n$eventRuleDetail' This message substitutes the text in the -msg argument for the $notifyMsg, outputs a newline and the word Event then the contents of the eventType through eventArgs, newline and the word Event Rule and then the contents of eventArgsExpr through notifyCallHomeFile.
20282-14
Rev.1
7-15
Table 7-6: Notification Syntax Argument -ccDst Description Optional cc specification Example -ccDst [email protected],[email protected] You can specify multiple recipients. -callHome yes
-callHome
Optional file
7-16
20282-14
Rev.1
If you issue the nzstop command, the system sends no in-memory aggregations, instead it updates the event log. In such cases, you should check the event log, especially if the aggregation interval is 15 minutes or longer. If you modify or delete an event rule, the system flushes all events aggregated for the event rule.
20282-14
Rev.1
7-17
7-18
20282-14
Rev.1
The valid values for the previousState and currentState arguments are:
initializing initialized offlining offliningNow offline offlineNow online restrictedOnline pausing pausingNow paused pausedNow preOnline preOnlining resuming restrictedResuming stopping stoppingNow stopped stoppedNow syncing synced syncingNow syncedNow failingBack failedBack maintaining maintain recovering recovered down unreachable badState
For more information about states, see Table 5-4 on page 5-7. Table 7-7 describes the state changes. Table 7-7: System State Changes Previous State Online Current State Not Online Severity Notify Varies Admins, NPS, DBAs Impact Action
20282-14
Rev.1
7-19
Table 7-7: System State Changes Previous State Not Online Not Synchronizing Synchronizing Current State Online Severity Notify n/a Admins, NPS, DBAs Admins, NPS Admins, NPS Impact Normal Query processing suspended until complete Query processing resumed when Online Action None None
Synchronizing n/a
Contact Netezza
Table 7-8 lists the arguments to the Hardware Service Requested event rule. Table 7-8: Hardware Service Requested Event Rule Arguments hwType Description The type of hardware affected Example Disk, Disk enclosure power supply, disk enclosure fan, SPU, AMM, chassis power supply, chassis fan 1013
hwId location
The hardware ID of the component that has reported a problem A string that describes the physical location of the component
7-20
20282-14
Rev.1
Table 7-8: Hardware Service Requested Event Rule Arguments errString Description If the failed component is not inventoried, it will be specified in this string. Specifies the serial number of the component, or Unknown if the component has no serial number. 601S496A2012 Example
devSerial
Hardware Restarted
If you enable the event rule HardwareRestarted, you receive notifications when each SPU successfully re-boots (after the initial startup). Restarts are usually related to a software fault, whereas hardware causes could include uncorrectable memory faults or a failed disk driver interaction. The following is the syntax for the event rule HardwareRestarted:
Event Rule HardwareRestarted
-name HardwareRestarted -on no -eventType hwRestarted -eventArgsExpr '' -notifyType email -dst '[email protected]' -ccDst '' -msg 'NPS system $HOST - $hwType $hwId restarted at $eventTimestamp.' -bodyText '$notifyMsg\n\nSPA ID: $spaId\nSPA Slot: $spaSlot\n' -callHome yes eventAggrCount 50
You can modify the event rule to specify that the system include the devices serial number, its hardware revision, and firmware revision as part of the message and/or subject. Table 7-9 describes the arguments to the Hardware Restarted event rule. Table 7-9: Hardware Restarted Event Rule Arguments hwType hwId spaId spaSlot Description The type of hardware affected Example spu, sfi, ps, fan
The hardware ID of the regen source SPU 1013 having the problem The ID of the SPA The SPA slot number A number between 1-32 For SPUs, a number between 1-14. For fans, L, M, R. For power supplies, L or R. 601S496A2012 7.21496rA2.21091rB1 1.36
The serial number of the SPU or SFI The hardware revision The firmware revision
20282-14
Rev.1
7-21
Note: You should consider aggregating this event. Set the aggregation count to the number of SPUs in your system divided by 4. For more information about event aggregation, see Aggregating Event E-mail Messages on page 7-16.
Table 7-10 lists the arguments to the Disk Space event rules. Table 7-10: Disk Space Event Rules Arguments Description hwType hwId The type of hardware affected Example spu, sfi, disk
The hardware ID of the SPU (z-series) 1013 or disk (TwinFin) that has the disk space issue The ID of the SPA The SPA slot number The data slice number 0,1,2,3 75, 80, 85, 90, 95 84
threshold The threshold value value The actual percentage full value
After you enable the event rule, the event manager sends you an e-mail message when the system disk space percentage exceeds the first threshold and is below the next threshold value. Note that the event manager sends only one event per sampled value. For example, if you enable the event rule Disk80PercentFull, which specifies thresholds 80 and 85 percent, the event manager sends you an e-mail message when the disk space is at least 80, but less than 85 percent full. When you receive the e-mail message, your actual disk space might have been 84 percent full.
7-22
20282-14
Rev.1
The event manager maintains thresholds for the values 75, 80, 85, 90, and 95. Each of these values (except for 75) can be in the following states: Armed The system has not reached this value. Disarmed The system has exceeded this value. Fired The system has reached this value. Re-armed The system has fallen below this value. Note: If you enable an event rule after the system has fired a threshold, you will not be notified that you have reached this threshold until you restart the system. Table 7-11 lists these thresholds and their states. Table 7-11: Threshold and States Threshold 75 80 85 90 95 Armed never startup startup startup startup Fired never >= 80 && < 85 >= 85 && < 90 >= 90 && < 95 >= 95 Disarmed never >= 80 >= 85 >= 90 >= 95 Re-armed never < 75 < 80 < 85 < 90
After the Netezza System Manager sends an event for a particular threshold, it disarms all thresholds at or below that value. (So if 90 fires, it will not fire again until it is re-armed). The Netezza System Manager re-arms all disarmed higher thresholds when the disk space percentage full value falls below the previous threshold, which can occur when you delete tables or databases. The Netezza System Manager arms all thresholds (except 75) when the system starts up. Note: To ensure maximum coverage, enable both event rules Disk80PercentFull and Disk90PercentFull. To send an e-mail message when the disk is more than 80 percent full, enable the predefined event rule Disk80PercentFull:
nzevent modify -u admin -pw password -name Disk80PercentFull -on yes -dst [email protected]
If you receive diskFull notification from one or two disks, your data may be unevenly distributed across the data slices (data skew). Data skew can adversely affect performance for the tables involved and for combined workloads. For more information about skew, see Avoiding Data Skew on page 9-9. Note: You should consider aggregating the e-mail messages for this event. Set the aggregation count to the number of SPUs. For more information about aggregation, see Aggregating Event E-mail Messages on page 7-16.
20282-14
Rev.1
7-23
Table 7-12 lists the arguments to the Runaway Query event rule. Note that the arguments are case sensitive. Table 7-12: Runaway Query Event Rule Arguments sessionId planId duration Description The ID of the runaway session The ID of the plan The amount of time (seconds) that the problem has existed. Examples Use these arguments for the email message.
Note: Do not aggregate this event. You should consider the performance impact based on the individual runaway query. When you specify the duration argument in the -eventArgsExpr string, you can specify an operator such as: ==, !=, >, >=, <, or <= to specify when to send the event notification. As a best practice, use the greater-than (or less-than) versions of the operators to ensure that the Netezza sends an event notification when the notification is detected slightly after (or before) the query timeout expires. For example, to ensure that a notification event is triggered when the duration of a query exceeds 100 seconds, specify the eventArgsExpr as follows:
-eventArgsExpr '$duration > 100'
If a query exceeds its limit, the system sends you an e-mail message telling you how long the query has been running. For example:
NPS system alpha - long-running query detected at 07-Nov-03, 15:43:49 EST. sessionId: 10056 planId: 27 duration: 105 seconds
7-24
20282-14
Rev.1
As a best practice, it is important to monitor the transition to or from the Online state, which affects system availability.
Table 7-13 lists the output from the SCSIPredictiveFailure event rule. Table 7-13: SCSI Predictive Failure Event Rule Arguments spuHwId diskHwId scsiAsc scsiAscq Description The hardware ID of the SPU that owns or manages the disk that reported the event The hardware ID of the disk The attribute sense code, which is an identifier of the SMART attribute The attribute sense code qualifier of the SMART attribute 1013 Vendor specific Vendor specific Example
20282-14
Rev.1
7-25
Table 7-13: SCSI Predictive Failure Event Rule Arguments fru location devSerial diskSerial diskModel diskMfg Description The FRU ID for the disk The location of the disk The serial number of the SPU to which the disk is assigned The disks serial number The disks model number The disks manufacturer 601S496A2012 7.21496rA2.21091rB1 Example
You can monitor eccErrors through e-mail messages or through the NzAdmin tool. For more information about hardware alerts, see Displaying Alerts on page 7-37. Table 7-14 lists the output from the EccError event rule. Table 7-14: ECC Error Event Rule Arguments hwType hwId spaId spaSlot errType Description The type of hardware affected The hardware ID of the problem source SPU The SPA ID The SPA slot number The type of error, that is, whether the 1 (Failure), 2 (Failure immierror is the type failure, failure possible, nent) 3 (Failure possible), 4 or failure imminent (Failure unknown) Examples spu (and sfi for z-series systems) 1013
7-26
20282-14
Rev.1
Table 7-14: ECC Error Event Rule Arguments errCode devSerial devHwRev devFwRev Description The error code The serial number of the SPU The hardware revision The firmware revision Examples 12 601S496A2012 7.21496rA2.21091rB1 1.36
The event rule RegenFault is enabled by default. Table 7-15 lists the output from the event rule RegenFault. Table 7-15: Regen Fault Event Rule Arguments hwIdSpu hwIdSrc locationSrc hwIdTgt locationTgt errString devSerial Description Examples
The hardware ID of the SPU that owns or manages 1013 the problem disk The hardware ID of the source disk The location string of the source disk The hardware ID of the target spare disk The location string of the target disk The error string for the regeneration issue The serial number of the owning or reporting SPU
20282-14
Rev.1
7-27
Table 7-16 lists the output from the SCSIDiskError event rule. Table 7-16: SCSI Disk Error Event Rule Argument spuHwId diskHwId location errType Description The hardware ID of the SPU that owns or manages the disk or FPGA The hardware ID of the disk where the error occurred The location string for the disk The type of error, that is, whether the 1 (Failure), 2 (Failure imminent) error is the type failure, failure possible, 3 (Failure possible), 4 (Failure or failure imminent unknown) The error code specifying the cause of the error 110 1013 Examples
errCode oper
The operation performed when the disk Decimal driver encountered the error; for TwinFin systems, the possible values are read or write The data partition number on which the 1 error occurred The logical block address where the error occurred The table ID where the error occurred 145214014 200350
7-28
20282-14
Rev.1
Table 7-16: SCSI Disk Error Event Rule Argument Description Examples 3 9
dataSliceId The data slice ID where the error occurred block devSerial fpgaBoardSerial diskSerial diskModel diskMfg The table-relative block number where the error occurred The serial number of the SPU that owns the disk or FPGA The serial number of the Netezza DB Accelerator card where the FPGA resides The disks serial number The disks model number The disks manufacturer
7.21496rA2.21091rB1 WesternDigital
20282-14
Rev.1
7-29
Table 7-17 lists the output from the Thermal Fault event rule. Table 7-17: Thermal Fault Event Rule Argument hwType hwId label Description The hardware type where the error occurred The hardware ID of the component where the fault occurred The label for the temperature sensor. For the Netezza DB Accelerator card, this is the BIE temperature. For a disk enclosure, it is temp-11 for the first temperature sensor on the first enclosure. A string that describes the physical location of the component The current temperature reading for the hardware component The error message The board temperature for the SPU exceeded 45 degrees centigrade. Examples SPU* or disk enclosure 1013
Table 7-18 lists the SystemHeatThresholdExceeded event rule arguments. Table 7-18: Sys Heat Threshold Event Rule Argument errCode errString Description The integer code for the onboard temper- 301 for warning, 302 for critical ature error The error message Thermal overload warning. Multiple devices are reporting excessive operating temperatures. Please investigate.
7-30
20282-14
Rev.1
Table 7-18: Sys Heat Threshold Event Rule Argument errType Description The type of error 4 (Unknown cannot fail over)
The default behavior is to execute the nzstop command and then use RPC to power off the Netezza system. Before you power on the machine, check the SPA that caused this event to occur. You may need to replace one or more SPUs or SFIs.
After you confirm that the temperature within the environment has returned to normal, you can power on the RPCs using the following command. Make sure that you are logged in as root or that your account has sudo permissions to run this command:
/nzlocal/scripts/rpc/spapwr.sh -on all
Table 7-19 describes the output from the histCaptureEvent rule. Table 7-19: histCaptureEvent Rule Arguments host Description The name of the Netezza system that had the history event The name of the active history configuration The storage limit size of the staging area in MB Examples nps1
configName
fullhist
storageLimit
20282-14
Rev.1
7-31
Table 7-19: histCaptureEvent Rule Arguments loadMinThreshold Description The minimum load threshold value in MB The maximum load threshold value in MB Reserved for future use. The load interval timer value in minutes The Netezza location of the history database The name of the query history database into which the captured data will be loaded The size in MB of the captured data currently being written to $NZ_DATA/ hist/staging/alc_$TIMESEQUENCE The size in MB of all staged files in the /nz/data/hist/loading directory The size in MB of capturedSize plus stagedSize The name of the directory which contains the currently captured data The number which represents the error problem:
97=History Storage Limit Exceeded 98=History Disk Full Threshold
Examples
loadMaxThreshold
localhost
database
capturedSize
stagedSize
storageSize dirName
alc_ $TIMESEQUENCE
errCode
could be a problem relating to a disk I/O error or an internal problem errString The text string (shown in errCode description) for the related error code History Storage Limit Exceeded
7-32
20282-14
Rev.1
=$nps\nTarget Database =$database\nLoaded Batch Size(MB) =$batchSize\nStaged Batches Size(MB) =$stagedSize\nBatch Directory =$dirName\nError Code =$errCode\nError Message = $errString\n' callHome yes -eventAggrCount 0
Table 7-20 describes the output from the histLoadEvent rule. Table 7-20: histLoadEvent Rule Arguments host configName storageLimit Description The name of the Netezza system that had the history event Name of the active history configuration The storage limit size of the staging area in MB The minimum load threshold value in MB The maximum load threshold value in MB Reserved for future use. The load interval timer value in minutes The location of the history database The name of the query history database into which the data failed to load The size in MB of the batch of history files which are currently being loaded (/nz/data/hist/loading/alc_$TIMESEQUENCE directory) The size in MB of all staged files in the /nz/ data/hist/loading directory except the batch which is currently loading The name of the directory which contains the staged batch files alc_ $TIMESEQUENCE localhost Examples nps1
batchSize
stagedSize
dirName
20282-14
Rev.1
7-33
Table 7-20: histLoadEvent Rule Arguments errCode Description The number which represents the error problem:
100=History Load Connection Failure
Examples
which indicates that the configuration used to collect the data could not be found on the system. The configuration may have been dropped or renamed before the files could be loaded. In this case, many fields in the event rule may be set to _UNKNOWN_ (for string fields) or 1 (for int fields).
102=History Load Failure, which could
be an ODBC failure such as corrupted configuration information, or an internal problem errString The text string (shown in errCode description) for the related error code History Load Config Info Not Found
Table 7-21 lists the output from the SpuCore event rule. Table 7-21: SPU Core Event Rule Argument hwId errString Description Examples
The hardware ID of the SPU on which a process 1013 cored Specifies the name of the process that created the core file
7-34
20282-14
Rev.1
Table 7-22 lists the output from the VoltageFault event rule. Table 7-22: Voltage Fault Event Rule Argument hwType hwId label Description The hardware type where the error occurred The hardware ID of the component where the fault occurred The label for the nominal voltage sensor. For example, voltage-1-1 represents the first voltage sensor in the first disk enclosure. For the Netezza DB Accelerator card, BIE 0.9V is an example for the 0.9V nominal voltage. A string that describes the physical location of the component Specifies the current voltage of the component, This value is a string which also includes the sensor that has exceeded the voltage threshold. Specifies more information about the voltage fault; if the problem component is the Netezza DB Accelerator card, it will be specified in the string. Examples SPU* or disk enclosure 1013
location curVolt
errString
20282-14
Rev.1
7-35
Note: The notification repeats every three hours if the object count remains above 90%, or when the object count drops below 85% but later reaches 59,000 again. Table 7-23 lists the output of the transaction limit event. Table 7-23: Transaction Limit Event Rule Argument curNumTX Description Specifies the current number of transaction objects which are in use. Examples
7-36
20282-14
Rev.1
Displaying Alerts
[nz@nzhost ~]$ nzevent add -name SpuNetIfChanged -eventType nwIfChanged -notifyType email -msg 'A network interface on a SPU has changed states.' -dst <your email here>
If a SPU has a core failure, the system manager also fails over that SPU.
Displaying Alerts
If the NzAdmin tool detects an alert, it displays the Alert entry in the navigation list. The NzAdmin tool displays each error in the list and indicates the associated component. The Component, Status, and other columns provide additional information. For the hardware alerts, the alert color indicator takes on the color of the related component. If, however, the component is green, the NzAdmin tool sets the alert color to yellow.
Figure 7-1: Alerts Window To view the alerts list, click the Alerts entry in the left pane. To get more information about an alert, double-click an entry or right-click and select Status to display the corresponding component status window. To refresh alerts, select View > Refresh or click the refresh icon on the toolbar.
20282-14
Rev.1
7-37
7-38
20282-14
Rev.1
CHAPTER 8
Establishing Security and Access Control
Whats in this chapter
Netezza Database Users and Groups Security Model Logon Authentication Netezza Client Encryption and Security Setting User and Group Limits Group Public Views
Managing security for the Netezza appliance is an important task. You can control access to the Netezza system itself by placing the appliance in a secured location such as a data center. You can control access through the network to your Netezza appliance by managing the Linux user accounts that can log in to the operating system. You control access to the Netezza database, objects, and tasks on the system by managing the Netezza database user accounts that can establish SQL connections to the system. This chapter describes how to manage Netezza database user accounts, and how to apply administrative and object permissions that allow users access to databases and tasks. This chapter also describes user session controls such as row limits and priority that help manage impacts to system performance by the database users. Note: Linux accounts allow users to log in to the Netezza server at the operating system level, but they cannot access the Netezza database via SQL. If some of your users require Linux accounts to manage the Netezza system as well as database accounts for SQL access, you could use identical names and passwords for the two accounts to ease management. For details on creating Linux user accounts, refer to your Linux documentation or the quick reference in Appendix B, Linux Host Administration Reference. Throughout this chapter, any references to users and groups imply Netezza database user accounts, unless otherwise specified.
8-1
assign permissions and access properties to that group, and then assign members to the group as applicable. The members of the group automatically inherit the groups permissions. If you remove a user from the group, the associated permissions for the group are likewise removed from the user. If a user is a member of more than one group, the user inherits the union of all permissions from those groups, plus whatever permissions may have been assigned to the user account specifically. So, for example, if you remove a user from a group that has Create Table permission or privileges, the user loses that permission unless the user is a member of another group that has been granted that privilege or the user account has been granted that privilege. As a best practice, you should use groups to manage the access permissions and rights of your database users rather than manage user accounts individually. Groups are an efficient and time-saving way to manage permissions, even if a group has only one member. Over time, you will typically add new users, drop existing users, and change user permissions as roles evolve. New Netezza software releases often add new permissions that you may have to apply to your users. Rather than manage these changes on an account-by-account basis, manage the permissions via groups and group membership. Note: You can also use Netezza groups as resource sharing groups (RSGs) for workload management. That is, you can create groups and assign them resource utilization percentages, which is the percentage of the Netezza resources that the group should receive when it and other RSGs are using the system. For a description of RSGs, see Chapter 12, Managing Workloads on the Netezza Appliance. You can create and manage Netezza database accounts and groups using any or a combination of the following methods: Netezza SQL commands, which are the most commonly used method NzAdmin tool, which provides a windows interface for managing users, groups, and permissions Web Admin, which provides web browser access to the Netezza system for managing users, groups, and permissions This chapter describes how to manage users and groups using the SQL commands. The online help for the NzAdmin and Web Admin interfaces provide more details on how to manage users and groups via those interfaces.
8-2
20282-14
Rev.1
General database users users who are allowed access to one or more databases for querying, and who may or may not have access to manage objects in the database. These users may also have lower priority for their work. Power database users users who require access to critical databases and who may use more complex SQL queries than the general users. These users may require higher priority for their work. They may also have permissions for tasks such as creating database objects, running user-defined objects (UDXs), or loading data. The access model serves as a template for the users and groups that you need to create, and also provides a map of access permission needs. By creating Netezza database groups to represent these roles or permission sets, you can easily assign users to the groups to inherit the various permissions, you can change all the users in a role by changing only the group permissions, and move users from one role to another by changing their groups, or by adding them to groups that control those permissions.
20282-14
Rev.1
8-3
The days value specifies the number of days that the password is valid, since the last date when the password changed. Specify a valid of 0 if you do not want passwords to expire using a system-wide setting. The default system setting is 0. You can specify user-specific password expiration dates using the CREATE|ALTER USER SQL commands.
8-4
20282-14
Rev.1
When a database users account expires, the user has very limited access to the Netezza system. The user can connect to the Netezza database, but the only query that the user is allowed to run is the following ALTER USER command, where newPassword represents their new account password:
SYSTEM(myuseracct)=> ALTER USER myuseracct SET PASSWORD 'newPassword'; ALTER USER
The admin user can expire a user account password immediately using the following command:
SYSTEM(ADMIN)=> ALTER USER myuseracct EXPIRE PASSWORD; ALTER USER
The expiration does not affect the users current session if the user is connected to a database. The next time that the user connects to a database, the user will have a restrictedaccess session and must change his password using the ALTER USER command.
The conf value is a string of parameters that specify the content requirements and restrictions: minlen Specifies the minimum length in characters (after deducting any credits) for a password. The default is the minimum value of 6; that is, even with credits, you cannot specify a password that is less than 6 characters. If you specify 10, for example, the user must specify at least 9 lowercase characters (with the lowercase letter default credit of 1) to meet the minimum length criteria. Note: There is a relationship between the minimum length of a password and its strength (that is, the use of mixed-case letters, digits, and non-alphanumeric characters that increase the complexity of the password string). If a user specifies only lowercase letters, which is considered a weak password, the minimum length of the password is minlen. If the user includes upper- and lowercase letters, digits, and symbols, the minlen requirement can be reduced with credits for the number and type of those additional characters. You can also use the credit values to require the presence of a minimum number of characters in the password. dcredit Specifies the maximum credit for including digits in the password. The default is 1 credit; if you specify a credit of 3, for example, the user receives 1 credit per digit up to the maximum of 3 credits to reduce the minlen requirement. If you specify a negative value such as -2, your users must specify at least two digits in their password.
20282-14
Rev.1
8-5
ucredit Specifies the maximum credit for including uppercase letters in the password. The default is 1 credit; if you specify a credit of 2, for example, the user receives 1 credit per uppercase letter up to the maximum of 2 credits to reduce the minlen requirement. If you specify a negative value such as -1, your users must specify at least one uppercase letter in their password. lcredit Specifies the maximum credit for including lowercase letters in the password. The default is 1 credit; if you specify a credit of 2, for example, the user receives 1 credit per lowercase letter up to the maximum of 2 credits to reduce the minlen requirement. If you specify a negative value such as -1, your users must specify at least one lowercase letter in their password. ocredit Specifies the maximum credit for including non-alphanumeric characters (often referred to as symbols such as #, &, or *) in the password. The default is 1 credit; if you specify a credit of 1, for example, the user receives 1 credit per nonalphanumeric character up to the maximum of 1 credits to reduce the minlen requirement. If you specify a negative value such as -2, your users must specify at least two non-alphanumeric characters in their password. For example, the following command specifies that the minimum length of a weak password is 10, and it must contain at least one uppercase letter. The presence of at least one symbol or digit allows for a credit of 1 each to reduce the minimum length of the password:
SYSTEM(ADMIN)=> SET SYSTEM DEFAULT PASSWORDPOLICY TO 'minlen=10, lcredit=0 ucredit=-1 dcredit=-1 ocredit=1'; SET VARIABLE
As another example, the following command specifies that the minimum length of a weak password is 8, it must contain at least two digits and one symbol; and the presence of lowercase characters offers no credit to reduce the minimum password length:
SYSTEM(ADMIN)=> SET SYSTEM DEFAULT PASSWORDPOLICY TO 'minlen=8, lcredit=0 dcredit=-2 ocredit=-1'; SET VARIABLE
8-6
20282-14
Rev.1
If you are using LDAP authentication, you do not specify a password for the account. The CREATE USER command has a number of options that you can use to specify timeout options, account expirations, rowset limits (the maximum number of rows a query can return), and priority for the users session and queries. The resulting user account is owned by the user who created the account. When you create users and groups, you can also specify session access time limits. The access time limits specify when users can start database sessions. User may be permitted to start sessions at any time on any day, or they may be given restricted access to certain days and/or certain hours of the day. If a user attempts to start a session during a time when they do not have access, the system displays an error message that they are outside their access time limits. Also, if a user attempts to run an nz* command that creates a database session, the command will also return the error if the user is not within the allowed access time window. For more information, see the access time information in the Netezza Advanced Security Administrators Guide. Note: Keep in mind that session settings such as access time restrictions, session timeouts, priority, and rowset limits, can be set on a per-user, per-group, and in some cases a system-wide level. The Netezza system checks the settings for a user first to find the values to use; if not set for the user, the system uses the group settings (whatever is the largest or highest settings for all the groups to which the user belongs); if not set for the group, the system uses the system-wide settings.
The command displays an error if the account that you want to drop owns objects; you must change the ownership of those objects or drop them before you can drop the user.
20282-14
Rev.1
8-7
The CREATE GROUP command also includes options that you can use to specify timeout options, rowset limits (the maximum number of rows a query can return), and priority for the sessions and queries of the group members. The resulting group is owned by the user who created the group. Note: Keep in mind that session settings such as timeouts, priority, and rowset limits, can be set on a per-user, per-group, and system-wide level. The Netezza system checks the settings for a user first to find the values to use; if not set for the user, the system uses the group settings (whatever is the largest or highest settings for all the groups to which the user belongs); if not set for the group, the system uses the system-wide settings.
Security Model
The Netezza security model is a combination of administrator privileges granted to users and/or groups, plus object privileges associated with specific objects (for example, table xyz) and classes of objects (for example, all tables). As part of the model, any privilege granted to a database group is automatically granted to (that is, inherited by) all the users who are members of that group. Note: Privileges are additive, which means that you cannot remove a privilege from a user who has been granted that privilege as a consequence of being a member of a group. Each object has an owner. Individual owners automatically have full access to their objects and do not require individual object privileges to manage them. The database owner, in addition, has full access to all objects within the database. The admin user owns all predefined objects and has full access to all administrative permissions and objects. For more information about the admin user, see Default Netezza Groups and Users on page 8-3.
Administrator Privileges
Administrator privileges give users and groups permission to execute global operations and to create objects.
8-8
20282-14
Rev.1
Security Model
Note: When you grant a privilege, the user you grant the privilege to cannot pass that privilege onto another user by default. If you want to allow the user to grant the privilege to another user, include the WITH GRANT OPTION when you grant the privilege. Table 8-1 describes the administrator privileges. Note that the words in brackets are optional. Table 8-1: Administrator Privileges Privilege Backup [Create] Aggregate [Create] Database [Create] External Table [Create] Function [Create] Group [Create] Index [Create] Library Description Allows the user to perform backups. The user can run the command nzbackup. Allows the user to create user-defined aggregates (UDAs), and to operate on existing UDAs. Allows the user to create databases. Permission to operate on existing databases is controlled by object privileges. Allows the user to create external tables. Permission to operate on existing tables is controlled by object privileges. Allows the user to create user-defined functions (UDFs) and to operate on existing UDFs. Allows the user to create groups. Permission to operate on existing groups is controlled by object privileges. For system use only. Users cannot create indexes. Allows the user to create user-defined shared libraries. Permission to operate on existing shared libraries.
[Create] Materialized Allows the user to create materialized views. View [Create] Procedure [Create] Sequence [Create] Synonym [Create] Table [Create] Temp Table [Create] User [Create] View Allows the user to create stored procedures. Allows the user to create database sequences. Allows the user to create synonyms. Allows the user to create tables. Permission to operate on existing tables is controlled by object privileges. Allows the user to create temporary tables. Permission to operate on existing tables is controlled by object privileges. Allows the user to create users. Permission to operate on existing users is controlled by object privileges. Allows the user to create views. Permission to operate on existing views is controlled by object privileges.
20282-14
Rev.1
8-9
Table 8-1: Administrator Privileges Privilege [Manage] Hardware Description Allows the user to perform the following hardware-related operations: view hardware status, manage SPUs, manage topology and mirroring, and run diagnostics. The user can run these commands: nzds and nzhw. Allows the user to perform commands and operations relating to history databases such as creating and cleaning up history databases. Allows the user to perform the following management operations: start/stop/pause/resume the system, abort sessions, and view the distribution map, system statistics, logs, and plan files from active query or query history lists. The user can use these commands: nzsystem, nzstate, nzstats, and nzsession priority. Allows the user to restore the system. The user can run the nzrestore command. Allows the user to create an unfenced user-defined function (UDF) or user-defined aggregate (UDA), or to unfence an existing fenced UDF or UDA if the user has permission to create or alter it. For more information, see the Netezza User-Defined Functions Developers Guide.
[Manage] Security
[Manage] System
Restore Unfence
8-10
20282-14
Rev.1
Security Model
Table 8-2: Object Privileges Privilege Delete Drop Execute GenStats Groom Description Allows the user to delete table rows. Applies only to tables. Allows the user to drop all objects. Allows the user to execute UDFs and UDAs in SQL queries. Allows the user to generate statistics on tables or databases. The user can run the GENERATE STATISTICS command. Allows the user to perform general housekeeping and cleanup operations on tables using the GROOM TABLE command. The GROOM TABLE command performs reclaim operations to remove deleted rows and also reorganizes tables based on the clustered base tables organizing keys. Allows the user to insert rows into a table. Applies only to tables. Allows the user to display an objects name, either in a list or in another manner. Applies to all objects. Allows the user to select (or query) rows within a table. Applies to tables and views. Allows the user to delete all rows from a table with no rollback. Applies only to tables. Allows the user to modify table rows, such as changing field values or changing the next value of a sequence. Applies to tables only.
20282-14
Rev.1
8-11
To assign a privilege to a class of objects in a particular database, sign on to the database and grant the privilege on the class to a user or group. When you assign a privilege to a class (such as table), the system allows the user or group that privilege on all the objects of that class whether or not the object existed at the time of the grant.
Assign privilege to object class
MYDB(ADMIN)=> GRANT SELECT ON TABLE TO user1 GRANT
To assign a privilege to a class of objects in all databases, sign on to the system database and grant the privilege on the class to a user or group.
Assign privilege to all databases
SYSTEM(ADMIN)=> GRANT SELECT ON TABLE TO user1 GRANT
Although the two previous GRANTS (GRANT SELECT ON TABLE TO user1) are identical, the effect of each statement is very different. The first is granted while you are connected to a particular database (MYDB). Therefore, the privilege affects only objects within the MYDB database. The second is granted while you are connected to the system database. This database has a special meaning because users cannot create objects within it. When you are defining privileges for user object classes within the system database, the system assumes you are requesting a global scope. Note: If both grants are issued on the same system, the grant issued within a database overrides the grant issued at the system level. Privilege Precedence Netezza uses the following order of precedence for permissions: 1. Privileges granted on a particular object within a particular database 2. Privileges granted on an object class within a particular database 3. Privileges granted on an object class within the system database You can assign multiple privileges for the same object for the same user. The Netezza system uses the rules of precedence to determine which privileges to use. For example, you can grant users privileges on a global level, but user privileges on a specific object or database level override the global permissions. For example, assume the following three GRANT commands: Within the system database, enter:
system(admin)=> GRANT SELECT,INSERT,UPDATE,DELETE,TRUNCATE ON TABLE TO user1
Using these grant statements and assuming that customer is a user table, user 1 has the following permissions: With the first GRANT command, user1 has global permissions to SELECT, INSERT, UPDATE, DELETE, or TRUNCATE any table in any database. The second GRANT command restricts user1s permissions specifically on the dev database. When user1 connects to dev, user1 can perform only SELECT, INSERT, or UPDATE operations on tables within that database.
8-12
20282-14
Rev.1
Security Model
The third GRANT command overrides privileges for user1 on the customer table within the dev database. As a result of this command, the only actions that user1 can perform on the customer table in the dev database are SELECT and LOAD. Table 8-3 lists the Netezza SQL built-in commands that you can use to display the privileges for users and groups Table 8-3: Netezza SQL Commands for Displaying Privileges Command Description \dg \dG \dp \dpg \dpu \du \dU Displays a list of all defined groups. Displays a list of all defined groups and the users in which they are members. Displays the list of all privileges assigned to a user, regardless of whether those privileges were assigned directly or through group membership. Displays a list of all privileges assigned to a group as a result of the GRANT command to the group. Displays a list of all privileges assigned to a user as a result of the GRANT command to the user. Displays a list of all defined users. Displays a list of all defined user and the group in which they are members.
Note: When revoking privileges, make sure you sign on to the same database where you granted the privileges, then use the commands in Table 8-3 to verify the results.
Revoking Privileges
You can revoke administrative and object privileges using the REVOKE command. When you revoke a privilege from a group, all the members of that group lose the privilege unless they have the privilege from membership in another group or via their user account. For example, to revoke the Insert privilege for the group public on the table films, enter:
SYSTEM(ADMIN)=> REVOKE INSERT ON films FROM PUBLIC; REVOKE
Privileges by Object
There are no implicit privileges. For example, if you grant a user all privileges on a database, you did not grant the user all privileges to the objects within that database. Instead, you granted the user all the valid privileges for a database (that is, alter, drop, and list).
20282-14
Rev.1
8-13
Table 8-4 describes the list of privileges by object. Table 8-4: Privileges by Object Privilege Aggregate Description Alter Change the name or ownership of a UDA Drop Drop a UDA Execute Execute a UDA in a query List List UDAs Alter Change the name of a database Drop Drop a database List See a database and sign on to it Alter Change the name or ownership of a function Drop Drop a function Execute Execute a function in a query List List functions Abort Abort a session Alter Change the name of a group Drop Drop a group List See a group Alter Change the name or ownership of a stored procedure Drop Drop a procedure Execute Execute a procedure in a query List List procedures Abort Abort a session or a transaction Alter Change the name of a user Drop Drop a user List See a user Alter Change the name of a table Delete Delete rows from a table Drop Drop a table GenStats Generate statistics for the table Insert Insert rows into a table List View a table Select Select rows in a table Truncate Delete all rows from a table Update Update rows from the table Delete Delete rows from a system table Insert Insert rows into a system table List View a system table Select Select rows in a system table Update Update rows from the system table
Database
Function
Group
Procedure
User
System Table
8-14
20282-14
Rev.1
Security Model
Table 8-4: Privileges by Object Privilege Sequence Description Alter Alter a sequence Drop Drop a sequence List List a sequence Select Select a sequence Update Use next value of a sequence List See a system view Select Select rows in a system view Alter Alter a synonym Delete Delete rows (if the synonym is pointed at a table) Drop Drop a synonym Insert Insert rows (if the synonym is pointed at a table) List List a synonym Select Select a synonym Update Update rows (if the synonym is pointed at a table) Alter Alter a view Drop Drop a view List See a view Select Select rows in a view
Database statistic
20282-14
Rev.1
8-15
5. Add users to the group to grant them the permissions of the group; for example:
SYSTEM(ADMIN)=> ALTER USER jlee WITH IN GROUP administrators; ALTER USER
or
SYSTEM(ADMIN)=> ALTER GROUP administrators WITH USER jlee, bob; ALTER GROUP
8-16
20282-14
Rev.1
Logon Authentication
Logon Authentication
The Netezza system offers two authentication methods for Netezza database users: Local authentication, where Netezza administrators define the database users and their passwords using the CREATE USER command or through the Netezza administrative interfaces. In local authentication, you use the Netezza system to manage database accounts and passwords, as well as to add and remove database users from the system. This is the default authentication method. LDAP authentication, where you can use an LDAP name server to authenticate database users and manage passwords as well as database account activations and deactivations. The Netezza system then uses a Pluggable Authentication Module (PAM) to authenticate users on the LDAP name server. Note that Microsoft Active Directory conforms to the LDAP protocol, so it can be treated like an LDAP server for the purposes of LDAP authentication. Authentication is a system-wide setting; that is, your users must be either locally authenticated or authenticated using the LDAP method. If you choose LDAP authentication, note that you can create users with local authentication on a per-user basis. Note that the Netezza host supports LDAP authentication for database user logins only, not for operating system logins on the host.
Local Authentication
Local authentication validates that the user name and password entered with the logon match the ones stored in the Netezza system catalog. The manager process that accepts the initial client connection is responsible for initiating the authentication checks and disallowing any future requests if the check fails. Because users can make connections across the network, the system sends passwords from clients in an opaque form. The Netezza system manages users names and passwords. It does not rely on the underlying (Linux) operating systems user name and password mechanism, other than on user nz, which runs the Netezza software. Note: When you create a new user for local authentication, you must specify a password for that account. You can explicitly create a user with a NULL password, but note that the user will not be allowed to log on if you use local authentication.
LDAP Authentication
The LDAP authentication method differs from the local authentication method in that the Netezza system uses the user name and password stored on the LDAP server to authenticate the user. Following successful LDAP authentication, the Netezza system also confirms that the user account is defined on the Netezza system. The LDAP administrator is responsible for adding and managing the user accounts and passwords, deactivating accounts, and so on, on the LDAP server. The Netezza administrator must ensure that each Netezza user is also defined within the Netezza system catalog. The Netezza user names must match the user names defined in the LDAP server. If the user names do not match, the Netezza administrator should use the ALTER USER command to change the user name to match the LDAP user name, or contact the LDAP administrator to change the LDAP user name. Note the following characteristics of LDAP authentication:
20282-14
Rev.1
8-17
After the LDAP authentication process completes successfully, the Netezza system looks up the user in the system catalog. The system displays an error message if it does not find the user, and it terminates the session. If authentication fails, you will see the message LDAP authentication failed. The system notes the reason for the failure in the /nz/kit/log/postgres/pg.log file. Netezza users should notice no difference between LDAP and local authentication. When you CREATE or ALTER a user account, a password is not required if you use LDAP authentication. (Local authentication continues to require a password for user accounts.) To use LDAP authentication, you use the SET AUTHENTICATION command to select LDAP authentication and specify the necessary configuration parameters. The command requires some information about the LDAP server, such as server name or IP address and some LDAP server configuration settings. The SET AUTHENTICATION command is described in detail in the Netezza Database Users Guide; the following sections describe some important administrative information about LDAP authentication.
8-18
20282-14
Rev.1
Logon Authentication
For example:
tls_cacertfile /nz/certs/cacert.pem tls_cert /nz/certs/clientcrt.pem tls_key /nz/certs/clientkey.pem
4. Use the SET AUTHENTICATION LDAP SSL ON command and any additional configuration arguments (based on your LDAP server configuration) to restore the LDAP authentication. Since the server is transitioning from local to LDAP authentication, it copies the ldap.conf file with your new certificate pathnames to ldap.conf.orig, and enables LDAP authentication. Note: After using the SET AUTHENTICATION command or making any manual changes to the ldap.conf file, restart the Netezza system using the nzstop and nzstart commands. This ensures that the Netezza system uses the latest settings from the ldap.conf file.
20282-14
Rev.1
8-19
Table 8-6: Authentication-Related Commands Command SHOW AUTHENTICATION Description Displays the Netezza systems current configuration for authentication. Creates a Netezza user, including an optional password. (When you create new users and use local authentication, you must specify a password.) Modifies a Netezza user account. (If you change from LDAP to local authentication, you may need to alter user accounts to ensure that they have a password defined on the Netezza system.)
CREATE USER
ALTER USER
8-20
20282-14
Rev.1
2. Locate the line containing the invalid_attempts. 3. Copy the line, paste the copy after the current line, remove the comment character (#), and change the value for invalid_attempts. 4. Save your changes. 5. Restart the Netezza system for your changes to take effect.
20282-14
Rev.1
8-21
If you use your own CA certificate files, make sure that you save the server CA files in a location under the /nz directory. If you have an HA Netezza system, save the certificates on the shared drive under /nz so that either host can access the files using the same pathname. You must also edit the /nz/data/postgresql.conf file to specify your server certificate files. To edit the postgresql.conf file to add your own CA server certificate and keys files, do the following: 1. Log in to the Netezza system as the nz user account. 2. Using any text editor, open the /nz/data/postgresql.conf file. Note: Use caution when editing postgresql.conf. It contains important configuration parameters for the Netezza system operation. 3. Locate the following section in the file:
# # Connection Parameters # #tcpip_socket = false ssl = true # Uncomment the lines below and mention appropriate path for the # server certificate and key files. By default the files present # in the data directory will be used. #server_cert_file='/nz/data/security/server-cert.pem' #server_key_file='/nz/data/security/server-key.pem'
4. Delete the pound sign (#) character at the beginning of the server_cert_file and server_ key_file parameters and specify the pathname of your CA server certificate and keys files where they are saved on the Netezza host. Client users must install a copy of the CA root certificate file on their client systems. The client users will specify the location of the CA root certificate when they run commands such as nzsql, nzhw, and others. Note: Make sure that the keys file is not password protected; by default, it is not. 5. Save and close the postgresql.conf file. Any changes that you make to the postgresql.conf file take effect the next time that the Netezza system is stopped and restarted.
8-22
20282-14
Rev.1
If your users are already located within the secure firewall of your network or they use a protocol such as ssh to securely connect to the Netezza system, you might require them to use unsecured communications, which avoids the performance overhead of secured communications. If you have one or more clients who are outside that firewall, you might require them to use secured connections. The Netezza system provides a flexible way to configure access security and encryption for your client users. To configure and manage the client access connections, you use the SET CONNECTION, DROP CONNECTION, and SHOW CONNECTION commands. These commands manage updates to the /nz/data/pg_hba.conf file for you, and provide mechanisms for remote updates, concurrent changes from multiple administrators, and protection from accidental errors editing the file. Note: Never edit the /nz/data/pg_hba.conf file manually. Use the Netezza SQL commands to specify the connection records for your Netezza system. A connection record has the following syntax:
type dbName ipAddress addressMask authType
The field descriptions follow: type specifies a connection record type. The type field can have one of the following values: host specifies the access permission for users who connect to Netezza databases using IP connections. Users in the specified IP range may use secured or unsecured connections; the Netezza host will accept either. hostssl specifies the access permission for only those users who connect to Netezza databases using SSL secured IP connections. Users in the specified IP range who request unsecured connections will be rejected. hostnossl specifies the authentication for users who request to connect with unsecured IP connections. Users in the specified IP range who request secured connections will be rejected. local specifies the authentication for users who connect over a UNIX socket; that is, they are logged in locally to the Netezza system, such as at the administration console. dbName specifies the name of the DB to which the user may request a connection. The value can be ALL to allow connections to any database on the Netezza system (as long as their user account has object permissions to that database) or a specific database name. ipAddress specifies an IP address in standard decimal notation for one or more client users who might connect to the Netezza system. This field is used only for host, hostssl, and hostnossl connection types. addressMask specifies an IP address mask in standard decimal notation to identify a range of one or more client users who might connect to the Netezza system. This field is used only for host, hostssl, and hostnossl connection types. For details about subnet masks, refer to any general TCP/IP documentation. For example, a mask of 0.0.0.0 indicates that the record is for a connection request from the specific ipAddress value. An ipAddress of 1.2.3.4 and a mask of 255.255.255.0 indicates that the record defines connection attempts for any client that has an IP address in the range of 1.2.3.1255.
20282-14
Rev.1
8-23
authType specifies the authentication method for the Netezza system. Specify this value when you create a connection record for local (for LDAP, you cannot specify an authentication type). The values are: trust, md5,crypt, password, and SHA_256. For more information about authentication methods, refer to Logon Authentication on page 8-17. For information on local values, see the Netezza Database Users Guide.
In the sample output, the connection requests define the following capabilities: Connection ID 1 specifies that the Netezza host will accept connection requests from any local user (someone logged in directly to the Netezza) to all databases. Connection ID 2 specifies that the host will accept either secured or unsecured connection requests from any local user (connecting via IP) to all databases. Connection ID 3 specifies that the host will accept either secured or unsecured connection requests from any remote client user (connecting via IP) to any database. It is important to note that the host may accept a connection request, but the user must still pass account authentication (username/password verification), as well as have permissions to access the requested database. The first record that matches the client connection information is used to perform authentication. If the first chosen record does not work, the system does not look for a second record. If no record matches, access is denied. With the default records shown above, any client user who accesses the Netezza and has proper user account and password credentials will be allowed a connection; they could request either secured or unsecured connections, as the Netezza host accepts either type.
This command adds a connection record to the database. A sample SHOW CONNECTION command follows, with the new record added as ID 3:
8-24
20282-14
Rev.1
SYSTEM(ADMIN)=> SHOW CONNECTION; CONNID | CONNTYPE | CONNDB | CONNIPADDR | CONNIPMASK | CONNAUTH --------+-----------+--------+-------------+-----------------+-------1 | local | all | | | trust 2 | host | all | 0.0.0.0 | 0.0.0.0 | md5 3 | hostssl | all | 1.2.3.4 | 255.255.255.255 | SHA256 (3 rows)
This example shows the importance of record precedence. Note that record ID 2 will be the first match for all of the users who remotely connect to the Netezza system. Because it is set to host, this record will allow either secured or unsecured connections based on the connection request from the client. To ensure that the user at 1.2.3.4 is authenticated for a secure connection, drop connection record 2 and add it again using a new SET CONNECTION record to place the more general record after the more specific record for 1.2.3.4.
20282-14
Rev.1
8-25
If the attribute is not set for the USER, use the MOST RESTRICTIVE value set for all of the groups of which that user is a member. If the attribute is not set for the user or any of the users groups, use the system default value. Table 8-8 describes these settings. Table 8-8: User and Group Settings Setting Rowset limit Scope User, group, and system Valid Range Default Value Description Maximum rowset limit per query. For more information, see Specifying User Rowset Limits on page 8-27. Maximum time allocated to a query. For more information, see Specifying Query Timeout Limits on page 8-27.
Query timeout
Unlimited (zero)
Session limit
Unlimited (zero)
When a SQL session is idle for longer than the specified period, the system terminates the session. For more information, see Specifying Session Timeout on page 8-28. Defines the default and maximum priority for the user or group.
Session priority
None
When you change these values, the system sets them at session startup and they remain in effect for the duration of the session. You specify the system defaults with the SET SYSTEM DEFAULT command. To display the system values, use the SHOW SYSTEM DEFAULT command. To set a system default, use a command similar to the following, which sets the default session timeout to 300 minutes:
SYSTEM(ADMIN)=> SET SYSTEM DEFAULT SESSIONTIMEOUT TO 300; SET VARIABLE
To show the system default for the session timeout, use the following syntax:
SYSTEM(ADMIN)=> SHOW SYSTEM DEFAULT sessiontimeout; NOTICE: 'session timeout' = '300' SHOW VARIABLE
8-26
20282-14
Rev.1
20282-14
Rev.1
8-27
The syntax to create a group and set the default priority is:
CREATE GROUP group_name WITH DEFPRIORITY TO HIGH;
8-28
20282-14
Rev.1
20282-14
Rev.1
8-29
Table 8-9 describes the common system views and the type of information that the view provides. In some cases, the view returns more than the information listed in the table. Table 8-9: Public Views View Name _v_aggregate _v_database _v_datatype _v_function _v_group _v_groupusers _v_operator _v_procedure Data Returned Objid, aggregate name, owner, and create date Objid, Database name, owner, and create date Objid, datatype, owner, description, and size Objid, function name, owner, create date, description, result type, and arguments Objid, Group name, owner, and create date Objid, Group name, owner, and user name Objid, operator, owner, create date, description, opr name, opr left, opr right, opr result, opr code, and opr kind Objid, procedure, owner, create date, object type, description, result, number of arguments, arguments, procedure signature, built in, procedure source, proc, executed as owner Objid, object name, owner, create date, object type, attr number, attr name, attr type, and not null indicator Objid, object name, owner, create date, object type, attr number, attr name, and attr default value Database owner, relation, constraint name, contype, conseq, att name, pk database, pk owner, pk relation, pk conseq, pk att name, updt_type, del_type, match_type, deferrable, deferred, constr_ord Objid, seq name, owner, and create date ID, PID, UserName, Database, ConnectTime, ConnStatus, and LastCommand Objid, table name, owner, and create date Objid, table name, owner, create date, dist attr number, and dist attr name Objid, User name, owner, valid until date, and create date Objid, User name, owner, and group name Objid, view name, owner, create date, rel kind, rel checks, rel triggers, has rules, unique keys, foreign keys, references, has p keys, and number attributes
8-30
20282-14
Rev.1
Table 8-10 describes the views that show system information. You must have administrator privileges to display these views. Table 8-10: System Views View Name _v_sys_group_priv _v_sys_index _v_sys_priv _v_sys_table _v_sys_user_priv _v_sys_view Output GroupName, ObjectName, DatabaseName, Objecttype, gopobjpriv, gopadmpriv, gopgobjpriv, and gopgadmpriv objid,SysIndexName, TableName, and Owner UserName, ObjectName, DatabaseName, aclobjpriv, acladmpriv, aclgobjpriv, and aclgadmpriv objid, SysTableName, and Owner UserName, ObjectName, DatabaseName, ObjectType, uopobjpriv, uopadmpriv, uopgobjpriv, and uopgadmpriv objid, SysViewName, and Owner
20282-14
Rev.1
8-31
8-32
20282-14
Rev.1
CHAPTER 9
Managing User Content on the Netezza Appliance
Whats in this chapter
Creating Databases and User Tables Creating Distribution Keys Avoiding Data Skew Using Clustered Base Tables Updating Database Statistics Grooming Tables Managing Sessions Running Transactions Netezza Optimizer and Query Plans Viewing Query Status and History
Unlike other database solutions, the Netezza appliance does not require a database administrator (DBA) to manage and control user databases. Instead, there are a few system administration tasks relating to the creation and management of the user content stored on the system. This chapter describes some basic concepts of Netezza databases, and some management and maintenance tasks that can help to ensure the best performance for user queries. You can manage Netezza databases and their objects using SQL commands that you run through the nzsql command (which is available on the Netezza system and in the UNIX client kits) as well as by using the NzAdmin tool, Web Admin interface, and data connectivity applications like ODBC, JDBC, and OLE DB. This chapter focuses on running SQL commands (shown in uppercase, such as CREATE DATABASE) via the nzsql command interface to perform tasks.
9-1
You cannot delete the system database. The admin user can also make another user the owner of a database, which gives that user admin-like control over that database and its contents. The database creator becomes the default owner of the database. The owner can remove the database and all its objects, even if other users own objects within the database. Within a database, permitted users can create tables and populate them with data for queries. For details on the loading process options, see Chapter 10, Loading Data into the Netezza Appliance.
N+2, or fewer, bytes, depending on char(n*) and varchar(n) Note that char data types of more than 16 bytes actual content are represented on disk as if they were varchar data types of the same nominal size. char(1) nchar(n*) and nvarchar(n) Note that nchar and nvarchar characters are always stored as if they were nvarchars. 1 byte N+2 to (4 * N) + 2
9-2
20282-14
Rev.1
Keep in mind the following characteristics of Netezza tables: In all tables, every record also includes three 8-byte special fields that represent a rowid, the transaction ID of the transaction that created the row, and the transaction ID of the transaction that deleted the row (which is 0 if the row has not been deleted). These columns are referred to as the special columns or specials. Every varchar data type whose declared size is greater than 16 and whose actual content is an odd number of bytes gets a pad byte. Most records also include a header that consists of a length (2 bytes) and a null vector (N/8 bytes, where N is the number of columns in the record). The system rounds up the size of this header to a multiple of 4 bytes. The only time a record does not contain a header is if there are no nullable columns and no variable-sized columns (varchar and char data types over 16 bytes). Because every record begins on a 4-byte boundary, round up your overall record size accordingly. The smallest unit of allocation on a data slice is an extent, which currently is 3 MB of disk space. Note that this number could change in future releases of the software.
20282-14
Rev.1
9-3
The system gives the host and each of the SPUs a block of sequential rowids that they can assign. When they use up a block, the system gives them another block, which explains why the rowids within a table are not always sequential. The system stores the rowid with each database record. It is an 8-byte integer value. You can use the rowid keyword in a query to select, update, or delete records. For example:
SELECT rowid, lname FROM employee_table; UPDATE employee_table SET lname = John Smith WHERE rowid = 234567;
Querying by some other field, such as name, might be difficult if you have 10 John Smiths in the database. In a new installation, the initial rowid value is 100,000. The next available rowid value is stored in the /nz/data/RowCounter file.
9-4
20282-14
Rev.1
Calculating compression ratios... The values below show the estimated size ratio of a compressed table to its uncompressed form. An uncompressed table is approximately <ratio> times larger than its compressed version. Estimates are more accurate for large tables and those without skew. Other values shown include the compressed table size, an estimate of the uncompressed table size, and the storage savings gained by compressing the table. tablename | database | ratio | compressed_mb | uncompressed_mb | saved_mb ----------+----------+-------+---------------+-----------------+--------saledeml | sales | 4.68 | 1,278.63 | 5,983.97| 4,705.34 saledim | sales | 2.71 | 783.00 | 2,121.93| 1,338.93 stores | sales | 13.31 | 632.75 | 8,421.90| 7,789.15 saleitem | sales | 3.67 | 714.38 | 2,621.76| 1,907.38 regions | sales | 2.22 | 405.00 | 899.10| 494.10 salepern | sales | 1.77 | 378.00 | 669.06| 291.06 saleitem1 | sales | 3.73 | 674.63 | 2,516.35| 1,841.73 customers | sales | 4.40 | 351.00 | 1,544.40| 1,193.40 dimens11 | sales | 1.00 | 63.25 | 63.25| 0.00 (10 rows)
The sample output shows several tables where the ratio of compressed size to uncompressed tables is about 1 (or the same size). These tables are likely not yet compressed, or they might contain data that is not compressed (such as non-null floating points or nonnull character strings). In several of the example tables in the output, compressed tables generally range from 1 to about 5 times smaller, and in one case (the stores table), the table is 13 times smaller than its uncompressed version. Compression rates vary based on the content of the table and the ordering of the data. Well-ordered tables compress better than unordered tables. The compressedTableRatio command syntax follows:
Usage: /nz/kit/bin/adm/compressedTableRatio {-alldbs | -db <database>} {-alltbls | -t <table>}
Table 9-2 describes the compressedTableRatio command arguments. Table 9-2: compressedTableRatio Command Arguments Argument -alldbs Description Calculates the compression ratios for all databases. You must specify either -alldbs or a specific database using the -db argument. Calculates the compression ratios for a specific database. You must specify either -alldbs or a specific database using the -db argument. Calculates the compression ratio for all tables in the specified database or databases. You must specify either -alltbls or a specific table using the -t argument.
-db database
-alltbls
20282-14
Rev.1
9-5
Table 9-2: compressedTableRatio Command Arguments Argument -t table Description Calculates the compression ratio for the specific table in the specified database or databases. You must specify either -alltbls or a specific table using the -t argument. Specifies the user account name to access the Netezza. By default, the command uses the value of NZ_USER. Specifies the users password. By default, the command uses the value of NZ_PASSWORD.
-u username
-pw password
9-6
20282-14
Rev.1
Parallel processing is more efficient when you have distributed table rows evenly across the data slices. Tables used together should use the same columns for their distribution key. For example, in an order system application, use the customer ID as the distribution key for both the customer table and the order table. If a particular key is used largely in equi-join clauses, then that key is a good choice for the distribution key.
20282-14
Rev.1
9-7
When you create a subset table or temp table, you do not need to specify a new distribution key or distribution method. Instead, allow the new table to inherit the parent tables distribution key. This avoids the extra data distribution that can occur because of the non-match of inherited and specified keys.
Verifying Distribution
When the system creates records, it assigns them to a logical data slice based on their distribution key value. You can use the datasliceid keyword in queries to determine how many records you have stored on each data slice and thus, whether the data is distributed evenly across all data slices. To check your distribution, run the following query:
select datasliceid, count(datasliceid) as Rows from table_name group by datasliceid order by Rows;
You can also view the distribution from the NzAdmin tool. To view record distribution for a table you must have the following object privileges: list on the database, list on the table, and select on the table.
9-8
20282-14
Rev.1
The Record Distribution window displays the distribution of data across all the data slices in your system for the specific table. The Records column displays the total number of records, the minimum number of records, the maximum number of records, the average records per data slice, and the standard deviation (population computation). The Distribution Columns Section displays the distribution key columns for the table. 4. To see the specific record count for a data slice, place your cursor over an individual data slice bar. The system displays the record count and the data slice identifier in the status bar.
20282-14
Rev.1
9-9
9-10
20282-14
Rev.1
Table 9-3: Table Skew Column Max/Data slice Avg/Data slice Total Description The size of the tables largest portion on a data slice in MB. The average data slice size in MB across all the data slices. The total table size in MB.
20282-14
Rev.1
9-11
and save them in the same or nearby extents. Netezza also creates zone maps for the organizing columns to accelerate the performance of queries on that table that restrict using the organizing keys. Figure 9-3 shows a simple model of a table, such as a transaction table. In its unorganized form, the data is organized by the date and time that each transaction occurred, and the color indicating a unique transaction type. If your queries on the table most often query by date/time restrictions, those queries will perform well because the date/time organization matches the common restrictions of the queries. However, if most queries restrict on transaction type, you can increase query performance by organizing the records by transaction type. Queries that restrict on transaction type will improve performance because the records are organized and grouped by the key restriction; the query can obtain the relevant records more quickly, whereas they would have to scan much more of the table in the date/time organization to find the relevant transactions. By organizing the data in the table so that commonly filtered data is located in the same or nearby disk extents, your queries can take advantage of the zone maps ability to eliminate unnecessary disk scans to find the relevant records. Unorganized Records CBT Records
Figure 9-3: Organizing Tables with CBTs CBTs are most often used for large fact or event tables which could have millions or billions of rows. If the table does not have a record organization that matches the types of queries that run against it, scanning the records of such a large table requires a lengthy processing time as full disk scans could be needed to gather the relevant records. By reorganizing the table to match your queries against it, you can group the records to take advantage of zone maps and improve performance. CBTs offer several benefits: CBTs support multi-dimension lookups where you can organize records by one, two, three, or four lookup keys. In the example shown in Figure 9-3, if your queries commonly restrict on transaction type and store ID, you can organize records using both of those keys to improve query performance. CBTs improve query performance by adding more zone maps for a table because the organizing key columns are also zone mapped (if the organizing column data type supports zone maps). CBTs increase the supported data types for zone-mapped columns, thus allowing you to improve performance for queries that restrict along multiple dimensions.
9-12
20282-14
Rev.1
CBTs allow you to incrementally organize data within your user tables in situations where data cannot easily be accumulated in staging areas for pre-ordering before insertions/loads. CBTs can help you to eliminate or reduce pre-sorting of new table records prior to a load/insert operation. CBTs save disk space. Unlike indexes, materialized views and other auxiliary data structures, CBTs do not replicate the base table data and do not allocate additional data structures.
20282-14
Rev.1
9-13
Time Time with timezone Interval You specify the organizing keys for a table when you create it (such as using the CREATE TABLE command), or when you alter the table (such as using ALTER TABLE). When you define the organizing keys for a table, note that Netezza does not automatically take action to reorganize the records; you use the GROOM TABLE command to start the reorganization process. You can add to, change, or drop the organizing keys for a table using ALTER TABLE. Note that the additional or changed keys take effect immediately, but you must groom the table to reorganize the records to the new keys. You cannot drop a column from a table if that column is specified as an organizing key for that table.
9-14
20282-14
Rev.1
The system uses statistics for many purposes: Based on the number of records, the number of distinct values for a column, and assuming uniform distribution between the min and max values, the optimizer estimates the number of relevant rows and determines which is the smaller of two join tables. Based on the min and max values, the optimizer determines what type of math needs to be performed (for example, 64-bit or 128-bit). If there are nulls in the database tables, then during code generation the system must generate additional code to test and check fields for null values. Extra code means extra CPU cycles during execution time. The GENERATE STATISTICS command collects this information. If you have the GenStats privilege, you can run this command on a database, table, or individual columns. By default, the admin user can run the command on any database (to process all the tables in the database) or any individual table. The admin user can assign other users this privilege. For example, to give user1 privilege to run GENERATE STATISTICS on one or all tables in the DEV database, the admin user must grant user1 LIST privilege on tables in the system database, and GENSTATS from the dev database, as in these sample SQL commands:
SYSTEM(ADMIN)=> GRANT LIST ON TABLE TO user1; DEV(ADMIN)=> GRANT GENSTATS ON TABLE TO user1;
For more information about the GenStats privilege, see Table 8-1 on page 8-9. Table 9-5 describes the nzsql command syntax for these cases. Table 9-5: Generate Statistics Syntax Description A database (all tables) A specific table (all columns) Individual columns in a table Syntax GENERATE STATISTICS; GENERATE STATISTICS ON table_name; GENERATE STATISTICS ON my_table(name, address, zip);
The GENERATE STATISTICS command reads every row in every table to determine dispersion values (no sampling). It provides the most accurate and best quality statistics.
20282-14
Rev.1
9-15
9-16
20282-14
Rev.1
When you have temporary tables that contain a large number of rows and which will be used in JOIN clauses. For more information about the GENERATE STATISTICS command, see the Netezza Database Users Guide.
20282-14
Rev.1
9-17
Zone Maps
Zone maps are automatically generated internal tables that the Netezza system uses to improve the throughput and the response time of SQL queries against large grouped or nearly ordered date, timestamp, byteint, smallint, integer, and bigint data types. Zone maps reduce disk scan operations required to retrieve data by eliminating records outside the start and end range of a WHERE clause on restricted scan queries. The Netezza Storage Manager uses zone maps to skip portions of tables that do not contain rows of interest and thus reduces the number to extents to scan and the search time, disk contention, and disk I/O.
The following actions can help to resolve this error: Groom the table to remove outdated or deleted rows, which can reduce the table size. If the table has skew, re-distribute the table in a different way, such as on random for example.
9-18
20282-14
Rev.1
Grooming Tables
If the table is evenly distributed, or if a change in distribution would affect queries, you could split the table into two or more smaller tables, and then combine them into a view with a UNION ALL operation.
Grooming Tables
As part of your routine database maintenance activities, you should plan to recover disk space occupied by outdated or deleted rows. In normal Netezza operation, an update or delete of a table row does not remove the old tuple (version of the row). This approach benefits multiversion concurrency control by retaining tuples that could potentially be visible to other transactions. Over time however, the outdated or deleted tuples are of no interest to any transaction. After you have captured them in a backup, you can reclaim the space they occupy using the SQL GROOM TABLE command. Note: Starting in Release 6.0, you use the GROOM TABLE command to maintain the user tables by reclaiming disk space for deleted or outdated rows, as well as to reorganize the tables by their organizing keys. The GROOM TABLE command does not lock a table while it is running; you can continue to read, update, and write/insert to the groomed table while the table is being groomed. For details about the GROOM TABLE command, see the Netezza Database Users Guide. Note the following best practices when you groom tables to reclaim disk space: You should groom tables that receive frequent updates or deletes more often than tables that are seldom updated. If you have a mixture of large tables, some of which are heavily updated and others that are seldom updated, you might want to set up periodic tasks that routinely groom the frequently updated tables. Grooming deleted records has no effect on your database statistics, because the process physically removes records that were already logically deleted. When you groom a table, the system leaves the min/max, null, and estimated dispersion values unchanged. For more information on when to run the GENERATE STATISTICS command, see Running the GENERATE STATISTICS Command on page 9-16. Physically reclaiming the records, however, does affect where the remaining records in the table are located. So when you physically reclaim records, the system updates the zone map. Note: When you delete a tables contents completely, consider using the TRUNCATE rather than the DELETE command, which eliminates the need to run the GROOM TABLE command.
20282-14
Rev.1
9-19
in Release 6.0. For example, the -scanblocks and -scanrecords options are not supported and will return an error. For details on the supported command syntax, see nzreclaim on page A-34. Several examples follow: To use the GROOM TABLE command in a SQL session:
MYDB(USER1)=> GROOM TABLE ORDERS; NOTICE: Groom processed 25 pages; purged 9 records; scan size shrunk by 9 pages; table size shrunk by 9 extents. GROOM RECORDS ALL
If you have created scripts to run nzreclaim from the command line as in the previous example, you can update those scripts to use the new SQL GROOM TABLE command as in the following example:
[nz@nzhost ~]$ nzsql mydb -u user1 -pw password -c "groom table mynation"
As shown in the example, the nzreclaim command calls the GROOM TABLE command to update and reclaim the table. You should migrate to using the GROOM TABLE command directly.
9-20
20282-14
Rev.1
Managing Sessions
Managing Sessions
A session represents a single connection to a Netezza appliance. Sessions begin when users perform any of the following actions: Invoke the nzsql command; the session ends when they enter \q (quit) to exit the session. invoke the nzload command, the NzAdmin tool, or other client commands; the session ends when the command completes, or when the user exits the user interface.
Viewing Sessions
You can use the nzsession command to display the list of current user sessions and to list the session types. You can be logged in as any database user to use the nzsession show command; however, some of the data displayed by the command could be obscured if your account does not have correct privileges. The admin user can see all the information. To list all active sessions, enter:
nzsession show -u admin -pw password ID Type User Start Time PID Database Priority Name Client IP Client PID Command ----- ---- ----- ----------------------- ----- ------------------------ --------- ---------- -----------------------16129 sql ADMIN 12-Apr-10, 15:39:11 EDT 11848 TPCH1_NOTHIN normal 127.0.0.1 11821 select * from lineitem; 16133 sql ADMIN 12-Apr-10, 15:45:26 EDT 11964 SYSTEM normal 127.0.0.1 11963 SELECT session_id, clien State -----idle active
If you are a database user who does not have any special privileges, information such as the user name, database, client PID, and SQL command appear only as asterisks, for example:
nzsession show -u user1 -pw pass ID Type User Start Time PID Database State Priority Name Client IP Client PID Command ----- ---- ----- ----------------------- ----- -------- ------ ------------ --------- ---------- -----------------------16129 sql ***** 12-Apr-10, 15:39:11 EDT 11848 ***** idle normal ***** ***** 16134 sql USER1 12-Apr-10, 15:48:00 EDT 12012 SYSTEM active normal 127.0.0.1 12011 SELECT session_id, clien
For a description of the output from the nzsession command, see nzsession on page A-37.
20282-14
Rev.1
9-21
Note: Do not abort system sessions. Doing so can cause your system to fail to restart. To abort transaction SID 31334, enter:
nzsession abortTxn -u admin -pw password -id 31334
The session remains active, only the transaction has been aborted. Note: You can abort SQL, client, load, backup, and restore sessions. You can also use the NzAdmin tool to abort a transaction. For a description of the nzsession command output, see nzsession on page A-37.
Running Transactions
A transaction is a series of one or more operations on database-related objects and/or data. Transactions provide the following benefits: Ensure integrity among multiple operations by allowing all or none of the operations to take effect. You accomplish this by starting a transaction, performing operations, and then executing either a commit or a rollback (also called an abort). Provide a means of canceling completed work for a series of operations that fail before finishing. Provide a consistent view of data to users, in the midst of changes by other users. The combination of create and delete transaction IDs associated with each data row plus Netezza internal controls guarantee that once a transaction has begun, new transactions or ones that have yet to be committed do not affect the view of the data.
9-22
20282-14
Rev.1
Running Transactions
20282-14
Rev.1
9-23
9-24
20282-14
Rev.1
Table 9-7 summarizes the differences in system response in queueing implicit and explicit transactions once the number of read/write transactions reaches 31. Table 9-7: The 32nd READ/WRITE Transaction Queueing Explicit Implicit N/A Xa
begin_queue_if_full=T (default)
Explicit
begin_queue_if_full=T set session read only
Explicit
begin_queue_if_full=F
BEGIN SELECT
X (read only) X
X (read only) X Ec E E E E E E X
CREATE CREATE TABLE AS DROP TRUNCATE INSERT DELETE UPDATE CREATE/MODIFY temporary table a. X = starts executing
X X X X Qb Q Q X
E E E E E E E X
20282-14
Rev.1
9-25
Execution Plans
The optimizer uses statistics to determine the optimal execution plan for queries. The statistics include the following: The number of rows in the table The number of unique or distinct values of each column The number of NULLs in each column The minimum and maximum of each column For the optimizer to create the best execution plan that results in the best performance, it must have the most up-to-date statistics. For more information about running statistics, see Updating Database Statistics on page 9-14.
To obtain an HTML plan, use either the EXPLAIN or SET command. An example using EXPLAIN PLANGRAPH follows.
EXPLAIN PLANGRAPH SELECT * FROM foo;
With EXPLAIN PLANGRAPH, the system displays the output to the nzsql terminal. You can copy and paste the output into a file that you can open in your browser. An example using SET follows.
SET enable_print_plan_html=1; SELECT * FROM FOO;
The SET command saves the output to a file on the host. You can specify the location for the file. For example:
SET print_plan_path = /tmp;
In this case, the output would be saved to /tmp/plan#.html (The system begins with the number 1 and names subsequent output sequentially.) Whether you use EXPLAIN PLANGRAPH or SET, the output displays the query plan pictorially as a tree of nodes (ovals), representing how joins are processed. Note the following in regards to how to interpret the representations. Ovals formed with unbroken single lines and clear backgrounds (not shaded) are executed on the SPUs. Shaded ovals represent nodes that the host (DBOS) executes. Ovals formed with dashed lines represent virtual nodes (typically subquery scans). Ovals formed with double lines represent fabric joins streaming nodes that are either broadcast or distributed.
9-26
20282-14
Rev.1
To obtain a text plan, use either the EXPLAIN or SET command.The system displays the output to the nzsql terminal unless you redirect it to a file.
EXPLAIN PLANTEXT SELECT * FROM foo; OR SET enable_print_plan_text=1; SELECT * FROM foo;
You can also use the NzAdmin tool to display information about queries.
20282-14
Rev.1
9-27
You can also use the nzstats command to view the Query Table and Query History Table. For more information, see Table 13-12 on page 13-10 and Table 13-13 on page 13-11. Table 9-8 lists the _v_qrystat view, which lists active queries. Table 9-8: The _v_qrystat View Columns Session Id Plan Id Client Id Client IP address SQL statement State Submit date Start date Priority Priority text Estimated cost Estimated disk Estimated mem Snippets Current Snippet Result rows Result bytes Description The ID of the session that initiated this query. The internal ID of the plan associated with this query. The internal client ID associated with this query. The client IP address. The SQL statement. Note that the statement is not truncated as it is with the nzstats command. The state number. The date and time the query was submitted. The date and time the query started running. The priority number. The priority of the queue when submitted (normal or high). The estimated cost, as determined by the optimizer. The units are thousandths of a second, that is, 1000 equals one second. The estimated disk usage, as determined by the optimizer. The estimated memory usage, as determined by the optimizer. The number of snippets in the plan for this query. The current snippet the system is processing. The number of rows in the result. The number of bytes in the result.
Table 9-9 describes the _v_qryhist view, which lists recent queries. Table 9-9: The _v_qryhist View Columns Session Id Plan Id Client Id Description The Id of the session that initiated this query. The internal Id of the plan associated with this query. The internal client Id associated with this query.
9-28
20282-14
Rev.1
Table 9-9: The _v_qryhist View Columns Client IP address DB name User SQL statement Submit date Start date End date Priority Priority text Estimated cost Estimated disk Estimated mem Snippets Snippet done Result rows Result bytes Description The client IP address. The name of the database the query ran on. The user name. The SQL statement. Note that the statement is not truncated as it is with the nzstats command. The date and time the query was submitted. The date and time the query started running. The date and time that the query ended. The priority number. The priority of the queue when submitted (normal or high). The estimated cost, as determined by the optimizer. The estimated disk usage, as determined by the optimizer. The estimated memory usage, as determined by the optimizer. The number of snippets in the plan for this query. The number of snippets that have completed. The number of rows in the result. The number of bytes in the result.
20282-14
Rev.1
9-29
9-30
20282-14
Rev.1
C H A P T E R 10
Backing Up and Restoring Databases
Whats in this chapter
General Information on Backup and Restore Methods Using the nzbackup Command Using the nzrestore Command Using the Veritas NetBackup Connector Using the IBM Tivoli Storage Manager Connector
This chapter describes how to backup and restore data on the Netezza system. It provides general information on backup and restore methods, and also describes how to use the third-party storage solutions that are supported by the Netezza system. As a best practice, make sure that you schedule regular backups of your user databases and your system catalog to ensure that you can restore your Netezza system. Make sure that you run backups prior to (and after) major system changes, so that you have snapshots of the system before and after those changes. A regular and current set of backups can protect against loss of data following events such as disaster recovery, hardware failure, accidental data loss, or incorrect changes to existing databases.
10-1
Table 10-1 lists the differences among the backup and restore methods. Table 10-1: Choosing a Backup and Restore Method Feature Schema backup Full automatic database backup Manual per-table backup Manual per-table restore Veritas Tivoli Storage Manager Automatic incremental Compressed internal format Non-proprietary format Machine-size independent Rowid preserved Transaction ID preserved Upgrade safe Downgrade safe
a.
This method usually takes more time to complete than the compressed internal format backups and loads.
The CREATE EXTERNAL TABLE command and the procedures for using external tables are described in detail in the Netezza Data Loading Guide.
Overview
The Netezza system contains data which is critical to the operation of the system and to the user databases and tables stored within the Netezza. The data includes the Netezza catalog metadata, the user databases and tables, and access information such as users, groups, and global permissions. Netezza provides a set of commands to backup and restore this information, as described in Table 10-2. Table 10-2: Backup/Restore Commands and Content Information Netezza host data (catalog metadata) User databases Netezza users, groups, and permissions Backup nzhostbackup nzbackup nzbackup Restore nzhostrestore nzrestore nzrestore
10-2
20282-14
Rev.1
Note: The Netezza backup processes do not back up host software such as the Linux operating system files or any applications that you may have installed on the Netezza host, such as the Web Admin client. If you accidentally remove files in the Web Admin installation directories, you can reinstall the Web Admin client to restore them. If you accidentally delete Linux host operating system or firmware files, contact Netezza Support for assistance in restoring them. The Netezza backup and restore operations can use network filesystem locations as well as several third-party solutions such as Veritas NetBackup and Tivoli Storage Manager as destinations.
Database Completeness
The standard backup and restore using the nzbackup and nzrestore commands provide transactionally consistent, automated backup and restore of the schema and data for all objects of a database, including ownership and permissions for objects within that database. You can use these commands to backup and restore an entire database, as well as to restore a specific table in a database. The nzrestore command requires that the database be dropped or empty when you restore the database. Similarly, before you restore a table, you must first drop the table or use the -droptables option to allow the command to drop a table that is going to be restored.
Portability
Before performing a backup, consider where you plan to restore the data. For example, if you are restoring data to the same Netezza system or to another Netezza system (which could be a different model type or have a later software release), use the compressed internal format files created by the nzbackup command. The compressed internal format files load more quickly than text external format files. You can restore a database created on one Netezza model type to a different Netezza model type, such as a backup from a TwinFin 6 to a TwinFin 12, if the destination Netezza has the same or later Netezza release. A restore runs slower when you change the destination model type, because the host on the target system must process and distribute the data slices according to the target models data slices to SPU topology. When transferring data to a new Netezza system, you do not have to restore the users and groups before the data. You can restore them in any order. If you plan to load the Netezza data to a different system (that is, a non-Netezza system), the text format external tables are the most portable. Data in text external tables can be read by any product that can read text files, and can be loaded into any database that can read delimited text files.
20282-14
Rev.1
10-3
A compressed binary format external table (also known as an internal format table) is a proprietary format which typically yields smaller data files, retains information about the Netezza topology, and thus is often faster to backup and restore. The alternative to compressed binary format is text format, which is a non-proprietary external table format that is independent of the Netezza topology, but yields larger files and can be slower to backup and restore. The different backup/restore methods handle data compression in the following manner: When you use the standard backup using the nzbackup /nzrestore commands, the system automatically uses compressed external tables as the data transfer mechanism. When you use compressed external table unload, the system compresses the data and only uncompresses it when you reload the data. Use manually created external compressed tables for backup when you want table-level backup or the ability to send data to a named pipe, for example, when using a named pipe with a third-party backup application. When you use text format unload, the data is not compressed. For large tables, it is the slowest method and the one that takes up the most storage space.
Multi-Stream Backup
The Netezza backup process is a multi-stream process. If you specify multiple filesystem locations, or if you use third-party backup tools that support multiple connections, the backup process can parallelize the work to send the data to the backup destinations. Multi-stream support can improve backup performance by reducing the time required to transfer the data to the destination. To use multi-stream backups, you use the -streams num option of the nzbackup command. The maximum number of streams is 16. For filesystem backups, the system uses one stream for each backup destination. For third-party backup applications, the system uses the value specified for the -streams option; or, if not specified, the value of the host.bnrNumStreamsDefault configuration setting. Note: If you use multi-stream backup to a third-party backup tool, make sure that you review the support for maximum jobs or parallelism in that tool. Some tools such as NetBackup have a limit on the number of concurrent streams. If you specify more streams than the NetBackup tool supports, the backup job will be queued. For Tivoli backups, the maximum number of streams is controlled by the MAXSESSIONS option in the Tivoli Admin console (dsmadmc). You can display the value using query option MAXSESSIONS and you can set it using setopt MAXSESSIONS value. If you specify more streams than the MAXSESSIONS value, the Tivoli server displays the error Error: Connector init failed: 'ANS1351E (RC51) Session rejected: All server sessions are currently in use and the backup aborts. Netezza backup processes include a test to check that the backup tool supports the number of requested streams. If that test completes successfully, the actual backup process starts. If the test fails due to connection timeouts, the nzbackup process exits with the error: Stream unresponsive after 300 seconds, operation aborted. Check concurrency limits on server.
10-4
20282-14
Rev.1
Only backup operations that transfer table data support multiple destinations and streams. These operations include full and incremental backups. Other operations such as -schemaonly backup, -users backup, and the reports, use only a single destination and a single stream, even if you specify multiple destinations. The restore process is always a singlestream process.
Special Columns
The backup/restore method you use affects how the system retains specials. The term specials refers to the end-user-invisible columns in every table that the system maintains. The specials include rowid, datasliceid, createxid, and deletexid. Table 10-3 describes how the backup method affects these values. Table 10-3: Retaining Specials Special rowid nzbackup and nzrestore Retain Compressed External Tables Retain Text Format External Tables Not unloaded
datasliceid Retain when the machine Retain when the machine Recalculate size stays the same, other- size stays the same, othwise recalculates. erwise recalculates. createxid Receive the transaction Receive the transaction ID Receive the transaction of transaction performing ID of transaction perform- ID of transaction performing the restore. the restore. ing the restore. Set to zero. Set to zero. Set to zero.
deletexid
Upgrade/Downgrade Concerns
The backup method you select also affects your ability to restore data after a Netezza software release upgrade or downgrade. Backups created with the nzbackup command can be safely reloaded/restored after an upgrade of the Netezza software. Backups created with the nzbackup command are not guaranteed to support reload/restore after a Netezza software downgrade. These backup formats are subject to change between releases. Compressed external table backups can be safely reloaded/restored after an upgrade of the Netezza software. Compressed external table backups are not guaranteed to support reload/restore after a Netezza software downgrade. These backup formats are subject to change between releases. Text format external tables are insensitive to software revisions, and can be reloaded to any Netezza software release.
20282-14
Rev.1
10-5
You can then reload those records into the original source table or a new table of the same schema. For more information, see the Netezza Data Loading Guide.
10-6
20282-14
Rev.1
20282-14
Rev.1
10-7
The nzhostbackup command pauses the system while it runs; this allows it to checkpoint and archive the current /nz/data directory. The command resumes the system when it completes. The command typically takes only a few minutes to complete. It is recommended that you run database and host backups during a time when the Netezza system is least busy with queries and users. The nzhostrestore command synchronizes the SPUs with the restored catalog on the host; as a result, it will roll back any transactions that occurred after the host backup. The host restore operation cannot roll back changes such as drop table, truncate table, or groom operations. If these changes occurred after the host backup was made, the host restore could cause those affected tables to be in an inconsistent state. You should inspect the data in those tables, and if necessary, reload the tables to match the time of the host backup. After you use the nzhostrestore command, note that you cannot perform an incremental backup on the database; you must run a full backup first. For more information about the nzhostbackup and nzhostrestore commands, see nzhostbackup on page A-21 and nzhostrestore on page A-23.
The directory_name value specifies the pathname of the system data directory to back up. The default is the NZ_DATA_DIR, which is usually /nz/data. The file value specifies the pathname of the archive table that you will create. This file is a gzipped tar file. The timeout value specifies the maximum time to wait (in seconds) for system activities to finish before starting the backup. After the system has waited the maximum time, it cancels any remaining queries and starts the backup. The default timeout is 60 seconds. An example follows:
nzhostbackup /backups/nzhost_latest.tar.gz Starting host backup. System state is 'online'. Pausing the system ... Checkpointing host catalog ... Archiving system catalog ... Resuming the system ... Host backup completed successfully. System state is 'online'.
The -f (force) option causes the command to accept the defaults for prompts and confirmation requests.
10-8
20282-14
Rev.1
The -catverok option skips the catalog verification checks. By default, the command checks the catalog version of the current /nz/data directory and the archived data directory. If the catalog versions are not the same, or if the command cannot detect the catalog version of the current data directory, the command exits with an error message similar to the following:
Unable to determine catalog version of data directory at /nz/data.1.0, hence exiting. If you are sure that catalog versions of current and that of the archived data directory are same, use the command-line switch -catverok to skip this check.
Use caution with this switch; if you are not sure that the catalog versions are the same, do not bypass the checks. Contact Netezza Support for assistance. The directory_name value specifies the data directory to restore (default /nz/data). The file value specifies the archive file created by the nzhostbackup command. The nzhostrestore command pauses the system before starting the restore, and resumes the system after it finishes. An example follows:
nzhostrestore /backups/nzhost_latest.tar.gz Starting host restore Extracting host data archive ... Restore host data archived Thu Dec 24 03:42:02 EST 2009? (y/n) [n] y Stopping the system ... Starting topology restore ... Stopping the system ... Warning: The hardware ids will be reassigned. The hardware id assignments from the archived system catalog have been saved in '/tmp/hwids-old.z.tar' Reinitializing hardware metadata ... Restoring the devmap / topology tables ... Stopping the system ... Starting the system ... Waiting for system to go online ... Checking for orphaned SPU tables ... Loading hardware ids ... Topology recovery completed successfully. Stopping the system ... Warning: The restore will now rollback spu data to Thu Dec 24 03:42:02 EST 2009. This operation cannot be undone. Ok to proceed? (y/n) [n] y Installing system catalog to '/nz/data.1.0' ... StarSynchronizing data on spus ... done. Stopping the system ... Restore complete. You can now start the system using 'nzstart'.
After the restore, the hardware IDs for the SPUs and disks typically change; however, their location and roles remain the same as they were before the host restore. Note that a failed SPU could become active again after a host restore.
20282-14
Rev.1
10-9
If any tables were created after the host backup, the nzhostrestore command marks these tables as orphans, which means that they are inaccessible and consume disk space. The nzhostrestore command checks for orphaned tables and creates a script that you can use to drop orphaned user tables. The nzhostrestore command also rolls back the data on the SPUs to match the transaction point of the catalog in the host backup.
Table 10-4 describes the command options. Table 10-4: The nzbackup Command Options Argument -h -rev -host Description Displays the help for the command. Displays the software revision of the command. Specifies the hostname or IP address of the Netezza host. Value of NZ_ HOST Default Value Example
10-10
20282-14
Rev.1
Table 10-4: The nzbackup Command Options Argument -v[erbose] -db database -dir directory Description Specifies the verbose mode, lists the objects being backed up. Specifies the database that you are backing up. Value of NZ_ DATABASE -db ttdev -dir /home/user/ backups or -dir /home/ backup1 /home/ backup2/ /home/ backup3/ Default Value Example
Specifies a list of one or more space-separated, full pathnames of the directories where the data is to be stored. This option applies to filesystem only (not veritas or tivoli). You can specify up to 16 directories.
Note: The directories you specify
are the root for all backups. The system manages the backups in the subdirectories within each root directory. -dirfile Specifies a file with a list of backup target directories, one per line. Names the connector to which you are sending the backup, either filesystem, veritas, or tivoli.
-connector conname
filesystem
-connectorArgs args
Specifies a colon-separated list of passthrough arguments for the connector. The argument string must be enclosed in double-quotation marks. Specifies a differential backup (that is, only the data that has changed since the last backup).
name=value[:nam e=value:...]
-differential
-cumulative
Specifies a cumulative backup (that is, the command backs-up only what has changed since the prior full backup).
20282-14
Rev.1
10-11
Table 10-4: The nzbackup Command Options Argument -users Description Default Value Example -users
Backs up all users and groups, and any privileges which were defined in the system database. If you specify this option, you cannot specify -db. For more information, see Backing Up and Restoring Users, Groups, and Permissions on page 10-19. Note that the command backs up all users and groups regardless of whether they are referenced by any permission grants. The system backs up all global adminlevel permissions (those that are not associated with particular databases). The system does not back up permissions associated with specific databases, because they are saved during regular database backup of each database. Specifies the Netezza user name Value of NZ_ to connect to the database. USER Specifies the users password. Backs up the data using the specified number of streams. Value of NZ_ PASSWORD See MultiStream Backup on page 10-4.
-schema-only
Saves only the schema of the specified database, but not the user data in tables or views. The schema includes the definitions of objects such as tables, views, synonyms, sequences, and others, as well as any access privileges defined in the database. This option is an easy way to replicate an empty database schema within a Netezza system. Prints the backup history report.
-schema-only
-history
10-12
20282-14
Rev.1
Table 10-4: The nzbackup Command Options Argument -backupset ID Description Specifies the backup set you wish to use for incremental backup, rather than the default.
Note: The default backup set is
the most recent backup set of the database you specify. You can override the default by using this option. -secret value Specifies a string value needed to generate a 256-bit symmetric key, which is used to encrypt the host key in the backed up data. -secret toplevel
Reporting Errors
The nzbackup command writes errors to the log file /nz/kit/log/backupsvr/backupsvr.pid.date.log. For more information about the log files, see System Logs on page 6-12.
20282-14
Rev.1
10-13
For example, to allow a user to back up all databases, perform the following steps: 1. Invoke nzsql and connect to the system database:
nzsql system
nzbackup Examples
Several examples of the nzbackup command follow: To back up the contents of the database db1 to disk in the /home/user/backups directory, enter:
nzbackup -dir /home/user/backups -u user -pw password -db db1
The nzbackup command saves the database schema, data, and access permissions for all the objects and user data in the database. Sample output follows:
Backup of database db1 to backupset 20090116125409 completed successfully.
You can use the -v (verbose) command option to display more detail about the backup:
[Backup Server] : Starting the backup process [Backup Server] : Backing up functions [Backup Server] : Backing up aggregates [Backup Server] : Backing up to /home/user/backups/Netezza/hostid/ DB1/20090116125619/1/FULL [Backup Server] : Transferring UDX object files [Backup Server] : Start retrieving the schema [Backup Server] : Retrieving user information [Backup Server] : Backing up sequences [Backup Server] : Backing up table schema. [Backup Server] : Backing up External Tables. [Backup Server] : Backing up External table settings. [Backup Server] : Backing up Table Constraints [Backup Server] : Backing up synonyms [Backup Server] : Backing up stored procedures [Backup Server] : Backing up materialized views [Backup Server] : Backing up view definitions. [Backup Server] : Retrieving group information [Backup Server] : Retrieving group members [Backup Server] : Backing up ACL information [Backup Server] : Start retrieving the data. [Backup Server] : Backing up table AAA [Backup Server] : Backing up table BBB [Backup Server] : Backing up table sales % [Backup Server] : Operation committed Backup of database db1 to backupset 20090116125619 completed successfully.
10-14
20282-14
Rev.1
To back up the contents of the database db2 to filesystem locations in the /export/ backups1 and /export/backups2 directories, enter:
nzbackup -dir /export/backups1 /export/backups2 -u user -pw password db db2
The nzbackup command saves the database schema, data, and access permissions for all the objects and user data in the database. The database is saved in the two specified filesystem locations. To back up only the schema of the database db1 to disk in the /home/user/backups directory, enter:
nzbackup -dir /home/user/backups -schema-only -u user -pw password -db db1
The nzbackup command saves the schema (that is, the definition of the objects in the database and any access permissions defined in the database) to a file. An example follows (also using the -v option) :
[Backup Server] : Starting the backup process [Backup Server] : Backing up functions [Backup Server] : Backing up aggregates [Backup Server] : Backing up to /home/user/backups/Netezza/hostid/ DB1/20090116125907/1/SCHEMA [Backup Server] : Transferring UDX object files [Backup Server] : Start retrieving the schema [Backup Server] : Retrieving user information [Backup Server] : Backing up sequences [Backup Server] : Backing up table schema. [Backup Server] : Backing up External Tables. [Backup Server] : Backing up External table settings. [Backup Server] : Backing up Table Constraints [Backup Server] : Backing up synonyms [Backup Server] : Backing up stored procedures [Backup Server] : Backing up materialized views [Backup Server] : Backing up view definitions. [Backup Server] : Retrieving group information [Backup Server] : Retrieving group members [Backup Server] : Backing up ACL information [Backup Server] : Operation committed Backup of schema for database db1 completed successfully.
To back up the users, groups, and access control lists to disk in the /home/user/backups directory, enter:
nzbackup -dir /home/user/backups -users -u user -pw password
The nzbackup command saves the users, group memberships, and access control permissions to objects as defined in the system catalog/database. Note that it does not capture user privileges granted in specific databases. An example follows:
[Backup Server] : Starting the backup process [Backup Server] : Start retrieving the schema [Backup Server] : Backing up to /home/user/backups/Netezza/hostid/ SYSTEM/20090116130124/1/USERS [Backup Server] : Retrieving user information [Backup Server] : Retrieving group information [Backup Server] : Retrieving group members [Backup Server] : Backing up ACL information
20282-14
Rev.1
10-15
[Backup Server] : Operation committed Backup of users, groups, and global permissions completed successfully.
Backup and restore both use this directory structure. Backup uses it to find backupsets with which to associate an incremental. Restore uses it to derive incremental restore sequences. The backup process finds the most recent backup set for a given database for incremental backup (unless you override the backup set). The restore process finds the most recent backup set for -db or -sourcedb, and current host or -npshost. You can override the most recent backup set using the nzrestore command options -sourcedb, -npshost, or -backupset Note: The most recent backup set for backup or restore is the most recently begun backup set, or the most recent full backup. If you move the backup archives from one storage location to another, you must maintain the directory structure. If you want to be able to perform an automated restore, all the backup increments must be accessible.
Incremental Backups
Incremental backups are database backups that save only the data that has changed since the last backup. Because the system copies a small subset of the data, incremental backups require less time to complete than full backups. They allow you to keep your backups current while reducing the frequency of time-consuming full backups. Netezza supports two types of incremental backups: differential and cumulative. Differential Includes all the changes made to the database since the previous backup (full, differential, or cumulative). Cumulative Includes all the changes made to the database since the last full backup. Cumulative backups incorporate and replace any differential backups performed since the last full backup. Use cumulative backups to consolidate differential backups so that if you need to restore data the restoration will require fewer steps and less media. Figure 10-1 shows sample backups, beginning with a full backup, then a series of differential and cumulative backups.
10-16
20282-14
Rev.1
Diff
Diff
Diff
Diff Diff
Diff
Diff
Diff
Figure 10-1: Database Backups Timeline The backups in Figure 10-1 comprise a backup set, which is a collection of backups written to a single location consisting of one full backup and any number of incremental backups.
The following is the syntax for a differential backup written to the Veritas application:
nzbackup -db <db_name> -differential -connector Veritas
The following is the syntax for a cumulative backup written to the Veritas application:
nzbackup -db <db_name> -cumulative -connector Veritas
20282-14
Rev.1
10-17
Notes on backup-groom synchronization: The system keeps groom/reclaim and incremental backups synchronized. GROOM TABLE uses information stored in the system catalog to identify incremental backups, using the most recent incremental backup for guidance. Groom limits its operation to transactions captured by that backup and its predecessors. Groom avoids the reclaiming of rows not yet captured in incremental backup. You can override the system behavior by specifying a particular backup set on the GROOM TABLE command line. When you perform any backup of a database, you trigger the synchronization. The system assumes that incremental backups follow a full backup. To override the default groom behavior, use the backupset option. To reclaim all rows, use backupset NONE. You can also choose a specific backup set. For example, run the nzbackup -history command to view the backup set IDs in the report:
Database Type Start Date Backup Set --------------------------------------------------------------dev Full 2006-06-01 20:00:00 20060601200000 dev Differential 2006-06-04 20:00:00 20060601200000 dev Full 2006-06-08 20:00:00 20060608200000 dev Differential 2006-06-11 20:00:00 20060608200000
From this backup history report, you could choose to use the June 1 backup set rather than the June 8 backup set:
nzreclaim -backupset 20060601200000 -db dev
10-18
20282-14
Rev.1
using the NzAdmin tool, or the Web Admin interface. This section describes how to use the nzbackup command; for details on the interfaces, refer to the online help for NzAdmin and Web Admin. Your Netezza user account must have appropriate permissions to view backup history for databases: If you are the admin user, you can view all entries in the backup history list. If you are not the admin user, you can view entries if you are the database owner, or if you have backup or restore privileges for the database. The following is the syntax to display the backup history for a database:
nzbackup Database -------SQLEXT 09.log -history -db name Backupset Seq # OpType Status Date Log File -------------- ----- ------- --------- ------------------- ---------------------20090109155818 1 FULL COMPLETED 2009-01-09 10:58:18 backupsvr.9598.2009-01-
Note: You can further refine your results by using the -db and -connector options, or use the -v option for additional information. You use the -db option to see only the history of a specified database. The command displays the following information: Table 10-6: Backup History Source Column Database Description The name of the backup database.
Backup Set The unique value that identifies the backup set. Seq.No Op Type Date Status Log File The sequence number that identifies the increment within the backup set. The type of backup (full, differential, cumulative, schema-only, or users). The date/time that the backup was initiated. The current status (completed, failed, in-progress). The name of the log file.
20282-14
Rev.1
10-19
For example, suppose you have four users (user1 to user4) and you grant them the following permissions:
nzsql SYSTEM(ADMIN)=> GRANT CREATE TABLE TO user1; SYSTEM(ADMIN)=> \c db_product DB_PRODUCT(ADMIN)=> GRANT CREATE TABLE TO user2; DB_PRODUCT(ADMIN)=> GRANT LIST ON TABLE TO user3; DB_PRODUCT(ADMIN)=> GRANT LIST ON emp TO user4;
User1 has global Create Table permission, which allows table creation in all databases on the Netezza system. User2 and User3 have Create and List permission to tables in the db_product database. User4 has List permission only to the emp table in the database db_product. Table 10-7 describes the results when you invoke the nzbackup and nzrestore commands using different options. Table 10-7: Backup and Restore Behavior Method nzbackup/nzrestore -db db_product User Backed Up/Restored user2 user3 user4 nzbackup/nzrestore -users user1 user2 user3 user4 Permission Backed Up/Restored CREATE tables in the db_product database. LIST on all tables in the db_ product database. LIST on the emp table in the db_product database. CREATE tables in the system database.
A regular backup of the db_product database does not include user1 or the CREATE TABLE GRANT to user1, because those privileges are defined in the system database (the system catalog). A -users backup and restore includes all users (in this case, users1-4), but it only includes the Create Table permission for user1, which is also defined in the system database. The -users backup and restore does not include the privileges defined specifically in the db_product database. A -users backup and restore does not include the admin user or the public group.
10-20
20282-14
Rev.1
Using the nzrestore -users command allows you to restore users, groups, and permissions. The restoration of users and groups is nondestructive, that is, the system only creates users and groups if they do not exist. It does not drop users and groups. Permission restoration is also nondestructive, that is, the system only grants permissions. It does not revoke permissions. Note: Keep in mind when restoring data and users from a backup that the backup reverts your system to a point in the past. Your user community and their access rights may have changed, or if you are restoring to a new system, a very stale backup may not reflect your current user community. After you make any significant user community changes, it is strongly recommended that you back up the latest changes. After restoring from a backup, check that the resulting users, groups, and permissions match your current community permissions.
20282-14
Rev.1
10-21
The nzrestore -schema-only command does not restore the /nz/data directory; instead, it creates a new database or populates an empty database with the database schema from the backed-up database. The command creates the objects in the database, such as the tables, synonyms, sequences, views, and so on, and applies any access permissions as defined in the database. It does not restore data to the user tables in the database; the restored tables are empty. Note: In rare cases, a large number of schema objects could cause a restore to fail, with the system indicating a memory limitation. In such cases, you may need to adjust how you restore your database. For example, if you attempt to restore a database that includes a large number of columns (such as 520,000), you would likely receive an error message that indicates a memory limitation. (The memory limitation error could result from a large number or columns or other schema objects.) You would likely need to perform a schema-only restore followed by two or more table-level restore operations.
Table 10-8 lists the nzrestore command options. Table 10-8: The nzrestore Command Options Argument -h -rev -v[erbose] -db database -dir directory list Description Displays the help for the command. Displays the software revision of the command. Specifies the verbose mode, lists the objects being restored. Specifies the name of the database to restore. Specifies the full pathnames of the directories where the backed up schema and data files are stored. (Used only for restores from filesystem backups.) If you use multiple backup locations, you should specify the superset of source locations in this -dir argument. For example, if backup increment 1 was written to LOCA and LOCB, and backup increment 2 was written to LOCB and LOCC, you can restore the data in a single operation by specifying all three locations. Specifies a file with a list of the backup source directories, one per line. Specifies the connector that you are reading or restoring the backup from, either filesystem, veritas, or tivoli.
10-22
20282-14
Rev.1
Table 10-8: The nzrestore Command Options Argument -connectorArgs args -backupset ID Description Specifies a colon-separated list of passthrough arguments for the connector. The argument string must be enclosed in double-quotation marks. Specifies the backup set, overriding the default.
-sourcedb dbname Specifies the backup set database, overriding the default.
Note: nzrestore restores the most recent backup of -db unless you
specify a different backup set with the option -sourcedb. -npshost host By default, restores look for backup sets that were created by the local Netezza host. If you use nzrestore to migrate databases, schemas, or user backups made on a different Netezza host, use this option to specify the host that created the backup set. Restores the table or tables as specified in the table_list argument, which is a space-separated list of tables.
-tables table_list
-tablefile filename Restores the tables listed in the table file, which is a file that contains a list of tables with one table per line. -droptables -suspendMViews -increment [ID | NEXT | REST] Drops the tables in the table list before restoring for a table-level restore. Leave materialized views suspended after a table-level or incremental restore. If you specify an increment ID, the command restores up to the specified increment by sequence number. If you specify NEXT instead of ID, the command restores the next increment from the backup set. If you specify REST instead of ID, the command restores the remaining increments from the backup set. Makes the database read-only to prevent modifications during the restore. Any of the following can represent true: 1, t, T, y, Y, true, TRUE, yes, Yes, or YES. Any of the following can represent false: 0, f, F, n, N, false, False, FALSE, no, No, or NO.
Note: If you do not specify this option, the database remains
-lockdb
unlocked, which will not allow subsequent incremental restore operations. -unlockdb Unlocks the database without performing another restore.
20282-14
Rev.1
10-23
Table 10-8: The nzrestore Command Options Argument -users Description Restores only the users, groups, and global permissions. Specify this option instead of a target database. The system restores all users and groups regardless of whether they are referenced by any permission grants. The creation of the users, groups and global permissions is nondestructive; that is, if a user or group exists, the system will not overwrite it. If you specify verbose mode, the nzrestore command displays at least one user or group creation error message, and tells you to view the restore log for details. When transferring data to a new machine, you do not have to restore the users and groups before the data. You can restore them in any order. Restores the users, groups, and global permissions rather than a database. You cannot specify -db when you specify this option. For more information, see Backing Up and Restoring Users, Groups, and Permissions on page 10-19. Disables the restoration of users or groups. Disables the restoration of permissions. Specifies the user name for connecting to the database to perform the restore. Specifies the users password. Restores only the database schema (the definitions of objects and access permissions), but not the data in the restored tables. Specifies a string value needed to generate a 256- bit symmetric key, which is used to decrypt the host key in the data. Used with -schema-only, restores the user-defined objects (functions, aggregates) in every increment. Lists the name and type of each database object in a backup archive.
Note: For file system backup locations, you must also specify -dir for
-noUsers -noAcl -u username -pw password -schema-only -secret value -allIncs -contents
the location of the backup archive and -db for a specific database. -history -incrementlist Prints a restore history report. Prints a report of the available backupsets and increments.
Note: You must specify -connector. You can also specify -npshost and/
or -sourcedb. -disableGroom Disables the automatic groom of versioned tables at the end of the restore operation.
10-24
20282-14
Rev.1
Table 10-8: The nzrestore Command Options Argument -disableSecurityCheck Description For row-secure tables, disables the security metadata comparisons between the backup set and the target database. The target database must have a compatible MLS model with the levels, categories, and cohorts defined in the backup set. In some instances, the backup set could include older, unused metadata that is not present in the target database; by default, the nzrestore fails in this case. You can use this switch to bypass the overall metadata check, but if the backup set has data that includes a label which is not in the target database, the restore fails and is rolled back.
Reporting Errors
The nzrestore command writes errors to the /nz/kit/log/restoresvr/restoresvr.pid.date.log file. For more information about the log files, see System Logs on page 6-12.
Note: If the database does not exist, you must first create an empty database and then assign the restore privilege to the user. Note that you must assign the restore privilege on an empty database. For example, to allow a user to restore all databases, perform the following steps: 1. Invoke nzsql and connect to the system database:
20282-14
Rev.1
10-25
nzsql system;
Note: The restored database is owned by the original creator. If that user no longer exists, the system displays a warning and changes the ownership to the admin user.
nzrestore Examples
Several example of the nzrestore command follow. To restore the database db1 from the /home/user/backups directory:
nzrestore -db db1 -u user -pw password -dir /home/user/backups -v
To restore the only the schema (objects and user permissions, but not the table and view data) of db1 to a new, empty database named new_db1:
nzrestore -db new_db1 -sourcedb db1 -schema-only -u user -pw password -dir /home/user/backups
This command restores the users, groups, and global privileges as defined in the system catalog. Note that if a user or group currently exists in the system catalog, the command grants any additional privileges as defined in the backup. The command does not revoke any current privileges that are not also defined in the backup. To list all of the objects such as tables, synonyms, user-defined objects, and others that were saved in a database backup, use the nzrestore -contents command as follows:
nzrestore -contents -db dev -dir /net/backupsvr/nzbackups Database: TPCH_TEST List of relations Oid | Type | Name -----------+----------------+----------------------------210854 | SEQUENCE | MY_SEQ 203248 | TABLE | NATION 203264 | TABLE | REGION 203278 | TABLE | PART
10-26
20282-14
Rev.1
| | | | | | |
| | | | | |
Restoring Tables
You can use the nzrestore command to identify specific tables in an existing backup archive and restore only those tables to the target database.
20282-14
Rev.1
10-27
Note: When listing multiple tables with the -tables option, separate table names with spaces. As in a standard restore, by default the system restores the tables schema and data. To suppress restoration of the data, use the -schema-only option. Keep in mind the following: You can specify the nzrestore command line options in any order. If your table names contain spaces, enclose the names in double quotes. If your table names begin with dashes (-), you can restore them by listing them in a single file and using the -tablefile option. You can restore to a different target database than the original backup (use the -sourcedb option to find the backup). If the target database does not exist, the system creates it. If the table exists in the database with the same name as the table you are restoring, both copies of the table exist until the transaction is complete. If there is not enough disk space for both versions of the table, you must manually drop the table before running the table-level restore.
Managing Transactions
As with a full-database restore, the system is available to all users during a table-level restoration. The majority of a table-level restoration occurs within a single transaction. The system handles other concurrent operations on the same table in the following manner: If a concurrent operation begins before the restore has dropped the table, it succeeds. If the concurrent operation begins after the restore table drop, the system suspends the concurrent operation until the restore operation either is committed or rolled back. If the restore transaction is committed, the concurrent operation fails and the system displays an error. If the restore transaction is rolled back, the concurrent operation succeeds against the original table. If a concurrent non-read-only transaction locks the same table, the system suspends the restore operation. If you abort the table-level restore, the system returns the database to its original state.
10-28
20282-14
Rev.1
When you restore data, the restoration software reads the metadata to frame the increment, validates the operation against the backup set, and performs the restore. The restore software associates the increment with a backup set on either the source Netezza or the target Storage Management System (SMS) by finding (by default) the most recent backup of the same database from the same source system.
The command displays the following information: Table 10-10: Backup History Target Column Database Description The name of the backup database.
Backup Set The unique value that identifies the backup set. Seq.No Op Type Hostname The sequence number that identifies the increment within the backup set. The type of backup (full, differential, cumulative, schema-only, or users). The name of the source system.
You can override the default host and database. For example, to specify another host use the -npshost option (where -npshost is the source Netezza system that created the backup), and to specify another database, specify the -sourcedb option.
nzrestore -db dev -connector Veritas -npshost nps_dev -sourcedb mydev
If you do not want to restore the most recent backup set, you can specify a specific backup set with the -backupset option.
nzrestore -db dev -connector Veritas -backupset 20060623200000
Note: Use the -incrementlist option to view a report listing all full and incremental backups.
20282-14
Rev.1
10-29
Up-to-x Restore Up-to-x restore restores a database from a full backup and then up to the specified increment. You can follow the up-to-x restore with a step-by-step restore. Note: Issue the -incrementlist option to view a report listing increment numbers. For example, the following command restores the full backup of database dev and then up to increment 4.
nzrestore -db dev -connector Veritas -increment 4
Step-by-step Restore Step-by-step restore restores single incrementals in chronological order. The nzrestore command maintains a restore history system table on the target system and queries this table to determine which increment to restore. Note: Remember to lock the database with the first nzrestore command and to unlock it with the last. For example, the following command line restores the full backup and then up to a specific incremental of the database dev, and then steps through the following incrementals.
nzrestore -db dev -connector Veritas -increment 4 -lockdb true nzrestore -db dev -connector Veritas -increment Next -lockdb true nzrestore -db dev -connector Veritas -increment Next -lockdb false
Note: To begin with the first increment when the database does not yet exist, specify the option, -increment 1. You can then step through the increments by specifying -increment Next. Remainder Restore A remainder restore restores all the incremental backups from a backup set not yet restored to the database. For example, the following command line restores the remaining increments.
nzrestore -db dev -connector Veritas -increment REST
10-30
20282-14
Rev.1
Note: You can further refine your results using the -db and -connector options, or use the -v option for additional information. You use the -db option to see only the history of a specified database. The command displays the following information: Table 10-11: Restore History Source Column Description
Restore DB The name of the restore database. Backup DB The name of the source database. Backup Set The unique value that identifies the backup set. Seq.No Database OpType Db Locked Date Status Log File The sequence number that identifies the increment within the backup set. The name of the backup database. The type of restore (for example, users, full, Incr:upto, Incr:next, Incr:rest). Whether the database is locked. The date/time that the restore was initiated. The current status (completed, failed, in-progress). The log file for the restore.
20282-14
Rev.1
10-31
Keyword Phrase Optional user-supplied keyword phrase. Could be used to help distinguish between backups in the Client Backups Report in NetBackup. You might use the database name. Type of Backup Automatic For Netbackup-scheduled backups Application For user-initiated backups * A policy must include at least one schedule with which you can set the valid time windows for Netezza backups and the calendar or frequency specifications for automatic NetBackup-initiated backups. Note that because you can restore at any time, there is no need for a schedule. The Netezza hostname The Netezza host-resident script file that launches the appropriate Netezza database backup. Specify the full path on the Netezza host.
Schedule Schedule
Client
Name
10-32
20282-14
Rev.1
20282-14
Rev.1
10-33
The file should include the variables CLIENT_CONNECT_TIMEOUT and CLIENT_ READ_TIMEOUT. Set both to the value 18000. Add the variables if they are not in the file:
CLIENT_CONNECT_TIMEOUT = 18000 CLIENT_READ_TIMEOUT = 18000
6. Make sure that the backups done by one host are visible to another host. If you have a Netezza HA environment, for example, the backups performed by Host 1 should be visible to Host 2. There are many ways that you can make the backups from one host visible to another. Refer to the manual, "Veritas System Administrators Guide for UNIX, Volume 1," specifically "Chapter 8, Managing Client Restores." Two possible methods follow: You can open access to all hosts by touching the following file on the Netbackup Master Server.
touch /usr/openv/netbackup/db/altnames/No.Restrictions
Note: If the touch command fails, make sure that the altnames directory exists. If necessary, create the altnames directory and re-run the command. You can give Host1 access to all backups created by Host2 and vice versa. To do this, you need to touch two files:
touch /usr/openv/netbackup/db/altnames/host1 touch /usr/openv/netbackup/db/altnames/host2
For example, if the names of your HA hosts are nps10200-ha1 and nps10200-ha2 then you would create the following files:
touch /usr/openv/netbackup/db/altnames/nps10200-ha1 touch /usr/openv/netbackup/db/altnames/nps10200-ha2
Note: You must use one of the two methods above to open access. If you skip this step, your restore will not work correctly on an HA system. This also applies to redirected restores. Refer to Redirecting a Restore on page 10-36.
10-34
20282-14
Rev.1
6. In the pop-up window, click the pull-down menu and select the RedHat Linux operating system that is running on your Netezza host. Most Netezza systems use Intel,RedHat 2.4, but if you are not sure, run the uname -r command on your Netezza host to display the kernel release number. Click OK and then click Next in the Client List dialog. Note: The operating systems in the drop-down list are based on the client binaries installed on the NetBackup master server. The list may be empty, or may not include the Red Hat Linux client software, if you have not installed the correct client software on the NetBackup server. For more information about installing the client software, refer to the Veritas NetBackup Installation Guide. 7. In the Backup Type dialog, select Automatic Backup to enable it, then click Next. Note: Do not specify values for the full path script. You supply this information in a later step. 8. In the Rotation dialog, select your time slot rotation for backups and how long to retain the backups, then click Next. 9. In the Start Window dialog, select the time options for the backup schedule and click Next. 10. A dialog appears and prompts you to save or cancel the backup policy that you created. Click Finish to save the backup policy.
If you are concerned about using a clear-text password, you could perform the same nzbackup as follows: a. Change user to root. b. Cache the password for user joe by using the nzpassword command. c. Invoke nzbackup without the password, as follows.
nzbackup -db sales -connector veritas -u joe
20282-14
Rev.1
10-35
After you cache the password, you can use nzbackup without the -pw option. You only need to cache the password one time. Backups initiated using the nzbackup command on the Netezza host use the schedule of type Application Backup. You can click the Schedules tab and check that the schedule for allowing backups is set appropriately.
Note: Rather than specify the -connectorArgs argument, you could set the environment variables DATASTORE_SERVER and DATASTORE_POLICY. If you set the environment variables and then use the command line argument -connectorArgs, the command line argument takes precedence.
Note: Rather than specify the -connectorArgs argument, you could set the environment variable DATASTORE_SERVER. If you set the environment variable and then use the command line argument -connectorArgs, the command line argument takes precedence. The restore operation does not use a NetBackup policy or schedule.
Redirecting a Restore
Typically, you restore a backup to the same Netezza host from which it was created. If you want to restore a backup created on a different Netezza host: Configure Veritas NetBackup for a redirected restore. Refer to the Veritas NetBackup documentation for more information. Use the -npshost option of the nzrestore command to identify the Netezza host from which the backup was created. Sample syntax follows:
nzrestore -db dbname -connector veritas -connectorArgs "DATASTORE_ SERVER=NetBackup_master_server" -npshost origin_nps
10-36
20282-14
Rev.1
Troubleshooting
The Activity Monitor (Figure 10-2) in the Veritas NetBackup Administration Console shows the status of all backups and restores.
Figure 10-2: Activity Monitor If an activity failed, you can double-click the failed entry to obtain more information in the Job Details window. Figure 10-3 shows a sample window.
20282-14
Rev.1
10-37
10-38
20282-14
Rev.1
4. Set the storage unit or other policy attributes, as desired. 5. Log on to the Netezza host. 6. Create the host backup following your environments backup policy. An example follows.
nzhostbackup /nz/tmp/hostbackup.20070521
7. Transfer the file to NetBackup using the bpbackup utility. An example follows.
bpbackup -p nzhostbackup -w -L /nz/tmp/hostbackup.log /nz/tmp/ hostbackup.20070521
Note the following important points for the bpbackup utility and the example: Specify the explicit path to the bpbackup command if it is not part of your accounts PATH setting. The default location for the utility is /usr/openv/netbackup/bin. In the sample command, the -L option specifies the log file where the status of the backup operation is written. You should review the file because the utility does not return error messages to the console. The -w option causes the bpbackup utility to run synchronously; it does not return until the operation has completed. The -p option specifies the name of the NetBackup policy, which you defined in step 1 on page 10-38. You can display syntax for the bpbackup utility by running bpbackup without options. Note: An alternative to the bpbackup command is the bp interactive NetBackup client utility. The utility steps you through a backup or a restore.
Performing a Restore
Run the bprestore NetBackup utility to restore the host backup file. An example follows.
bprestore -p nzhostbackup -w -L /nz/tmp/hostrestore.log /nz/tmp/ hostbackup.20070521
Note the following important points for the bprestore utility and the example: Specify the explicit path to the bprestore command if it is not part of your accounts PATH setting. The default location for the utility is /usr/openv/netbackup/bin. You can display syntax for the bprestore utility by running bprestore without options. You can also refer to the Veritas manual, NetBackup Commands for UNIX. Note: An alternative to the bprestore command is the bp interactive NetBackup client utility. The utility steps you through a backup or a restore.
20282-14
Rev.1
10-39
For the two NetBackup policies you create, one performs the user-directed backup and the other creates an automatic schedule that executes the script. The contents of a sample script, /nz/opt/backup/nzhostbackup.sh, follow:
#!/bin/bash # # nphostbackup.sh - perform backup of host catalog and send it # to NetBackup. # # set up the user (password cached using nzpassword) export NZ_USER=nzuser # set up the backup filename today=/bin/date +%Y%m%d filename=nzhostbackup.${today} # path to NetBackup client utilities nbbin="/usr/openv/netbackup/bin" # host backup to disk /bin/bash /nz/kit/bin/nzhostbackup /nz/tmp/${filename} # transfer backup file to NetBackup using user-directed policy # for NPS host file system ${nbbin}/bpbackup -p nzhostbackup -w /nz/tmp/${filename} # return success/failure status to NetBackup for the Activity Monitor exit $?
Note the following important points for the sample script: The bpbackup utility references the nzhostbackup policy, which is a NetBackup policy of type Standard. The policy includes a schedule that allows for a user-directed backup during the desired time period, and lists the Netezza host as a client. To execute the script, you create a NetBackup policy of type DataStore. You can set this policy to have an automatic schedule for regular host backups. You set the frequency and time period for the backups. Ensure that the policy lists the script file in Backup Selections. Note that the script file reference must include the full path to the backup file as you would reference it on the Netezza host. Because the script runs as root on the Netezza host, the Netezza user must be set inside the script using the NZ_USER variable. The users password must have been cached using the nzpassword utility.
10-40
20282-14
Rev.1
5. Enter the following commands to install the 32-bit TSM ADSM API and the Tivoli Storage Manager Backup-Archive (BA) client. (The BA client is optional, but it is recommended because it provides helpful features such as the ability to cache passwords for TSM access and also to create scheduled commands.) a. rpm -i TIVsm-API.i386.rpm b. rpm -i TIVsm-BA.i386.rpm Make sure that you use the default installation directories for the clients (which are usually /opt/tivoli/tsm/client/api and /opt/tivoli/tsm/client/ba). After the installation completes, proceed to the next section to configure the Netezza as a client.
20282-14
Rev.1
10-41
3. Copy the file dsm.opt.smp to dsm.opt. Save the copy in the current directory. For example:
cp dsm.opt.smp dsm.opt
4. Edit the dsm.opt file using any text editor. In the dsm.opt file, proceed to the end of the file and add the following line, shown in bold below, where server is the hostname of the TSM server in your environment:
****************************************************************** * IBM Tivoli Storage Manager * * * * Sample Client User Options file for UNIX (dsm.opt.smp) * ****************************************************************** * * * * * This file contains an option you can use to specify the TSM server to contact if more than one is defined in your client system options file (dsm.sys). Copy dsm.opt.smp to dsm.opt. If you enter a server name for the option below, remove the leading asterisk (*).
****************************************************************** * SErvername A server name defined in the dsm.sys file SErvername server
If you have multiple TSM servers in your environment, you can add a definition for each server. However, only one definition should be the active definition. Any additional definitions should be commented out using the asterisk (*) character. The active dsm.opt entry determines which TSM server is used by the Tivoli connector for backup/restore operations. If there are multiple uncommented SERVERNAME entries in dsm.opt, the first uncommented entry is used. 5. Save and close the dsm.opt file. 6. Copy the file dsm.sys.smp to dsm.sys. Save the copy in the current directory. For example:
cp dsm.sys.smp dsm.sys
10-42
20282-14
Rev.1
7. Edit the dsm.sys file using any text editor. In the dsm.sys file, proceed to the end of the file and add the settings, shown in bold below, where server is the name of the TSM server in your environment, serverIP is the hostname or IP address of the TSM server, and client_NPS is the node name for the Netezza host client:
****************************************************************** * IBM Tivoli Storage Manager * * * * Sample Client System Options file for UNIX (dsm.sys.smp) * ****************************************************************** * * * * * * * This file contains the minimum options required to get started using TSM. Copy dsm.sys.smp to dsm.sys. In the dsm.sys file, enter the appropriate values for each option listed below and remove the leading asterisk (*) for each one. If your client node communicates with multiple TSM servers, be sure to add a stanza, beginning with the SERVERNAME option, for each additional server.
****************************************************************** SErvername server COMMMethod TCPip TCPPort 1500 TCPServeraddress serverIp NODENAME client_NPS
As a best practice, for the nodename value, use the naming convention client_NPS, where client is the hostname of the Netezza host, to help uniquely identify the client node for the Netezza host system. If you have multiple TSM servers in your environment, you can create another set of these definitions and append each set to the file. For example:
SErvername COMMMethod TCPPort TCPServeraddress NODENAME SErvername COMMMethod TCPPort TCPServeraddress NODENAME server1 TCPip 1500 server1Ip client_NPS server2 TCPip 1500 server2Ip client_NPS
Note: If you specify more than one TSM server definition in the dsm.sys file, you can create corresponding definitions in the dsm.opt file as described in step 4. 8. If you installed the Tivoli 5.4 client software on your hosts, you must also add the following options in the dsm.sys file.
ENCRYPTIONTYPE DES56 PASSWORDACCESS prompt
Verify that there are no other uncommented lines for the ENCRYPTIONTYPE and PASSWORDACCESS options. Note: The PASSWORDACCESS prompt option disables automatic, passwordless TSM authentication. Each operation using the Tivoli connector requires you to enter a pass-
20282-14
Rev.1
10-43
word. You can supply the password in the nzbackup and nzrestore connectorArgs option as "TSM_PASSWORD=password" or you can set TSM_PASSWORD as an environment variable. 9. Save and close the dsm.sys file. 10. If you installed the BA client kit, do one of the following steps: Change to the /opt/tivoli/tsm/client/ba/bin directory and repeat Steps 3 through 9 of this procedure to configure the BA client dsm.opt and dsm.sys files. Make sure that the changes that you make to the API client files are identical to the changes that you make for the BA client files. Copy the dsm.opt and dsm.sys files from the /opt/tivoli/tsm/client/api/bin directory to the /opt/tivoli/tsm/client/ba/bin directory. Managing Tivoli Transaction Sizes For Tivoli configurations, the TXNGROUPMAX option specifies the number of objects that can be transferred between a client and the server in one backup transaction. The maximum value is 65000. The default value is 256 objects. If the value is too low, your backups could fail with a start a new transaction session error. If you encounter this error, you should review and increase the TXNGROUPMAX setting to a value that is larger than the maximum number of objects that a single backup operation will try to create. For example, if you are performing incremental backups, then use a value that is at least twice the table count. Also add a small number (5) of additional objects for backup metadata files. If your database has UDXs, add an additional 2 objects for each UDX. If you are using multi-stream backups, then use the maximum value of either double the UDXs, or double the tables divided by the stream count, and add the additional 5 objects for metadata objects. To set the TXNGROUPMAX value using the GUI, go to the Policy Domains and Client Nodes - <Your client node> - Advanced Settings - Maximum size of a transaction. The options are "Use server default" or "Specify a number (4-65,000)". Be sure to repeat thi process on each node (Host 1 and Host 2), and to use the same setting for each node. If you choose "specify a number", note that the setting cannot be changed from the client. If you chose "use server default", you can specify the value from the clients using the dsmadmc application, 'setopt txngroupmax <value>' or 'update node txngroupmax=<value>').
2. Edit the dsm.sys file using any text editor and add the following line:
10-44
20282-14
Rev.1
PASSWORDACCESS generate
Review the file to make sure that there are no other lines which contain the PASSWORDACCESS parameter. If there are, comment them out. 3. Save and close the dsm.sys file. 4. As a test, log in as root and run the following command to be prompted for the client password:
dsmc query session
5. Repeat Steps 1 through 3 to edit the /opt/tivoli/tsm/client/api/bin/dsm.sys API client file. This allows nzbackup to run using the TSM connector without specifying the TSM password. Note: The dsmc command is located in the /opt/tivoli/tsm/client/ba/bin directory. The client installation also creates symbolic links to the TSM commands in the /usr/bin directory. If /usr/bin is included in your PATH variable, you will not need to specify a full pathname to the command. After the client authentication is successful, subsequent logins will not prompt for a password until the password changes at the TSM server.
If you create more than one scheduled operation, note that the TSM scheduler does not support overlapping schedules for operations; that is, one operation must start and complete before a new operation will be allowed to start. If you create operations with overlapping schedules, the second operation will likely be skipped (will not start) because the first operation is still running. Make sure that you allow enough time for the first operation to complete before a new operation is scheduled to run.
20282-14
Rev.1
10-45
The tsm_server value is the hostname or IP address of the TSM server. Log in using an account created for the TSM server. If you cannot access the web interface, the interface may have been stopped on the server. Refer to your TSM documentation for more information about accessing the TSM server using a command shell or SSH session, and starting the TSM server and/or ISC Console. The following procedures assume that you have used a Web browser to connect to the ISC Console and have logged in successfully.
10-46
20282-14
Rev.1
6. If you are creating a new pool select Create a new disk volume and enter a volume name and size. The volume name should be an absolute pathname; for example, if you want to create a volume named vol under the /home/backups directory, type /home/ backups/vol, then click Next. 7. A Summary window appears to display messages about the successful creation of the storage pool and its information. Click Finish.
20282-14
Rev.1
10-47
4. Select a policy domain and select Modify Policy Domain from the Select Action list. The policy_name Properties area appears. 5. Click the arrow to the right of Client Nodes to expand the client nodes list. 6. Select Create a client node from the Select Action drop-down list. The Create Client Node area appears. 7. Type a name for the Netezza host. The name must match the name specified in the dsm.sys file on the client system. 8. Enter and confirm a password for client authentication, and choose an expiration for the password. Click Next to continue. The Administrators area appears. 9. You can either select Create administrator and assign it owner authority to node or Assign owner authority to selected administrator, then click Next. (The owner authority allows the administrator of a node to perform administrative tasks such as changing the client properties.) 10. A Summary window appears to display messages about the successful creation of the client node. Click Finish. The newly created client node now appears in the Client Nodes list. 11. Select the newly created client node and select Modify Client Node from the Select Action drop-down list. The node Properties area appears. 12. Click the Communications tab on the left. The Communications area appears. 13. Type in the TCP address and port in the fields. You can specify the hostname of the client (the Netezza system hostname) and any unused port value (for example, 9000). To list the used ports on the system, use the netstat command. 14. Click the Advanced Settings tab on the left. The Advanced Settings area appears. 15. Change the maximum size of transaction value to a value such as 4096. The maximum number of objects in a transaction cannot exceed 65000. Use caution when selecting a maximum for the number of objects per transaction; larger numbers can impact performance. Try to estimate the maximum number of objects in the database and set the value accordingly. You could begin with an estimate of 3 times the number of tables in the database, for example. 16. Click OK to save the settings.
10-48
20282-14
Rev.1
3. Select the TSM server from which you will be managing your Netezza systems, and then select View Policy Domains from the Select Action list. The server Policy Domains area appears. 4. Select a policy domain and select Modify Policy Domain from the Select Action list. The policy_name Properties area appears. 5. Click the arrow to the right of Client Nodes to expand the client nodes list. 6. Select Create a client node from the Select Action drop-down list. The Create Client Node area appears. 7. Type a name for the proxy node. The name must match the name specified in the /nz/data/config/backupHostname.txt file on the Netezza client system. 8. Enter and confirm the password for client authentication (which was defined in Step 7 of Registering a Netezza Client on a TSM Server on page 10-47), and choose an expiration for the password. Click Next to continue. The Administrators area appears. 9. You can either select Create administrator and assign it owner authority to node or Assign owner authority to selected administrator, then click Next. 10. A Summary window appears to display messages about the successful creation of the client node. Click Finish. The newly created client node now appears in the Client Nodes list. To grant the client node(s) proxy authority over the new proxy node: 1. In the left navigation frame of the ISC Console, click Tivoli Storage Manager. A dropdown list appears. 2. Click Policy Domains and Client Nodes. The Policy Domains page appears in the right frame. 3. Select the TSM server from which you will be managing your Netezza systems, and then select View Policy Domains from the Select Action list. The server Policy Domains area appears. 4. Select a policy domain and select Modify Policy Domain from the Select Action list. The policy_name Properties area appears. 5. Click the arrow to the right of Client Nodes to expand the client nodes list. 6. Select the proxy node and then select Modify Client Node from the Select Action dropdown list. The client Properties area appears. 7. Select the Proxy Authority tab on the left, and then select Grant Proxy Authority from the Select Action drop-down list on the right. The Grant Proxy Authority area appears. 8. Select the client node that represents the Netezza host. If the Netezza system is an HA system, select the client node that represents the common IP information which is used to access the Netezza system. 9. Click OK to complete the proxy assignment.
20282-14
Rev.1
10-49
Redirecting a Restore
Typically, you restore a backup to the same Netezza host from which it was created. If you want to restore a backup that was created on one Netezza host to a a different Netezza host, you must adjust the proxy settings. For example, assume that you have a Netezza host named NPSA, for which you have defined a client node named NPSA NPS and a proxy node named NPSA on the TSM server. Assume also that there is a backup file for the NPSA host on the TSM server. If you wish to load the backup file onto a different Netezza host named NPSB, then you must first ensure that NPSB has been registered as a client to the TSM server. Assume that there is a client node for NPSB NPS and a proxy node named NPSB for this second host. To redirect the restore file from NPSA to NPSB, you must grant the client node NPSB NPS proxy authority over the proxy node NPSA. After you grant the proxy authority to NPSB NPS you should be able to restore the backup for NPSA to the NPSB host using a command similar to the following:
nzrestore -db database -connector tivoli -npshost NPSA
The value database is the name of the database which was backed up from the Netezza host NPSA.
10-50
20282-14
Rev.1
There are some configuration settings changes that can help to avoid these errors and complete the backups for large databases. It is important to note that these configuration settings depend upon factors such as network speed, TSM server load, network load, and other factors. The values below are conservative estimates based on testing, but the values for your environment could be different. As a best practice, if you encounter errors such as timeouts and space limitations, try these conservative values and adjust them to find the right balance for your server and environment. For example: COMMTIMEOUT Specifies the time in seconds that the TSM server waits for an expected client response. The default is 60 seconds. You can obtain the current value of the setting using the QUERY OPTION COMMTIMEOUT command. For large databases, consider increasing the value to 3600, 5400, or 7200 seconds to avoid timeout errors, which could occur if the complete transfer of a database does not complete within the time limit:
SETOPT COMMTIMEOUT 3600
IDLETIMEOUT Specifies the time in minutes that a client session can be idle before the TSM server cancels the session. The default is 15 minutes. You can obtain the current value of the setting using the QUERY OPTION IDLETIMEOUT command. For large databases, consider setting the value to 60 minutes as follows:
SETOPT IDLETIMEOUT 60
The default size of the TSM server database, 16MB, may be inadequate for large Netezza databases. Depending upon the size of your largest Netezza database, you can increase the default TSM database size to a value such as 500MB. The default size of the recovery log, 8MB, may be inadequate for large Netezza databases or Netezza databases that have a large number of objects (tables, UDXs, and so on). An increased value such as 500MB may be more appropriate.
20282-14
Rev.1
10-51
1. In the left navigation frame of the ISC Console, click Tivoli Storage Manager. A dropdown list appears. 2. Click Server Maintenance. 3. Select the TSM server for which your Netezza system is a client. 4. On the Select Action list, select Server Properties. 5. Select the Database and Log tab from the left navigation frame of the Server Properties area. 6. In the Database area on the Select Action list, select Add Volume. 7. In the Volume name field, type the absolute path of the new volume you want to create. 8. In the New volume size field, type an appropriate size for the new volume. If you are not sure, use the value 500. 9. To start using the new volume immediately, select When adding the new volume, expand the database capacity by and in the field, enter a value that is smaller than the value specified for the New volume size field. 10. Click OK to create the volume. To add space automatically with a space trigger: 1. Repeat steps 1 through 5 of the previous procedure to navigate to the Database and Log area. 2. In the Database area on the Select Action list, select Create Space Trigger. 3. Specify values for the field for the automatic database expansion trigger. Use the online help to obtain details about the operation of each field and setting. The key fields to set for your environment are the Begin expansion at this percentage of capacity, Expand the database by this amount, and Maximum size fields. 4. Click OK to create the trigger. You can also create a database space trigger using the define spacetrigger db command. For example, the following command creates a trigger which increases the size of database by 25% when it hits 85% of its capacity with no limit on maximum size:
define spacetrigger db fullpct=85 spaceexpansion=25 maximumsize=0
10-52
20282-14
Rev.1
5. To start using the new volume immediately, select When adding the new volume, expand the recovery log capacity by and in the field, enter a value that is smaller than the value specified for the New volume size field. 6. Click OK to create the volume. To add space automatically with a space trigger: 1. Repeat steps 1 through 5 of the previous procedure to navigate to the Database and Log area. 2. In the Log area on the Select Action list, select Create Space Trigger. 3. Specify values for the field for the automatic log expansion trigger. Use the online help to obtain details about the operation of each field and setting. The key fields to set for your environment are the Begin expansion at this percentage of capacity, Expand the log by this amount, and Maximum size fields. 4. Click OK to create the trigger. You can also create a database space trigger using the define spacetrigger log command. For example, the following command creates a trigger which increases the size of the recovery log by 25% when it hits 85% of its capacity with no limit on maximum size:
define spacetrigger log fullpct=85 spaceexpansion=25 maximumsize=0
In the command, note that the TSM server password is passed as a connector argument. The TSM_PASSWD is the client password as defined in Step 7 of the Registering a Netezza Client on a TSM Server on page 10-47. For example, the following sample command restores the Netezza database using TSM:
nzrestore -db myDb -connector tivoli -connectorArgs "TSM_ PASSWD=password"
20282-14
Rev.1
10-53
# Main script execution starts here ( nzhostbackup "${archive}" echo echo "Sending host backup archive '${archive}' to TSM server ..." dsmc archive "${archive}" ) exit 0
Similarly, you can create a script to retrieve and reload a host backup from the TSM server:
#!/bin/bash # # nzrestore_tsm - restore host backup from TSM using nzhostbackup_tsm # Main script execution starts here if [ "$#" -eq 0 ]; then archive="'/tmp/nzhostbackup*'" echo "Querying for backups in ${archive} for host ${hostname} ..." echo dsmc query archive "${archive}" exit 0 fi if [ "$#" -eq 1 ]; then archive_name="${1}" archive="${archive_name}" echo "Restoring the specified backupset '${archive}' ..." echo ( dsmc retrieve "${archive}" echo echo "Archive '${archive}' retrieved, restoring it..." nzhostrestore "${archive}" ) fi exit 0
10-54
20282-14
Rev.1
2. Click Policy Domains and Client Nodes. The Policy Domains page appears in the right frame. 3. Select the TSM server from which you will be managing your Netezza systems, and then select View Policy Domains from the Select Action list. The server Policy Domains area appears. 4. Select the policy domain that you created for your Netezza host (as described in Creating a Policy Domain on page 10-47) and select Modify Policy Domain from the Select Action list. 5. Select the Client Node Schedules list to expand it. 6. From the Select Action list, select Create a Schedule. The Create Schedule area appears. 7. In the create schedule area, do the following: a. Enter a name for the schedule in the Schedule name field. You can also supply an optional description for the schedule. b. Select the option Command - run a command on a client node machine. c. Click Next. The Select Command Options area appears. 8. In the Command to run field, specify the absolute path of the script you wish to execute and click Next. An example path name follows:
'sh /nz/scripts/mybackup.sh'
Note: The path name is the absolute path of the script file which resides on the Netezza host and must be preceded by the command sh and enclosed in quotes when it has spaces, as shown in the example. In most cases, the script is an nzbackup or nzrestore command operation. For a backup client schedule, the backup script usually contains a single command line that invokes nzbackup for a particular backup operation. You can create the script manually using a text editor. 9. In the Select Repetition Options area, select the data and time and the frequency for the client schedule, then click Next. The Advanced Schedule Options area appears. Note: Note that the TSM scheduler does not support overlapping schedules for operations; that is, one operation must start and complete before a new operation will be allowed to start. Make sure that you allow enough time for the first operation to complete before a new operation is scheduled to run. 10. You can accept the defaults on the Advanced Schedule Options area and click Next. The Associate Client Nodes area appears. 11. Select the client nodes (one or more Netezza hosts) that you want to associate with this schedule. Make sure that you select the client node for the Netezza host, not its proxy node, then click Next. A Summary area appears. Note: Typically you would select only one client node (that is, one Netezza host) to perform this operation at one time. However, it is possible to select multiple client nodes if you want to schedule the operation for multiple hosts to occur at the same time. 12. Review the information in the Summary and click Finish to create the client schedule.
20282-14
Rev.1
10-55
Because the script runs as root on the Netezza host, the Netezza user must be set inside the script using the NZ_USER variable or specified with the -u user argument. The users password must have been cached using the nzpassword utility, set inside the script using NZ_PASSWORD, or specified using the -pw password argument. You can use the backup history to check the status of a backup operation. For more information, see Backup History Report on page 10-18.
Troubleshooting
The following sections describe some common problems and workarounds.
Client-Server Connectivity
You can check the network connections and configuration settings to ensure that the Netezza host (the client) can connect to the TSM server. To check connectivity, use the following command:
dsmc query session
The command prompts for the client user password, and after a successful authentication, it shows the session details.
The file value specifies the pathname of a file on the Netezza system. As a result of the command, the file should be saved in the configured storage pool for the Netezza client. For the test, you could rename the test file to ensure that the subsequent retrieval test works. To restore the single file, use the following command:
dsmc retrieve file
As a result of the command, the file should be retrieved from the storage pool archive and saved on the Netezza system. For complete descriptions of the TSM commands, arguments, and operations, refer to the Tivoli Storage Manager documentation.
Session Rejected
An error such as Session rejected: Unknown or incorrect ID entered is probably a result of one of the following problems: The Netezza host has not been correctly registered on the TSM server. The dsm.sys file on the Netezza host is not correct. You should confirm the information in both configurations and retry the operation.
10-56
20282-14
Rev.1
20282-14
Rev.1
10-57
10-58
20282-14
Rev.1
C H A P T E R 11
Query History Collection and Reporting
Whats in this chapter
Query History Concepts Query History Loading Process Disabling History Collection Changing the Owner of a History Database Changing Query History Configuration Settings Displaying Query History Configuration Settings Dropping History Configurations Query History Views and User Tables History Table Helper Functions
Query history captures details about the user activity on the Netezza system, such as the queries that are run, query plans, table access, column access, session creation, and failed authentication requests. The history information is saved in a history database. Permitted users can review the query history information to obtain details about the users and activity on the Netezza system. Note: The query history feature replaces any previous query history tools for the Netezza system. Note that the older query history views _v_qryhist and _v_qrystat provided in previous Netezza releases are maintained for backward compatibility and they will be deprecated in a future release.
11-1
4. Enable query history collection. The result is a set of captured data files which will be loaded into the query history database. 5. Enable access privileges for the users who will be reviewing and reporting on the history information. The following sections describe these tasks in more detail.
11-2
20282-14
Rev.1
The command can take several minutes to complete, depending upon how busy the Netezza system is. This command assigns the user smith as the owner of the database, and assigns the user histusr as the account which will be used to load the history data which is collected. Both the owner and user accounts must exist on the Netezza system before you run the command. You cannot specify the admin user as the owner or user of the database. The command grants the necessary privileges to the users specified for owner and user. For details about the command, see nzhistcreatedb on page A-19.
For more information about the command, see nzhistcleanupdb on page A-17.
20282-14
Rev.1
11-3
After running the nzhistcleanupdb command, you can run nzreclaim to completely remove the deleted rows in the table.
Before you drop a history database, make sure that the active history configuration is not configured to load data to it. If you drop the active history database, load operations to that database will fail.
11-4
20282-14
Rev.1
The configuration name, user name and database name are identifiers and can be enclosed in quotation marks. For example: sample configuration, sample user, and sample qhist db are all valid names. The version number, which must be 1 for Release 4.6 systems, must match the version number specified in the nzhistcreatedb command; otherwise, the loader process will fail. The following command creates a history configuration named hist_disabled that disables history collection:
SYSTEM(ADMIN)=> CREATE HISTORY CONFIGURATION hist_disabled HISTTYPE NONE;
For details about the command, see the CREATE HISTORY CONFIGURATION command syntax in the Netezza Database Users Guide. When you create or alter a history configuration to HISTTYPE NONE, the command automatically sets the default values of CONFIG_LEVEL, CONFIG_TARGETTYPE, and CONFIG_COLLECTFILTER parameters to HIST_LEVEL_NONE, HIST_TARGET_LOCAL, and COLLECT_ALL respectively.
20282-14
Rev.1
11-5
Then, to start collecting history using that configuration, you stop and restart the Netezza software as follows:
nzstop nzstart
For details about the command, see the SET HISTORY CONFIGURATION command syntax in the Netezza Database Users Guide.
11-6
20282-14
Rev.1
History Database
Error Area
Figure 11-1: Query History Staging and Loading Areas The staging area is located in the $NZ_DATA/hist/staging directory. The staging area could have one or several subdirectories named alc_$TIMESEQUENCE, which contain batches (that is, one or more) captured history data files. The captured data history files are saved as external tables in text format. The alc* directories also have a CONFIG-INFO file to identify the history configuration which was active when the files were created. The captured files in the staging area are transferred to the loading area based on the configuration load settings. From the loading area, the alcloader process (the loader) loads the external tables into the query history database. The loading frequency, as well as the target history database and the user account to access that database, are specified in the current configuration settings. The loading area is located in the $NZ_DATA/hist/loading directory, and it contains a subdirectory named alc_$TIMESEQUENCE for the batch of history files that it is loading (the load in progress). There could be zero, one, or several subdirectories if there are several queued batches waiting to be loaded. Note: If a batch of files cannot be loaded for some reason, the loader moves the batch to the $NZ_DATA/hist/error directory. This error directory contains any failed loads. Errors can occur if you deactivate and drop an active configuration before its history files are loaded, if the user password no longer matches, or if the history database is dropped or locked. After history files are successfully loaded, the Netezza system deletes the batch of external tables to clean up and free the disk space.
20282-14
Rev.1
11-7
environments. Because of the continuous loading of data, this setting can cause a performance impact on Netezza systems. Busy When the captured data in the staging area meets or exceeds the max threshold, transfer it to the loading area.
11-8
20282-14
Rev.1
Table 11-1: History Loader Settings and Behavior Load Interval 0 Min Threshold Non-zero Max Threshold 0 Loader State Idle Operation When the captured data in the staging area meets or exceeds the min threshold, transfer it to the loading area. Continue collecting data in the staging area until the loader is idle, then transfer the data to the loading area. When the captured data in the staging area meets or exceeds the min threshold, transfer it to the loading area. Continue collecting data in the staging area until the max threshold is reached or until the loader is idle, then transfer the data to the loading area. Transfer any captured data in the staging area to the loading area when the timer expires, regardless of amount of data or loader state. Transfer captured data in the staging area to the loader when the timer expires, or when the data meets or exceeds the max threshold. When the timer expires, transfer the captured data in the staging area to the loading area if it meets or exceeds the min threshold. When the timer expires, transfer the captured data in the staging area to the loading area if it meets or exceeds the min threshold or the max threshold.
Note: This is the recommended combination for a production
Busy
Non-zero
Non-zero
Idle Busy
Nonzero
N/A
Nonzero Nonzero
Non-zero
N/A
Non-zero
N/A
Nonzero
Non-zero
Non-zero
Idle
Netezza system. You can tune the values of the three loading settings for your environment as described in the text following this table. Busy If the staging area meets or exceeds the max threshold, transfer the captured data in the staging area to the loading area. Otherwise, continue collecting data until the next timer expiration.
Depending upon the loader settings and how much history data is collected, it is possible for the alcloader process to become busy loading history data. You might notice that there are several batch directories in the loading area, which indicates queued and waiting load requests. Depending upon how much history data you collect and the overall utilization of the Netezza system, you might want to try various values for the loader settings to tune it for best operation in your environment. Based on the load settings and how busy the loader is, there can be a delay between the time that query history data is captured, and the time when it is loaded and available for reporting in the query history database. You can tune the loader settings to help reduce the
20282-14
Rev.1
11-9
delay and balance the load frequency without unduly impacting the Netezza system. Also, since the captured data is saved in text-based external files, the history reporting users can also review the files in the staging area to obtain information about very recent activity. To ensure that the load staging area size does not grow indefinitely, there is a STORAGELIMIT setting which controls how large the staging area can be in MB. If the staging area reaches or exceeds this size limit, Netezza stops collecting history data. An administrator must free up disk space in the storage areausually by adjusting the loader settingsto free up disk space so that history collection can resume. The STORAGELIMIT value must be greater than LOADMAXTHRESHOLD.
Then, to place that configuration into effect, stop and restart the Netezza software:
nzstop nzstart
11-10
20282-14
Rev.1
To change the ownership of a history database: 1. Log in to the Netezza system as the nz user. 2. Make sure that you have a database user account for the new owner of the configuration and database, for example:
nzsql -c "create user qhist with password 'qhistpw'"
4. If you are changing the active history configuration, disable history collection (hist_disabled is the sample configuration created earlier in this chapter):
nzsql -c "Set history configuration hist_disabled"
6. Change the history database ownership, where histdb is the name of the history database:
nzsql c "alter database histdb owner to qhist"
9. Repeat Step 5 to restart the Netezza software and resume history collection using the all_hist configuration.
20282-14
Rev.1
11-11
SYSTEM(ADMIN)=> SHOW HISTORY CONFIGURATION; CONFIG_NAME | CONFIG_NAME_DELIMITED | CONFIG_DBNAME | CONFIG_DBNAME_DELIMITED | CONFIG_DBTYPE | CONFIG_TARGETTYPE | CONFIG_LEVEL | CONFIG_HOSTNAME | CONFIG_USER | CONFIG_USER_DELIMITED | CONFIG_PASSWORD | CONFIG_LOADINTERVAL | CONFIG_LOADMINTHRESHOLD | CONFIG_LOADMAXTHRESHOLD | CONFIG_DISKFULLTHRESHOLD | CONFIG_STORAGELIMIT | CONFIG_LOADRETRY | CONFIG_ENABLEHIST | CONFIG_ENABLESYSTEM | CONFIG_NEXT | CONFIG_CURRENT | CONFIG_VERSION -------------+-----------------------+---------------+-------------------------+--------------+-------------------+--------------+-----------------+-------------+----------------------+-----------------+---------------------+-------------------------+------------------------+--------------------------+---------------------+-----------------+-------------------+---------------------+-------------+----------------+--------------DISABLEQHIST | f | | f | 3 | 1 | 1 | localhost | | f | | -1 | -1 | -1 | -1 | -1 | -1 | f | f | f | f | 1 (1 row)
If you do not specify a configuration name, the command displays information for the active configuration. If you specify ALL, the command displays information about all the defined configurations. If you want to change the active configuration, you must first use the SET command to activate a different configuration (such as a history disabled configuration) and restart the Netezza software to put that configuration into effect. You can then change the settings for the previously active configuration. Use the SET command to reactivate it, and restart the Netezza software to put the modified configuration into effect. For details about the command, see the SHOW HISTORY CONFIGURATION command syntax in the Netezza Database Users Guide.
If you want to drop the active configuration, you must first set to a new configuration and restart the Netezza software; then you can drop the non-active configuration. As a best practice, you should not drop the configuration until the loader has finished loading any captured data for that configuration. To verify whether there are any batches of history data for the configuration that you want to drop, you can do the following: 1. Open a shell window to the Netezza system and log in as the admin user. 2. Change to the /nz/data/hist directory. 3. Use a command such as grep to search for CONFIG-INFO files that contain the name of the configuration that you want to drop. For example:
grep -R -i basic .
11-12
20282-14
Rev.1
4. Review the output of the grep command to look for messages similar to the following:
./loading/alc_20080926_162803.964347/CONFIG-INFO:BASIC_HIST ./staging/alc_20080926_162942.198443/CONFIG-INFO:BASIC_HIST
These messages indicate that there are batches in the loading and staging areas that use the BASIC_HIST configuration. If you drop that configuration before the batch files are loaded, the loader will classify them as errors when it attempts to process them later. If you want to ensure that any captured data for the configuration is loaded, do not drop the configuration until after the command in Step 3 returns no output messages for the configuration that you want to drop. For details about the command, see the DROP HISTORY CONFIGURATION command syntax in the Netezza Database Users Guide.
20282-14
Rev.1
11-13
Figure 11-2: The Query History Configuration Dialog The Configuration Name drop-down list contains any configurations already created on the system, either using this dialog box or by the CREATE HISTORY CONFIGURATION command. When you select a configuration, the window displays the settings for that configuration. If you select the current (active) configuration, the dialog box displays a message that you cannot edit the current configuration. The fields will be displayed but they are not modifiable. To create a new history configuration, type a new configuration name and supply the information for the required fields. Refer to the CREATE HISTORY CONFIGURATION command syntax in the Netezza Database Users Guide for details about the fields and their values. Click OK to save your new history configuration.
11-14
20282-14
Rev.1
To make the selected configuration the current (active) configuration, click Set as Current. A confirmation dialog appears to inform you that you have changed the current configuration, but the changes will not take effect until you restart the Netezza software. Until you restart the server, the previously active configuration remains in effect using its settings specified the last time that the Netezza software was started. To alter an existing configuration, select it in the Configuration Name drop-down list and change the settings as applicable. If you want to alter the active configuration, you must first select a different configuration, then click Set as Current to make it the current configuration. You can then select the formerly active configuration to edit it.
_v_querystatus
The _v_querystatus view shows the query data collected for running/active queries. Even if history collection is disabled, this view is still populated with data for the active queries. Table 11-2: _v_querystatus Name npsinstanceid opid Type integer bigint Description Instance ID of the nzstart command Operation ID (This is a key field for joining this table with _v_planstatus to get a list of the plans for a running query.) Client session identifier (as seen by sessionrelated commands) Client ID of the SQL client Process ID of the client IP address of the client Host name of the client Session user ID Session user name
20282-14
Rev.1
11-15
Table 11-2: _v_querystatus Name dbid dbname sqltext submittime priority pritext Type bigint name nvarchar(1024) timestamp integer name Description Database ID for the connection Database name for the connection The SQL query string, which is truncated for performance reasons Submit time of the query Session priority Session priority in text string format
_v_planstatus
The _v_planstatus view shows the plan data and session data collected for running/active queries. Even if history collection is disabled, this view is still populated with data for the active queries.. Table 11-3: _v_planstatus Name npsinstanceid opid Type integer bigint Description Instance ID of the nzstart command Operation ID (This is a key field for joining this table with _v_querystatus to get a list of the plans for a running query.) DBOS plan ID DBOS transaction ID Client session identifier (as seen by sessionrelated commands) Client ID of the SQL client Process ID of the client IP address of the client Host name of the client Session user ID Session user name Database ID for the connection Database name for the connection
11-16
20282-14
Rev.1
Table 11-3: _v_planstatus Name submittime queuetime Type timestamp timestamp Description Submit time of the plan Time at which the plan was queued to the gate keeper. Time at which the first snippet was prepared Time at which the plan was placed on the GRA queue Start time of the plan execution Flag for main plan Session priority Session priority in text string format Gate keeper priority Gate keeper priority in text string format State of the plan, which could be: PENDING = 1, QUEUED = 2, RUNNING = 3, ABORTED = 4, or DONE = 5 The count of the number of restarts Estimated total cost Estimated disk cost Estimated memory cost Total number of snippets Snippets which have completed execution Number of result rows Number of result bytes
preptime gratime
timestamp timestamp
20282-14
Rev.1
11-17
$v_hist_queries
The $v_hist_queries view shows information about the completed queries and their status, runtime seconds (for total, cumulative queued, prep time and GRA time), and number of plans. Table 11-4: $v_hist_queries View Name npsid Description A unique ID for the Netezza system (This value is generated as a sequence on the target database where this view resides.) The instance ID of the nzstart command for the source Netezza system Operation ID, which is used as a foreign key from query epilog, overflow as well as plan, table, column access tables. A foreign key into the hist_log_entry_$SCHEMA_VERSION table with the npsid and npsinstanceid The session ID (will be NULL for a failed authentication) The name of the database to which the session is connected The unique checksum of the query The first 8 KB of the query text The time the query was submitted to Postgres The time the query finished execution The total query runtime (as interval and in seconds)
npsinstanceid
opid logentryid
sessionid dbname queryid query submittime finishtime runtime runtime_seconds status verbose_status queuetime queued_seconds preptime prep_seconds gratime gra_seconds numplans numrestarts
The amount of time the query was queued (as interval and in seconds) The amount of time the query spent in "prep" stage (as interval and in seconds) The amount of time the query spent in GRA (as interval and in seconds) The number of plans generated The cumulative number of times the plans were restarted
11-18
20282-14
Rev.1
$v_hist_incomplete_queries
The $v_hist_incomplete_queries view lists the queries that were not captured completely. The problem may be that there was a system reset at the time of logging or because some epilog/prolog has not been loaded into the database yet. Table 11-5: $v_hist_incomplete_queries View Name npsid Description A unique ID for the Netezza system (This value is generated as a sequence on the target database where this view resides.) The instance ID of the nzstart command for the source Netezza system Operation ID, which is used as a foreign key from query epilog, overflow as well as plan, table, column access tables. A foreign key into the hist_log_entry_$SCHEMA_VERSION table with the npsid and npsinstanceid The session ID (will be NULL for a failed authentication) The name of the database to which the session is connected The unique checksum of the query The first 8 KB of the query text The time the query was submitted to Postgres
npsinstanceid opid
logentryid
$v_hist_table_access_stats
The $v_hist_table_access_stats view lists the names of all the tables captured in table access and provides some cumulative statistics. Table 11-6: $v_hist_table_access_stats View Name dbname schemaname tablename refs Description The name of the database to which the session is connected The schema name as specified in catalog.schema.table The table name of the table The number of times that this table was referenced
20282-14
Rev.1
11-19
Table 11-6: $v_hist_table_access_stats View Name num_selected num_inserted num_deleted num_updated num_truncated num_dropped num_created num_genstats num_locked num_altered Description The number of times that this table was SELECTED from, INSERTED into, DELETED from, UPDATED, TRUCATED, DROPPED, CREATED, "GENSTATS", LOCKED, or ALTERED
$v_hist_column_access_stats
The $v_hist_column_access_stats view lists the names of all tables captured in table access and provides some cumulative statistics. Table 11-7: $v_hist_column_access_stats View Name dbname schemaname tablename columname Refs num_selected num_updated num_where num_grouped num_having num_ordered num_altered num_genstats Description The name of the database to which the session is connected The schema name as specified in catalog.schema.table The table name of the table The name of the column The number of times that this column was referenced The number of times this column was referenced in SELECT, UPDATE, WHERE, GROUP BY, HAVING, ORDER BY, ALTER, or GENERATE STATISTICS clauses.
$v_hist_log_events
The $v_hist_log_events view shows information about the events that occurred on the system. Table 11-8: $v_hist_log_events View Name npsid Description A unique ID for the Netezza system (This value is generated as a sequence on the target database where this view resides.)
11-20
20282-14
Rev.1
Table 11-8: $v_hist_log_events View Name npsinstanceid Description The instance ID of the nzstart command for the source Netezza system Operation ID, which is used as a foreign key from query epilog, overflow as well as plan, table, column access tables. A foreign key into the hist_log_entry_$SCHEMA_VERSION table with the npsid and npsinstanceid The session ID (will be NULL for a failed authentication) The name of the database to which the session is connected The timestamp when the operation occurred The integer code and text string describing the actual operation. The valid values are one of the following:
1 = session create 2 = session logout 3 = failed authentication 4 = query prolog 5 = query epilog 6 = plan prolog 7 = plan epilog
opid
checksum details
These are the checksum and query for query prolog entries, signature and plan information for plan prolog entries. For other log entries, checksum is NULL and details will have other information like status for epilogs. The OID of the database where the table resides The name of the database where the table resides The client type, such as none, nzsql, odbc, jdbc, nz(un)load, cli, bnr, reclaim, old-loader (depcrecated), or internal
$hist_version
The $hist_version table shows information about the schema version number of the history database. Table 11-9: $hist_version Name hversion Type integer Description Schema version of the history database
20282-14
Rev.1
11-21
Table 11-9: $hist_version Name dbtype Type char(1) Description Specifies the type of history database ("q" indicates a query database)
$hist_nps_$SCHEMA_VERSION
The $hist_nps_$SCHEMA_VERSION table describes each source Netezza system for which history is captured in the target database. When a Netezza system connects to a history database for the first time, a record is added to this table. Table 11-10: $hist_nps_$SCHEMA_VERSION Name npsid Type integer Description A unique ID for the Netezza system, and the primary key for this table (This value is generated as a sequence on the target database where this table resides.) UUID of the Netezza system, which is a unique ID (generated on the source Netezza system) Host name of the source Netezza system IP address of the source Netezza system Instance ID of the source Netezza system when this record was inserted
uuid
char(36)
$hist_log_entry_$SCHEMA_VERSION
The $hist_log_entry_$SCHEMA_VERSION table captures the log entries for the operations performed. It shows the sequence of operations performed on the system. This table is not populated if history collection has never been enabled or if hist_type = NONE. Table 11-11: $hist_log_entry_$SCHEMA_VERSION Name logentryid Type bigint Description Unique ID for the operation in the source Netezza system. This column together with npsid and npsInstanceId form the primary keys for this table. Note that logentryid is just a sequential ID of an operation. The instance ID of the nzstart command for the source Netezza system Netezza ID for the source system whose data is captured in this table
npsinstanceid npsid
integer integer
11-22
20282-14
Rev.1
Table 11-11: $hist_log_entry_$SCHEMA_VERSION Name sessionid Type bigint Description The session ID (will be NULL for a failed authentication) An operation code, which can be one of the following:
OP_SESSION_CREATE = 1 OP_SESSION_LOGOUT = 2 OP_FAILED_AUTH = 3 OP_QUERY_PROLOG = 4 OP_QUERY_EPILOG = 5 OP_PLAN_PROLOG = 6 OP_PLAN_EPILOG = 7
op
integer
time
timestamp
$hist_failed_authentication_$SCHEMA_VERSION
The $hist_failed_authentication_$SCHEMA_VERSION table captures only the failed authentication attempts for every operation that is authenticated. A successful authentication results in a session creation. A failed authentication does not result in a session creation, but it instead creates a record with a unique operation ID in this table. Table 11-12: $hist_failed_authentication_$SCHEMA_VERSION Name npsid Type integer Description Netezza ID for the source system whose data is captured in this table Instance ID of the nzstart command for the source Netezza system A foreign key into the hist_log_entry_$SCHEMA_VERSION table with the npsid and npsinstanceid IP address of the client that made the connection attempt The name string for the sessionUserId The timestamp when the operation occurred
npsinstanceid
integer
logentryid
bigint
clientip
char(16)
sessionusername time
nvarchar(512) timestamp
20282-14
Rev.1
11-23
Table 11-12: $hist_failed_authentication_$SCHEMA_VERSION Name failuretype Type integer Description One of the following codes that represent the authentication failure type:
1 failed authentication due to bad user-
name/password
2 failed authentication due to concurrency 3 failed authentication due to user access
time limits
4 user account disabled after too many
failed password attempts failure varchar(512) The text message for the failure type code
$hist_session_prolog_$SCHEMA_VERSION
The $hist_session_prolog_$SCHEMA_VERSION table stores details about each created session. Every successful authentication or session creation adds an entry to this table with a unique operation ID. Table 11-13: $hist_session_prolog_$SCHEMA_VERSION Name npsid npsinstanceid Type integer integer Description Unique ID of the source Netezza system Monotonically increasing nzstart instance ID of the source Netezza system This is a foreign key into the hist_log_entry_$SCHEMA_VERSION table with the npsid and npsinstanceid. This with npsid and npsinstanceid will also be a primary key for this table. Process ID of Postgres on source Netezza system Connection time on the source Netezza system Session priority on the source Netezza system Maximum priority for this session User ID that created this session Current user ID for this session. This could be different from the sessionUserId. The operating user ID for whom the ACL and permission will be used for validating permissions
logentryid
bigint
operatinguserid
bigint
11-24
20282-14
Rev.1
Table 11-13: $hist_session_prolog_$SCHEMA_VERSION Name sessionusername Type nvarchar(128) Description The session user name which corresponds to sessionUserId The user name which corresponds to currentUserId The user name which corresponds to operatingUserId The OID of the database to which the session is connected The name of the database to which the session is connected The hostname of the client that established the session The IP address of the client making the connection The process ID of the client The type of the client such as:
0 None 1 LibPq client 2 ODBC client 3 JDBC client 4 nzload / nzunload 5 client of client manager 6 nzbackup / nzrestore 7 nzreclaim 8 old loader 9 Internal Netezza tool
currentusername
nvarchar(128)
operatingusername dbid
nvarchar(128) bigint
dbname
nvarchar(128)
clienthost clientip
varchar(256) char(16)
clientpid clienttype
integer integer
sessionid
integer
The Netezza session ID. This is NOT unique across nzstart. This value along with npsid and npsinstanceid will be the foreign key from query, plan, table, and column access tables. Netezza client ID of the client The value of the session variable for sessionUserId The value of the session variable for sessionUserId
npsclientid rowsetlimit
integer integer
sessiontimeout
integer
20282-14
Rev.1
11-25
Table 11-13: $hist_session_prolog_$SCHEMA_VERSION Name querytimeout Type integer Description The value of the session variable for sessionUserId The value of the session variable for sessionUserId The value of the session variable for sessionUserId The value of the session variable for sessionUserId The value of the session variable for sessionUserId The value of the session variable for sessionUserId
srqueuetimeout
integer
qcmaxrestarts resourcegroupid
integer bigint
resourcegroupname resourcepercentage
nvarchar
integer
$hist_session_epilog_$SCHEMA_VERSION
The $hist_session_epilog_$SCHEMA_VERSION table stores details about each session when the session is terminated. Each session completion creates an entry in this table with a unique operation ID. Table 11-14: $hist_session_epilog_$SCHEMA_VERSION Name npsid logentryid Type integer bigint Description Unique ID of the source Netezza system This is a foreign key into the hist_log_entry_$SCHEMA_VERSION table with the npsid and npsinstanceid. This with npsid and npsinstanceid form the primary key for this table. The Netezza session ID. This is NOT unique across nzstart. This with npsid and npsinstanceid will be the foreign key from query, plan, table, and column access tables. Monotonically increasing nzstart instance ID of the source Netezza system Timestamp of the session termination
sessionid
bigint
npsinstanceid
integer
endtime
timestamp
$hist_query_prolog_$SCHEMA_VERSION
The $hist_query_prolog_$SCHEMA_VERSION table contains the initial data collected at the start of a query.
11-26
20282-14
Rev.1
A query with or without a plan, and a plan without a query, causes the creation of a record with an operation ID in the $hist_operation_$SCHEMA_VERSION table. The query prolog and epilog, plan prolog and epilog, table access, and column access for that query will share the same operation ID (opid). Thus, this will be a key for joining all query-related data. The session related data will be retrieved using the foreign key sessionid. Table 11-15: $hist_query_prolog_$SCHEMA_VERSION Name npsid Type integer Description This value along with the npsInstanceId and opid form the foreign key into the operation table. Operation ID, which is used as a foreign key from query epilog, overflow as well as plan, table, column access tables. Instance ID of the source Netezza system This is a foreign key into the hist_log_entry_$SCHEMA_VERSION table with the npsid and npsinstanceid. This with npsid and npsinstanceid will also be a primary key for this table. The Netezza session ID. This with npsid and npsinstanceid will be the foreign key from query, plan, table, and column access tables. Operation ID of the parent stored procedure. For Release 4.6, this is null. User ID used for execution of this query. For Release 4.6, this is null. Username used for execution of this query. For Release 4.6, this is null. The first 8 KB of the query text. Any remaining text in the query appears in the query text overflow table. Submit time of the query The checksum of the entire query string, which can help to identify identical queries.
opid
bigint
npsinstanceid logentryid
integer bigint
sessionid
bigint
parentopid
bigint
userid
bigint
username
nvarchar(128)
querytext
nvarchar(8192)
submittime checksum
timestamp bigint
20282-14
Rev.1
11-27
$hist_query_epilog_$SCHEMA_VERSION
The $hist_query_epilog_$SCHEMA_VERSION table contains the final data collected at the end of the query. Table 11-16: $hist_query_epilog_$SCHEMA_VERSION Name npsid Type integer Description This value along with the npsInstanceId and opid form the foreign key into the operation table. Operation ID. Used as a foreign key from query epilog, overflow as well as plan, table, column access tables to query prolog. This is a foreign key into the hist_log_entry_$SCHEMA_VERSION table with the npsid and npsinstanceid. This with npsid and npsinstanceid will also be a primary key for this table. Instance ID of the source Netezza system The Netezza session ID. This with npsid and npsinstanceid will be the foreign key from query, plan, table, and column access tables into session tables. Finish time of the query The number of rows affected by the SQL query. Applicable for select, insert, update, delete, and CTAS queries. Note that the result rows in the plan epilog is internal to Netezza and specifies the number that the plan returns to the query.
opid
bigint
logentryid
bigint
npsinstanceid sessionid
integer bigint
finishtime resultrows
timestamp bigint
11-28
20282-14
Rev.1
Table 11-16: $hist_query_epilog_$SCHEMA_VERSION Name status Type integer Description Completion status of the query. The valid values are:
-1: Query execution aborted. nzsession abort -2: Query cancelled by user using Control-C.
QUERY_FAILED_PARSING.
-4: Query failed during Postgres rewrite.
QUERY_FAILED_REWRITE.
-5: Query failed during planning.
QUERY_FAILED_PLANNING.
-6: Query failed during execution.
QUERY_FAILED_EXECUTION.
-7: Reserved for future use. -8: Query failed ACL check.
QUERY_FAILED_ACLCHECK.
-9: Query failed by other generic errors.
QUERY_FAILED_GENERIC.
$hist_query_overflow_$SCHEMA_VERSION
The $hist_query_overflow_$SCHEMA_VERSION table stores the overflow of the query string if it is greater than 60000 bytes. Table 11-17: $hist_query_overflow_$SCHEMA_VERSION Name npsid Type integer Description This value along with the npsInstanceId and opid form the foreign key into the operation table. Operation ID. Used as a foreign key from query epilog, overflow as well as plan, table, column access tables to query prolog. Instance ID of the source Netezza system Session ID. This with npsid and npsinstanceid will be foreign key from query, plan, table and column access tables into session tables.
opid
bigint
npsinstanceid sessionid
integer bigint
20282-14
Rev.1
11-29
Table 11-17: $hist_query_overflow_$SCHEMA_VERSION Name next Type integer Description This is the pointer to next ID record in the sequence. The last record has next value of -1. The first record has sequenceid 0 (zero). This is the sequence ID of each entry. There is one for each query text fragment. The overflow part of the query string
sequenceid
integer
querytext
nvarchar(8192)
$hist_service_$SCHEMA_VERSION
The $hist_service_$SCHEMA_VERSION table records the CLI usage from the localhost or remote client. It logs the command name and the timestamp of the command issue. This information is collected in the query history when COLLECT SERVICE is enabled in the history configuration. For more information, see the Netezza Advanced Security Administrators Guide. Table 11-18: $hist_service_$SCHEMA_VERSION Name npsid Type integer Description This value along with the npsInstanceId and opid form the foreign key into the operation table. Instance ID of the source Netezza system This is a foreign key into the hist_log_entry_$SCHEMA_VERSION table with the npsid and npsinstanceid. This with npsid and npsinstanceid will also be a primary key for this table. Session ID. This is a foreign key into session_$SCHEMAVERSION and is generated by the source Netezza system. This field along with npsid will be the foreign key into session_$SESSIONVERSION.
npsinstanceid logentryid
integer bigint
sessionid
bigint
11-30
20282-14
Rev.1
Table 11-18: $hist_service_$SCHEMA_VERSION Name servicetype Type bigint Description The code for the command, which is one of the following integer values:
1 nzbackup 2 nzrestore 3 nzevent 4 nzinventory (obsoleted in 5.0) 5 nzreclaim 6 nzsfi (obsoleted in 5.0) 7 nzspu (obsoleted in 5.0) 8 nzstate 9 nzstats 10 nzsystem
service
varchar(512)
$hist_state_change_$SCHEMA_VERSION
The $hist_state_change_$SCHEMA_VERSION table logs the state changes in the system. It logs Online, Paused, Offline and Stopped. For the Online state change, the logging occurs after the system has gone Online. In other cases, the logging occurs before the state transition is made to the respective state. This information is collected in the query history when COLLECT STATE is enabled in the history configuration. For more information, see the Netezza Advanced Security Administrators Guide. Table 11-19: $hist_state_change_$SCHEMA_VERSION Name npsid Type integer Description This value along with the npsInstanceId and opid form the foreign key into the operation table. Instance ID of the source Netezza system This is a foreign key into the hist_log_entry_$SCHEMA_VERSION table with the npsid and npsinstanceid. This with npsid and npsinstanceid will also be a primary key for this table.
npsinstanceid logentryid
integer bigint
20282-14
Rev.1
11-31
Table 11-19: $hist_state_change_$SCHEMA_VERSION Name changetype Type bigint Description The code for the change type, which is one of the following integer values:
1 The system is Online. 2 The system is going into the Paused
state.
3 The system is going into the Offline
state.
4 The system is going into the Stopped
state. change varchar(512) The text string for the change code as described in changetype
$hist_table_access_$SCHEMA_VERSION
The $hist_table_access_$SCHEMA_VERSION table records the table access history for a query. This table becomes enabled whenever query history type is Table. Table 11-20: $hist_table_access_$SCHEMA_VERSION Name npsid Type integer Description This value along with the npsInstanceId and opid form the foreign key into the operation table. Operation ID. Used as a foreign key from query epilog, overflow as well as plan, table, column access tables to query prolog. Session ID. This with npsid and npsinstanceid will be foreign key from query, plan, table and column access tables into session tables. A plain sequence number of the entry. It starts at zero for every npsid, npsinstanceid, and opid. It increments monotonically for table access records for each query. Instance ID of the source Netezza system OID of the database where the table resides The name of the database where the table resides The OID of the schema as specified in catalog.schema.table
opid
bigint
sessionid
bigint
seqid
integer
11-32
20282-14
Rev.1
Table 11-20: $hist_table_access_$SCHEMA_VERSION Name schemaname Type nvarchar(128) Description The schema name as specified in catalog.schema.table The table id of the table The table name of the table The following bits will set to true if table appears in: (usage & 1) <> 0 = selected (usage & 2) <> 0 = inserted (usage & 4) <> 0 = deleted (usage & 8) <> 0 = updated (usage & 16) <> 0 = truncated (usage & 32) <> 0 = dropped (usage & 64) <> 0 = created (usage & 128) <> 0 = statsgenerated (usage & 256) <> 0 = locked (usage & 512) <> 0 = altered
$hist_column_access_$SCHEMA_VERSION
The $hist_column_access_$SCHEMA_VERSION table records the column access history for a query. This table becomes enabled whenever query history type is Column. Table 11-21: $hist_column_access_$SCHEMA_VERSION Name npsid Type integer Description This value along with the npsInstanceId and opid form the foreign key into the operation table. Operation ID. Used as a foreign key from query epilog, overflow as well as plan, table, column access tables to query prolog. Session ID. This with npsid and npsinstanceid will be foreign key from query, plan, table and column access tables into session tables. Instance ID of the source Netezza system A plain sequence number of the entry. It starts at zero for every npsid, npsinstanceid, and opid. It increments monotonically for table access records for each query. The name of the column
opid
bigint
sessionid
bigint
npsinstanceid seqid
integer integer
columnname
nvarchar(128)
20282-14
Rev.1
11-33
Table 11-21: $hist_column_access_$SCHEMA_VERSION Name columnid Type integer Description The column position as it appears in the logical table definition; starts at 1 The following bits will set to true if column appears in: (usage & 1) <> 0 = in_select (usage & 2) <> 0 = in_set (usage & 4) <> 0 = in_where (usage & 8) <> 0 = in_groupby (usage & 16) <> 0 = in_having (usage & 32) <> 0 = in_orderby (usage & 64) <> 0 = in_alter OID of the database where the table resides The name of the database where the table resides The OID of the schema as specified in catalog.schema.table The schema name as specified in catalog.schema.table The table ID of the table The table name of the table
usage
integer
schemaname
nvarchar(128)
tableid tablename
bigint nvarchar(128)
$hist_plan_prolog_$SCHEMA_VERSION
The $hist_plan_prolog_$SCHEMA_VERSION table records the plan history information. This is the data collected at the beginning of the plan execution. This table becomes enabled whenever query history type is Plan. Table 11-22: $hist_plan_prolog_$SCHEMA_VERSION Name npsid Type integer Description This value along with the npsInstanceId and opid form the foreign key into the query table. Instance ID of the source Netezza system Operation ID. Used as a foreign key from query epilog, overflow as well as plan, table, column access tables to query prolog.
npsinstanceid opid
integer bigint
11-34
20282-14
Rev.1
Table 11-22: $hist_plan_prolog_$SCHEMA_VERSION Name logentryid Type bigint Description This is a foreign key into the hist_log_entry_$SCHEMA_VERSION table with the npsid and npsinstanceid. This with npsid and npsinstanceid will also be a primary key for this table. Session ID. This with npsid and npsinstanceid will be foreign key from query, plan, table and column access tables into session tables. Plan ID (used to make a equi join in addition to npsid, npsinstanceid, and opid to match a plan prolog to a plan epilog record) DBOS transaction id Gate keeper priority Submit time of the plan Gate keeper queue time of the plan Time when the first snippet is prepped Time when the plan is queued to GRA Start time of plan execution Flag for the main plan of a query The estimated cost of the plan bigint bigint integer bigint The estimated disk space of the plan The estimated memory of the plan The total number of snippets The signature of the plan. If two plans have the same signature, especially for the same query, most likely the plans are identical. The count of query restart after a state change. The value is zero if there has been no restart.
sessionid
bigint
planid
integer
xid gkpriority submittime queuetime preptime gratime starttime ismainplan estimatedcost estimateddisk estimatedmem totalsnippets signature
qcrestart
integer
20282-14
Rev.1
11-35
$hist_plan_epilog_$SCHEMA_VERSION
The $hist_plan_epilog_$SCHEMA_VERSION table records the plan history information. This is the data collected at the end of the plan execution. This table becomes enabled whenever query history type is Plan. Table 11-23: $hist_plan_epilog_$SCHEMA_VERSION Name npsid Type integer Description This value along with the npsInstanceId and opid form the foreign key into the query table. Instance ID of the source Netezza system Operation ID. Used as a foreign key from query epilog, overflow as well as plan, table, column access tables to query prolog. This is a foreign key into the hist_log_entry_$SCHEMA_VERSION table with the npsid and npsinstanceid. This with npsid and npsinstanceid will also be a primary key for this table. Session ID. This with npsid and npsinstanceid will be foreign key from query, plan, table and column access tables into session tables. The plan ID (used to make a equi join in addition to npsid, npsinstanceid, and opid to match a plan prolog to a plan epilog record) The ending time of the plan execution The number of snippets that are done The number of result rows The number of result bytes A status for the success or failure of the plan. The value is 0 for a successful completion, or a non-zero error code for a failure.
npsinstanceid opid
integer bigint
logentryid
bigint
sessionid
bigint
planid
integer
11-36
20282-14
Rev.1
FORMAT_QUERY_STATUS ()
Use this function to display text string versions of the $hist_query_epilog.status column data. The return value is one of the following status values: "sucess" "aborted" "cancelled" "failed parsing" "failed rewrite" "failed planning" "failed execution" "permission denied" "failed" "trasaction aborted"
FORMAT_PLAN_STATUS ()
Use this function to display text string versions of the $hist_plan_epilog.status column data. The return value is one of the following status values: "sucess" "aborted"
FORMAT_TABLE_ACCESS()
Use this function to display text string versions of all bits set in the $hist_table_access.usage column data. The return value is a comma-separated list of one or more of the following values: "sel" "ins" "del" "upd" "drp" "trc" "alt" "crt" "lck" "sts"
20282-14
Rev.1
11-37
FORMAT_COLUMN_ACCESS()
Use this function to display text string versions of all bits set in the $hist_column_access.usage column data. The return value is a comma-separated list of one or more of the following values: "sel" "set" "res" "grp" "hav" "ord" "alt" "sts"
Example Usage
The following sample query shows how you can use these helper functions.
SELECT substr (querytext, 1, 50) as QUERY, format_query_status (status) as status, tb.tablename, format_table_access (tb.usage), co.columnname, format_column_access (co.usage) from "$hist_query_prolog_1" qp inner join "$hist_query_epilog_1" qe inner join "$hist_table_access_1" tb inner join "$hist_column_access_1" co
using (npsid, npsinstanceid, opid) using (npsid, npsinstanceid, opid) using (npsid, npsinstanceid, opid)
where exists (select tb.dbname from "$hist_table_access_1" tb where tb.npsid = qp.npsid and tb.npsinstanceid = qp.npsinstanceid and tb.opid = qp.opid and tb.tablename in (^nation^, ^orders^, ^part^, ^partsupp^, ^supplier^, ^lineitem^, ^region^)) and tb.tableid = co.tableid;
11-38
20282-14
Rev.1
C H A P T E R 12
Managing Workloads on the Netezza Appliance
Whats in this chapter
Overview Managing Short Query Bias Managing GRA Managing PQE Managing the Gate Keeper
The workload of a Netezza appliance consists of user-initiated jobs such as SQL queries, administration tasks, backups, and data loads, as well as system-initiated jobs such as regenerations, rollbacks, and the background rewriter tasks. The terms workload and job are used interchangeably to describe the work being performed by a Netezza system. Workload management (WLM) is the process of assessing the workload of the system and using job control and prioritization features to allocate the appropriate share of resources to jobs running on the system. This chapter describes the Netezza workload management features and how to configure them. As a best practice, work with your Netezza Sales or Support representative to assess the WLM features that are most appropriate for your environment and users. Do not modify the WLM configuration settings without careful analysis of the impact of the changes. Inappropriate changes and settings can impact system behavior in unintended ways and thus should be carefully planned and implemented for your business environment.
Overview
The following sections provide information on service level planning and the WLM features.
12-1
Yes
Gate keeper
No
Most environments typically use only a subset of these features; the features depend upon the methodology that you use to manage jobs in your environment.
12-2
20282-14
Rev.1
Overview
When multiple jobs or users compete for system resources, you might want the Netezza system to prioritize certain jobs over others. Workload management is a process of classifying jobs and specifying resource allocation rules so that the system can assign resources using a predetermined service policy. You can identify jobs as higher or lower in priority than other jobs, and you can partition the system resources so that groups of users receive a minimum or a maximum percentage of resources when several groups compete for system resources. Netezza has some predefined service policies to help prioritize certain jobs or work. For example, the Netezza admin user account has special characteristics that prioritize its work over other users work. Similarly, certain types of jobs may have priority over user queries or other less-critical system jobs.
Concurrent Jobs
Netezza imposes a limit on the number of concurrent jobs that can run on the system at one time. The limit is controlled by the system registry setting gkMaxConcurrent, which has a default value of 48. Therefore, the system can run up to 48 concurrent jobs as long as there are sufficient resources (CPU, disk, memory, and so on) to support all of those jobs. In some environments, a smaller value may be appropriate for the types of jobs that typically run on the system. A smaller number of concurrent jobs may result in better performance and thus better response time for users. During new system testing, your Sales representative can work with you to identify whether your environment would benefit from a smaller gkMaxConcurrent setting. If you determine that a lower setting might be better for your system, you can change a registry configuration setting to lower the value. To change the setting, you need access to a Netezza user account that has Manage System privilege (such as the admin user). The following examples use the sample account usr1. 1. Pause the system:
nzsystem pause Are you sure you want to pause the system (y|n)? [n] y
You can display the current value of a registry setting using the following command:
nzsystem showRegistry | grep gkMaxConcurrent host.gkMaxConcurrent = 20
20282-14
Rev.1
12-3
host.schedSQBReservedGraSlots=10
host.schedSQBReservedSnSlots=6
host.schedSQBReservedSnMB=50
host.schedSQBReservedHostMB=64 Figure 12-1: SQB Queuing and Priority Also, because short queries are typically not resource intensive, the Netezza can run several short queries at a time while the longer work continues.
12-4
20282-14
Rev.1
Table 12-2 describes the configuration registry settings that control the SQB defaults. To change the setting you use the nzsystem command to pause the system, set the value, and then resume the system. Table 12-2: Short Query Bias Registry Settings Name host.schedSQBEnabled Type Default Description bool true Enables SQB. If you disable SQB, the Netezza will not reserve any resources for short queries while it is engaged in other work. If you disable SQB, users who run a short query to perform a dimensional lookup, for example, might observe what appears to be a hanging query until some ongoing work completes and the system runs the short query. Defines the time threshold for queries that the system defines as short in seconds. Defines the number of GRA scheduler slots reserved for short queries. Defines the number of snippet scheduler slots reserved for short queries. Specifies how much memory in MB on each SPU to reserve for short query execution. Specifies how much memory in MB to reserve on the host for short query execution.
host.schedSQBNominalSecs host.schedSQBReservedGraSlots
int int
2 10 6 50
host.schedSQBReservedHostMb int
64
For example, if you want to change the definition of a short query in your environment from two seconds to five seconds, do the following (usr1 must have Manage System privilege): 1. Pause the system:
nzsystem pause Are you sure you want to pause the system (y|n)? [n] y
You can also display the current value of a registry setting as follows:
nzsystem showRegistry | grep schedSQBNominalSecs host.schedSQBNominalSecs = 5
20282-14
Rev.1
12-5
Managing GRA
If your environment has distinct groups of users who use the system at the same time, you can use GRA to partition the system so that each group receives a portion of the system resources when the group is active. These groups are called resource sharing groups (RSGs). GRA is enabled by default.
12-6
20282-14
Rev.1
Managing GRA
This command creates the bob user account and configures it to use the rptusers RSG. The rptusers RSG must exist and it must have a non-zero resource minimum for the command to complete successfully. If at some point you drop the rptusers RSG, the user accounts in that group are reassigned to the Public RSG. Also, after you assign a user to an RSG, you cannot change the RSGs minimum resource percentage to 0.
When all three RSGs are busy with jobs on the system, the GRA scheduler works to balance the jobs and resource utilization as shown in Figure 12-2.
Figure 12-2: GRA Usage Sharing To create these RSGs and to alter the existing group Public from its default maximum percentage, you can use SQL commands or the NzAdmin tool. For a description of creating groups using NzAdmin, refer to the online help for that interface.
20282-14
Rev.1
12-7
You can then assign Netezza user accounts to the RSG. Note that a user account can be assigned to only one RSG. You can add users to the group when you create a group, as in the following sample command:
SYSTEM(ADMIN)=> CREATE GROUP analysts WITH RESOURCE MINIMUM 50 RESOURCE MAXIMUM 100 USER bob,jlee; CREATE GROUP
The Netezza system ensures that members of the Analysts group get at least 50% of the available system resources when all the RSGs are active. At the same time, the system ensures that RptQuery group members and Public users are not starved for resources.
12-8
20282-14
Rev.1
Managing GRA
If only a few of the RSGs are busy, the system has more resources to give to the active RSGs, but it applies the minimum and maximum resource percentages to ensure fair allocations. For example: If the Analysts RSG is the only active group, it can use up to 100% of the system resources for its work. If the RptQuery RSG is the only active group, it can use up to 60% of the available system resources (its RESOURCE MAXIMUM). The remaining 40% of the available system resources remain unallocated until there is new work from other RSGs or the admin user. If the Analysts and Public RSGs are busy, their resource minimums total 70% and their resource maximums total 180%. The system determines their allowed resource percentages as follows:
Public Analyst min 20 50 max 80 100 allowed 29% = (20 / (20 + 50)) 71% = (50 / (20 + 50))
If the RptQuery and Public RSGs are busy, the system determines their allowed resource percentages as follows. This example shows that the excess is apportioned to each RSG, but never to exceed the maximum percentage.
RptQuery Public min 30 20 max 50 80 allowed 50% = (30 / (20 + 30))= 60 (but 50 is max%) 50% = (20 / (20 + 30))= 40 (plus 10 which RptQuery cannot use)
Netezza frequently adjusts the resource percentages based on the currently active RSGs and their jobs. Because work is often submitted and finished very quickly, at any one point in time it might appear that certain RSGs have received no resources (because they are inactive) while other RSGs are monopolizing the system because they are continually active. Over time, and especially during peak times when all RSGs are actively using the system, the GRA usage typically averages out to the RSGs allowed percentage. The measure of whether a group is receiving its allowed resource percentage is called compliance; Netezza offers several reports that you can use to monitor resource group compliance. For more information, see Monitoring Resource Utilization and Compliance on page 12-14.
20282-14
Rev.1
12-9
Using the example Analysts, RptQuery, and Public RSGs, assume that users in all of the RSGs are active and so is the admin user. The resource allocations shown in Figure 12-2 on page 12-7 would change to the following percentages shown in Figure 12-3.
Figure 12-3: Impacts of the Admin User on GRA The admin user receives 50% of the available resources, so the other RSGs receive half of their configured percentages. For example, if admin and all three RSGs are busy, the Analysts group gets 25%, the RptQuery group gets 15%, and the Public group gets 10%. As a best practice, do not let your users run as the admin user for their work. Instead, create an administrative users RSG (for example, NzAdmins) with an appropriate resource percentage and the correct object and administrative permissions. Add your administrative user accounts as members to that RSG so that their work does not severely impact the other RSGs. An administrative users group also makes it easier to manage the account permissions and membership for those users collectively, rather than managing permissions for each user account on a case-by-case basis.
12-10
20282-14
Rev.1
Managing GRA
Figure 12-4: Multiple Jobs in a Group Share the Groups Resources As you plan the resource percentages for each RSG, be sure to consider the number of concurrent active jobs that are likely to occur for that group. You may need to adjust the resource allocation percentages to ensure that very busy groups have enough resources to complete the expected number of concurrent jobs in a timely manner. You can also configure a limit on the number of active jobs from an RSG to ensure that a specific number of active jobs have reasonable resource allocations; any additional jobs will wait until the active jobs finish.
20282-14
Rev.1
12-11
Netezza uses the host.snPriorityWeights registry setting to specify the relative weights for each priority job; that is, the setting controls the ratio of resources to priority. By default, the host.snPriorityWeights setting is 1,2,4,8, which means that low priority jobs have a weight of 1, normal=2, high=4, and critical=8. As with the GRA percentages, the Netezza system sums the weights of all the concurrent jobs and allocates resource percentages based on the job weight over the sum of the weights. For example, Figure 12-5 shows how priority of jobs affects the distribution of resources within a resource group. When the system is fully subscribed, it applies the priority ratios to identify how much of each groups resources are applied to each job. For the Analysts group as described in Figure 12-2 on page 12-7, assume that there is one critical job and one normal job. The Netezza system uses a default 8:2 weighting ratio (or 4:1) to allocate resources between critical and normal priority jobs. Critical job = 8/(8+2) or 80% of the resources for the Analysts group Normal job = 2/10 or 20% of the resources for the Analysts group Thus, the critical priority job would receive 80% of the Analysts groups 50% allocation, for a total of 40% of the resources. The normal job would receive 20% of the groups 50% of resources, which is 10%.
Figure 12-5: GRA and Priority For the RptQuery group, which has one Critical and two High priority jobs and a 30% resource allocation, the system calculates the job resource allocations as follows: Critical priority job = 8/16 points (50% of the groups resources). Each High priority job = 4/16 points (25% of the groups resources). Thus, the Critical priority job receives half of the groups 30% for a total of 15%, and each each high priority job receives one-quarter of the total 30%, or about 7% of the groups resources. For the Public group, which has two Low priority jobs and a 20% group resource allocation, the system divides the groups resources equally. Thus, each low priority job receives approximately 10% of the system resources.
12-12
20282-14
Rev.1
Managing GRA
You must pause the system, change the setting, and resume the system for the changes to take effect.
20282-14
Rev.1
12-13
Table 12-6 describes the GRA scheduler horizon and compliance registry settings. Table 12-6: GRA Compliance Registry Settings Name host.schedGRAHorizon Type int Default 3600 Description Specifies the amount of time in seconds for the GRA horizon, which is the time range over which the GRA scheduler calculates the compliance of a resource scheduling group. Specifies the percentage threshold below which an RSG is identified as very underserved. A group that is 10% or more below its allowed percentage is very underserved. Specifies the percentage threshold below which an RSG is identified as underserved. A group that is 5% or more (up to the very underserved threshold) below its allowed percentage is underserved. Specifies the percentage threshold above which an RSG is identified as overserved. A group that is 5% or more (up to the very overserved threshold) above its allowed percentage is overserved. Specifies the percentage threshold above which an RSG is identified as very overserved. A group that is 10% or more above its allowed percentage is very overserved.
host.schedGRAVeryUnderLimit
int
-10
host.schedGRAUnderLimit
int
-5
host.schedGRAOverLimit
int
10
12-14
20282-14
Rev.1
Managing GRA
host.snVtUpdateInterval int
host.graVtUpdateInterval int
600 sec
To display compliance and resource usage using the _v_sched_gra_ext view, you can use a SQL command similar to the following (note that the output lines are very long and wrap in the sample below):
20282-14
Rev.1
12-15
SELECT * FROM _v_sched_gra_ext; ENTRY_TS | GROUPID | PLANS_STARTED | PLANS_FINISHED | PLANS_WAITING_LONG | PLANS_WAITING_SHORT | PLANS_RUNNING_LONG | PLANS_RUNNING_SHORT | TARGET_JOB_MAX | TARGET_ RSG_PCT | TARGET_RSG_MAX | ACTUAL_RSG_PCT | ACTUAL_RSG_PCT_SAMPLE| ACTUAL_JOB_MAX | ALLOWED_RSG_PCT | ALLOWED_RSG_PCT_SAMPLE | RSG_HORIZON_US | COMPLIANCE | SAMPLE_SECS | BUSY_SECS | HOST_CPU_SECS | HOST_DISK_READ_SECS | HOST_DISK_WRITE_SECS | HOST_FABRIC_SECS | SPU_CPU_SECS | SPU_DISK_READ_SECS | SPU_DISK_WRITE_SECS | SPU_FABRIC_SECS | GROUPNAME | START_TIME | END_TIME 1280741126077846 | 4900 | 39 | 39 | 0 | 0 | 0.028 | 0 | 100 | 0 | 2| 5 | 0 | 3600000000 | 0 | 599.45 | 14.48 | 9.13 | 0 | 0.13 | 0 | 0 | 0 | _ADMIN_ | 2010-0 8-02 04:25:26.077846 | 2010-08-02 05:25:26.0778 0 | 100 | 2 | 0 | 0 |
For each active resource group, the system provides information about how busy each group is, and how the scheduler is managing the GRA resources as well as scheduler resources. Note: Within the view output, you may notice an _ADMIN_ resource group. This is a system-default group for the admin user account and cannot be modified.
12-16
20282-14
Rev.1
Managing GRA
20282-14
Rev.1
12-17
12-18
20282-14
Rev.1
Managing PQE
Figure 12-8: Resource Allocation Performance Graph The lines for each group show the resource usage trends through the day with the usage percentage on the left vertical axis. The blue shaded background shows the number of jobs running at each time interval with the job count on the right side vertical axis) The drop-down list allows you to select a different day of resource usage to display.
Managing PQE
If your environment has distinct types of jobs that each have different priorities or service level goals, you can use priority settings to help Netezza identify and prioritize the more critical jobs over the less critical ones. Netezza uses the priority query execution (PQE) settings to identify the jobs with the highest importance. When combined with GRA, Netezza assigns more resources to higher priority jobs over lower priority jobs; for queued jobs waiting to run, Netezza schedules the higher priority jobs to run before the lower priority jobs. When used with the gate keeper, PQE can be used queue and control the number of each type of job that is allowed to run at a given time on the system. You assign priority to jobs in several ways: You can assign a priority to a group of users; each user inherits the priority of the group. You can assign priority to a user, which can override a priority specified for the users group(s). You can assign a priority as a system default priority for any users who do not have a priority set by their group or account. When you configure priority for a user, group, or system-wide, you can specify a default priority and a maximum priority. The system does not allow the user to specify a priority greater than his or her maximum priority.
20282-14
Rev.1
12-19
The admin user as well as permitted users can change the priority of a running job. You can raise the jobs priority, or decrease a jobs priority. Users can raise their jobs priority to the maximum allowed for them as individuals or as members of a group. For more information about priority assignment, see Specifying Session Priority on page 12-20.
Priority user jobs. These jobs take precedences over Yes normal jobs Default operation level for all jobs Lowest priority user jobs, background loads, jobs that should not affect other activity Lowest priority system jobs Yes Yes No
The syntax to create a group and set the default priority is:
CREATE GROUP group_name WITH DEFPRIORITY HIGH;
12-20
20282-14
Rev.1
To change the priority of a session using the ALTER SESSION command, enter:
MYDB(USER)=> ALTER SESSION 21664 SET PRIORITY TO HIGH; ALTER SESSION
You can use the alter session command to change priority within a script. If you do not specify a session ID, the system assumes the current session. You can also use the NzAdmin tool to change the priority of sessions. You can use the nzsession command to show information about the current sessions and their priority. Note: Use caution in assigning the critical and high priority. If you assign too many jobs to the high or critical priority, you could bring normal and low priority work to a standstill.
36
Figure 12-9: Using PQE to Control Job Concurrency by Runtime and Priority
20282-14
Rev.1
12-21
In Figure 12-9, the gate keeper configuration settings allow up to 36 critical, 4 high, 2 normal, and 2 low priority jobs to run concurrently. If the maximum number of jobs for a specific priority are already running, the gate keeper queues any additional jobs of that type (as in the Normal and Low queues). A job of any priority could be queued because there are not enough resources available to run that specific job. (Although not shown in the figure, requests from the gate keeper proceed to the GRA scheduler for WLM processing before they proceed to the SPUs.) Table 12-9 describes the configuration registry settings that you can use to change the gate keeper defaults. To change the setting you use the nzsystem command to pause the system, set the value, and then resume the system. Table 12-9: Gate Keeper Registry Settings Name host.gkEnabled Type Default Description bool yes Enables the gate keeper. If you enable the gate keeper, jobs submitted to the Netezza are first processed by the gatekeeper and allowed to pass to the GRA only when the number of currently running jobs are less than the configured priority and/or response time thresholds. Specifies whether gatekeeper and GRA are both enabled. The default is no. Specifies the number of high priority queries that the gatekeeper will allow to run at one time assuming that resources and query slots are available. High priority jobs under this threshold will be allowed to move on to the GRA scheduler for processing; otherwise, the extra jobs are queued. Specifies the number of low priority queries that the gatekeeper will allow to run at one time assuming that resources and query slots are available. High priority jobs under this threshold will be allowed to move on to the GRA scheduler for processing; otherwise, the extra jobs are queued. Specifies the number of normal priority queries that the gate keeper sends to the SPUs for processing. If there are 48 active queries, any additional queries are queued at the gate keeper normal queue to wait for active queries on the SPU to finish. If you provide a comma-separated list of values for gkMaxPerQueue, the gate keeper uses the values to set the queue length for the normal priority runtime queues.
host.schedAllowGKandGRA host.gkHighPriQueries
bool no int 36
host.gkLowPriQueries
int
36
host.gkMaxPerQueue
int
48
12-22
20282-14
Rev.1
Table 12-9: Gate Keeper Registry Settings Name host.gkQueueThreshold Type Default Description -1 Specifies the time limit in seconds for queries in the normal queue. If gkQueueThreshold=-1, the gate keeper creates only one normal queue which does not restrict queries by their runtime. If you provide a comma-separated list of values for gkQueueThreshold, the gate keeper creates several queues to hold the queries that have an estimated runtime within that range.
The gate keeper uses a default critical priority queue of 36, so the gate keeper allows up to 36 critical priority queries at one time assuming that resources and query slots are available. This is a hardcoded configuration setting and cannot be changed. If you do not use PQE, all jobs are considered Normal; the gate keeper uses only one queue to process new work requests. Figure 12-10 illustrates the case in which gate keeper is enabled but PQE is not used to prioritize the queries. Netezza Host Normal Netezza SPUs
48
host.gkMaxPerQueue=48 host.gkMaxConcurrent=48
Figure 12-10: Gate Keeper Default Normal Work Queue Optionally, the Normal queue offers settings that you can use to configure additional queuing controls. For example, Figure 12-11 shows how you can use the host.gkMaxPerQueue and host.gkQueueThreshold settings to create up to four queues to hold queries of different estimated runtimes. You can also configure the gate keeper to allow more of the very short queries to run and less of the longer ones, which can improve performance for the shorter queries.
20282-14
Rev.1
12-23
<1
20
host.gkMaxPerQueue=20,5,3,1 host.gkQueueThreshold=1,10,60,-1 Figure 12-11: Gate Keeper Time-Based Normal Queues and Registry Settings If you provide a comma-separated list of values for gkQueueThreshold, the gate keeper creates several queues to hold the queries that have an estimated runtime within that range. In Figure 12-11, the gkQueueThreshold setting defines four queues: a queue for queries with estimated runtimes of less than 1 second; one for queries with an estimated runtime of 1 up to 10 seconds; one for queries with estimated runtimes of 10 up to 60 seconds; and one for queries that have runtimes of 60 or greater seconds. Using the gkMaxPerQueue setting, you can control the number of queries from each queue that are sent to the SPU for processing. In this example, the gate keeper will allow up to 20 queries from the <1 second queue to pass on for processing, with up to 5 queries from the 1-<10 second queue; up to 3 queries from the 10-<60 second queue; and only 1 from the 60> second queue. Thus, the gate keeper will send more of the faster queries and less of the longer-running queries for processing. With these queue settings, only one 60-second or greater query can be active on the SPU at one time, and the gate keeper will queue any additional 60-second or greater queries until the first one completes.
12-24
20282-14
Rev.1
C H A P T E R 13
Displaying Netezza Statistics
Whats in this chapter
Netezza Stats Tables Displaying System Statistics
The nzstats command displays operational statistics about system capacity, faults, and performance. Operational statistics provide you with the following information: A high-level overview of how your system is running in a context of recent system activity Details so that you can diagnose problems, understand performance characteristics, and interface to system management software
13-1
Table 13-1: Netezza Groups and Tables Group/Table Host Interface Table Host Mgmt Channel Table Host Network Table Host Table Description Provides information about the hosts interface. Provides information about the systems management channel from the hosts viewpoint. For more information See Host Interface Table on page 13-4. See Host Management Channel Table on page 13-6.
Provides information about the See Host Network Table on systems main UDP network layer page 13-7. from the hosts viewpoint. Provides information about each host. See Host Table on page 13-8.
HW Mgmt Channel Provides information about each See Hardware Management Table SPU/SFI management channel Channel Table on page 13-9. from the SPUs or SFIs viewpoint. Per Table Per Data Provides information about tables See Per Table Per Data Slice Slice Table on a per-data slice basis. Table on page 13-10. Query Table Provides information about active See Query Table on page 13-10. queries as obtained from the _v_qrystat view. Provides a list of the last 2000 queries that completed as recorded in the _v_qryhist view. Provides information about a SPUs disk partitions. Provides information about each SPUs memory. Provides information about the system as a whole. Provides information about database tables and views. See Query History Table on page 13-11. See SPU Partition Table on page 13-12. See SPU Table on page 13-13. See System Group on page 13-13. See Table Table on page 13-14.
Query History Table SPU Partition Table SPU Table System Group Table Table
Database Table
If you are the user admin, you can use the nzstats command to display the Database Table, which displays information about the databases. It has the following columns: Table 13-2: Database Table Column DB Id DB Name Description A unique value for each DBMS database. The name of the database.
13-2
20282-14
Rev.1
Table 13-2: Database Table Column Create Date Owner Id Num Tables Num Views Num Active Users Description The date and time this database was created. The user ID for the user that owns this database. The number of user tables associated with this database. The number of user views associated with this database. The number of users currently attached to this database.
DBMS Group
The DBMS Group displays information about the database server. It has the following columns: Table 13-3: DBMS Group Column Num Databases Num Groups Num Users Num Tables Num Views Num SQL Sessions Num Queries Num Queries Running Num Queries Waiting Num Transactions Description The total number of user databases. The total number of groups. The total number of database users. The total number of user tables. The total number of user views. The total number of current SQL sessions/connections. The total number of queries that have been submitted, but not completed. The total number of currently executing queries. The total number of currently queries waiting to be run. The total number of open and recent transactions maintained by the Transaction Manager.
20282-14
Rev.1
13-3
Table 13-4: Host CPU Table Column Ticks Idle Ticks Non-idle Ticks Avg Load Description The number of CPU ticks that have occurred. A tick is 1/100th of a second. Linux uses the term jiffy for this amount of time. The number of ticks where the CPU is not doing anything (that is, running the idle task). Non-idle ticks represents time that the CPU is either in user or system mode. The average, as calculated over the last minute, of the utilization percentage for the processor. (Note that commands such as top show the average utilization for shorter periods of time, such as only the last three seconds.)
13-4
20282-14
Rev.1
Table 13-6: Host Interfaces Table Column State State Text MTU MAC Address IP Address In Bytes In Bytes-64 In Byte Rate In Pkts In Pkt Rate In Errors Out Bytes Out Bytes-64 Out Byte Rate Out Pkts Out Pkt Rate Out Errors Description The current state of the host interface. Up is 1 and down is 2. The textual description of the interface state. The size of the largest datagram that can be sent/received on the interface, specified in bytes. The interface's address at the protocol layer immediately below the network layer in the protocol stack. The interface's IP address. The total number of bytes received on the interface, including framing characters. A 64-bit version of the In Bytes managed object, updated every 15 seconds. The previous 1 minute average rate of bytes received (15 seconds granularity). The total number of packets received on the interface. The previous 1 minute average rate of packets received (15 seconds granularity). The number of inbound packets that contain errors preventing them from being deliverable to a higher-layer protocol. The total number of bytes transmitted out of the interface, including framing characters. A 64-bit version of the Out Bytes managed object, updated every 15 seconds. The previous 1 minute average rate of bytes sent (15 seconds granularity). The total number of packets sent on the interface. The previous 1 minute average rate of packets sent (15 seconds granularity). The number of outbound packets that could not be transmitted because of errors.
20282-14
Rev.1
13-5
13-6
20282-14
Rev.1
Table 13-7: Host Management Channel Table Column Out Retransmit Rate Out Retransmit Q Len Description The previous 1 minute average rate of retransmissions (15 seconds granularity). The number of entries in the retransmit queue.
20282-14
Rev.1
13-7
Table 13-8: Host Network Table Columns Out Retransmit Rate Out Retransmit Q Len Description The previous 1 minute average rate of retransmissions (15 seconds granularity). The number of entries in the retransmit queue.
Host Table
The Host Table displays information about each host on the system. It has the following columns: Table 13-9: Host Table Column Host ID OS Type OS Version Num CPUs Num File Systems Swap Space Free Swap Space Used Swap Space % Used Swap Space Real Memory Free Real Memory Used Real Memory % Used Real Memory Shared Memory Free Shared Memory Used Shared Memory % Used Shared Memory Description A unique value for each host in the system (always 1). The type of the host's operating system (Linux). The version of the host's Linux operating system. The number of processors in the host. The number of file systems in the host. The total swap size in KB. The amount of free swap space in KB. The amount of used swap space in KB. The percent of used disk space. The total real memory in KB. The amount of free real memory in KB. The amount of used real memory in KB. The percent of used real memory. The total shared memory in KB. The amount of free shared memory in KB. The amount of used shared memory in KB. The percent of used shared memory.
13-8
20282-14
Rev.1
20282-14
Rev.1
13-9
Table 13-10: Hardware Management Channel Table Column Out Retransmit Rate Out Retransmit Q Len Description The previous 1 minute average rate of retransmissions (15 seconds granularity). The number of entries in the transmit queue.
Query Table
If you are the admin user, you can use the nzstats command to display the Query Table, which displays information about the queries currently 'running/executing' on the Netezza server. Those queries which have completed execution and whose results sets are being returned to a client user will not be listed in this table. You can use the system view _v_qrystat to view the status of queries running. For more information see Table 9-8 on page 9-28. Note: This query table uses the _v_qrystat view for backward compatibility and will be deprecated in a future release. For more information about the new query history feature, see Chapter 11, Query History Collection and Reporting. The query table has the following columns: Table 13-12: Query Table Column Query Id Session Id Plan Id Client Id Client IP Addr SQL Statement State Description The ID of the query. The ID of the session that initiated this query. The internal ID of the plan associated with this query. The internal client ID associated with the querys session. The clients IP address. The SQL statement. You can see the entire string by increasing the width of the column. The state of the query in integer form.
13-10
20282-14
Rev.1
Table 13-12: Query Table Column State Text Submit Date Start Date Elapsed Time Priority Priority Text Estimated Cost Estimated Disk Description The state of the query in text form. Possible states are pending, queued, running. The date and time that the query was submitted. The date and time that the query started running. The estimated elapsed time, as determined by the optimizer. The priority number. The priority text string. The estimated seconds, as determined by the optimizer. The estimated disk usage, as determined by the optimizer.
Estimated Memory The estimated memory usage, as determined by the optimizer. Snippets Snippets Done The number of snippets (steps) in the plan for this query. The number of snippets that have finished.
Snippets Done Pct The percentage of snippets that have finished. Result Rows Result Bytes The number of rows in the result. The number of bytes in the result.
20282-14
Rev.1
13-11
Table 13-13: Query History Table Column User Id Client IP Addr SQL Statement Submit Date Start Date End Date Elapsed Time Priority Priority Text Estimated Cost Estimated Disk Estimated Mem Snippets Snippets Done Result Rows Result Bytes Description The users name. The clients IP address. The SQL statement. You can see the entire string by increasing the width of the column. The date and time that the query was submitted. The date and time that the query started running. The date and time that the query completed. The estimated elapsed time, as determined by the optimizer. The priority number. The priority text string. The estimated seconds, as determined by the optimizer. The estimated disk usage, as determined by the optimizer. The estimated memory usage, as determined by the optimizer. The number of snippets (steps) in the plan for this query. The number of snippets processed. The number of rows in the result. The number of bytes in the result.
13-12
20282-14
Rev.1
Table 13-14: SPU Partition Table Column Used Space % Used Space Description The amount of used partition space in KB. The percent of used partition space.
SPU Table
The SPU Table displays information about each SPUs processor and memory. It has the following columns: Table 13-15: SPU Table Column HW ID Memory Free Memory Used Memory % Used Memory Description The index into the hardware inventory table. The total memory in KB. The amount of free memory in KB. The amount of used memory in KB. The percent of used memory.
System Group
The System Group displays information about the system as a whole. It has the following columns: Table 13-16: System Group Column Name Description Contact Location IP Addr Up Time Up Time Text Date State Description The administrator-assigned name of the system. A description of the system. The name of the contact person for this system and contact information. The physical location of this node (for example, telephone closet, 3rd floor.) The primary IP address of the system. The time in seconds since the management portion of the system was last re-initialized. The time printed in minutes and seconds. The systems local date and time of day. The current state of the system (from the nzstate command) as an integer.
20282-14
Rev.1
13-13
Table 13-16: System Group Column State Text Model Serial Num Num Data Slices Num SFIs Num SPUs Num Failovers Num Regen Tasks Description The text description of the system state. This matches the display from the nzstate command. The Netezza model number for this system. Used in the callHome.txt file. The serial number for this system. Used in the callHome.txt file. The number of data slices. The number of SFIs (sum of all hosts). The number of SPUs. The number of failover tasks running. The number of regeneration tasks running.
Table Table
If you are the user admin, you can use the nzstats command to display the Table Table, which displays information about database tables. It has the following columns: Table 13-17: Table Table Column DB ld DB Name Table Id Table Name Create Date Type Num Columns Row Size Disk Space Description The ID corresponding to the database for this table. The name of the database. A unique value for this table. The name of this table. The date and time that this table was created. The type of this table (table, view) expressed as its type integer. The number of table columns. The length of a table row. The total disk space used to store this table in KB. You can use the -allocationUnit option to show the disk space used in extents or blocks. The average disk space used by each dataslice of the table in KB. The disk space consumed by the largest dataslice for the table in KB. The ID of the largest data slice.
13-14
20282-14
Rev.1
Table 13-17: Table Table Column Min Space Per DS Min Space DS Id Space Skew Description The disk space consumed by the smallest dataslice for the table in KB. The ID of the smallest data slice. The ratio that shows how disparate the dataslice sizes are as calculated by (maximum dataslice size - minimum dataslice size) / average dataslice size.
Note: The information in the output is obtained from the /nz/data/config/callHome.txt file. If that file has not been customized for your Netezza system, the command output may contain general placeholder text. For more information about customizing the callHome.txt file, see Callhome Feature on page 5-10.
20282-14
Rev.1
13-15
13-16
20282-14
Rev.1
C H A P T E R 14
Managing the MantraVM Service
Whats in this chapter
Mantra Information Starting and Stopping the MantraVM Service Managing the MantraVM Service Accessing the Mantra Web Interface Troubleshooting
This chapter describes how to manage and use the MantraVM service. The MantraVM service is a virtual server environment that runs the Netezza Mantra compliance and auditing application directly on the Netezza host. The MantraVM service is installed on new TwinFin systems; however, some TwinFin systems might have included a separate Mantra appliance. If your system has an /nz/mantravm directory, the MantraVM service is installed on the system. Note: Skimmer systems do not support the MantraVM service.
Mantra Information
The MantraVM service supports the Netezza Mantra application on TwinFin systems, as shown in Figure 14-1. You can start, stop, and obtain the status of the MantraVM service using the service mantravm commands. You use the mantractl command to configure and manage the MantraVM service in this environment. MantraVM Service
14-1
Within the MantraVM service, the Mantra application operates identically to a standalone Mantra appliance; the management tasks are identical in terms of configuration, reporting, backups, and so on. For details about Mantra compliance reporting, events, and configuration, see the Netezza Mantra Administration Guide, which is available on the Mantra Web interface. To access the guide, see Accessing the Mantra Web Interface on page 14-8.
14-2
20282-14
Rev.1
Mantra Documentation
The Mantra documentation is installed in the MantraVM service image. To access the documentation, connect to the Mantra Web interface and go to the Support page to download an online version of the Netezza Mantra Administration Guide. For a description of how to access the Mantra Web interface in the MantraVM service environment, see Accessing the Mantra Web Interface on page 14-8. Also, if you download the Mantra Console from the Web interface Support page, you can also access the documentation using the Help menu on the Console. For details about the Netezza Mantra compliance application and how to create policies, run reports, monitor activity and events, and use the Mantra interfaces, refer to the Netezza Mantra Administration Guide.
Note that it might require a few minutes for the MantraVM service to start; until that time, the external (management) IP address may be unreachable. If the MantraVM service is disabled, you cannot start the Mantra compliance monitoring. For example:
[root@nzhost1 ~]# service mantravm start Service disabled
For more information, see Enabling the MantraVM Service on page 14-5.
20282-14
Rev.1
14-3
The command output indicates that the MantraVM service is running on the Netezza host. In addition, the status shows whether the MantraVM service is enabled or disabled on the system. If you log in to the standby host and run the service mantravm status command, the output appears similar to the following because the service is stopped on the standby host:
[root@nzhost2 ~]# service mantravm status Service status: stopped mantractl flag: standby
In the event of a failover or a manual migration to the standby host, the heartbeat processes will start the MantraVM service on the host to resume the Mantra capabilities.
The output shows sample addresses for the external and internal IP addresses. The external IP address is the management interfacethis is the IP address that you use in a Web browser to connect to the Mantra Web interface. The output also lists the inter-
14-4
20282-14
Rev.1
faces that are being monitored for query activity; if no interfaces are configured for monitoring, the output displays the word default. Note that the output also shows that the MantraVM service is enabled. If the service is not enabled, the service may not be running, or if it is, it will not be restarted the next time the mantravm service starts. For example:
[root@nzhost1 ~]# ./mantractl External IP Address of MantraVM: 1.2.3.4 Internal IP Address of MantraVM: 10.1.2.3 mantravm service enabled? false MantraVM Version: 1.0.060210-2010 Interfaces Monitored: eth8,usb0
The command uses the /nz/mantravm/mantravm.cfg file to define the virtual environment. If the file does not exist, the command will create a new mantravm.cfg file. Do not modify or customize the mantravm.cfg file manually; instead, use the mantractl commands to modify the MantraVM configuration settings.
20282-14
Rev.1
14-5
To disable the MantraVM service: 1. Log in to the active Netezza host as the root user. 2. Change to the following directory or include this path in the command line of Step 3:
[root@nzhost1 ~]# cd /nz/mantravm
3. Confirm that the MantraVM service is running using the following command:
[root@nzhost1 mantravm]# service mantravm status Service status: running mantractl flag: enabled
If the service status is stopped, make sure that the service is enabled and follow the instructions in Starting the MantraVM Service on page 14-3 to start the service. Repeat the service mantravm status command to confirm that the service is running before you proceed to the next step. 4. Run the following command, where ipaddr is the new IP address that you are configuring:
[root@nzhost1 mantravm]# ./mantractl setip ipaddr Please enter the MantraVM password: Please wait while the required ip address changes are made.
It can take a few seconds to configure the IP address before users can connect to the Mantra console or Web interface. If you run the setip command very soon after starting the MantraVM service, you could encounter some temporary connection issues (such as an unreachable host, or unsuccessful mantractl commands) while the IP is being configured. If you wait a minute or so, then retry the commands, the commands should succeed and work normally.
14-6
20282-14
Rev.1
To reconfigure the MantraVM IP addresses: 1. Log in to the active Netezza host as the root user. 2. Change to the following directory:
[root@nzhost1 ~]# cd /nz/mantravm
3. Confirm that the MantraVM service is running and enabled using the following command:
[root@nzhost1 mantravm]# service mantravm status Service status: running mantractl flag: enabled
If the mantractl flag is disabled, follow the instructions in Enabling the MantraVM Service on page 14-5 to enable the service. If the service status is stopped, follow the instructions in Starting the MantraVM Service on page 14-3 to start the service. Repeat the service mantravm status command to confirm that the service is enabled and running before you proceed to the next step. 4. Run the following command. You must enter the Mantra admin user password to proceed with the configuration.
[root@nzhost1 ~]# ./mantractl configip Please enter the MantraVM password: Please wait while the required ip address changes are made.
3. Confirm that the MantraVM service is running and enabled using the following command:
[root@nzhost1 mantravm]# service mantravm status Service status: running mantractl flag: enabled
If the service status is stopped, follow the instructions in Starting the MantraVM Service on page 14-3 to start the service. If the mantractl flag is disabled, follow the instructions in Enabling the MantraVM Service on page 14-5 to enable the service. Repeat the service mantravm status command to confirm that the service is enabled and running before you proceed to the next step. 4. Run the following command:
[root@nzhost1 ~]# ./mantractl nwreconfig
20282-14
Rev.1
14-7
For systems that have less than four monitoring interfaces available, sample output follows:
mantravm service stopped Starting mantravm service Please wait while the MantraVM internal network is being reconfigured. This will take a few minutes
If the system has more than four network interfaces, the command prompts you to select the four that you want to monitor as in the following sample output:
The following are the interfaces that can be actively monitored by the Mantra. Please choose any four of these interfaces. Please note that one of these interfaces should be on the same subnet as the external ip being configured on the Mantra to ensure connectivity. eth13 eth8 eth10 usb0 eth9 Please enter interface 1 to be Please enter interface 2 to be Please enter interface 3 to be Please enter interface 4 to be Chosen Interfaces: mantravm service stopped Starting mantravm service Please wait while the MantraVM This will take a few minutes. monitored: monitored: monitored: monitored: eth8 eth10 eth13 eth9
If you do not select at least one interface that shares the same subnet as the external IP address, the command displays an error and exits. You must run the command again to select the monitoring interfaces.
14-8
20282-14
Rev.1
Troubleshooting
traps, configure IP and DNS settings, download Mantra Agent install packages, access user documentation, and so on. For a full description of the Web Interface, see the Netezza Mantra Administration Guide. To access the Mantra Web interface, open a Web browser and enter the following URL where ipaddr is the external IP address (management address) of the MantraVM service:
https://ipaddr
Note: You can display the IP address using the mantractl command. Make sure that you communicate the external IP address to the Mantra users at your site who use the Web interface or the Console application. The Netezza Mantra login page appears. Log in using an existing Mantra user account. There is a default user account named admin (which is not the same as the Netezza admin database user account). The admin password is specified when the MantraVM application was installed. The default password is netezza. The admin user can create additional Mantra user accounts for accessing the console and Web interface.
Troubleshooting
The following sections describe some possible conditions and troubleshooting steps for the MantraVM service.
Event Throttling
Mantra contains an event throttle mechanism that helps to prevent unintentionally vague or all-encompassing policies from overwhelming the Mantra database with stored event data. The event throttle limits the number of events that can be stored in the event database during a single calendar day. If your configured policies capture more than the throttle limit of event data, an alarm is raised and any event traffic that exceeds the limit is monitored and analyzed, but it is deflected away from the event database until the throttle alarm resets automatically at midnight or is cleared manually by an administrator. For more information about event throttling and how to configure it, see the Netezza Mantra Administration Guide.
20282-14
Rev.1
14-9
To resolve the issue, remove unnecessary files in the /nz partition to free disk space. If you are not sure which files to delete, contact Support for assistance to identify temporary and other files that can be safely removed. After you increase the available disk space, you can restart the MantraVM service following the instructions in Starting the MantraVM Service on page 14-3.
14-10
20282-14
Rev.1
APPENDIX
Netezza CLI
You can use the Netezza CLI to manage the Netezza software, hardware, and databases. Netezza Support may also ask you to run specific low-level diagnostic commands to investigate problems. This chapter provides information about the Netezza user commands and the Netezza Customer Service commands.
nzcontents
For command syntax, see nzcontents on Displays the revision and build number of all page A-7. For more information, see Software Revision Levels on page 6-1. the executables, plus the checksum of Netezza binaries. Converts character encodings for loading with the nzload command or external tables. For command syntax, see nzconvert on page A-7. For more information, refer to the Netezza Database Users Guide.
nzconvert
A-1
Table A-1: Command Line Summary Command nzds Description Manages and displays information about the data slices on the system. Displays and manages event rules. For more information For command syntax, see nzds on page A-8.
nzevent
For command syntax, see nzevent on page A-12. For more information, see Appendix 7, Managing Event Rules.
nzhistcleanupdb
Deletes old history For command syntax, see nzhistcleanupdb information from a his- on page A-17. For more information, refer to tory database. Chapter 11, Query History Collection and Reporting. Creates a history database with all its tables, views, and objects for history collection and reporting. Backs up the host information, including users and groups. Restores the host information. Manages system hardware components. For command syntax, see nzhistcreatedb on page A-19. For more information, refer to Chapter 11, Query History Collection and Reporting. For command syntax, see nzhostbackup on page A-21. For command syntax, see nzhostrestore on page A-23. For command syntax, see nzhw on page A-25.
nzhistcreatedb
nzhostbackup
This command is obso- See the command nzhw on page A-25. lete in Release 5.0. Loads data into database files. Stores a local copy of the users password. For command syntax and more information, see the Netezza Data Loading Guide. For command syntax, see nzpassword on page A-31. For more information, see Creating Encrypted Passwords on page 2-14.
nzreclaim
Grooms databases and For command syntax, see nzreclaim on page A-34. For more information, see Groomtables to remove deleted and/or outdated ing Tables on page 9-19. rows, and also reorganizes the tables based on their organizing kets. Restores the contents of a database backup. For command syntax and more information, see Using the nzrestore Command on page 10-21.
nzrestore
A-2
20282-14
Rev.1
Table A-1: Command Line Summary Command nzrev Description Displays the current software revision for any Netezza software release. For more information For command syntax, see nzrev on page A-36. For more information, see Software Revision Levels on page 6-1.
nzsession
Shows a list of current For command syntax, see nzsession on system sessions (load, page A-37. For more information, see Managing Sessions on page 9-21. client, and sql). Supports filtering by session type or user, allows you to abort sessions, and change the current job list for a queued session job. This command is obso- See the command nzhw on page A-25. lete in Release 5.0. This command is obso- See the command nzhw on page A-25. lete in Release 5.0. Invokes the SQL command interpreter. For usage information, see Creating Databases and User Tables on page 9-1. For command syntax, see the Netezza Database Users Guide. For command syntax, see nzstart on page A-42. For more information, see Managing the System State on page 6-6. For command syntax, see nzstate on page A-44. For more information, see Displaying the Current System State on page 6-3. For command syntax, see nzstats on page A-46. For more information, see Displaying Netezza Statistics on page 13-1. For command syntax, see nzstop on page A-49. For more information, see Managing the System State on page 6-6. For command syntax, see nzsystem on page A-51. For more information, see Managing the System State on page 6-6.
nzstart
nzstate
Displays the current system state or waits for a specific system state to occur before returning. Displays system level statistics. Stops the system.
nzstats
nzstop
nzsystem
nztopology
This command is obso- See the command nzds on page A-8. lete in Release 5.0.
20282-14
Rev.1
A-3
Command Privileges
Table A-2 lists the administrative privileges that may be required for certain commands. The database user account may require one or more of these privileges for a command to complete successfully. Note that the terms in square brackets are optional. Table A-2: Administrator Privileges Privilege [Create] Aggregate [Create] Database [Create] External Table [Create] Function [Create] Group [Create] Index [Create] Library Description Allows the user to create user-defined aggregates (UDAs). Permission to operate on existing UDAs. Allows the user to create databases. Permission to operate on existing databases is controlled by object privileges. Allows the user to create external tables. Permission to operate on existing tables is controlled by object privileges. Allows the user to create user-defined functions (UDFs). Permission to operate on UDFs. Allows the user to create groups. Permission to operate on existing groups is controlled by object privileges. For system use only. Users cannot create indexes. Allows the user to create user-defined shared libraries. Permission to operate on existing shared libraries.
[Create] Materialized View Allows the user to create materialized views. [Create] Procedure [Create] Sequence [Create] Synonym [Create] Table [Create] Temp Table [Create] User [Create] View [Manage] Hardware Allows the user to create stored procedures. Allows the user to create database sequences. Allows the user to create synonyms. Allows the user to create tables. Permission to operate on existing tables is controlled by object privileges. Allows the user to create temporary tables. Permission to operate on existing tables is controlled by object privileges. Allows the user to create users. Permission to operate on existing users is controlled by object privileges. Allows the user to create views. Permission to operate on existing views is controlled by object privileges. Allows the user to perform the following hardware-related operations: view hardware status, manage SPUs, manage topology and mirroring, and run diagnostics. The user can run the commands: nzhw and nzds. Allows the user to perform commands and operations relating to history databases such as creating and cleaning up history databases.
[Manage] Security
A-4
20282-14
Rev.1
Table A-2: Administrator Privileges Privilege [Manage] System Description Allows the user to perform the following management operations: start/stop/pause/resume the system, abort sessions, view the distribution map, system statistics, and logs. The user can run the commands: nzsystem, nzstate, nzstats, and nzsession priority. Allows user to perform backups. The user can run the command nzbackup. Allows the user to restore the system. The user can run the nzrestore command. Allows the user to create an unfenced user-defined function (UDF) or user-defined aggregate (UDA), or to unfence an existing fenced UDF or UDA if the user has permission to create or alter it. For more information, see the Netezza User-Defined Functions Developers Guide.
Table A-3 describes the list of available object privileges. As with administrator privileges, specifying the WITH GRANT option allows a user to grant the privilege to others. Table A-3: Object Privileges Privilege Abort Alter Delete Drop Execute GenStats Groom Insert List Select Description Allows the user to abort sessions. Applies to groups and users. Allows the user to modify object attributes. Applies to groups, users, and tables. Allows the user to delete table rows. Applies only to tables. Allows the user to drop objects such as databases, groups, users, tables, and others. Allows the user to run UDXs such as user-defined functions, aggregates, and shared libraries. Allows the user to generate statistics on tables or databases. The user can run the GENERATE STATISTICS command. Allows the user to groom tables to reclaim disk space and reorganize data. The user can run the SQL GROOM TABLE command. Allows the user to insert rows into a table. Applies only to tables. Allows the user to display an objects name, either in a list or in another manner. Applies to all objects. Allows the user to select (or query) rows within a table. Applies to tables and views.
20282-14
Rev.1
A-5
Table A-3: Object Privileges Privilege Truncate Update Description Allows the user to delete all rows from a table with no rollback. Applies only to tables. Allows the user to modify table rows, such as changing field values. Applies only to tables.
Exit Codes
The nz* commands typically return 0 to indicate a successful completion. If the command returns 1 or a non-zero number, the command encountered an error and failed. The error could be a problem during the nz* command itself or it may be a failure in a subcommand. If a command failed, refer to the messages that appear in the command shell window for possible additional information about the cause of the failure.
nzbackup
Use the nzbackup command to back up your database. For a complete description of the nzbackup command and its use, see The nzbackup Command Syntax on page 10-10.
A-6
20282-14
Rev.1
nzcontents
nzcontents
Use the nzcontents command to display the Netezza program names, the revision level, the build level, and the checksum of binaries. This command takes several seconds to run and results in multiple lines of output. Programs with no revisions are either scripts or special binaries
Syntax
The nzcontents command uses the following syntax:
nzcontents [-h]
Description
The nzcontents command has the following characteristics.
Privileges Required
You do not need special privileges to run the nzcontents command.
Common Tasks
Use the nzcontents command to display the names of programs, and their revision and build level.
Related Commands
Use the nzrev command to display the software revision level. Use the nzsystem showRev command to show software revision levels.
Usage
The following provides some sample usage: To display the software programs and their revisions, enter:
nzcontents Revision Stamp Build Stamp CheckSum ------------------------ --------------------------------- -------------Directory 6.0.0-0.B-1.P-0.Bld-12478 2010-04-15.12478.dev.cm.12478 1821... ab685... 3a52... 6.0.0-0.B-1.P-0.Bld-12478 2010-04-15.12478.dev.cm.12478 d3f2...
nzconvert
Use the nzconvert command to convert between any two encodings, between these encodings and UTF-8, and from UTF-32, -16, or -8 to NFC, for loading with the nzload command or external tables.
20282-14
Rev.1
A-7
Syntax
The nzconvert command uses the following syntax:
nzconvert [-h|-rev] [options]
Options
For information on nzconvert options, refer to the Netezza Database Users Guide.
Description
The nzconvert command has the following characteristics.
Privileges Required
No special privileges are required to use this command.
Common Tasks
Use the nzconvert command to convert character encoding before loading with the nzload command or external tables.
Related Commands
Load converted data with the nzload command.
nzds
Use the nzds command to manage and obtain information about the data slices in the system.
Syntax
The nzds command has the following syntax:
nzds [-h|-rev] [-hc] subcmd [subcmd_options]
A-8
20282-14
Rev.1
nzds
Inputs
The nzds command takes the following inputs: Table A-4: nzds Input Options Input nzds rebalance [-force] Description Rebalances the data slices from SPUs that are doing extra duty to spare SPUs; also rebalances any overloaded SAS paths to ensure that the SAS paths between the SPUs and the disks carry equal traffic. Include the -force option if you do not want to be prompted with a confirmation. When a SPU fails, the data slices that it manages are distributed to the remaining SPUs in the same SPU chassis. After you replace a failed SPU, or after you bring a spare SPU online, you can rebalance the data slice management among the SPUs to obtain an optimal performance topology. Copies all of the partitions of the source disk to a spare disk and brings the spare disk into the topology. This repair operation is known as disk regeneration. Use the -ds option to specify a comma-separated list of source data slices by their IDs (you must specify two the primary data slice ID and the mirror data slice IDand they must be on the same disk). Use the -dest option to specify the hardware ID of the target spare disk. Include the -force option if you do not want to be prompted with a confirmation. Displays information about the data slice topology. The show subcommand is the default and displays a list of all the data slices on the system and information about status, the SPU that manages the data slice, the Primary Storage (that is, the disk ID where the primary copy of the data slice resides), the Mirror Storage (that is, the disk ID where the mirror copy of the data slice resides), and % Used (the amount of space in the data slice that contains data). You can specify one or more options to show specific output. Displays information about the data slice topology and includes information about locations and disk space. Displays information about the data slices which are owned by a particular S-Blade in the SPA. Displays inforamtion about the specific data slice. Displays inforamtion about the data slices assigned to the specified hardware.
nzds show [-detail] nzds show -spa id nzds show -ds id nzds show -id hwId
20282-14
Rev.1
A-9
Table A-4: nzds Input Options Input nzds show -caCertFile path Description Specifies the pathname of the root CA certificate file on the client system. This argument is used by Netezza clients who use peer authentication to verify the Netezza host system. The default value is NULL which skips the peer authentication process. Specifies the security level that you want to use for the session. The argument has four values:
preferredUnsecured This is the default value.
Specify this option when you would prefer an unsecured connection, but you will accept a secured connection if the Netezza system requires one.
preferredSecured Specify this option when you
want a secured connection to the Netezza system, but you will accept an unsecured connection if the Netezza system is configured to use only unsecured connections.
onlyUnsecured Specify this option when you
want an unsecured connection to the Netezza system. If the Netezza system requires a secured connection, the connection will be rejected.
onlySecured Specify this option when you want a
secured connection to the Netezza system. If the Netezza system accepts only unsecured connections, or if you are attempting to connect to a Netezza system that is running a release prior to 4.5, the connection will be rejected. nzds show -regenStatus [-detail] Displays information about the status of any disk regenerations that are in progress. The command displays information about the Data Slice being regenerated, its SPU owner, the Source data slice ID, its Destination data slice ID, the Start Time of the regeneration, and % Done. Include the -detail option for more information such as the locations of the SPUs and storage areas. Displays information about data slices that are reporting problems. The command displays a list of data slices to investigate and their Status, SPU, Primary Storage, Mirror Storage, and % Used. Include the -detail option for more information such as location details and data slice size.
Note: The size of the data slice is reported in
A-10
20282-14
Rev.1
nzds
Options
The nzds command takes the following options: Table A-5: nzds Options Option -host hostname -u user -pw <password> -timeout <db name> Description Specifies the hostname or IP address of the Netezza system. Specifies the database user name [NZ_USER]. Specifies the users password [NZ_PASSWORD]. Specifies the amount of time in seconds to wait for the command to complete before exiting with a timeout error. Default is 300.
Description
The nzds command has the following description.
Privileges Required
Your database user account must have the Manage Hardware privilege.
Common Tasks
Use the nzds command to manage and display information about the data slices in the system. You can also use this command to create a balanced topology for best performance of the system.
Related Commands
Use in conjunction with other system commands, such as the nzsystem and nzhw commands.
Usage
The following provides some sample usage: To rebalance the data slices after placing a new or replacement SPU into service, use the following command:
nzds rebalance -u user -pw password
To regenerate a data slice to a spare disk destination, use the following command:
nzds regen -ds "1,2" -dest 1030 -u user -pw password
To regenerate a data slice to a spare disk destination, use the following command:
nzds show -regenstatus Data Slice SPU Source Destination Start Time ---------- ---- ------ ----------- --------------5 1092 1035 1014 09-Apr-09, 07:24:55 EDT 6 1092 1035 1014 09-Apr-09, 07:24:55 EDT % Done -------0.01 0.01
20282-14
Rev.1
A-11
To show the data slice information for the system, use the following command:
nzds show Data Slice ---------1 2 3 4 5 6 ... Status -------Healthy Healthy Healthy Healthy Healthy Healthy SPU Primary Storage Mirror Storage % Used ---- ---------------- --------------- ------1081 1011 1030 0.07 1081 1030 1011 0.09 1081 1049 1068 0.09 1081 1068 1049 0.09 1081 1012 1031 0.08 1081 1031 1012 0.09
Note: The sample output shown for this command is truncated for the documentation. To show the data slices with detailed (verbose) data, use the following command:
nzds show -detail Data Slice Status SPU Spu Location Primary Storage Primary Storage Location Mirror Storage Mirror Storage Location % Used Size (GiB) ---------- -------- ---- ----------------------- ---------------- --------------------------------- --------------- --------------------------------- ------- ----------1 Healthy 1081 rack1.spa1.spu1.dpart0 1011 rack1.spa1.diskEncl1.disk1.ppart1 1030 rack1.spa1.diskEncl2.disk1.ppart3 0.07 400.71 2 Healthy 1081 rack1.spa1.spu1.dpart1 1030 rack1.spa1.diskEncl2.disk1.ppart1 1011 rack1.spa1.diskEncl1.disk1.ppart3 0.10 400.71 3 Healthy 1081 rack1.spa1.spu1.dpart2 1049 rack1.spa1.diskEncl3.disk1.ppart1 1068 rack1.spa1.diskEncl4.disk1.ppart3 0.09 400.71 4 Healthy 1081 rack1.spa1.spu1.dpart3 1068 rack1.spa1.diskEncl4.disk1.ppart1 1049 rack1.spa1.diskEncl3.disk1.ppart3 0.09 400.71
Note: The sample output shown for this command is truncated for the documentation. To show the data slice issues reported for the system, use the following command:
nzds show -issues Data Slice ---------1 2 9 10 Status -------Repairing Repairing Repairing Repairing SPU Primary Storage Mirror Storage % Used ---- ---------------- --------------- ------1003 1011 1015 0.00 1003 1011 1015 0.00 1003 1013 1020 0.00 1003 1013 1020 0.00
nzevent
Use the nzevent command to perform any of the following: Show a list of event rules. Copy a predefined template event rule and use it as your source to add a new rule.
A-12
20282-14
Rev.1
nzevent
Modify an existing event rule or a copied predefined template. Add a new event rule. Delete an event rule. Generate events.
Syntax
The nzevent command uses the following syntax:
nzevent [-h|-rev|-hc] subcmd [subcmd options]
Inputs
The nzevent command takes the following inputs: Table A-6: nzevent Input Options Input nzevent add options nzevent copy options nzevent delete options nzevent generate options nzevent listEventTypes options Description Adds an event rule. Copies a predefined template event rule or an existing event rule. Deletes an event rule. Generates an event. Lists the valid event types.
nzevent listNotifyTypes options Lists the notification types. nzevent modify options nzevent show options Modifies an event rule. Displays the event rules.
Options
The nzevent command takes the following options: Table A-7: nzevent Options Command All nzevent commands Option -u user -pw password -host name -timeout secs Description Specifies the database user name [NZ_USER]. Specifies the users password [NZ_PASSWORD]. Specifies the hostname or IP address [NZ_HOST]. Specifies the time to wait before exiting with a timeout error (default = 300). Does not apply to listEventTypes and listNotifyTypes.
20282-14
Rev.1
A-13
Table A-7: nzevent Options Command nzevent add or nzevent copy or nzevent modify Option -eventType type -eventArgsExpr expr -name value Description Specifies the event type for the event. For a list of the event types, see Table 7-3 on page 7-8. Specifies the optional match expression for further filtering. For more information, Table 7-4 on page 7-13. If you are adding a new event, specifies the event rule name. If you are copying an event, specifies the name of the event you are copying. If you are modifying an event, specifies the name of the event that you are changing. If you are modifying or copying an event, specifies the name of the new event. If you are copying an existing event, uses the rule specified with the -name option as a template for this new rule. Specifies the type of notification to generate for this event. The notify types are email and runCmd. Specifies the notification destination (notify-type specific). For email, it is the e-mail address. For runCmd, it is the full path of the command or command file to run. Specifies additional notification destination (email only). Specifies the notification message to send. For email, this is the subject string and cannot be blank. For runCmd, this is the argument for -msg parameter. Specifies additional text to send with the notification message. Specifies whether to append system information to the notification message. For email, the system sends /nz/kit/data/config/callHome.txt as an attachment. This file contains customer information such as company, address, contact, and system information such as model number, serial number, and so on. For runCmd, the system passes the file path to the command. Enables or disables processing for this rule.
-on bool
A-14
20282-14
Rev.1
nzevent
Table A-7: nzevent Options Command Option -eventAggrCount int nzevent delete -force Description Specifies the number of events to aggregate (email events only). You can specify a number between 1 and 1000. Does not prompt for confirmation.
-name rule_name Deletes the event rule <rule_name>. nzevent generate -eventType type -eventArgs expr -force nzevent show Generates the specified type of event. For a list of the event types, see Table 7-3 on page 7-8. Specifies a list of one or more optional event arguments (<tag>=<value>, ...). Flushes all aggregate events and sends a notification (email only).
-name rule_name Displays only the event rule corresponding to the rule_name. If you do not specify a name, the command displays all event rules. -syntax -maxColW chars Displays the rule in CLI syntax. Specifies the maximum number of characters to print in each output table column. The default is 24 characters. Allows you to specify the output display. The value values are
Horizontal Displays the event types in a
-orient type
table.
Vertical Displays each event as a complete
record.
Auto Selects the display based on the num-
ber of rows. -caCertFile path Specifies the pathname of the root CA certificate file on the client system. This argument is used by Netezza clients who use peer authentication to verify the Netezza host system. The default value is NULL which skips the peer authentication process.
20282-14
Rev.1
A-15
Table A-7: nzevent Options Command Option -securityLevel level Description Specifies the security level that you want to use for the session. The argument has four values:
preferredUnsecured This is the default
value. Specify this option when you would prefer an unsecured connection, but you will accept a secured connection if the Netezza system requires one.
preferredSecured Specify this option when
you want a secured connection to the Netezza system, but you will accept an unsecured connection if the Netezza system is configured to use only unsecured connections.
onlyUnsecured Specify this option when you
want an unsecured connection to the Netezza system. If the Netezza system requires a secured connection, the connection will be rejected.
onlySecured Specify this option when you
want a secured connection to the Netezza system. If the Netezza system accepts only unsecured connections, or if you are attempting to connect to a Netezza system that is running a release prior to 4.5, the connection will be rejected.
Description
The nzevent command does the following:
Privileges Required
Your database user account must have Manage System privilege.
Common Tasks
Use the nzevent command to set the preconfigured event rules, and to create your own event rules.
Related Commands
Use the nzsession command to view and manage sessions. Use the nzsystem command to change system states.
A-16
20282-14
Rev.1
nzhistcleanupdb
Usage
The following provides some sample usage: To add an event rule, enter:
nzevent add -name Newrule -u admin -pw password -host nzhost -on yes -eventType sysStateChanged -eventArgsExpr $previousState == online && $currentState != online -notifyType email -dst [email protected] -msg NPS system $HOST went from $previousState to $currentState at $eventTimestamp. -bodyText $notifyMsg\n\nEvent:\n$eventDetail\nEvent Rule:\n$eventRuleDetail
To copy a template event rule from the template table to the user-modifiable table, enter:
nzevent copy -u admin -pw password -useTemplate -name HostNoLongerOnline -on yes -dst [email protected]
nzhistcleanupdb
Use this command to periodically delete old history information from a history database.
Syntax
The command has the following syntax:
nzhistcleanupdb [options]
20282-14
Rev.1
A-17
Inputs
The nzhistcleanupdb command takes the following input options. Note that the input options have two forms for the option names. Table A-8: nzhistcleanupdb Input Options Input -d | --db dbname Description Specifies the name of the history database from which you want to remove old data. The name must be a valid, unquoted, identifier. Specifies the hostname of the Netezza system where the database resides. The default and only value for this option is NZ_HOST. Specifies the user account that permits access to the database. The default is NZ_USER. The user must have Delete privileges on the history database tables. Specifies the password for the user account. The default is NZ_PASSWORD. Specifies a date and time value; all history data with a time and date prior to this value will be deleted. The year, month, and day values are required. The hours, minutes, and seconds values are optional; if they are not specified, the default is 12:00 AM of the specified day. Does not prompt for confirmation. Displays the usage and syntax for the command.
-n | --host host
-u | --user user
-p | --pw password
-f | --force -h | --help
Description
After running the nzhistcleanupdb command, you can groom the table to completely remove the deleted rows in the table.
Privileges
You must be the nz user to run this command, and you must specify a database user account who is either the owner or user of the history database or who has administration privileges to update the history database and its tables.
Related Commands
See nzhistcreatedb for a description of how to create a history database.
A-18
20282-14
Rev.1
nzhistcreatedb
Usage
The following sample command deletes history data which is older than October 31, 2009 from the histdb history database:
[nz@nzhost ~]$ nzhistcleanupdb -d histdb -u smith -pw password -t "2009-10-31" About to DELETE all history entries older than 2009-10-31 00:00:00 (GMT) from histdb. Proceed (yes/no)? :yes BEGIN DELETE 0 DELETE 98 DELETE 34 DELETE 0 DELETE 0 DELETE 188 DELETE 188 DELETE 62 DELETE 65 DELETE 0 DELETE 0 DELETE 0 DELETE 503 COMMIT
nzhistcreatedb
Use this command to create a history database with all its tables, views, and objects for history collection and reporting.
Syntax
The command has the following syntax:
nzhistcreatedb [options]
Inputs
The nzhistcreatedb command takes the following input options. Note that the input options have two forms for the option names. Table A-9: nzhistcreatedb Input Options Input -d | --db dbname Description Specifies the name of the history database that you want to create. Specifies the hostname of the Netezza system where the database will reside. The default and only value for this option is NZ_HOST. Specifies the type of database to create. The only valid value is query (or q or Q).
-n | --host host
-t | --db-type dbtype
20282-14
Rev.1
A-19
Table A-9: nzhistcreatedb Input Options Input -o | --owner user Description Specifies an existing database user account which will be made the owner of the history database. The specified user account must have Create Database privilege. The default is NZ_USER. If you specify a different account for the -o and -u arguments (owner and user), the specified owner account must have List privileges on USER objects. Specifies the password for the owner user account. The default is NZ_PASSWORD. Specifies an existing Netezza user account which will be used to load history data into the database. The user will be granted the privileges needed to perform those insert operations on the history database. The default is the user specified for owner. The users password is not specified in this command; instead, it is specified in the history configuration. Specifies the schema version of the history database which will be created. For Release 4.6, the number is 1.
Note: The version must match the version number speci-
-p | --pw password
-u | --user user
-v | --schema num
fied for the active history configuration; otherwise, the loader process will fail. -h | --help Displays the usage and syntax for the command.
Outputs
The nzhistcreatedb command has the following output messages. Table A-10: nzhistcreatedb Output Messages Message History database name created successfully ! ERROR: History database qhist not created: ERROR: GrantRevokeCommand: group/user "name" not found ERROR: History database dev not created: ERROR: createdb: object "hist1" already exists. Description The command created the history database and all its tables and views. The command failed because the specified user name did not exist on the system.
The command failed because the specified database name already exists on the system.
A-20
20282-14
Rev.1
nzhostbackup
Table A-10: nzhistcreatedb Output Messages Message ERROR: History database hist1 not created: nzsql: Password authentication failed for user 'name' ERROR: History database hist1 not created: ERROR: CREATE DATABASE: permission denied. ERROR: History database hist1 not created: ERROR: GrantRevokeCommand: permission denied on "bug". Description The command failed because the password for the specified owner was not correct.
The command failed because the specified owner does not have Create Database privileges on the system.
The specified owner account does not have List privilege on the specified user account or the User object class. The owner must have List privilege to complete the privilege assignments.
Description
The nzhistcreatedb command creates a history database and configures its ownership and access permissions. It creates the history database object, all the history tables and views, and grants the permissions for the owner and user accounts specified in the command. Note that the command can take several (four to five) minutes to complete processing.
Privileges
You must be the logged in as the nz user to run this command.
Related Commands
See nzhistcleanupdb for a description of how to periodically delete old history information from the database.
Usage
The following sample command creates a query history database named qhist:
nzhistcreatedb -d qhist -t q -v 1 -u histusr -o myuser -p password History database qhist created successfully !
Note: The command usually requires several minutes to complete, depending upon how busy the Netezza system is.
nzhostbackup
Use the nzhostbackup command to back up the Netezza data directory and system catalog on the host. In the rare situations when a Netezza host server or disk fails, but the SPUs and their data are still intact, you can restore the /nz/data directory (or whatever directory you use for the Netezza data directory) from the host backup without the additional time to restore all of the databases. For more information, see Host Backup and Restore on page 10-7.
20282-14
Rev.1
A-21
Before running the nzhostbackup command, you must do one of the following: Pause the system. Set the NZ_USER and NZ_PASSWORD environment variables to a user who has permission to pause the system. Set NZ_USER to a user who has permission to pause the system, and cache that users password. Note: If you run the nzhostbackup command, then change a user's password and then run the nzhostrestore command, the old password will be replaced.
Syntax
The nzhostbackup command uses the following syntax:
nzhostbackup [-g GRACE_PERIOD] [-D DATA_DIR] FILE nzhostbackup -h
Inputs
The nzhostbackup command takes the following inputs: Table A-11: nzhostbackup Input Options Input FILE nzhostbackup -h nzhostbackup -g GRACE_ PERIOD Description Specifies the archive file that you want to create. This file is a gzipped tar file. Displays online help for this command. Specifies the maximum time to wait (in seconds) for queries (or any system action, such as a load) to finish before the system begins the backup. After the system has waited this amount of time, it cancels any remaining queries and starts the backup. The default is 60 seconds. Specifies the data directory that you want to back up. The default is the Netezza data directory (NZ_DATA_ DIR).
nzhostbackup -D DATA_DIR
Description
The nzhostbackup command does the following:
Privileges Required
You must specify a database user account that has Manage System privileges.
Common Tasks
You can run the nzhostbackup command when the system is online, paused, offline, or stopped.
A-22
20282-14
Rev.1
nzhostrestore
If you run the nzhostbackup command while the system is online, the nzhostbackup command pauses the system for the duration of the backup. All currently running queries run to completion before the backup begins, subject to the time_out value you specify, or 60 seconds if you do not specify time_out. The system queues new queries until the backup completes. The system cancels currently running queries that do not complete by the time the time_out value has passed, or within 300 seconds if not specified.
Related Commands
Use the nzhostrestore command to restore your Netezza metadata.
Usage
The following provides some same usage: To back up the default data directory, enter:
nzhostbackup /home/host/backup.tar.gz
To specify a timeout period of 5 minutes, rather than the default 60 seconds, enter:
nzhostbackup -g 300 /home/host/backup.tar.gz
nzhostrestore
Use the nzhostrestore command to restore your Netezza data directory and metadata. The nzbackup and nzrestore commands also back up the system catalog and host data, but in situations where a Netezza host server fails but the SPUs and their data are still intact, you can use the nzhostrestore command to quickly restore the catalog data without reinitializing the system and restoring all of the databases. For more information, see Host Backup and Restore on page 10-7. Note: After you perform an nzhostrestore, the system reverts to the mirroring roles (that is, topology) it had when it was last online. After you use the nzhostrestore command, note that you cannot perform an incremental backup on the database; you must run a full backup first.
20282-14
Rev.1
A-23
Syntax
The nzhostrestore command uses the following syntax:
nzhostrestore [-f] [-D DATA_DIR] [-catverok] FILE nzhostrestore -h
Inputs
The nzhostrestore command takes the following inputs: Table A-12: nzhostrestore Input Options Input FILE nzhostrestore -h Description Specifies the archive file that you want to restore. Displays online help for this command.
nzhostrestore -D DATA_DIR Specifies the Netezza data directory to restore. The default is the data directory (NZ_DATA_DIR), which is usually /nz/ data.
Options
The nzhostrestore command uses the following options: Table A-13: nzhostrestore Options Option -catverok Description Skips the catalog verification checks. By default, the command checks the catalog version of the current /nz/data directory and the archived data directory. If the catalog versions are not the same, or if the command cannot detect the catalog version of the current data directory, the command exits with an error message similar to the following:
Unable to determine /nz/data.1.0, hence versions of current directory are same, to skip this check. catalog version of data directory at exiting. If you are sure that catalog and that of the archived data use the command-line switch -catverok
Use caution with this switch; if you are not sure that the catalog versions are the same, do not bypass the checks. Contact Netezza Support for assistance. -D data_dir -f Specifies the destination data directory. Specifies force, which means that the command does not issue two confirmation prompts. The prompts appear at the beginning and end of the program.
Restore host data archived Thu May 25 11:24:58 EDT 2006? (y/n) [n] Warning: The restore will now rollback spu data to Thu May 25 11:24:58 EDT 2006. This operation cannot be undone. Ok to proceed? (y/n) [n]
A-24
20282-14
Rev.1
nzhw
Description
The nzhostrestore command does the following:
Privileges Required
You must specify a database user account that has Manage System privileges.
Common Tasks
The nzhostrestore command pauses the system before starting the restore. Note: After a restoration, any SPUs that previously had a role other than active, spare, or failed are assigned to the role mismatched. The previous roles include assigned, inactive, or mismatched. For more information about SPU roles, see Hardware Roles on page 5-5. For more information about the nzhw command, see nzhw on page A-25.
Notes
If tables are created after the host backup, the nzhostrestore command marks these tables as orphaned on the SPUs. They are inaccessible and consume disk space. The nzhostrestore command checks for these orphan tables and creates a script you can use to drop orphaned user tables. For example, if you ran the nzhostrestore command and it found orphaned tables, you would see the following message:
Checking for orphaned SPU tables... WARNING: found 2 orphaned SPU table(s). Run sh /tmp/nz_spu_orphans.18662.sh after the restore has completed and the system is Online to remove the orphaned table(s).
Related Commands
Use the nzhostbackup command to back up your host metadata.
Usage
The following provides sample usage: To restore the default data directory, enter:
nzhostrestore /home/host/backup.tar.gz
nzhw
Use the nzhw to manage the hardware of the Netezza system. (The nzhw command replaces the nzspu and nzsfi commands.) The command allows you to show information about the system hardware as well as take actions such as activate or deactivate components, locate components, or delete them from the system.
20282-14
Rev.1
A-25
Syntax
The nzhw command has the following syntax:
nzhw [-h|-rev] [-hc] subcmd [subcmd options]
Inputs
The nzhw command takes the following inputs: Table A-14: nzhw Input Options Input nzhw activate -id hwId Description Makes a specified hardware component such as a SPU or a disk available as a spare from a non-Active role (such as Failed or Mismatched). Specify the hardware ID of the SPU or disk that you want to activate. Changes the role of a spare SPU or a spare disk to Inactive, which makes the component unavailable to the system. Attempting to deactivate an active component that has a role other than Spare results in an error. Specify the hardware ID of the spare SPU or disk that you want to deactivate. Include the -force option if you do not want to be prompted with a confirmation. Changes the role of a SPU or disk to Failed, which makes the component unavailable to the system. If you fail over a SPU, the system reassigns the data slices managed or owned by that SPU to the other active SPUs in the chassis. Failing over a disk causes the system to use the disks mirror partition as the primary partition. For more information about the processing of a failover, see Failover Information on page A-29. Specify the hardware ID of the spare SPU or disk that you want to fail over. Include the -force option if you do not want to be prompted with a confirmation.
nzhw locate [-id hwId | -all] Identifies a component and its location in the system. [-off] When used with -id, the command displays a string for the physical location of the hardware component identified by the hwid value. For SPUs, disks, and disk enclosures, the command also turns on its indicator LED so that a technician at the Netezza system can find the component in the rack. When used with -all, the command turns on the indicator LEDs of all the SPUs and disks in the system. The -off option specifies that the command should turn off the indicator LED for the specified component or all SPUs and disks.
Note: If the hardware type specified for the command does
not have an LED, the command only displays the location string for that component.
A-26
20282-14
Rev.1
nzhw
Table A-14: nzhw Input Options Input nzhw reset {-id hwId | -all | -spa spaId } [-force] Description Resets the specified hardware component. Currently, only a SPU is supported as a reset target using this command. You can specify one of the following target options:
-id hwid to reset a particular SPU designated by its hard-
ware ID
-all to reset all SPUs in the system -spa spaId to reset all the SPUs in the specific SPA iden-
tified by its SPA ID. Include the -force option if you do not want to be prompted with a confirmation. nzhw delete -id hwId [-force] Deletes the specified hardware component from the system database. The hardware component must have a role of Mismatched, Failed, or Inactive. A hardware component in any other role results in an error. A SPU or disk can be identified by its unique hardware ID. Specify the hardware ID of the component that you want to delete. Include the -force option if you do not want to be prompted with a confirmation. Displays a list of the valid hardware types that you can input for the nzhw show -type hardwareType command. Displays information about the specified hardware component(s). If you do not specify any options, the command displays a list of every component in the system and its Type, Hardware ID (HW ID), Location, Role, and State. You can specify one or more options (described as follows) to show specific output. Specifies the pathname of the root CA certificate file on the client system. This argument is used by Netezza clients who use peer authentication to verify the Netezza host system. The default value is NULL which skips the peer authentication process.
20282-14
Rev.1
A-27
Table A-14: nzhw Input Options Input nzhw show -securityLevel Description Specifies the security level that you want to use for the session. The argument has four values:
preferredUnsecured This is the default value. Specify
this option when you would prefer an unsecured connection, but you will accept a secured connection if the Netezza system requires one.
preferredSecured Specify this option when you want a
secured connection to the Netezza system, but you will accept an unsecured connection if the Netezza system is configured to use only unsecured connections.
onlyUnsecured Specify this option when you want an
unsecured connection to the Netezza system. If the Netezza system requires a secured connection, the connection will be rejected.
onlySecured Specify this option when you want a
secured connection to the Netezza system. If the Netezza system accepts only unsecured connections, or if you are attempting to connect to a Netezza system that is running a release prior to 4.5, the connection will be rejected. nzhw show -id hwId [-detail] Displays information only about the component with the specified hardware ID. Include the -detail option for more information such as serial number, hardware version, and additional details. Displays information about the hardware components which are owned by a particular S-Blade in SPA. Displays information only about the components of the specified hardware type. To display the supported hardware types, use the nzhw listTypes command. If the system has no hardware of the specified type, or if the type is not supported, the command displays a message. Include the -detail option for more information such as serial number, hardware version, and additional details. Displays information about hardware components that are reporting problems. The command displays a list components to investigate and their Type, Hardware ID (HW ID), Location, Role, and State. Include the -detail option for more information such as serial number, hardware version, and additional details.
nzhw show -spa [spa id] nzhw show -type hwType [-detail]
A-28
20282-14
Rev.1
nzhw
Options
The nzhw command takes the following options: Table A-15: nzhw Options Option -host hostname -u user -pw <password> -timeout <db name> Description Specifies the hostname or IP address of the Netezza system. Specifies the database user name [NZ_USER]. Specifies the users password [NZ_PASSWORD]. Specifies the amount of time in seconds to wait for the command to complete before exiting with a timeout error. Default is 300.
Description
The nzhw command has the following description.
Privileges Required
You must specify a database user account that has Manage Hardware privilege.
Common Tasks
Use the nzhw command is the primary command for managing and displaying information about the Netezza system and its hardware components.
Related Commands
Use in conjunction with other system commands, such as the nzsystem and nzds commands.
Failover Information
When you use the nzhw command to fail over a component, the command checks the system and the affected component to make sure that the command is appropriate before proceeding. Currently, the command operates only on SPUs and disks. For example, if you try to fail over an active component that does not have an available secondary component (such as SPUs that can take ownership of the data slices managed by the SPU that you want to failover, or an active mirror for the disk that you want to fail over), the command returns an error. Similarly, if you try to fail over a component that is not highly available, the command will return an error. For TwinFin systems, one SPU can manage up to 16 data slices.
20282-14
Rev.1
A-29
Usage
The following provides some sample usage: To activate a failed or mismatched SPU identified as ID 1003 use the following command:
nzhw activate -id 1003 -u user -pw password
To deactivate the spare disk identified by hardware ID 1081 without being prompted, use the following command:
nzhw deactivate -id 1081 -force
To fail over the SPU identified by hardware ID 1084, use the following command:
nzhw failover -id 1084
To locate the SPU identified by hardware ID 1061, use the following command:
nzhw locate -id 1061 Turned locator LED 'ON' for SPU: Logical Name:'spa1.spu5' Physical Location:'1st Rack, 1st SPA, SPU in 5th slot'.
To light the locator LED of all the SPUs and disks, use the following command:
nzhw locate -all Turned locator LED 'ON' for all Spus and Disks.
To reset the SPU identified by hardware ID 1084, use the following command:
nzhw reset -id 1084
To reset all the SPUs in the SPA identified by ID 1002, use the following command:
nzhw reset -spa 1002
To delete the disk identified by hardware ID 1081, use the following command:
nzhw delete -id 1081
To show the hardware information for the system, use the following command:
nzhw show Description HW ID ------------- ----Rack 1001 SPA 1002 SPU 1003 DiskEnclosure 1004 Fan 1005 Fan 1006 Fan 1007 Fan 1008 PowerSupply 1009 PowerSupply 1010 Disk 1011 Disk 1012 ... Location --------------------rack1 spa1 spa1.spu7 spa1.diskEncl4 spa1.diskEncl4.fan1 spa1.diskEncl4.fan2 spa1.diskEncl4.fan3 spa1.diskEncl4.fan4 spa1.diskEncl4.pwr1 spa1.diskEncl4.pwr2 spa1.diskEncl4.disk1 spa1.diskEncl4.disk2 Role -----Active Active Active Active Active Active Active Active Active Active Active Active State -----None None Online Ok Ok Ok Ok Ok Ok Ok Ok Ok
Note: The sample output shown for this command is truncated for the documentation.
A-30
20282-14
Rev.1
nzload
To show specific information for a component such as the SPUs, use the following command:
nzhw show -type spu Description HW ID Location ----------- ----- ---------SPU 1003 spa1.spu7 SPU 1080 spa1.spu1 SPU 1081 spa1.spu3 SPU 1082 spa1.spu11 SPU 1084 spa1.spu5 SPU 1085 spa1.spu9 Role -----Active Active Active Active Active Active State -----Online Online Online Online Online Online
To show the hardware issues reported for the system, use the following command:
nzhw show -issues Type HW ID Location Role State ---- ----- --------------------------- ------ ----Disk 1041 rack1.spa1.diskEncl2.disk12 Failed Ok
To list the supported hardware types for the nzhw show -type hwType command, use the following command:
nzhw listTypes Description Type ------------- -------Rack rack SPA spa SPU spu DiskEnclosure diskEncl Disk disk Fan fan PowerSupply pwr MM mm
nzload
Use the nzload command to load ASCII data into database tables. For a complete description of the nzload command and how to load data into the Netezza system, refer to the Netezza Data Loading Guide.
nzpassword
Use the nzpassword command to manage passwords. The primary use is to store your password locally and thus use Netezza CLI commands without having to type your password on the command line.
Syntax
The nzpassword command uses the following syntax:
nzpassword subcmd [subcmd options]
20282-14
Rev.1
A-31
Inputs
The nzpassword command takes the following inputs: Table A-16: nzpassword Input Options Input nzpassword add options nzpassword delete options nzpassword resetkey options Description Adds a locally cached password. Removes the locally cached passwords. In normal system operation and without any options, this command creates a new, unique client key and reencrypts the user passwords with the new key. If you have an existing password file that was created using older (pre-Release 6.0 or pre-Release 4.6.6 clients), this command also converts the old Blowfishencrypted passwords to AES-256-encrypted passwords. The client key used for the encryption is auto-generated. For more information about using encrypted passwords, refer to Creating Encrypted Passwords on page 2-14. Displays cached passwords.
nzpassword show
Options
The nzpassword command uses the following options: Table A-17: nzpassword Options Command nzpassword add Option -host name -u user -pw password -timeout secs Description Specifies a hostname or IP address [NZ_ HOST]. Specifies the Netezza user name [NZ_ USER]. Specifies the users password [NZ_ PASSWORD]. Specifies how long to wait for the command to time out (in seconds) before returning an error. The default is 300. Specifies the database user name [NZ_ USER]. Specifies a hostname or IP address [NZ_ HOST]. Deletes all cached passwords.
nzpassword delete
A-32
20282-14
Rev.1
nzpassword
Table A-17: nzpassword Options Command nzpassword resetkey Option -none Description If you must downgrade to a previous release, or if your client users must support mixed releases of clients, you can use the nzpassword resetkey -none command to convert AES-256-encrypted passwords to Blowfish-encrypted passwords. For more information about using encrypted passwords, refer to Creating Encrypted Passwords on page 2-14. Shows the cached passwords for the current user. The command displays the message No cached passwords if there are none to display.
nzpassword show
N/A
Description
The nzpassword command does the following:
Privileges Required
You must be logged in as nz or any valid Linux account for the Netezza system.
Common Tasks
Use the nzpassword command to store a local version of your password.
Related Commands
Use in conjunction with the CREATE USER or ALTER USER command.
Usage
The following provides sample usage: To add a password, enter:
nzpassword add -u user -pw password -host nzhost
To reset the client key and create new encryptions of the passwords, enter:
nzpassword resetkey
For more information about using encrypted passwords, refer to Creating Encrypted Passwords on page 2-14.
20282-14
Rev.1
A-33
nzreclaim
Use the nzreclaim command to recover disk space used by updated or deleted data using the GROOM TABLE command. Note: Starting in Release 6.0, the SQL GROOM TABLE command has replaced the nzreclaim command. The nzreclaim command is now a wrapper that calls the GROOM TABLE command to reclaim space. if you have existing scripts that use the nzreclaim command, those scripts will continue to run, although some of the options may be deprecated since they are not used by GROOM TABLE. You should transition to using the GROOM TABLE command in your scripts.
Syntax
The nzreclaim command uses the following syntax:
nzreclaim [-h|-rev] [options]
Inputs
The nzreclaim command takes the following inputs: Table A-18: nzreclaim Input Options Input nzreclaim -backupset options nzreclaim -blocks options nzreclaim -records options nzreclaim -startEndBlocks options Description Grooms the tables in a backupset (backupset ID) or no backup set (NONE). Removes empty blocks at the beginning of the table. Removes deleted records from a database or table. Removes empty blocks from the beginning and the end of the table.
Options
The nzreclaim command takes the following options: Table A-19: nzreclaim Options Option -u user -pw password -host name -db database Description Specifies the database user name [NZ_USER]. Specifies the users password [NZ_PASSWORD]. Specifies hostname or IP address [NZ_HOST]. Grooms one or all tables in a specific database [NZ_DATABASE]. You can use the -t option to specify a table, or -allTbls to groom all the tables.
A-34
20282-14
Rev.1
nzreclaim
Table A-19: nzreclaim Options Option -allDbs Description Grooms all databases. You can use the -t option to specify a table to groom in all databases, or -allTbls to groom all tables in all databases. Grooms the specified table name. You can use the -db option to groom the table in one database, or -allDbs to groom that table in all the databases. Grooms all the tables in the database. You can use the -db option to groom all the tables in one database, or -allDbs to groom all tables in all databases.
-t tbl
-allTbls
Description
The nzreclaim command does the following:
Privileges Required
You must have the Groom object privilege for the tables that you want to reclaim or reoirganize.
Common Tasks
Use the nzreclaim command to groom tables and recover disk space. Specify either recordlevel or block-level reclamation. To remove all unused records throughout the table, specify nzreclaim -records. To remove blocks from the beginning of the table, specify nzreclaim -blocks. To remove unused blocks from the beginning and end of the table, specify nzreclaim -startEndBlocks.
Related Commands
Use the TRUNCATE command if you are deleting an entire table.
Usage
The following provides sample usage: To run a record-level groom on all the tables in the emp database, enter:
nzreclaim -u admin -pw password -db emp -t mytable nzsql -u admin -pw password emp -c"groom table mytable " 2>&1 NOTICE: Groom processed 392131 pages; purged 2342 records; scan size unchanged; table size unchanged. GROOM RECORDS ALL
To run a block-level groom on all the tables in the emp database, enter:
nzreclaim -u admin -pw password -blocks -db emp
20282-14
Rev.1
A-35
To run a block-level groom and remove blocks from the beginning and end of the table, enter:
nzreclaim -u user -pw password -startEndBlocks -db emp
nzrestore
Use the nzrestore command to restore your database from a backup. For a complete description of the nzrestore command and its use, see Using the nzrestore Command on page 10-21.
nzrev
Use the nzrev command to display the Netezza software revision level. Note: On Linux systems, you can use the nzcontents command to display the revision and build number of all the executables, plus the checksum of binaries.
Syntax
The nzrev command uses the following syntax:
nzrev [-h|-rev] [options]
Inputs
The nzrev command takes the following inputs: Table A-20: nzrev input Options Input nzrev -dirSuffix Description Displays the directory suffix form. For example, for Release 5.0 Beta1, the output is:
5.0.B1
nzrev -rev
Displays the entire revision string including all fields (such as variant and patch level). For example:
5.0.0-0.B-1.P-0.Bld-7581
Note: Entering the nzrev -rev command on the host is the same as entering the nzsystem showRev -u user -pw password -host host command on the client system. If you use only the nzrev command on the client, the command displays the revision of the client kit. nzrev -shortLabel Displays an abbreviated revision label. For example:
5.0.6
nzrev -buildType
Description
The nzrev command does the following:
A-36
20282-14
Rev.1
nzsession
Privileges Required
You do not need special privileges to run the nzrev command.
Common Tasks
Use the nzrev command to display the revision level of Netezza software components.
Related Commands
See the nzcontents command.
Usage
The following provides sample usage: To display the directory suffix form, enter:
nzrev -dirSuffix 5.0.6.P1
nzsession
Use the nzsession command to view and manage sessions.
Syntax
The nzsession command uses the following syntax:
nzsession subcmd [subcmd options]
Inputs
The nzsession command takes the following inputs: Table A-21: nzsession Input Options Input nzsession abort options nzsession abortTxn options Description Aborts a running user session. Aborts a users transaction.
20282-14
Rev.1
A-37
Table A-21: nzsession Input Options Input nzsession listSessionTypes Description Lists the session types, which include the following:
sql database SQL session sql-odbc database SQL session through ODBC sql-jdbc database SQL session through JDBC load data load session (nzload) client client UI or CLI session bnr Backup and restore session reclaim database reclaim session (nzreclaim) loadsvr data load session (deprecated loader)
Changes priority of the current and all subsequent jobs of this session. Displays the list of current user sessions.
A-38
20282-14
Rev.1
nzsession
Options
The nzsession command takes the following options: Table A-22: nzsession Options Command All nzsession commands Option -u user -pw password -host name -caCertFile path Description Specifies the database user name [NZ_USER]. Specifies the users password [NZ_PASSWORD]. Specifies hostname or IP address [NZ_HOST]. Except listSessionTypes. Specifies the pathname of the root CA certificate file on the client system. This argument is used by Netezza clients who use peer authentication to verify the Netezza host system. The default value is NULL which skips the peer authentication process. Specifies the security level that you want to use for the session. The argument has four values:
preferredUnsecured This is the default
-securityLevel level
value. Specify this option when you would prefer an unsecured connection, but you will accept a secured connection if the Netezza system requires one.
preferredSecured Specify this option when
you want a secured connection to the Netezza system, but you will accept an unsecured connection if the Netezza system is configured to use only unsecured connections.
onlyUnsecured Specify this option when you
want an unsecured connection to the Netezza system. If the Netezza system requires a secured connection, the connection will be rejected.
onlySecured Specify this option when you
want a secured connection to the Netezza system. If the Netezza system accepts only unsecured connections, or if you are attempting to connect to a Netezza system that is running a release prior to 4.5, the connection will be rejected. -timeout secs nzsession abort, and abortTxn -id num -force Specifies the time to wait in seconds for the command to complete. The default is 300. Specifies the session ID. Does not prompt for confirmation.
20282-14
Rev.1
A-39
Table A-22: nzsession Options Command Option Description Specifies the session ID. Changes the session priority to high. Changes the session priority to normal. Changes the session priority to low. Changes the session priority to critical. Displays the active transactions for the system. Specifies the maximum number of characters to print in a column. The default is 24.
nzsession priority -id num -high -normal -low -critical nzsession show -activeTxn -maxColW chars
Description
The nzsession command does the following:
Privileges Required
The admin user has full privileges to display all session information, to abort sessions and transactions, and to change the priority of a session. Other database user accounts require no special privileges to use the nzsession show command to see all the sessions that are currently active on the system. However, non-admin users will see asterisks instead of the user name, client process Id (PID), database, and SQL command unless they have List privilege on User (to see details about the user, client PID, and SQL command) and List privilege on Database (to see the database name). Users must have the Manage System privilege to change the priority of sessions, and Abort privilege to abort sessions and/or transactions.
Common Tasks
Use the nzsession command to manage sessions. Note that you cannot use a Release 5.0 nzsession client command to manage sessions on a Netezza system that is running a release prior to 5.0.
A-40
20282-14
Rev.1
nzsession
The name of the session owner. The time the session was started. The process identification number of the command you are running. The name of the database. The state of the session, which can be one of the following:
Idle The session is connected, but not currently executing any
command.
Active The session is executing a command (usually applies to a
issued.
XactIdle Transaction idle. There is a SQL session, but it is not run-
ning a query. Priority Name The priority of the session, which can be one of the following:
Critical The highest priority for user jobs. High The session jobs are running on the high priority job queue. Normal The sessions jobs are running on the large or small job
queue.
Low The lowest priority for user jobs.
The IP address of the client system. The process identification number of the client system. The last command executed.
20282-14
Rev.1
A-41
Related Commands
Use in conjunction with the nzstats and nzsystem commands.
Usage
The following provides sample usage: To show all sessions, enter:
nzsession show -u bob -pw password ID Type User Start Time PID Client IP Client PID Command ----- ---- -------- ----------------------- ------------- ---------- -----------------------16049 sql ***** 28-Jan-10, 08:28:24 EST 26399 ***** ***** 16052 sql BOB 28-Jan-10, 08:29:27 EST 26612 127.0.0.1 26611 SELECT session_id, clien Database State Priority Name
This sample output appears for a user (bob) who does not have permission to see the details of the sessions on the system. Only the details for bobs sessions appear. For a user who has List permission on user and database objects, the output shows all the details:
nzsession show -u sysadm -pw password ID Type User Start Time PID Client IP Client PID Command ----- ---- -------- ----------------------- ------------- ---------- -----------------------16049 sql DBUSR 28-Jan-10, 08:28:24 EST 26399 127.0.0.1 26398 select * from orders; 16054 sql SYSADM 28-Jan-10, 08:48:22 EST 30515 127.0.0.1 30514 SELECT session_id, clien Database State Priority Name
You can use the -activeTxn option to display the active sessions that will be impacted by a state change (such as pausing -now) before you initiate the state change.
nzstart
Use the nzstart command to start system operation after you have stopped the system. The nzstart command is a script that initiates a system start by setting up the environment and invoking the startup server.
A-42
20282-14
Rev.1
nzstart
Note: You must run nzstart on the host. You cannot run it remotely.
Syntax
The nzstart command uses the following syntax:
nzstart [options]
Inputs
The nzstart command takes the following inputs: Table A-24: nzstart Inputs Input nzstart -h nzstart -D dataDir nzstart -log file nzstart -noWait nzstart -timeout value Description Displays help. Specifies the data directory to use. By default, it is install_dir/ data. Sends the daemon output to the log file instead of to /dev/null. Does not wait for the system to go online. Specifies the number of seconds to wait for the command to complete before exiting with a timeout error. The default is 300. Start a new Netezza system. (Used only the first time a new system is started.)
nzstart -newSystem
Description
The nzstart command does the following:
Privileges Required
You must be able to log on to the host system as the nz user.
Common Tasks
Use the nzstart command to start system operation after you have stopped the Netezza system. The nzstart command verifies the host configuration to ensure that the environment is configured correctly and completely; it displays messages to direct you to files or settings that are missing or misconfigured.
Related Commands
See the nzstop command.
Notes
The nzstart script has a default time out, which is 120 seconds + 3* the number of SPUS. (This default is subject to change in subsequent releases.)
20282-14
Rev.1
A-43
If the system has not started by this time, the nzstart command returns and prints an warning message indicating that the system has failed to start in xxx seconds. The system, however, continues to try to start. You can override the default time out by specifying a timeout.
Usage
The following provides sample usage: To specify a directory, enter:
nzstart -D /tmp/data
nzstate
Use the nzstate command to display the current system state or to wait for a particular system state to occur.
Syntax
The nzstate command uses the following syntax:
nzstate [-h|-rev|-hc] subcmd [subcmd options]]
Inputs
The nzstate command takes the following inputs: Table A-25: nzstate Inputs Input nzstate listStates nzstate show options Description Displays the system states and a description. Displays the current state. This is the default if you type the command without any arguments.
nzstate waitFor options Waits for the system to reach the specified state. Note that you cannot wait for a state that ends in -ing.
A-44
20282-14
Rev.1
nzstate
Options
The nzstate command takes the following options: Table A-26: nzstate Options Command nzstate listStates nzstate show -u user -pw password -host name -timeout secs Option Description Takes no options. Specifies the database user name [NZ_USER]. Specifies the users password [NZ_PASSWORD]. Specifies hostname or IP address [NZ_HOST]. Specifies the number of seconds to wait for the command to complete before exiting with a timeout error. The default is 300. Prints only the current state symbol. Prints the expected state if it is different from the current state. Displays more information about why the system is in the Down state. Waits for the specified state to occur. Use the listStates subcommand to display the state types. Specifies the database user name [NZ_USER]. Specifies the users password [NZ_PASSWORD]. Specifies hostname or IP address [NZ_HOST]. Specifies the number of seconds to wait for the command to complete before exiting with a timeout error. The default is 300.
Description
The nzstate command does the following:
Privileges Required
You do not need special privileges to run the nzstate listStates command. You must specify a database user account to show or wait for states.
Common Tasks
Use the nzstate command to display the current state.
Related Commands
See the nzsystem command.
20282-14
Rev.1
A-45
Usage
The following provides sample usage To list the states, enter:
nzstate listStates State Symbol Description ------------ -----------------------------------------------------------initialized used by a system component when first starting paused already running queries will complete but new ones are queued pausedNow like paused, except running queries are aborted offline no queries are queued, only maintenance is allowed offlineNow like offline, except user jobs are stopped immediately online system is running normally stopped system software is not running down system was not able to initialize successfully
To wait for the offline state until the state change occurs or the command timer expires, enter:
nzstate waitFor -u user -pw password -host nzhost -type offline
To display more information about a system that is in the down state, enter:
nzstate -reason The system is DOWN because failing over SPUs results in invalid topology
nzstats
Use the nzstats command to display operational statistics about system capacity, faults, and performance.
Syntax
The nzstats command uses the following syntax:
nzstats [-h|-rev|-hc] subcmd [subcmd options]]
Inputs
The nzstats command takes the following inputs: Table A-27: nzstats Inputs Input Description
nzstats listFields options Displays the fields for a group or a table. nzstats listTypes nzstats show options Displays the group and table types. Displays the stats from the System Group table.
A-46
20282-14
Rev.1
nzstats
Options
The nzstats command takes the following options: Table A-28: nzstats Options Command nzstats listFields Option -type type Description Specifies the type of group or table that you want to list. The default is system. Valid values include:
dbms DBMS Group system System Group database Database Table host Host Table hostCpu Host CPU Table hostFileSystem Host File System Table hostIf Host Interface Table hostMgmtChan Host Management Channel
Table
hostNet Host Network Table hwMgmtChan HW Management Channel
Table
query Query Table queryHist Query History Table spu SPU Table spuPartition SPU Partition Table table Table Table tableDataSlice Per Table Per Data Slice
Table You can list the valid types using the nzstats listTypes command. nzstats listTypes Lists the valid types for which you can display information, as shown in the listFields description.
20282-14
Rev.1
A-47
Table A-28: nzstats Options Command nzstats show Option -u user -pw password -host name -timeout secs Description Specifies the database user name [NZ_USER]. Specifies the users password [NZ_PASSWORD]. Specifies the hostname or IP address [NZ_ HOST]. Specifies the number of seconds to wait for the command to complete before exiting with a timeout error. The default is 300. Specifies the type of table that you want to show. The default is system.You can list the valid types using the nzstats listTypes command. Shows only the specified columns (for example, 1,4,5). Shows only the columns whose name contains the str string. Specifies the output orientation. It can be auto, horizontal, or vertical. Formats numbers in the output for improved readability. Formats memory fields with size options such as KB, MB, or GB for improved readability. For the Table table, outputs the disk space used value in bytes (default), extents, or blocks. The valid values are usedbytes, extents, or usedblocks.
-type type
-cols list -colMatch str -orient type -fmtNum -fmtMemFlds format -allocationUnit units
Description
The nzstats command does the following:
Privileges Required
Your database user account must have the Manage System privilege to show the actual system statistics. Any user can list the fields and types.
Common Tasks
Use the nzstats command to display operational statistics.
Related Commands
Use in conjunction with the nzsession and nzsystem commands.
A-48
20282-14
Rev.1
nzstop
Usage
The following provides sample usage: To list the types, enter:
nzstats listTypes Group/Table Type Description ---------------- -----------------------------dbms DBMS Group system System Group database host hostCpu hostFileSystem hostIf hostMgmtChan hostNet hwMgmtChan query queryHist spu spuPartition table tableDataSlice Database Table Host Table Host CPU Table Host File System Table Host Interface Table Host Management Channel Table Host Network Table HW Management Channel Table Query Table Query History Table SPU Table SPU Partition Table Table Table Per Table Per Data Slice Table
To show the columns that match the string Num Data Slices, enter:
nzstats show -u Slices" Field Name --------------Num Data Slices user -pw password -host nzhost -colMatch "Num Data Value ----46
nzstop
Use the nzstop command to stop system operation. Stopping a system stops all Netezza host processes. Unless you specify otherwise, stopping the system waits for all running jobs to complete. Use either the nzsystem stop or the nzstop command to stop system operation. The nzstop command is a script that initiates a system stop by halting all processing. Note: You must run nzstop while logged in as a valid Linux user such as nz on the host. You cannot run the command remotely.
Syntax Description
The nzstop command uses the following syntax:
nzstop options
20282-14
Rev.1
A-49
Inputs
The nzstop command takes the following inputs: Table A-29: nzstop Inputs Input nzstop -h nzstop -timeout secs Description Displays the help for the nzstop command. Specifies the number of seconds to wait for the command to complete before exiting with a timeout error. The default is 300.
Options
The nzstop command takes the following options: Table A-30: nzstop Options Command nzstop -h nzstop -timeout Option <time to wait> Description No options. Specifies the timeout value.
Description
The nzstop command does the following:
Privileges Required
You must be able to log on to the Netezza system as a valid Linux user such as nz.
Common Tasks
Use the nzstop command to stop the system.
Related Commands
See the nzsystem command.
Usage
The following provides sample usage: To display help, enter:
nzstop -h
A-50
20282-14
Rev.1
nzsystem
nzsystem
Use the nzsystem command to change the system state, and show and set configuration information.
Syntax
The nzsystem command uses the following syntax:
nzsystem [-h|-rev|-hc] subcmd [subcmd_options]
Inputs
The nzsystem command takes the following inputs: Table A-31: nzsystem Inputs Input nzsystem offline options nzsystem pause options Description Takes the system offline. Pauses the system. Use this command to pause the system for administrative work, but allow all current transactions to complete. Stops and then automatically restarts the system. Returns the system to the online state. Configures a system setting. Caution: Do not change your system settings unless directed to do so by Netezza Support.
nzsystem showRegistry options Displays the systems configuration registry. nzsystem showRev options nzsystem showState options Displays the systems software revision level. Displays the system state. This is the default subcommand if you type the nzsystem command without any subcommands. It is also the same as the nzstate show command. Displays any hardware or dataslice issues found on the system. Stops the system.
20282-14
Rev.1
A-51
Options
The nzsystem command takes the following options: Table A-32: nzsystem Options Command All nzsystem commands Option -u user -pw password -host name -timeout secs Description Specifies the database user name [NZ_USER]. Specifies the users password [NZ_PASSWORD]. Specifies the hostname or IP address [NZ_ HOST]. Specifies the number of seconds to wait for the command to complete before exiting with a timeout error. The default is 300. Does not prompt for confirmation. Aborts the transactions that cannot be restarted after the state transition. Specifies the time for the work to finish before resorting to -now. The default is 300 seconds.
set
-regFile file_name Loads the registry configuration file. -args -ignoreErrors Specifies the configuration argument and its value(s) (<tag>=<value[, value,...]>). Skips unavailable or erroneous settings. Shows the build string for the Netezza software as set by the Configuration Manager (CM). Shows the label version of the build string.
showRev
-build -label
Description
The nzsystem command does the following:
Privileges Required
You can run a subset of the commands such as showRev and showState using any database user account. However, your database user account must have the Manage System privilege to start or manage the system states as well as to set or show the registry settings.
Common Tasks
Use the nzsystem command to show and change system state.
Related Commands
See the nzstart, nzstop, and nzstate commands.
A-52
20282-14
Rev.1
nzsystem
Usage
The following provides sample usage: To take the system offline, enter:
nzsystem offline -u user -password password -host nzhost
To start the system again, use the nzsystem resume command. To pause the system, enter:
nzsystem pause -u user -password password -host nzhost
To start the system again, use the nzsystem resume command. To restart the system, enter:
nzsystem restart -u user -password password -host nzhost -now
Dataslice Issues : Data Slice ---------5 6 Status ---------Unmirrored Unmirrored SPU Primary Storage Mirror Storage ---- ---------------- --------------1194 1139 1194 1139 % Used ------95.90 95.63
20282-14
Rev.1
A-53
nzconvertsyscase Unsafe
nzdumpschema
Safe
nzlogmerge
Safe
nzdbg
Unsafe
nzdumpcat
Unsafe
nzdumpmem
Unsafe
A-54
20282-14
Rev.1
Table A-33: Diagnostic Commands Command Usage Description Dumps information about the transaction log used by the database. Although many invocations of this command are safe, some invocations can crash your system. Internal command used when system recovery is required. Running this command results in data loss. Provides low-level access to the Linux-based SPUs. Running this command could cause the system to crash or data to be lost. Internal command that performs low-level diagnostics. Internal command that performs low-level diagnostics. Internal command that performs low-level diagnostics. Re-initializes the system. Use this command only if you intend to create a new system. Running this command on an operational system results in data loss. For more information, see nzinitsystem on page A-58. Loads a database catalog. This command is used in system recovery. Used internally by the system during upgrade and downgrade. Running this command could produce unexpected results. Resets the database transaction log. Running this command could cause data corruption. Internal command that performs low-level diagnostics. Nzlogmerge uses some GPL components.
nzdumptxjournal Unsafe
toporegen nzpush
Unsafe Unsafe
nzloadcat nzmakedatakit
Dangerous Dangerous
nzconvertsyscase
Use the nzconvertsyscase command to convert the Netezza system to the opposite case, for example from upper to lower or vice versa. Note: Your database must be offline when you use this command (that is, use nzstop first to stop the system).
Syntax
The nzconvertsyscase command uses the following syntax:
20282-14
Rev.1
A-55
Inputs
The nzconvertsyscase command takes the following inputs: Table A-34: nzconvertsyscase Input Options Input nzconvertsyscase -D nzconvertsyscase -l nzconvertsyscase -u nzconvertsyscase -v nzconvertsyscase -L Description Specifies the data directory. Required. Converts the system to lower-case character strings. Converts the system to upper-case character strings Validates the conversion without making any changes. Use this option to check for duplicate names. Logs the command message output to the nzconvertsyscase logfile. The default is nzconvertsyscase.log.
Note: You must specify either l or u. If you specify neither option, the command displays an error. After converting your system, you must rebuild all views and synonyms in every database.
Description
The nzconvertsyscase command does the following: Privileges Required You must be the system administrator.
Common Tasks Use the nzconvertsyscase command to convert from one default case to another. The command uses the values in the objdelim and attdelim fields in the system tables _t_object and _t_attribute to determine if the identifiers should be converted or retained. The script converts only the names of objects and attributes created as regular identifiers. It does not convert delimited identifiers. Note: If you want to convert the identifier case within a database to the opposite of the default system case, contact Netezza Support.
Usage
The following provides sample usage: To convert to lowercase, enter:
nzconvertsyscase -l -D /nz/data
A-56
20282-14
Rev.1
nzdumpschema
Use the nzdumpschema command to generate a shell script with SQL statements that duplicate a database by extracting the given database's schema and statistics. Note: Because no actual data is dumped, you cannot use this command to back up a database.
Syntax
The nzdumpschema command uses the following syntax:
nzdumpschema [-h] database [outfile] [outdir] [datadir]
The nzdumpschema command takes the following inputs: Table A-35: nzdumpschema Inputs Option -h database outfile Description Displays this help Specifies the name of a database for which you want statistics and the schema. Specifies a file to which the command output is written. If you do not specify an output file, the output is written to standard output. Specifies the output directory where UDX object files registered in the database will be written. Specifies the location of the data directory, which is typically /nz/data. The default is /nz/data. This option is used only when outdir is specified.
outdir
datadir
Description
You must be the admin user to run the nzdumpschema command. Common Tasks Use the nzdumpschema command to dump the table and view definitions, the database statistical information, and optionally, any UDXs that are registered within the database. It is a diagnostic tool that you can use to troubleshoot a variety of problems relating to a query. You must run it from the host Netezza system. You cannot use -u, -pw, -host, or other nz CLI options. You have must have set the NZ_USER and NZ_PASSWORD environment variables. You must specify a database. If the database includes registered user-defined objects (UDXs), you can also dump copies of the object files that were registered for use with those routines. If you do not specify an output file, the nzdumpschema command writes to standard output.
20282-14
Rev.1
A-57
Related Commands
None
Usage
The following provides sample usage: To dump table and view definitions to the file named empDBOut, enter:
nzdumpschema empDB empDBOut
To dump the sales database to the file salesSchema and its user-defined objects to the directory /tmp/UdxObjs, enter:
nzdumpschema sales salesSchema /tmp/UdxObjs
If you relocate the object files in /tmp/UdxObjs to another location, be sure to edit the object pathnames used in the salesSchema file to reflect the new location of the object files.
nzinitsystem
When a system is being initialized, the basic host catalog information is written. Because the nzinitsystem command overwrites an existing catalog, therefore it causes data loss. If you run this command while the system is operational, unpredictable results could occur. If you run without a command-line option, the nzinitsystem command attempts to create a host catalog, but will not overwrite an existing catalog:
nzinitsystem
If you run the nzinitsystem command with the -reinit option, it re-initializes the host catalog. Running this command while the system is in operation could result in unpredictable system behavior or data loss:
nzinitsystem -reinit
If you run the nzinitsystem command with the -lowercase option, it changes the default identifier case to be lowercase character strings, which means that any identifier enclosed in special delimiters is automatically converted to lower case. Note that you must include the -reinit option.
nzinitsystem -lowercase -reint
Syntax
The nzinitsystem command uses the following options: Table A-36: nzinitsystem Options Option -D dataDir -lowercase -reinit -uppercase Description Specifies the location of the data directory Forces the default identifier case to be lower case character strings Removes the existing data contents and reinitializes the system Forces the default identifier case to be upper case character strings. This is the default case
A-58
20282-14
Rev.1
nzlogmerge
Each system component produces a log file that is stored in a subdirectory of the /nz/kit/log directory. Each entry in this file contains a timestamp. For troubleshooting, it is often required to merge these entries in chronological order. To merge all the log files, the nzlogmerge command syntax is:
nzlogmerge list of files to merge
Syntax
The nzlogmerge command takes the following options: Table A-37: nzlogmerge Options Option -h or ? -v -t hours -a datetime -b datetime files Description Displays this help Verbose mode Specifies the log messages in the last t hours Captures the log entries after the specified time and before the specified time. The dattime value must be in the format YYYY-MM-DD HH:MM:SS. List of files to merge
20282-14
Rev.1
A-59
A-60
20282-14
Rev.1
APPENDIX
The -G switch specifies a comma-separated list of existing Linux groups to which the user should be added. Do not type any spaces in the comma-separated group list. For example, to create an account called kilroy and to assign that account to the staff, admin, and dev Linux user groups, execute the following command as root:
useradd -G staff,admin,dev kilroy
This useradd command creates a user called kilroy and also a user private group called kilroy. It also adds user kilroy to the staff, admin, and dev Linux groups.
B-1
This usermod command changes the groups to which the kilroy user belongs.
This userdel command deletes the kilroy account, but does not delete kilroys home directory.
To change another accounts password when you are logged in as root, enter:
passwd user_name New UNIX password: (enter the new password) Retype new UNIX password: (enter the new password again) passwd: All authenticaton tokens updated successfully.
B-2
20282-14
Rev.1
This groupdel command deletes the staff group. Note that you cannot remove a users primary group. You must first remove the user or change the users primary group.
The -r switch causes a reboot. You can specify either the word now or any time value. You could use the -h switch to halt the system. In that case, Linux also powers down the host if it can. If you have a Netezza HA system, use caution when shutting down a host. Shutting down the active host causes the HA software to fail over to the standby host to continue Netezza operations, which may not be what you intended.
20282-14
Rev.1
B-3
Answer yes to all prompts. The goal is to recover metadata, but some data might be lost. The fsck command should return your system to consistent state; if not, contact Netezza Support. Do not use fsck to repair mounted partitions. If you are trying to repair a mounted partition, you must first unmount the partition using the umount command, or you must boot the host from the emergency repair CD (the install DVD has a repair mode) to fix a partition such as the root partition (/).
To display the pid, tty, time, cmd used by the command, enter:
ps -C dbos -<cmdname>
To display a full process tree which shows parent/child process relationships, enter:
ps axf
B-4
20282-14
Rev.1
The top command displays real-time information about CPU activity and lists the most CPU intensive tasks on the system. The system updates the display every five seconds by default. To display system CPU utilizations, enter:
top
Note: When you kill a process with the kill signal, you lose any unsaved data for that process.
The sample date command sets the time to midnight EST. To set the system date, enter:
date -s "06/01/2009 01:30:00EST
The sample date command sets the date to June 1, 2009, 1:30 AM EST.
20282-14
Rev.1
B-5
System Administration
This section describes some useful Linux commands that you can use.
Displaying Directories
You can use the ls command to display information about directories: ls -l Displays the long listing. ls -lt Sorts the listing by modification time. ls -ltu Sorts the listing by access time. This is useful to find out who accessed the file, when, and which files were used. ls -l --full-time Includes the full date and time in the listing.
Finding Files
You can use several commands to locate files, commands, and packages: locate string Locates any file on the system that includes the string within the name. The search is fast because it uses a cache, but it might not show recently added files. find -name *string* Finds any file in the current directory, or below the current directory, that includes string within the name. which command Displays the full path for a command or executable program. rpm -qa Lists all the packages installed on the host.
B-6
20282-14
Rev.1
System Administration
Miscellaneous Commands
You can use the following commands for system administration: nohup command Runs a command immune to hangups and creates a log file. Use this command when you want a command to run no matter what happens with the system. For instance, use this command if you want to avoid having a dialup, VPN timeout, or a disconnect network cable cancel your job. unbuffer command Disables the output buffering that occurs when the programs output is redirected. Use this command when you want to see output immediately. UNIX systems buffer output to a file, so that a command can appear hung until the buffer is dumped. colrm [startcol [endcol]] Removes selected columns from a file or stdin. split Splits a file into pieces.
20282-14
Rev.1
B-7
B-8
20282-14
Rev.1
APPENDIX
Netezza User and System Views
Whats in this appendix
User Views System Views
This appendix contains information about Netezza user and system views.
User Views
Table C-1 describes the views that display user information. Note that to see a view, users must have the privilege to list the object. Table C-1: User Views View Name _v_aggregate _v_database _v_datatype _v_function Description Returns a list of all defined aggregates Returns a list of all databases Returns a list of all system datatypes Returns a list of all defined functions Returns a list of all groups Output objid, Aggregate, Owner, CreateDate objid, Database, Owner, CreateDate objid, DataType, Owner, Description, Size objid, Function, Owner, CreateDate, Description, Result, Arguments objid, GroupName, Owner, CreateDate Ordered By Aggregate Database DataType Function nzsql \da \l \dT \df
Returns a list of all users objid, GroupName, Owner, of a group UserName Returns a list of all user indexes Returns a list of all defined operators objid, IndexName, TableName, Owner, CreateDate objid, Operator, Owner, CreateDate, Description, oprname, oprleft, oprright, oprresult, oprcode, and oprkind
C-1
Table C-1: User Views View Name _v_procedure Description Returns a list of all the stored procedures and their attributes Output Ordered By nzsql
objid, procedure, owner, create- Procedure date, objtype, description, result, numargs, arguments, proceduresignature, builtin, proceduresource, sproc, and executedasowner objid, ObjectName, Owner, CreateDate, ObjectType, attnum, attname, format_ type(attypid,attypmod), and attnotnull objid, ObjectName, Owner, CreateDate, Objecttype, attnum, attname, and adsrc objid, SeqName, Owner, and CreateDate ObjectName, and attnum
_v_relation_ column
Returns a list of all attributes of a relation (table, view, index, and so on.) Returns a list of all attributes of a relation that have defined defaults Returns a list of all defined sequences
_v_relation_ column_def
_v_sequence _v_session
SeqName ID
\ds \act
Returns a list of all active ID, PID, UserName, Database, sessions ConnectTime, ConnStatus, and LastCommand Returns a list of all user tables objid, TableName, Owner, and CreateDate
TableName
\dt
Returns a list of all fields objid, TableName, Owner, Create- TableName, and used to determine the Date, DistNum, and DistFldName DistNum tables data distribution Returns a list of all user table indexes TableName, and T.objid, TableName, T.Owner, IndexName, CreateDate, I.indkey, IndexName l.indisunique, l.indisprimary, T.relhasrules, and T.relnatts UserName UserName, and GroupName
_v_user _v_usergroups
Returns a list of all users objid, UserName, Owner, ValidUntil, and CreateDate Returns a list of all objid, UserName, Owner, and groups of which the user GroupName is a member Returns a list of all user views
\du \dU
_v_view
objid, ViewName, Owner, Create- ViewName Date, relhasindex, relkind, relchecks, reltriggers, relhasrules, relukeys, relfkeys, relhaspkey, and relnatts
\dv
C-2
20282-14
Rev.1
System Views
System Views
Table C-2 describes the views that display system information. You must have administrator privileges to display these views. Table C-2: System Views View Name _v_sys_group_priv Description Output Ordered By DatabaseName, GroupName, and ObjectName nzsql \dpg <group>
Returns a list of all GroupName, ObjectName, defined group privileges DatabaseName, Objecttype, gopobjpriv, gopadmpriv, gopgobjpriv, and gopgadmpriv Returns a list of all sys- objid,SysIndexName, Tabletem indexes Name, and Owner Returns a list of all user privileges. This is a cumulative list of all groups and user-specific privileges. UserName, ObjectName, DatabaseName, aclobjpriv, acladmpriv, aclgobjpriv, and aclgadmpriv
_v_sys_index _v_sys_priv
_v_sys_table _v_sys_user_priv
Returns a list of all sys- objid, SysTableName, and tem tables Owner Returns a list of all defined user privileges UserName, ObjectName, DatabaseName, ObjectType, uopobjpriv, uopadmpriv, uopgobjpriv, and uopgadmpriv
SysTableName
\dSt
_v_sys_view
Returns a list of all sys- objid, SysViewName, and tem views Owner
SysViewName
\dSv
20282-14
Rev.1
C-3
C-4
20282-14
Rev.1
APPENDIX
System Configuration File Settings
Whats in this appendix
System Startup Configuration Options
System Manager Configuration Options Other Host Processes Configuration Options SPU Configuration Options
This appendix provides a reference for many of the system configuration file settings. You can display the current system configuration file settings using the nzsystem showRegistry command. For more information, see nzsystem on page A-51. Never change or customize the system registry unless directed to by Netezza Support or by a documented Netezza procedure. The descriptions in this appendix are provided for reference information only.
Note: A default of zero in many cases indicates a compiled default not the actual value zero. Text (yes/no) and numbers indicate actual values.
startup.hostSwapSpaceLimit
131072
D-1
Table D-1: Startup Configuration Options Parameter startup.maxConnections startup.maxRebootRetries startup.mismatchOverRide startup.noLock startup.noPad startup.numSpares startup.numSpus startup.overrideSpuDiskSize startup.overrideSpuRev startup.planCacheFiles startup.planHistFiles startup.queryHistTblSize Default 500 3 yes no no 0 14 no 0 2000 2000 Description Specifies the default maximum number of client connections. The maximum number of connections is 2000. Specifies the number of times the system tries to reboot. Overrides the mismatched SPU designation. FOR INTERNAL USE ONLY. DO NOT CHANGE. Simulator mode. FOR INTERNAL USE ONLY. DO NOT CHANGE. Simulator mode. FOR INTERNAL USE ONLY. DO NOT CHANGE. Historical. Historical. Specifies whether to override the SPU disk size check. FOR INTERNAL USE ONLY. DO NOT CHANGE. Overrides the SPU revision. FOR INTERNAL USE ONLY. DO NOT CHANGE. PARAMETER REMOVED as of Release 4.0. Specifies the number of files that can exist in the /nz/kit/log/planhist/ directory. Specifies the number of queries to maintain in the Query History table. The default and suggested value is 2,000. The range of values permitted is 0 to 15000.
Note: This setting is used for the _v_qryhist view, which is main-
tained for backward compatibility. For more information about the new query history, see Chapter 11, Query History Collection and Reporting. startup.runVirtSfi startup.simMode startup.spuSimMemoryMB startup.startupTimeout startup.stopNow startup.virtualDiskSize no no 0 600 no 128 Simulator mode. FOR INTERNAL USE ONLY. DO NOT CHANGE. Simulator mode. FOR INTERNAL USE ONLY. DO NOT CHANGE. Simulator mode. FOR INTERNAL USE ONLY. DO NOT CHANGE. Specifies the number of seconds of grace after system startup. Allows for staggered starting of SPUs. FOR INTERNAL USE ONLY. DO NOT CHANGE. Simulator mode. FOR INTERNAL USE ONLY. DO NOT CHANGE.
D-2
20282-14
Rev.1
15 1 3 300
sysmgr.eccErrDurationFailover 0 sysmgr.enableAutoFailover sysmgr.enableAutoRegen sysmgr.enableAutoReset sysmgr.enableBalanced Regen sysmgr.enableDiskFpgaFailover yes yes yes yes yes
sysmgr.enAutoRestSpuForQdr- no Failure
20282-14
Rev.1
D-3
Table D-2: System Manager Configuration Options Option sysmgr.enclStatusElementFilterForFailover Default 160 Description Specifies a decimal value that represents a combination of the SCSI element status (SES) codes for which the system manager will fail over a disk drive. The status codes and their numeric values follow:
Unsupported = 0 OK = 2 Critical = 4 Non Critital = 8 Unrecoverable = 16 Not Installed = 32 Unknown = 64 Not Available = 128 No Access = 256 Manufacturers Reserved = 512 Manufacturers Reserved = 1024 Manufacturers Reserved = 2048 Manufacturers Reserved = 4096 Manufacturers Reserved = 8192 Manufacturers Reserved = 16384 Manufacturers Reserved = 32768
The default value of 160 is a combination of the Not Installed and Not Available options. This means that, by default, the system will fail a disk only when its SES status is either "Not Installed" or "Not Available. The system sends a Hardware Status Requested event for all of these status codes. sysmgr.logDiskSuccessOnRetry yes sysmgr.maxAggregateEventInt- 120 erval sysmgr.maxRebootFreqPerHr 3 Specifies whether to log retry successes for disk I/O operations. Specifies the time interval (seconds) during which events are aggregated. Specifies the maximum number of reboots per hour before the system marks the SPU as failed. Specifies the maximum number of respawns (Netezza software restarts on the SPU) per hour before the system marks the SPU as failed. FOR INTERNAL USE ONLY. DO NOT CHANGE. Specifies the number of seconds that the Netezza system can be in the Pausing Now state before a stuck in state timeout event occurs. The timeout should be one minute (60 seconds) longer than the sysmgr.failOverTimeout. FOR INTERNAL USE ONLY. DO NOT CHANGE. Specifies the timeout value of the SFI. The value is in seconds.
sysmgr.maxRespawnFreqPerHr 6
sysmgr.numSpuPorts sysmgr.pausingStateTimeout
4 420
sysmgr.pktReadCount sysmgr.sfiResetTimeout
5 600
D-4
20282-14
Rev.1
Table D-2: System Manager Configuration Options Option sysmgr.smartErrCountFailover sysmgr.smartErrDurationFailover Default 1 0 Description Specifies the number of SMART errors to allow before failing over. Specifies the time interval across Netezza reboots that the system tracks SMART errors. Zero means forever. Specifies the time in seconds to wait for the application data to download to a TwinFin SPU before the SPU is reset (that is, powercycled). Specifies the time in seconds to wait for a TwinFin SPU to complete discovery before the SPU is reset (that is, power-cycled). Specifies the number of seconds a SPU can send a core file to the host before it is reset. Specifies the time in seconds to wait for a TwinFin SPU to finish initializing before the SPU is reset (that is, power-cycled). Specifies the number of seconds to wait for a poll reply from a SPU before the system manager resets it (that is, reboots Linux on a TwinFin SPU). Specifies the number of seconds to wait for a poll reply from a SPU before the system manager logs a warning message in the sysmgr.log file. This setting is no longer used for Release 5.0.x. See sysmgr.spuPollReplyTimeout. Specifies the number of seconds that the Netezza z-series system can be in the Syncronizing state before a stuck in state timeout event occurs. Does not apply to TwinFin systems. Specifies whether the noregen test is enabled. FOR INTERNAL USE ONLY. DO NOT CHANGE.
sysmgr.spuAppDownloadTime- 480 out sysmgr.spuDiscoveryTimeout sysmgr.spuDumpTimeout sysmgr.spuInitializingTimeout sysmgr.spuPollReplyTimeout 360 1440 90 600
sysmgr.testNoRegen
no
20282-14
Rev.1
D-5
Table D-3: Host Processes Option host.bnrFileSizeLimitGB Default 1024 Description Specifies the maximum file size, in bytes, that the backup process creates when backing up a database. The backup process creates a series of files of this size to ensure that it does not exceed the file size limitations of the backup destination(s). Specifies the number of streams to use for a backup operation. A value of zero causes the system to default to one stream per backup location. For more information, see Multi-Stream Backup on page 10-4. Specifies the number of seconds to wait for the backup process to test each stream of a multi-stream backup. If the test completes within the timeout limit, the backup process continues with the requested backup. If the timeout expires before the test completes, the problem typically is that you requested more streams than the tool can support for one backup operation. Review the backup tool documentation to ensure that you do not specify more streams than the tool can support. A value of 0 disables the timeout test to each stream. Specifies how to handle a query when the spool limit is reached. No, stops sending date. Yes, aborts the query. Unused. Allows access to deleted records. FOR INTERNAL USE ONLY. DO NOT CHANGE. Specifies the maximum number of characters above which specific compiler optimizations are applied. FOR INTERNAL USE ONLY. DO NOT CHANGE. Specifies the optimization mask for large queries. FOR INTERNAL USE ONLY. DO NOT CHANGE. Specifies the average snippet cost in seconds below which no compiler optimizations occur. FOR INTERNAL USE ONLY. DO NOT CHANGE. FOR INTERNAL USE ONLY. DO NOT CHANGE. Specifies whether gatekeeper queueing is enabled. If it is not, the gatekeeper does not hold back jobs. Specifies the priority threshold of some internal queries. FOR INTERNAL USE ONLY. DO NOT CHANGE. Specifies the maximum number of high priority queries allowed to run.
host.bnrNumStreamsDefault
host.bnrStreamInitTimeoutSec
300
no 4 no 50000
host.gencDiabKillOptMask host.gencInvokeOptSnippetCost
4 4
0 yes 8 36
D-6
20282-14
Rev.1
Table D-3: Host Processes Option host.gkLowPriQueries host.gkMaxConcurrent host.gkMaxPerQueue host.gkQueueThreshold host.gkVtUpdateInterval host.graVtUpdateInterval host.hostAckThreshold host.hostMaxMsgsOutstanding host.hostMaxPktsOnWire host.hostStaggerConstant host.maxClientSpoolMB host.maxOutstandingClientResults host.mergeMaxWaitingBlocks host.nzstatsRequireAdmin Default 36 48 48 -1 600 600 0 0 0 0 5120 2 4 yes Description Specifies the maximum number of low priority queries allowed to run. Specifies the total number of queries allowed to be running at a time. Specifies the maximum number of normal priority queries allowed to run. Specifies unlimited gatekeeper queue threshold. Unused. Specifies the seconds between updates to the _vt_sched_gra table. Specifies the packet acknowledgement frequency. Specifies the number of application messages on the host. Specifies the number of packets that can be transmitted without acknowledgment. Specifies random return of SPU data to reduce network congestion. Specifies the MB per client limit on spool files. Specifies the number of in-flight return sets before spooling. Specifies the maximum number of blocks per SPU before XOFF from the CmergePlan. Specifies that only the admin user can run the nzstats command. If set to no, other users who also have Manage System privilege will be allowed to run run the following commands:
nzstats show -type database nzstats show -type table nzstats show -type query nzstats show -type queryHist
host.qcLoadRegionSize host.qcMaxLoadMemory
500 1350
Specifies the maximum size in megabytes of the shared memory region for a particular idrDataReader process. Specifies the total amount of shared memory available for all loads. The default calculation is 80 percent of (TotalPhysicalMemory - sizeof (Standard Netezza Shared Memory)). If you specify another number you could reduce the amount of memory allocated to loads. This setting is deprecated.
host.queryHistShowInternal
no
20282-14
Rev.1
D-7
Table D-3: Host Processes Option host.reloadDisableValidityCheck host.reloadForceHostUncompress host.schedAllowGKandGRA host.schedGRAEnabled host.schedGRAHorizon host.schedGRAOverLimit host.schedGRAUnderLimit host.schedGRAVeryOverLimit host.schedGRAVeryUnderLimit host.schedSNHorizon host.schedSQBEnabled host.schedSQBGRABalBoost host.schedSQBMistakesSecs host.schedSQBNominalSecs host.schedSQBPriorityBoost host.schedSQBReservedGraSlots host.schedSQBReservedSnMB host.schedSQBReservedSnSlots host.snDiskReadCost host.snDiskWriteCost Default no no no yes 3600 5 -5 10 -10 600 Yes 0 20 2 0 10 50 6 4200 4200 Description Disables schema validation for compressed external reload. FOR INTERNAL USE ONLY. DO NOT CHANGE. Enables internal testing of host-side compression. FOR INTERNAL USE ONLY. DO NOT CHANGE. Specifies whether gatekeeper and GRA are enabled. The default is disabled. Enables guaranteed resource allocation. Specifies the amount (in seconds) of scheduler usage history to maintain. Specifies the over served amount between the actual GRA and the specified GRA for the resource group. Specifies the under served amount between the actual GRA and the specified GRA for the resource group. Specifies the very over served amount between the actual GRA and the specified GRA for the resource group. Specifies the very under served amount between the actual GRA and the specified GRA for the resource group. Specifies the amount (in seconds) of snippet scheduler usage history to maintain. Enables short query bias. Specifies compliance increase to groups with waiting short queries. Unused. Defines a short query in seconds. Specifies the boost given to short queries. Specifies the number of scheduling positions the GRA scheduler reserves for short queries. Specifies the amount of SPU memory reserved for short queries. Specifies the number of scheduler slots reserved for short queries. Specifies the cost (in ticks) for reading 128 KB data blocks from the SPU disks. Specifies the cost (in ticks) for writing 128 KB data blocks from the SPU disks.
D-8
20282-14
Rev.1
Table D-3: Host Processes Option host.snFabricTableBlocks Default 1536 Description Specifies in the assumed size [in 128KB blocks] of a table that is materialized and processed by DBOS, rather than streaming through in fixed size work units. This size is charged against the snHostMemoryQuota for each snippet that has such a table. Specifies the cost (in ticks) for handling 128 KB data blocks into/out of the host. Specifies the number of 128 KB blocks on the host that the snippet scheduler resource management allocates to snippets. Specifies a margin of error amount to allow groups assigned no resources to run. Specifies the weights assigned to low, normal, high and critical jobs. Enables snippet scheduling. If false, no queueing or resource checking occurs in the snippet scheduler. Specifies the maximum number of queries (at one snippet per query) that the snippet scheduler allows to run. Specifies the cost (in ticks) of writing 128 KB data blocks onto the fabric from the SPU. Specifies the number of 128KB blocks on SPU that the snippet scheduler resource management allocates to snippets. Specifies the scaling factor for the sorted data set size on SPUs. Specifies the number of seconds between updates to the _ vt_sched_sn table. Specifies the rate limit for host-result spooling. Specifies the return set batch size limit in bytes. Specifies the number of seconds between updates of the _VT_SYSTEM_UTIL virtual table. Unused. Specifies whether to retain Read Only transactions. Specifies the value in MB at which the unload flushes the page cache. FOR INTERNAL USE ONLY. DO NOT CHANGE.
host.snHostFabricCost host.snHostMemoryQuota
4200 16384
host.unloadWriteFlushThresholdMB 100
20282-14
Rev.1
D-9
Table D-3: Host Processes Option host.useAndOrTermLimit host.zoneMapPrepScanThresholdMs Default no 5000 Description Specifies whether to revert to the old behavior of not handling more than 400 terms in an AND or OR expression. In 128KB blocks, (320MB). When the optimizer estimate is greater than this size, the system uses the zone map data for the scan table time estimate. Note: The system does not create zone maps when the table is below a certain size, see system.zoneMapTableSizeThreshold.
system.allowDiskHashJoin system.asyncSpu2HostRAW
yes 3
system.avoidSwapWDatamgrLock system.bcastSAW
no 10
system.btOnError system.catch9752
0 no
system.cmdBcastNumReassembly 1 system.cmdBcastRAW 10
D-10
20282-14
Rev.1
Table D-4: SPU Configuration Options Option system.CRCUpgraderErrorBufferLimit system.ctrlNumReassembly Default 3 2 Description Specifies the buffer limit. Must be at least 1. FOR INTERNAL USE ONLY. DO NOT CHANGE. Specifies the number of reassembly buffers allocated by the SPU for the spu control channel Specifies the number of reassembly buffers allocated on the SPU for a broadcast channel. Specifies the number of Receive Available Window packets (RAW) used for data broadcast channels. Increasing the number will cause increased memory usage on the SPUS. FOR INTERNAL USE ONLY. DO NOT CHANGE. Placeholder for future feature. Placeholder for future feature. Placeholder for future feature. Placeholder for future feature. Placeholder for future feature. Placeholder for future feature. Placeholder for future feature. Placeholder for future feature. Placeholder for future feature. Placeholder for future feature. Specifies the upper limit (bytes) on the space used for the aggregation operation. FOR INTERNAL USE ONLY. DO NOT CHANGE. Specifies the upper limit (bytes) on the space used for the sort operation. FOR FOR INTERNAL USE ONLY. DO NOT CHANGE. Specifies the upper limit (bytes) on the space used for windows aggregation. FOR INTERNAL USE ONLY. DO NOT CHANGE. Specifies whether to disable validation of block data during FPGA reads. FOR INTERNAL USE ONLY. DO NOT CHANGE. Specifies whether to disable compute block data prior to writes and validation of block data during FPGA reads. FOR INTERNAL USE ONLY. DO NOT CHANGE. Specifies whether to disable all new CRC processing. Note that the FPGA will still calculate (but not validate) CRCs. FOR INTERNAL USE ONLY. DO NOT CHANGE.
system.dataBcastNumReassembly 4 system.dataBcastRAW 10
system.dbfsASpaceLimit system.dbfsBSpaceLimit system.dbfsChangeLogSize system.dbfsErrorLogSize system.dbfsInUse system.dbfsLogBlockChanges system.dbfsMaxPermFiles system.dbfsMaxSwapGrowthPct system.dbfsMaxTempFiles system.dbfsSwapSpaceLimit system.dbosAggrWorkBlocks
4096 4096
no no
no
20282-14
Rev.1
D-11
Table D-4: SPU Configuration Options Option system.disableMicroRegen system.disablePartialWriteRecovery system.disableSerialMirroring system.disableStrmNet system.disableStrmNetHost Default no no Description Unused. Specifies whether the system copies new disk block content to non-volatile memory. INTERNAL USE ONLY. DO NOT CHANGE. Specifies whether to revert to old-style mirroring. FOR INTERNAL USE ONLY. DO NOT CHANGE. Specifies whether SPU-to-SPU is enabled. FOR INTERNAL USE ONLY. DO NOT CHANGE. If set to true disables host-to-SPU distributes through SUDP. This includes loads and query distributes. The default is false. FOR INTERNAL USE ONLY. DO NOT CHANGE. Specifies whether the system nether computes nor validates swap-data CRCs and not request FPGA CRC validation on reads and writes of the SWAP partition data. FOR INTERNAL USE ONLY. DO NOT CHANGE. Defines (in megabytes) how much of the disk is rewritten each time the disk rewriter task is granted time to operate. Enables or disables the disk rewriter. When disabled, the rewriter performs no rewrites. When enabled, the disk rewriter performs rewrites under the constraints defined by the registry settings. The valid settings are true or false.
Note: As of Release 5.0.2 P-3 and 5.0.4, the background disk
no no no
system.disableSwapCRC
no
system.diskRewriterChunkSize system.diskRewriterEnabled
6 false
rewriter is disabled by default on TwinFin systems. system.diskRewriterFullRewriteP- 1 eriod system.diskRewriterIdlePeriod 5 Defines (in days) the minimum period between full disk rewrites. The period starts from the completion of the last full disk rewrite. Defines (in seconds) the idle period for the disk rewriter task on the SPUs. The idle period is the time the rewriter sleeps before checking for SPU idleness. Defines the maximum number of rewrite attempts that are performed on receiving a read error from the disk drive. Specifies the interval (in seconds) the disk controller for SMART attribute TEC values is polled. Specifies the number of seconds the SPU disk driver waits for a response after issuing an I/O request. The valid range is from 5-7200 seconds. You cannot set it to a value outside this range. Specifies whether to display detail-level log information.
3 86400 31
system.dumpDetail
D-12
20282-14
Rev.1
Table D-4: SPU Configuration Options Option system.durableMirroring Default yes Description Ensures that the primary and mirror data are updated on transaction commit. FOR INTERNAL USE ONLY. DO NOT CHANGE. Specifies broadcast ack aggregation protocol. When No, the same SPUs will always be the leaders for aggregation. Changing this parameter could cause decreased performance on those SPUS. FOR INTERNAL USE ONLY. DO NOT CHANGE. Specifies whether to enable clock synchronization for internal monitoring. FOR INTERNAL USE ONLY. DO NOT CHANGE. FOR INTERNAL USE ONLY. DO NOT CHANGE. Specifies whether to enable jumbo frames. This option specifies whether or your Netezza system will use large tables:
When set to yes, allows creation of tables as large as
system.enableAckAggrLdrRotation yes
disk applies. system.enableMirrors system.enableResetLog system.enableSAWScheme yes yes yes Specifies whether to enable mirroring. FOR INTERNAL USE ONLY. DO NOT CHANGE. Enables the reset log for exception errors. FOR INTERNAL USE ONLY. DO NOT CHANGE. Enables spu2spu permission protocol. Disabling the protocol could cause decreased performance due to packet loss. FOR INTERNAL USE ONLY. DO NOT CHANGE. Specifies the interval (in seconds) at which the SpuErrMgr checks for ECC errors. Specifies the number of disk extents (at 24 blocks per extent in the data partition) that the upgrade process computes and validates before sleeping. FOR INTERNAL USE ONLY. DO NOT CHANGE. Specifies whether data can be up updated during failover. Specifies the bit mask. For diagnostic purposes only. FOR INTERNAL USE ONLY. DO NOT CHANGE. FOR INTERNAL USE ONLY. DO NOT CHANGE. Enables decreasing the size of the FPGAs scan buffer. FOR INTERNAL USE ONLY. DO NOT CHANGE.
system.errMgrWakeupInterval system.extentsPerCRCBurst
1 2
no 0 no 0 0
3145728 Enables decreasing the size of the FPGA buffer. FOR INTERNAL USE ONLY. DO NOT CHANGE.
20282-14
Rev.1
D-13
Table D-4: SPU Configuration Options Option system.funnelSAW system.funnelsPerNIC system.hashflags system.heatNotifyEnabled Default 1 32 288 yes Description Specifies the number of send ahead packets allowed when funneling. FOR INTERNAL USE ONLY. DO NOT CHANGE. Specifies the number of funnels per NIC. to avoid packet loss. Specifies the details of hash table construction and probing. FOR INTERNAL USE ONLY. DO NOT CHANGE. Specifies whether notification is send when the SPUs and SFI cross temperature thresholds. Specifies the rearm interval. The rearm policy is the same for both yellow and red alerts. There is only one interval for the entire system. Specifies a single comm ack for this number of packets. The default is one for every 5 packets. FOR INTERNAL USE ONLY. DO NOT CHANGE. Specifies the number of Receive Available Window packets (RAW) for host-to-spu channels. Retransmits timeout (in seconds) for host-SPU distributes (in milliseconds). FOR INTERNAL USE ONLY. DO NOT CHANGE. Specifies the SAW for host-to-spu channels. Specifies the send window for host to SPU distributes (in packets). FOR INTERNAL USE ONLY. DO NOT CHANGE. Specifies the number (in kilobytes) to represent the maximum amount of data expected to cause transient skew. In other words, at any given time during a load or host distribute, the host may parse/read 128KB for a particular destination data slice before finding data for the next data slice. The system uses this number to calculate the amount of memory for receive buffers for a host2spu channel Specifies the SPU management channel broadcast response stagger parameter. Specifies the threshold of free pages at which a running SPU job starts interacting with the swapper daemon. FOR INTERNAL USE ONLY. DO NOT CHANGE. Specifies the number of blocks given to the target during regeneration. This option prevents the memory from filling up. Specifies the maximum size in KB of a broadcast message.
3 0 1 0 128
D-14
20282-14
Rev.1
Table D-4: SPU Configuration Options Option system.maxFlowCommChannels Default 200 Description Specifies the maximum number of channels that can be opened at any time. Used by flowcomm when allocating resources for channel tables. DO NOT CHANGE, unless you change other variables to allow an increased number of concurrent queries Specifies the maximum number of KB transmitted by one funnel leader, before rotating to another funnel leader. Setting it to zero disables funnel leader rotation. Limits the size of the jumbo frames used in the system. 9000 is the maximum size. FOR INTERNAL USE ONLY. DO NOT CHANGE Specifies the maximum number of times regeneration attempts to synchronize after discovering new writes. Specifies the SPU disk scan "read-ahead" parameter. FOR INTERNAL USE ONLY. DO NOT CHANGE. Specifies the maximum size of a small object heap. Do not change unless instructed by Netezza Support. Specifies the number of bytes of extra space to accommodate changing space needs for varchar columns in min/max aggregations. This setting has been deprecated as of Release 4.6 and is no longer used. Controls the number of maximum concurrent channels in use for host and SPU distributions. Specifies the number of maximum concurrent SPU-to-SPU distributes that can run. Specifies the maximum number of transactions. Relates to polling. FOR INTERNAL USE ONLY. DO NOT CHANGE. Specifies the number of reassembly buffers required for miniSpu2host channel. Because this channel sends small messages by definition, none are required, hence the -1. FOR INTERNAL USE ONLY. DO NOT CHANGE. Specifies the RAW for miniSpu2Host channel. Specifies the number of reassembly buffers allocated for the mirror channel. Specifies the RAW mirroring for the channel. Specifies the SAW mirroring for the channel.
system.maxFunnelLdrKB
5120
system.maxJumboFrameSize
9000
16 7 32 512
99999 0 0 65536 25
20282-14
Rev.1
D-15
Table D-4: SPU Configuration Options Option system.nuclStackThreshold system.numNICs system.osnetrxOomTimeoutSecs system.pollInterval system.printSpuDbosMsgInfo system.realFpga system.recPtrMaxCfg system.regenAlmostDoneCount Default 7000 1 3600 8 no yes Description Specifies the expression evaluator stack limit on the SPU. Specifies the number of network interface cards on the host. Obsolete. Specifies the number of seconds of polling before resetting the SPUs. Obsolete debug message logging facility. FOR INTERNAL USE ONLY. DO NOT CHANGE.
1677721 Specifies the number of array elements used in the sorting 6 machine. 64 Specifies the number of blocks that signal the start of synchronization. Specifies how many e-mails a regen-source SPU is allowed to send for each regen when it encounters a bad disk block. Implements regen throttling. The default is system dependent. Implements regen throttling. The default is system dependent. FOR INTERNAL USE ONLY. DO NOT CHANGE. FOR INTERNAL USE ONLY. DO NOT CHANGE. Specifies the total number of retry attempts before aborting an out of memory regeneration. Specifies the amount of time in milliseconds to sleep before retrying an out of memory regeneration. Specifies the total amount of time (seconds) spend sleeping on an out of memory regeneration. Specifies the NUCLEUS priority of the regen thread. Specifies the RAW mirroring for the regen channel. Specifies the SAW mirroring for the regen channel. Historical. The time slice in milliseconds for a regeneration. Specifies the number of rows IDs assigned at one time. Specifies the minimum time (in milliseconds) that fcomm waits before retransmitting a packet.
system.regenBadBlockEmailLimit 25 system.regenBlocksPerCycle system.regenBreatherMs system.regenGenericCtrl system.regenMode system.regenOomRetryCount system.regenOomRetrySleepMs 32 100 0 normal 6000 100
system.regenOomRetryThreshold- 1800 Secs system.regenPriority system.regenRAW system.regenSAW system.regenSkipBadHeaderCheck system.regenTimeSlice system.rowIdChunkSize system.rtxTimeoutMillis 10 3 3 no 10 100000 300
D-16
20282-14
Rev.1
Table D-4: SPU Configuration Options Option system.rtxWakeupMillis Default 200 Description Specifies the time interval (in milliseconds) that the fcomm retransmit task sleeps, before checking if packets need to be retransmitted Specifies the number of seconds that the upgrade process sleeps between bursts of CRC computation and validation. FOR INTERNAL USE ONLY. DO NOT CHANGE. Specifies the red level, which is 70 degrees centigrade. Specifies the yellow level, which is 50 degrees centigrade Specifies the number of reassembly buffers the host allocates for a spu2host channel. FOR INTERNAL USE ONLY. DO NOT CHANGE Specifies the RAW for spu2host channels. It must be small, because there are many SPUs, and only one host. Increasing it causes packet loss, and increases memory usage. FOR INTERNAL USE ONLY. DO NOT CHANGE. Specifies the SAW for spu2host channels. It must be small, because there are many SPUs, and only one host. Increasing it causes packet loss, and increases memory usage. FOR INTERNAL USE ONLY. DO NOT CHANGE. Specifies a single comm ack for this number of packets. FOR INTERNAL USE ONLY. DO NOT CHANGE. Retransmits timeout for SPU-SPU distributes (in milliseconds). FOR INTERNAL USE ONLY. DO NOT CHANGE. Specifies the send window for SPU-SPU distributes (in packets). FOR INTERNAL USE ONLY. DO NOT CHANGE. Specifies the number (in kilobytes) to represent the maximum amount of data expected to cause transient skew. In other words, at any given time during a load or host distribute, the host may parse/read 128KB for a particular destination data slice before finding data for the next data slice. The system uses this number to calculate the amount of memory for spu2spu distribution for spu2spu channels. Specifies SPU abort print buffer stack dump verbosity level. FOR INTERNAL USE ONLY. DO NOT CHANGE. Specifies the packet acknowledgement frequency. Specifies the PowerPC chip. 1 is the 855; 2 is the 405. FOR INTERNAL USE ONLY. DO NOT CHANGE.
70 50
system.spu2hostNumReassembly -1
system.spu2hostRAW
system.spu2hostSAW
0 0 0 32
20282-14
Rev.1
D-17
Table D-4: SPU Configuration Options Option system.spuCriticalTemperature system.spuCtrlRAW system.spuDiskSchedElvDepth Default 55 16 -1 Description Specifies the red level, which is 55 degrees centigrade. Specifies the RAW for spu control channel. FOR INTERNAL USE ONLY. DO NOT CHANGE. Specifies the SPU disk I/O scheduler elevator algorithm parameter (-1 = use compiled-in default). FOR INTERNAL USE ONLY. DO NOT CHANGE. Specifies the SPU disk I/O scheduler scheduling parameter (-1 = use compiled-in default). FOR INTERNAL USE ONLY. DO NOT CHANGE. Specifies the size of the messages for SPU-to-SPU distribution. Defines the send-ahead-window used for SPU2SPU communication. FOR INTERNAL USE ONLY. DO NOT CHANGE. FOR INTERNAL USE ONLY. DO NOT CHANGE. Specifies Mercury (1) or Sparrow (2) class system. FOR INTERNAL USE ONLY. DO NOT CHANGE. Specifies an adjustment to the internal priority of short jobs. Specifies the number of milliseconds that can elapse before a job is not longer defined as short. Specifies the speed of Ethernet backplane 100 MB for Sparrow/Finch. 1GB (1000) for Mustang. FOR INTERNAL USE ONLY. DO NOT CHANGE. Model dependent. Specifies the maximum number of job threads. FOR INTERNAL USE ONLY. DO NOT CHANGE. Specifies the number of packets that can be transmitted without acknowledgment on the SPUs. Specifies the amount of RAM on the SPU. Internal use only. Specifies the number of application messages on the SPUs. Specifies the Maximum Transfer Unit, that is, the maximum packet size. Specifies the SPI low memory comm receive deadlock threshold for a SPU abort. Specifies the SPI low memory comm receive deadlock threshold for a query abort. This setting has been obsoleted in Release 5.0.
-1
system.spuNonJobReservedBlocks N/A
D-18
20282-14
Rev.1
Table D-4: SPU Configuration Options Option system.spuPartitionSectorCountOverride system.spuPlanWorkBlocks system.spuRetransmitLoopTicks system.spuRetransmitResendTicks system.spuRetransmitTimeoutCycles system.spuRev system.spuRxDescPoolChunks system.spuSwapOrderMethod system.spuSwapPageAbandonments Default 0 2000 0 100 0 6 4 2 1000 Description FOR INTERNAL USE ONLY. DO NOT CHANGE. Specifies the gross (not net) amount of memory available to one snippet on the SPU. Specifies the re-send frequency. Specifies the timeout of unacknowledged packets. Simulator mode. FOR INTERNAL USE ONLY. DO NOT CHANGE. Specifies the SPU revision. 4 is Mercury; 5 is Sparrow. 6 is Mustang. FOR INTERNAL USE ONLY. DO NOT CHANGE. Specifies the SPU comm receive descriptor pool size. Specifies the host priority SPU swap order. Specifies the number of spuSwapWriteRetry attempts across all users since this SPU started its online session.FOR INTERNAL USE ONLY. DO NOT CHANGE. Controls the size of the dummy swap partition table. The default value allocates all available swap space. The actual swap space is the minimum of this option and the SpaceLimit option or the actual partition size. FOR INTERNAL USE ONLY. DO NOT CHANGE. Specifies artificially limiting the swap space for testing. FOR INTERNAL USE ONLY. DO NOT CHANGE. Specifies the number of retries of a single failed write to the swap partition before sending an error. FOR INTERNAL USE ONLY. DO NOT CHANGE. Specifies the yellow level, which is 45 degrees centigrade. Specifies the snippet scheduler Short Query Bias flags, 1=generate prep snippets at head of plan. FOR INTERNAL USE ONLY. DO NOT CHANGE. Specifies whether the FPGA ignores CRC checks on blocks whose layout is one. FOR INTERNAL USE ONLY. DO NOT CHANGE. Specifies the size of transaction IDs. Specifies the RAW for unicast2spu channels. FOR INTERNAL USE ONLY. DO NOT CHANGE.
system.spuSwapSpaceConfigured 0
system.spuSwapSpaceLimit system.spuSwapWriteRetries
0 2
system.spuWarningTemperature system.sqbFlags
45 1
system.tolderateOldCRC
no
system.txIdChunkSize system.unicast2spuRAW
1024 3
20282-14
Rev.1
D-19
Table D-4: SPU Configuration Options Option system.useFpgaPrep system.virtabSingleMutex system.zoneMapJoinBytes system.zoneMapjoinThreshold Default yes yes 4 1000 Description Specifies whether to generate plans that use the FPGAs filter or raw reads. Controls the locking of internal tables. FOR INTERNAL USE ONLY. DO NOT CHANGE. Specifies the number of megabytes per SPU that a zonemap join operation is allowed to consume. Specifies the maximum number of records in memory per SPU for a zonemap join. If greater than 1000 records, the system does not perform a zonemap join. Specifies the size, in MB per SPU, for a table to merit a zone map.
Note: If you change this value, you must regenerate all of your
system.zoneMapTableSizeThresh- 10 old
zone maps or risk wrong results. Do not change this value without consulting Netezza Support.
D-20
20282-14
Rev.1
Glossary
active node admin user administrator privileges aggregate functions alias AMM
AMPP
Asymmetric Massively Parallel Processing Atomicity/Consistency/ Isolation/Durability backup increment backup set
20282-14
Rev.1
Glossary-1
base table Basic Local Alignment Search Tool Binary Large Object BIST BLAST
A permanent table that stores data persistently until you destroy (drop) the table explicitly. See BLAST. See BLOB. Built In Self Test. Basic Local Alignment Search Tool is a search algorithm used by blastp, blastn, blastx, tblastn, and tblastx. You use BLAST functions to perform sequence similarity searching on CLOBs. You use BLAST-related pseudo fields to obtain statistical data on sequence matching. Binary Large OBject. A data type used in some databases to represent large values for fields of records; typical examples might be images in various formats (for example, a picture of an employee in GIF or JPEG format that is included as part of an employee record), movies in formats, such as MPEG, audio data, radar data, and so on. A group of contiguous sectors on a disk, contains a block header and some integral number of records. In the Netezza system, blocksize is defined as 128 KB. A start-up process, such as the process of starting a Netezza system from a powered off state, as well as the process for starting and initializing SPUs. See BIST. A Netezza feature that initiates e-mail messages to Netezza Support to identify failed parts and trigger a service call or the delivery of replacement components (depending on the level of user support purchased). Used to convert a value to a different type. A data structure in the core partition that describes table allocation. A catalog groups a collection of schemas into a single unit. A catalog provides a mechanism for qualifying the schemas names to avoid name conflicts. It is also the conceptual repository for the schemas metadata. An abstract linguistic concept such as "the Latin letter A" or "the Chinese character for sun." A single character can be represented by one or more glyphs. A general term for a hardware cage that contains devices. For example, a chassis could contain SPUs, disks, fan units, power supplies, or a combination of such devices. A Cluster Information Base (CIB) is a replicated store of cluster-related information. It typically includes static configuration data which defines the resources, cluster nodes, and constraints (or dependencies) in the cluster, as well as information about the current state of the cluster.
BLOB
character chassis
CIB
Glossary-2
20282-14
Rev.1
Glossary
CLI
(1) Callable language interface (ANSI SQL term). (2) Command Line Interface. Commands that users type at the command line prompt rather than through a graphical user interface. Netezza CLI commands include nzload, nzsql, nzsystem, and others. Configuration Manager. Defines the production version of the Netezza software. Conference on Data Systems Languages. An organization founded in 1959 by the U.S. Department of Defense. CODASYL was known for its definition of COBOL, but it was also involved with the network database model and the data description language (DDL) for defining database schemas. The name for the binary value associated with each character in a character set, such as Unicode or Latin-1. Rules that determine how data is compared, ordered, and presented. One field of data in a table definition, or in a record or row of a populated database. Unicode allows characters to have their own unique code point value and to be represented as combinations of other characters, called combining sequences. For example, the Angstrom character can be represented by the code point or by combining sequence "capital A" code point followed by the combining ring above code point. An arbitrary sequence or string of characters that are omitted or ignored during processing because they begin and possibly end with special characters that are recognized by the processor. For example, SQL comments typically begin with double dashes and extend to the end of the line. In multi-user environments, a system of controls that ensure that modifications made by one person do not adversely affect another concurrent user. See CM. Symbols that represent specific data values. The format of a constant depends on the data type of the value it represents. Constants are also called literals. An integrity condition that a database system must enforce. SQL-92 defines column constraints, foreign keys, and check conditions. A condition that arises when there are more active consumers of a resource than the system can serve simultaneously. When you use the nzload command, you can use a control file to specify additional options that the command line does not support. See UTC. A Netezza disk partition that is used for storing information about how disk space is being used. This includes directories, catalogs, dictionaries, and coarse indices. Estimate of the work (in time) required to execute the query. Central processing unit. The computing part of the computer. Customer Relationship Management. An integrated information system that is used to plan, schedule and control the presales and postsales activities in an organization.
CM CODASYL
comments
concurrency control Configuration Manager constants constraint contention control file Coordinated Universal Time core partition cost CPU CRM
20282-14
Rev.1
Glossary-3
cumulative backup
A type of backup used in conjunction with differential backups. A cumulative backup includes all the changes sine the last full backup. It consolidates and replaces all previous differential backups. The ability to execute queries that reference tables, views, and synonyms in other databases on the same Netezza server. See block. See DCL. See DDL. A state in which all the data values are stored correctly in the database. See DML. Complex statistical processing used to uncover patterns in large data sets. The data slice number represents that portion of the database stored on a disk. Each disk services a primary data slice and mirrors the primary data slice of another disk. During failover the specific disk on which the data slice resides can change, however the data slice number remains the same. A collection of persistent data, which is used by the application systems of a given enterprise. Database Operating System (runs on the Netezza host processor). Distributed Computing Environment. A device that establishes, maintains and terminates a session on a network. Data Control Language. Allows you to grant or revoke privileges to users or groups. Distributed Database Management System. A database physically stored in two or more computer systems. Although geographically dispersed, a distributed database system manages and controls the entire database as a single collection of data. Data Definition Language of SQL for defining tables, columns, views, constraints, users, privileges; primarily the create, alter and drop commands. Dynamic Host Configuration Protocol (RFC 2131). DHCP clients obtain their IP address assignments and other configuration information from DHCP servers. Provides a mechanism for allocating IP addresses dynamically so that addresses can be reused when hosts no longer need them. In TwinFin systems, a SPU within the SPU chassis that has the responsibility to monitor spare and inactive disks. Typically, this is the SPU that manages the least number of data slices. A configuration file that defines the configuration of SPUs and disks within a system, specific to the model type of the system. The mapping file is used to create and initialize the Netezza database the first time the system starts. It also communicates the device mappings to the SPUs when Netezza starts or after a topology change such as a SPU failure. Data structure that specifies all the tables, their columns, order, and data types.
cross database access data block Data Control Language Data Definition Language data integrity Data Manipulation Language data mining data slice
DDL DHCP
designated SPU
dictionary
Glossary-4
20282-14
Rev.1
Glossary
A type of incremental backup. It includes all the changes since the last full or incremental backup. Data structure on a SPU that describes the allocation status of disk extents. See extents. When a SQL transaction reads data written by concurrent uncommitted transactions. The process of identifying the storage topology and reporting information back to the system manager. The system manager uses this information to assign SPUs to disks (and to define the paths connecting them) and also to identify disk enclosure elements such as fans, power supplies, and sensors for temperature and voltage. The number of distinct values in a column. These values are useful to determine a good distribution column. See DCE. See DDBMS. The column or set of columns used to determine the distribution of data on the data slices. The Netezza systems uses a hash of the distribution key to determine the data slice location of a given row of the database. Data Manipulation Language of SQL for accessing and modifying database data; primarily the select, update, insert, delete, commit and rollback commands. Domain Name System. Used in the Internet for translating names of network nodes into addresses. A condition where a disk is servicing queries on its primary disk partition as well as its mirror disk partition because it is taking the place of a disk that has failed. Distributed Replicated Block Device (DRBD) is a block device driver that mirrors the content of block devices (hard disks, partitions, logical volumes, and so on) between servers. Static routes over direct cabling between two hosts, bonded. This network is dedicated to DRBD only. Error-Correcting Code. A memory system that tests for and corrects errors automatically. An item of data that is updated by the operating system or other control program. They typically reside in memory and can be read by applications to determine the current status of the system. Netezza environment variables include user name, password, and database among others. A physical switch that resides in a Netezza rack and connects the SPAs to the NICs installed on the host computer. Each rack includes at least one switch. Depending upon your Netezza configuration, you could have multiple switches in one or many racks. Extract, Transform, and Load. The process by which data is extracted from one or more source databases, filtered and standardized into common forms and encodings, then loaded into a target database (for example, a Netezza database).
dispersion Distributed Computing Environment Distributed Database Management System distribution key
ETL
20282-14
Rev.1
Glossary-5
EUC-JP EUC-KR execution plan expansion rack Extended UNIX Code extent Extract, Transform, and Load fabric
A way to use the Japanese JIS X0208, JIS X0213, and other related standards (usually called just the "JIS character set"). See Extended UNIX Code. A way to encode Korean with an 8-bit coding of ISO-2022-KR (KS X 1001), implemented by adding 128 to each byte. See Extended UNIX Code. A linear structure that defines the DBOS operations to be performed for a SQL statement. See rack. (EUC) is an 8-bit character encoding system used primarily for Japanese, Korean, and simplified Chinese. The smallest unit of allocation on a disk, contains some number of blocks. See ETL. Connects the host computer (Linux host and SMP host) with the system's SPUs. Because the Netezza fabric uses IP-based protocols, the devices on the fabric use IP addresses. For a Netezza HA host, an automatically triggered action by Linux-HA that causes the resource group to be failed over from the active node to the standby node. As a result, the standby node takes control of the resource group and becomes the active node. For a Netezza SPU, the process of transparently switching to the mirrored copy of the data when a SPU fails to respond. A method that forces a Netezza host out of the cluster after Heartbeat detects problems on that host which would prevent normal operation. In the Netezza environment, fencing typically causes a forced powercycle to stop the problematic host and thus force a failover of the nps resource group to the standby host. See FPGA. Represents a floating-point number. A floating point number is stored in a column defined as FLOAT(precision). The precision is greater than or equal to 1 and is expressed as the number of bits rather than the number of digits. The column or combination of columns whose values match the primary key of another table. Field Programmable Gate Array. The FPGA is a Netezza-designed engine that accelerates SQL query performance. The contents of the entire database copied to a new or empty backup destination. The creation of a new database and restoration of the contents of a full backup set to that database. Gigabit. One billion bits (technically 1,073,741,824 bits). Gigabyte (1024 MB). The concrete visual presentation of a character such as A. A single glyph can represent more than one character.
failover
fencing
Glossary-6
20282-14
Rev.1
Glossary
GRA
Guaranteed Resource Allocation. A policy that allows the system resources to be reserved by percentages. When there is contention for resources, the system grants access to that resource based on the defined percentage. The Linux system on which the Netezza software runs. See GRA. The mechanism that checks the health and liveness of the two Netezza nodes in the cluster. A multiprocessor computer that provides access to monitor basic Netezza functions. It includes a monitor and keyboard. The host receives queries and converts them into optimized execution plans. It runs the Linux operating system, and provides monitoring and diagnostic functions. See rack. The process of replacing hardware components without shutting down the system. An industry standard abbreviation for Internationalization (because there are 18 letters between the 'I' and the 'n'). It comprises software modifications to support multiple languages. International Components for Unicode. A library that enables software programs to work with text in multiple languages. Places the silicon processors in proximity to the storage, so it can filter and process records as they come off the storage disk drivetaking only the data that is relevant to the query. A defined set of properties, methods, and collections that form a logical grouping of behaviors and data. Between racks. For example, inter-rack connections have source and destination locations that reside on different racks. Within a rack. For example, intrarack connections have sources and destinations within the same rack. International Organization for Standardization. ISO SQL standards parallel ANSI standards. The property of a transaction that controls the degree to which data is isolated for use by one process and guarded against interference from other processes. See JDBC. Just a Bunch of Disks. A group of hard disks. An optional feature on a host rack, one 3 Unit JBOD can be installed and used as a staging area for data being extracted or loaded. Java Database Connectivity. Java analog to ODBC. A way to abstract access to databases.
ICU Intelligent Query Streaming interface inter-rack intrarack ISO isolation level Java Database Connectivity JBOD
JDBC
20282-14
Rev.1
Glossary-7
A piece of a query or other task to be run, including load/unload, mirroring/regen, DDL/DML operation and disk management. Kilobyte (1024 bytes). Words that have a fixed meaning in SQL. Keyboard Video Mouse. Part of the host computer. Local Area Network. A communications network that serves users within a confined geographical area. (ISO 8859-1) Is a an 8-bit character encoding. The 256 values correspond to the first 256 Unicode code points, and the first 128 values correspond to the 7-bit ASCII. Defines a pre-commit within a load. It is used if the system must restart a load. The network that Heartbeat uses to communicate between the two Netezza nodes. Sorted, projected, and materialized views (SPM) are views of user data tables (base tables) that project a subset of the base tables columns and are sorted on a specific set of the projected columns. Megabit (one million bits). Megabyte (1024 KB). See MTTR. See MTBF. See Mb. See MB. A sorting algorithm that works by merging sorted lists into larger sorted lists; in Netezza, DBOS on the host performs a merge-sort of sorted data received from multiple SPUs. Database description information; the ANSI system catalog contains the schema metadata for a SQL-92 database. In DRBD terms, a migration (or relocation) occurs when a user manually moves the nps resource group to the standby host, making the standby the active host. A disk partition used for storing tables that are a copy of another disks primary data. The SPU software responsible for replicating data stored on one storage device to a second storage device for high availability of data. The disk has valid data from another Netezza database. This is the case if you removed an active disk from another system or storage array, mistaking it for a spare.
Mb MB mean time to repair mean time between failures megabit megabyte merge-sort
Glossary-8
20282-14
Rev.1
Glossary
multipath
A storage configuration that supports multiple paths from servers to disks. The redundant paths, connections, and controller cards provide a degree of recovery and high availability in the event of failures to a component within the storage subsystem. The Linux software RAID driver which is responsible for mirroring using a RAID-1 algorithm. Mean Time Between Failures. The average time a component works without failure. It is the number of failures divided by the hours under observation. Mean Time to Repair. The average time it takes to repair a failed component. A namespace is the structure underlying SQL schemas. The namespace contains all the objects within the database plus all global objects (databases, users, groups, and system objects) There is only one namespace for each database. Not a Number. A data mining model configuration in which a column of a table contains a table. A Netezza-designed expansion board that provides the FPGA analysis engines, memory, and I/O bandwidth to process the queries and data communications from its associated SPU to the disks that the SPU owns. Network Interface Card. A card that attaches to a computer to control the exchange of data between the computer and components external to the computer. Attached to the Netezza host computer, a NIC connects the Ethernet switch to the host. When a SQL transaction re-reads data it previously read and finds that the data has been modified by another transaction (that committed since the initial read). Describes the translation of a body of text so that characters with multiple representations are encoded in one way. Normalization puts different representations of the same character sequence (as seen by the user) into a single uniform representation, which can then be subjected to byte-wise binary comparison as an equality test. Netezza Performance Server. The former name of the Netezza high performance, integrated database appliance. Specifies the absence of a value for a column in a row. Behaves as unknown in calculations. Default Netezza system administrator Linux account that is used to run the host software on Linux. The Netezza GUI for managing database operations. See ODBs. Object privileges authorize database users to access and maintain the data within a database object. See also administrator privileges. Open Database Connectivity. A way to abstract access to databases. ODBC 3.0 conforms to the SQL2 CLI standards. Object databases (ODBs), first designed in the 1980s, were meant to handle the complexity of data and relationships required by the object model of development.
NPS null nz user NzAdmin tool Object databases object privileges ODBC ODBs
20282-14
Rev.1
Glossary-9
See ODBC. A SPU which is connected to more than 8 data slices. By default, a SPU manages 6 or 8 data slices. If a SPU should fail, its data slices are reassigned to the remaining SPUs. That part of the system resources consumed by the system itself, not necessarily on behalf of a users operation. A condition that arises when the demands on the aggregate resources of a system exceed the systems total capacity. Area of disk that contains extents. Netezza disks have several partitions such as core data, swap, primary, and mirror. Power Distribution Unit. PDUs distribute power to SPUs within a rack, and connect to the racks UPSs or PDUs. When a SQL transaction re-executes a query returning a set of rows that satisfy a search condition and finds that the set of rows has changed due to another recently committed transaction. Power On Self Test. A series of tests that are run every time a hardware system or component is first powered on. The open source relational database version of the Postgres object database program from the University of California, Berkeley. See PDU. See POST. A column or set of columns that uniquely identifies all the rows in a table. The disk partition used for storing tables for which this disk is primarily responsible. The default group to which all users belong. The Preboot Execution Environment (PXE) is a set of methods that are used to boot an IBM host or server without the need for a disk (hard drive or diskette). A user-submitted unit of work that includes SQL statements. The physical structure designed to hold Netezza components securely. Redundant Array of Independent Disks. A way or arranging disks to provide performance and fault tolerance. The host computer includes drives in a RAID configuration. Relational Database Management System. A database organization method that links files together as required. In non-relational systems (hierarchical, network), records in one file contain embedded pointers to the locations of records in another, such as customers to orders and vendors to purchases. The same data type as FLOAT except that the DBMS defines the precision. REAL takes no arguments.
POST PostgreSQL Power Distribution Unit Power On Self Test primary key primary partition public group PXE query rack RAID
RDBMS
real
Glossary-10
20282-14
Rev.1
Glossary
record referential integrity regenerate relational database relocate (or migrate) resource resource group
A single row in a database table stored on a SPU disk with a record header followed by all the fields (column values) for this row. A state in which all foreign key values in a database are valid, by ensuring that the rows in the other tables exist. The process of copying the primary and mirror partitions of a failed disk to a spare disk. Refers to a database in which the data is stored in a uniform structure. A process of manually relocating the nps resource group from the active Netezza node to the standby node. Also called switchover or migration. A schedulable entity of the system. A group of all the applications, scripts, or services which are associated with a particular resource. A resource is a service or facility which is made to be highly available. The Netezza implementation has one resource group called nps which defines the services and resources that are started and monitored by Heartbeat. (A resource group was known as a service in the prior Netezza HA implementation.) To remove the database updates performed by partially completed transactions. A table entry consisting of one value for each column in the table. Some column values can be NULL. A limit on the amount of rows a user query can return. The administrator can specify this limit when creating a user or a group. In the Netezza TwinFin systems, the combined snippet processing server and Netezza Database Accelerator card (also referred to as a SPU). SAS Connectivity Module is a switch that resides in the SPU chassis and manages the connections between the SPUs and their corresponding disk enclosures. There are two SAS connectivity modules in each SPU chassis to improve availability. Also called a SAS expander. A condition that arises when the system resources are oversubscribed and the system can no longer demonstrate linear performance with incremental loads. A database contains one or more named schemas, which in turn contain tables. Schemas also contain other kinds of named objects, including data types, functions, and operators. Schemas allow you to use the same object name in different schemas without conflict. A command that retrieves information from one or more tables. A sequence is a named object in a database that supports a get next value method. A sequence value is an exact numeric that you can use where that type can be used. See SLA. A specific connection to the Netezza system that aggregates units of work for a particular user.
saturation schema
20282-14
Rev.1
Glossary-11
SFI
Switching Fabric Interface. On Netezza models such as the z-series and earlier, the SFI is responsible for network connectivity among all SPUs and the host computer. The SFI monitors and reports the status of all SPU cards, power supplies, and fans. (SJIS) is a character encoding for the Japanese language developed by the Japanese company ASCII. It is based on character sets defined within JIS standards JIS X 0201:1997 (for the single-byte characters) and JIS X 0208:1997 (for the double byte characters). The significant digits of floating point numbers are stored as a unit called the mantissa (or significand), and the location of the radix point (decimal point in base 10) is stored in a separate unit called the exponent. Service Level Agreement. A contact between the owner of the Netezza system and their customers to provide a certain level of service. Self Monitoring Analysis and Reporting Technology. A drive technology that reports its own degradation enabling the operating system to warn the user of potential failure. The Netezza Symmetric Multiprocessing (SMP) host controls and coordinates SPU activities, performs query plan optimization, table and database operations, and system administration. Storage Management System. A registered storage location for backups, such as a file system or a third-party backup system. A unit of database work (labor) to be performed by a Snippet Processing Unit (SPU). See SPA. See SPU. The process of making scheduling decisions at the snippet level rather than at the gatekeeper or GRA level. A logical connection between one CPU core, one FPGA engine, and its associated memory to process a snippet. Simple Network Management Protocol. A widely used network monitoring and control protocol. Snippet processing array. In a z-series system, a SPA is a collection of 14 SPUs and a network switch. In a TwinFin system, the SPA contains an S-Blade chassis and its associated storage array of disks, as well as two AMMs for management services, I/O modules that connect to the disk enclosures, and I/O modules for communication within the enclosure and to the hosts and other components of the rack. Sorted, projected, materialized views. See materialized view. The disk is available to become active in the event that a currently active disk has a nonrecoverable failure. A Snippet Processing Unit (SPU) performs as much of the query as possible at the lowest level possible, with query operations being done in parallel across all the SPUs. In TwinFin systems, this hardware component is referred to as an S-Blade.
Shift_JIS
significand
SLA SMART
SMP Host
SMS snippet snippet processing array Snippet Processing Unit snippet-level scheduling snippet processor SNMP SPA
Glossary-12
20282-14
Rev.1
Glossary
Structured Query Language. A language used to interrogate and process data in a relational database. Often pronounced sequel. SQL-99 allows for the creation of named character sets and for the declarations of a table column to include specification of the columns character set. SQL also has the notion of a "national character set." SQL-99 allows for the creation of named collations. Each character set has a default collation, but additional collations can be defined as pertaining to a given character set. The declaration of a character column can include its character set and its default collation. The target successor to SQL-92. Another name for SQL-92. The successor to SQL2, also called SQL-99. ANSI SQL standard adopted in 1992, also called SQL2. In Linux-HA, a backup node for the cluster that takes over in the event of a failover or relocate. This is called the secondary node in DRBD. A shoot the other node in the head failover design that detects when one node is in an unhealthy state and a failover is required. The STONITH process stops the unhealthy node and then reboots so that the nps resource group will be started on the other, healthy node. This is the specific implementation for the generic concept of fencing in Linux-HA. A storage array is a set of one or more disk enclosures which contain the user databases and tables in the Netezza system. The storage array is connected to and owned by one SPU chassis. See SMS. Netezza RDBMS evenly distributes (or stripes) all tables across all active (non-spare) disks based on the distribution key you specify. Striping keeps the system balanced and prevents overwhelming any one disk with too much data. Striping increases system efficiency. See SQL. Streaming User Datagram Protocol. A communications transport layer protocol for streaming data that is specific to the Netezza system. A disk partition used for the temporary storage of entities too large to fit in random access memory (RAM). An alternate way of referencing tables or views that reside in the current or other databases on the Netezza system. Synonyms allow you to create easy-to-type names for long table or view names. The set of database tables used to hold all the schema information for the system database.
SQL collation
storage array
system catalog
20282-14
Rev.1
Glossary-13
table
A relation. Contains the class of objects and has rows and columns. Table names must be unique within a schema. Tables can be permanent or temporary (within a single session). A lock on a table including all data and indexes preventing simultaneous access to the table by multiple transactions. Terabyte (1024 GB) Transmission Control Protocol/Internet Protocol. A communications protocol developed under contract from the U.S. Department of Defense to internetwork dissimilar systems. This de facto UNIX standard is the protocol of the Internet and has become the global standard for communications. A table that the DBMS destroys automatically at the end of a session or transaction. Trivial File Transfer Protocol. A version of the TCP/IP FTP protocol that has no directory or password capability. A period of time in which a particular job runs as if it had all the resources on the system. The mapping of portions of the database (called data slices) to individual disks, the mirroring assignments between the disks, the location of spare disks, and the SPU ownership for the active data slices. Transaction Processing Council, a group focused on providing level playing field benchmarks for databases; currently four flavors: transaction processing (TPC-C), ad hoc queries (TPC-H), business reporting (TPC-R), and web support (TPC-W). A group of database operations combined into a logical unit of work that is either wholly committed or rolled back. See TPC. User Datagram Protocol. A simple communications transport layer protocol. A character encoding representing each of the worlds characters as a unique 32-bit value, also called a code point. The standards bodies have agreed to limit the code point values to 21 bits. This means that three bytes are required for every character versus one byte per character in traditional ASCII. Various encodings are used to reduce the storage overhead for popular subsets of Unicode. Describes techniques for collating Unicode strings according to the customs of different countries, cultures, and so on. The standard algorithm calls for normalization of comparands, and the use of potentially three or four levels of comparison rules and attributes. Uninterruptible Power Supply. A UPS distributes power within a Netezza rack and protects against power surges and outages. See UDP. Coordinated Universal Time formerly Greenwich Mean Time (GMT). An 8-bit scheme for encoding Unicode code points as 1 to 4 bytes.
TPC
unicode collation
Glossary-14
20282-14
Rev.1
view
A view can be either a virtual table or a stored query. The data accessible through a view is not stored in the database as a distinct object, but rather as a select statement. The result set of the select statement forms the virtual table returned by the view. Vital product data (VPD) is information about a device that allows it to be managed or administered by other system components. VPD information usually includes a MAC address, serial number, and physical location information for the device. A user-specified selection of rows (or a logical partition of a query) that determines the set of rows used to perform certain calculations with respect to the current row under examination. Automatically created persistent tables that the system uses to improve the throughput and response time of SQL queries against large, group, or nearly ordered temporal and integer data. A SAS feature that separates data traffic such as between servers and disks so that servers use a certain set of disks. Zoning provides a means of security and access control between SPUs and their associated data.
VPD
window
zone maps
zoning
20282-14
Rev.1
E-15
E-16
20282-14
Rev.1
Index
Index
Symbols
$hist_column_access_$SCHEMA_VERSION table 11-33 $hist_failed_authentication_$SCHEMA_VERSION table 11-23 $hist_log_entry_$SCHEMA_VERSION table 11-22 $hist_nps_$SCHEMA_VERSION table 11-22 $hist_plan_epilog_$SCHEMA_VERSION table 11-36 $hist_plan_prolog_$SCHEMA_VERSION table 11-34 $hist_query_epilog_$SCHEMA_VERSION table 11-28 $hist_query_overflow_$SCHEMA_VERSION table 11-29 $hist_query_prolog_$SCHEMA_VERSION table 11-26 $hist_service_$SCHEMA_VERSION table 11-30, 11-31 $hist_session_epilog_$SCHEMA_VERSION table 11-26 $hist_session_prolog_$SCHEMA_VERSION table 11-24 $hist_table_access_$SCHEMA_VERSION table 11-32 $hist_version table 11-21 $HOME/.nzsql_history 3-9 $HOME/.nzsqlrc 3-10 /etc/ldap.conf file 8-18 /var/log/messages 4-2 _v_aggregate view 8-30, C-1 _v_database view 8-30, C-1 _v_datatype view 8-30, C-1 _v_function view 8-30, C-1 _v_group view 8-30, C-1 _v_groupusers view 8-30, C-1 _v_index view C-1 _v_operator view 8-30, C-1 _v_planstatus view 11-16 _v_procedure view 8-30 _v_qryhist 9-28 _v_qrystat 9-28 _v_querystatus view 11-15 _v_relation_column view 8-30, C-2 _v_relation_column_def view 8-30, C-2 _v_relation_keydata, view 8-30 _v_sched_gra view 12-15 _v_sequence view 8-30, C-2 _v_session view 8-30, C-2 _v_sys_group_priv view 8-31, C-3 _v_sys_index view 8-31, C-3 _v_sys_priv view 8-31, C-3 _v_sys_table view 8-31, C-3 _v_sys_user_priv view 8-31, C-3 _v_sys_view view 8-31, C-3 _v_table view 8-30, C-2 _v_table_dist_map view 8-30, C-2 _v_table_index view C-2 _v_user view 8-30, C-2 _v_usergroups view 8-30, C-2 _v_view view 8-30, C-2 absent device 5-7 Access Control List E-1 access, controlling to Netezza 8-1 accounts Linux users B-1 unlocking 8-21 ACID E-1 ACL E-1 active hardware 5-5 active host, identifying 4-5 admin database user account 1-2 definition of E-1 nzsession 9-22 object privileges 8-10 predefined user 8-3 privileges, user 9-1 user characteristics 8-3 admin user creating group of 8-16 resource allocations 12-9 administration interfaces about 3-1 list of 1-7 administration tasks 1-1 about 1-1 hardware 5-1 administrator privileges admin user 9-1 backup A-5 create group A-4 create table A-4 create user A-4 create view A-4 definition of E-1 description of 8-8 manage hardware A-4 manage security A-4 manage system A-5 restore A-5 security model 8-8 unfence A-5 aggregate functions E-1 alcloader process 11-7 alerts displaying 7-37 system summary page 3-20 alias E-1 allowed resources percentage 12-13 ALTER HISTORY CONFIGURATION command 11-11 alter privilege 8-10, A-5 American National Standards Institute E-1 AMPP E-1 AndExpr event rule 7-13 API E-1 ASCII E-1 assigned hardware 5-6 Asymmetric Massively Parallel Processing E-1 Atomicity/Consistency/Isolation/Durability E-1
A
abort privilege 8-10, A-5 program 6-12 transactions 9-22
Index-1
Index
authentication methods 8-17 authentication, clients 8-22 automatic host backup 10-39
B
backup 10-29 archive directory 10-16 automatic host 10-39 examples 10-14 Netezza CLI 10-36 permissions 10-19 privileges 8-9, 10-13, A-5 syntax 10-10 type 10-35 backup set E-1 base table E-2 base, directory 1-3 Basic Local Alignment Search Tool E-2 batch, error handling 3-9 bigint, integer type 9-2 bin, directory 1-4 bin/admin, directory 1-4 Binary Large Object E-2 BIST E-2 BLAST E-2 BLOB E-2 block E-2 blocksize E-2 bnrmgr, description 6-8 booting hardware 6-11 software 6-10 bootsvr, description 6-8 build number 6-2 Built In Self Test E-2
C
CA client certificate 8-19 CA client keys file 8-19 CA server certificate, adding 8-22 cache, directory 1-3 callhome definition of E-2 Netezza Customer Support Center 5-10 callHome.txt file, editing 5-10 cast E-2 catalog (SPU) E-2 catalog (SQL) E-2 certificate, SSL 8-21 certification authority (CA) 8-19 character E-2 CIB about 4-3 avoiding incorrect modifications 4-3 clear-text password 2-14 CLI E-3 commands, running 2-4 client command description A-55 session privilege 8-15
sessions list 8-16 client applications about 2-1 supported OS 2-2 Unicode support 2-12 UNIX, installing 2-2 clientmgr, description 6-8 cliqa command, description A-55 clitest command, description A-55 Cluster Information Base (CIB). SeeCIB. 4-3 cluster status, checking 4-6 clustered base table (CBT) 9-11 clustering mode, transitioning to 4-11 CM E-3 CODASYL E-3 code point E-3 collation E-3 color indicators, NzAdmin Tool 3-13 column E-3 combining sequences E-3 commands, proper format for identifiers 3-6 commands, timing B-7 comments E-3 Commlog, ODBC property 8-29 compliance 12-13 monitoring 12-15 component failure 6-11 compressed binary format, for external table unload 10-3 compression, used with backup and restore 10-3 concurrency control E-3 concurrent jobs 12-3 config, directory 1-4 CONFIG-INFO file 11-8 Configuration Manager connection methods, commands 8-25 connection record creating 8-24 dropping 8-25 precedence 8-25 showing 8-24 syntax 8-23 constants E-3 constraints, definition of E-3 content of files, displaying B-6 control file E-3 Coordinated Universal Time E-3 core partition E-3 cost, definition E-3 CPU E-3 CPU usage, displaying B-5 CRC, registry settings D-11 create database ability to 9-1 privilege 8-9, A-4 create external table admin privileges A-4 privilege 8-9, A-4 create external table privileges 8-9 create group A-4 privileges 8-9 CREATE HISTORY CONFIGURATION command, using 11-5 create materialized view, privilege 8-9, A-4
Index-2
Index
create sequence, privilege 8-9, A-4 create table privilege 8-9, 10-20, A-4 create temp table, privilege 8-9, A-4 create user A-4 create user, privileges 8-9 create view privilege 8-9, A-4 CRM E-3 crm_mon command, displaying status 4-6 crm_resource command, identifying active host 4-6 crm_verify command 4-18 cross database access E-4 cumulative backup E-4 custom1 event type 7-9
D
data block, see block Data Control Language, see DCL Data Definition Language, see DDL data integrity E-4 Data Manipulation Language. See DML data mining E-4 data skew avoiding 9-9 viewing 9-10 data slice status 5-17 data slices definition of E-4 Per Table Per Data Slice Table 13-2 data types, disk space usage 9-2 data, directory 1-3 database administration, about 1-1 database super user account 1-2 Database Table, nzstats 13-1, 13-2 databases definition of E-4 Netezza table 13-1 NzAdmin tool 3-12 nzsql 3-7 privileges 8-14 record header 9-3 statistic privilege 8-15 tuning 9-3 date command B-5 disk usage 9-2 DBMS Group, nzstats 13-1, 13-3 DBOS definition of E-4 nzDbosSpill 6-17 dbosDispatch 6-9 dbosEvent 6-9 DCE E-4 DCL E-4 DDBMS E-4 DDL E-4 delete, privilege 8-11, A-5 delimited identifiers, specifying in commands 3-6 Designated Coordinator (DC) host 4-7 DHCP E-4
dictionary E-4 differential backup E-5 digital certificates, for SSL 8-19 directories, displaying B-6 directory (SPU) E-5 dirty read E-5 disk space nzDbosSpill 6-17 reclaiming 9-19 threshold events 7-22 usage 9-2 disk status, monitoring disk errors 7-28 diskError event type 7-10 dispersion automatic statistics 9-16 definition of E-5 displaying hardware 5-2 DISTRIBUTE 9-6 distribute on create table command 9-6 hash 9-6 distribute on random, create table 9-6 Distributed Computing Environment. See DCE Distributed Database Management System. See DDBMS Distributed Replicated Block Device (DRBD). SeeDRBD. 4-1 distribution key 9-6 data skew 9-10 definition of E-5 distribute on 9-6 distribute on random 9-6 random distribution 9-10 selection criteria 9-7 striping E-13 subset tables 9-7 verifying 9-8 DML E-5 DNS E-5 DNS information changing 1-6 managing 1-5 showing 1-5 down state 5-7 down, system state 6-4 DRBD about 4-1 administration 4-13 protocol C 4-2 replicated directories 4-1 split-brain 4-15 states 4-14 status examples 4-15 synchronous mode 4-2 DROP HISTORY CONFIGURATION command 11-12 drop privilege 8-11, A-5
E
ECC E-5 ECC errors 7-26 eccError event type 7-9
Index-3
Index
egrep command B-7 e-mail for events 7-14 encrypted passwords 2-14 environment failure 6-11 installer 2-6 NZ_DATABASE 10-13 NZ_HOST 2-14 NZ_PASSWORD 2-15 NZ_USER 2-14 NzAdmin tool 3-12 PATH variable 1-4 port numbers 2-13 restore 10-25 variables 2-5, E-5 EqualityExpr event rule 7-13 errors categories system 6-11 fixing system B-4 nzbackup 10-13 offline system 6-3 regeneration 7-27 session manager 6-16 startup server 6-16 statistics server 6-17 Ethernet switch E-5 ETL E-5 EUC-JP E-6 EUC-KR E-6 event aggregation, time interval 7-16 attributes of 7-12 event rule actions 7-13 actions overview 7-3 adding 7-7 aggregating notifications 7-16 disabling 7-7 disk errors 7-28 displaying alerts 7-37 ECC/memory failures 7-26 email notifications 7-14 equality expressions 7-13 fpgaQdrFailure 7-36 hardware failed 7-20 hardware restarted 7-21 hardware temperature 7-29 query history 7-31 regen failures 7-27 runaway query 7-24 runCmd arguments 7-15 See nzevent command sendMail.cfg 1-4 SPU cores 7-34 substitution tags 7-13 system changes 7-19 system temperature 7-30 template reference 7-19 templates 7-1 TransactionLimitEvent 7-36 voltage faults 7-35 eventmgr, description 6-9 Execute privilege 8-11, A-5
execution plans, definition of E-6 exit code, description for nz commands A-6 expansion rack E-6 Extended Internet Services 1-7 extent definition of E-6 disk usage 9-3 external IP address, MantraVM 14-2 external tables, compressed data 10-3 Extract, Transform, and Load. See ETL
F
F5, control key 3-14 failed hardware 5-6 failover criteria 4-8 error actions 6-11 events 4-8 Linux-HA 4-1 timers 4-4 fair-sharing model 12-2 Field Programmable Gate Array. See FPGA files, finding B-6 float E-6 foreign key E-6 FORMAT_COLUMN_ACCESS () function 11-38 FORMAT_PLAN_STATUS () function 11-37 FORMAT_QUERY_STATUS () function 11-37 FORMAT_TABLE_ACCESS() function 11-37 FPGA E-6 fpgaQdrFailure event 7-12, 7-36 fsck, command B-4 full backup E-6 full restore E-6 fwMismatch event type 7-10
G
gate keeper about 12-21 configuration settings 12-22 Normal queues by runtime 12-23 nzsession command 12-21 GB E-6 GENERATE STATISTICS GenStats privilege A-5 generate statistics 8-11 GenStats privilege A-5 hints 9-16 syntax 9-15 tuning database tables 9-3 GenStats privileges 8-11 GenStats, privileges A-5 gkMaxConcurrent setting 12-3 glyph E-6 GRA E-7 GROOM command 9-19 groom command 9-19 Groom privileges 8-11 grooming tables 9-19 groupadd command B-3
Index-4
Index
groups adding Linux users B-3 Linux B-2 methods for managing 8-2 Netezza database 8-1 privilege 8-14 public 1-2, 8-3 rowset limits 8-27 setting permissions for members 8-2 using to simplify permission management 8-2 guaranteed resource allocation 12-6
H
ha.cf file 4-3 haclient group 4-19 hacluster group 4-19 user 4-19 hardware active 5-5 assigned 5-6 down state 5-7 failed 5-6 failure events 7-20 inactive 5-6 incompatible 5-6 invalid state 5-7 management channel table 13-2 mismatched 5-6 missing state 5-7, 6-4 none state 5-7 ok state 5-7 online state 5-7 privileges A-4 restart events 7-21 roles 5-5 spare 5-6 state 5-6 temperature events 7-29 types 5-3 unreachable state 5-7 Hardware Management Channel Table, nzstats 13-9 hardware privileges 8-10 hash, create table 9-6 Heartbeat clustering mode 4-11 configuration 4-3 daemon 4-1 failover timers 4-4 forcing shutdown 4-17 maintenance mode 4-10 manually controlling 4-9 required Linux users and groups 4-19 safe shutdown 4-9 startup 4-3 help about box 3-15 contents and index 3-15 helper functions example 11-38 query history 11-36
high availability (HA) solution 4-1 High-Availability Linux. See Linux-HA. histCaptureEvent 11-13 histCaptureEvent event type 7-10 histLoadEvent 11-13 histLoadEvent event type 7-11 history configuration, changing ownership of 11-10 history, sql sessions 3-9 home directory 1-3 host computer E-7 definition of E-7 host CPU table 13-1 host filesystem table 13-1 host interfaces table 13-2 host management channel table 13-2 host net table 13-2 host table 13-2 installation directory 1-3 Host CPU Table, nzstats 13-1, 13-3 Host Filesystem Table, nzstats 13-1, 13-4 Host Interfaces Table, nzstats 13-2, 13-4 Host Mgmt Channel Table, nzstats 13-2, 13-6 Host Net Table, nzstats 13-2, 13-7 host rack. See rack. Host Table, nzstats 13-2, 13-8 host. bnrNumStreamsDefault setting D-6 host.abortIfTxArrayFull setting D-5 host.autoRestartReclaim setting D-5 host.bnrFileSizeLimitGB setting D-6 host.bnrStreamInitTimeoutSec setting D-6 host.disableClientXoffSpus setting D-6 host.fpgaAllowXIDOverride setting D-6 host.gencDiabKillOptComplexity setting D-6 host.gencDiabKillOptMask setting D-6 host.gencInvokeOptSnippetCost setting D-6 host.gkEnabled setting D-6 host.gkFastVtScanLimit, configuration file D-6 host.gkHighPriQueries setting D-6 host.gkLowPriQueries setting D-7 host.gkMaxConcurrent setting D-7 host.gkMaxPerQueue setting D-7 host.gkQueueThreshold setting D-7 host.hostAckThreshold setting D-7 host.hostMaxMsgsOutstanding setting D-7 host.hostMaxPktsOnWire setting D-7 host.hostStaggerConstant setting D-7 host.maxClientSpoolMB setting D-7 host.maxOutstandingClientResults setting D-7 host.nzstatsRequireAdmin setting D-7 host.qcLoadRegionSize setting D-7 host.qcMaxLoadMemory setting D-7 host.reloadDisableValidyCheck setting D-8 host.reloadForceHostUncompress setting D-8 host.schedAllowGKandGRA setting D-8 host.snDiskReadCost setting D-8 host.snDiskWriteCost setting D-8 host.snFabricTableBlocks setting D-9 host.snHostFabricCost setting D-9 host.snHostMemoryQuota setting D-9 host.snSchedEnabled setting D-9 host.snSchedJobMax setting D-9 host.snSPUFabricCost setting D-9
Index-5
Index
host.snSpuMemoryQuota setting D-9 host.snSpuSortSizeFactor setting D-9 host.spoolRateLimitKBPerSec setting D-9 host.streamBatchSize setting D-9 host.txRetainReadOnly setting D-9 host.zoneMapPrepScanThreshold setting D-10 hostbnrEnableUsersBackup setting D-5 hostmergeMaxWaitingBlocks setting D-7 hot swap E-7 HW Mgmt Channel Table, nzstats 13-2 hwDiskFull event type 7-9 hwFailed event type 7-8 hwHeatThreshold event type 7-10 hwRestarted event type 7-9 hwServiceRequested event type 7-11 hwThermalFault event type 7-12 hwVoltageFault event type 7-11 hyperlinks, NzAdmin tool 3-15
killall command B-5 kit link 1-3 optimized 1-3 rev 1-4 KVM E-8
L
LAN E-8 latin-1 E-8 LD_LIBRARY_PATH 2-4 LDAP authentication 8-4, 8-17 about 8-17 commands 8-19 failures 8-18 returning to local authentication 8-18 LDAP server managing 8-17 required information for Netezza 8-18 LDAP, configuring SSL security 8-19 ldap.conf file, editing for SSL configuration 8-19 ldap.conf.orig file 8-18 less command B-6 limit clause 8-27 Linux accounts B-1 adding groups B-3 boot directories 1-3 changing passwords B-2 command line editing B-7 common procedures B-1 deleting accounts B-2 deleting groups B-3 directories, displaying B-6 file content, displaying B-6 files, finding B-6 groups B-2 log files, viewing B-6 miscellaneous commands B-7 modifying accounts B-2 modifying groups B-3 passwords 8-17 rebooting B-3 release level B-6 remote access 1-7 setting up accounts B-1 statistics B-4 stopping processes B-5 string matching B-7 system errors B-4 system time B-5 timing commands B-7 user 1-2 viewing statistics B-4 Linux users, adding B-1 Linux-HA about 4-1 active host, identifying 4-5 administration 4-3 failover 4-1 failover criteria 4-8
I
i18N, definition of E-7 ICU, definition of E-7 identifiers, in CLI 3-6 inactive hardware 5-6 incompatible hardware 5-6 incremental backup restore 10-30 indirect object privileges 8-15 initial configuration 1-2 initialized, system state 6-4 initializing, system state 6-4, 6-10 insert privilege 8-11 insert, privilege A-5 installation, Netezza 1-2 integer nzDbosSpill file 6-17 transaction id 9-4 intelligent query streaming E-7 interface E-7 interfaces 1-7 internal IP address 14-2 inter-rack E-7 intrarack E-7 invalid state 5-7 IP addresses, for HA system 4-17 ISO E-7 isolation levels E-7
J
Java Database Connectivity. JBOD E-7 JDBC, definition of E-7 job E-8 examples 12-21
See JDBC.
K
KB E-8 keywords, definition of E-8 kill command B-5
Index-6
Index
IP addresses 4-17 logging and messages 4-13 resource groups 4-1 resource migration 4-8 list privilege 8-11, A-5 load replay region E-8 loadmgr, description 6-9 Local Area Network See LAN local authentication 8-17 authentication methods about 8-4 commands 8-19 password requirements 8-17 log files query history 11-8 viewing B-6 log on authentication 8-17 invalid attempts 8-20 privilege 8-16 log, directory 1-4 logs, types of 6-12 actions 6-11 client 8-29 server 8-29 subdirectory 1-4
metadata E-8 migration, in HA 4-8 min/max values 9-15 minor release 6-2 mirror partition E-8 mirroring definition of E-8 primary set 5-19 mismatched definition of E-8 hardware 5-6 missing state 5-7, 6-4 mount commands 2-3 MTBF E-9 MTTR E-9 multi-stream backups 10-4
N
namespace E-9 NaN E-9 nested table E-9 NetBackup 10-31 configuring policy 10-32 integrating 10-33 Netezza definition of E-9 security model 8-8 starting 6-6 stopping 6-6 system states 6-4 uninstalling Windows tools 2-6 users and groups 8-1 Netezza clients UNIX, installing 2-2 UNIX, removing 2-4 Netezza Clients CD 2-1 Netezza command line interface 3-1 Netezza server, installing Windows tools 2-4 Netezza site certificate 2-10 Netezza system administrator account 1-2 Netezza Tools folder 2-5 Netezza Windows Client CD 2-4 Network Interface State Change event 7-36 NIC E-9 none state 5-7 nonrecoverable internal error 6-11 nonrepeatable reads E-9 normalization E-9 notifications for events 7-13 nps resource group cannot run 4-18 checking 4-6 contents 4-7 relocating to standby node 4-9 running on active host 4-6 safe shutdown 4-9 services 4-7 NTP server B-5 null E-9 numCpuCoreChanged event 7-37 numCpuCoreChanged event type 7-12
M
maintenance mode, transitioning to 4-10 major release 6-2 manage hardware privileges 8-10 manage system privileges 8-10 Mantra documentation, obtaining 14-3 Mantra Web interface 14-8 MantraVM service 14-1 changing IP configuration of 14-6 changing port monitoring 14-7 configuration of 14-4 disabling 14-5 enabling 14-5 hostname and IP address 14-2 internal IP and hostname 14-2 log files 14-2 management address 14-2 setting IP 14-6 starting 14-3 status of 14-4 stopping 14-3 user and group 14-2 version 14-5 mantravm user 14-2 master_db, database template 9-1 MB E-8 Mb E-8 Mean Time Between Failures. See MTBF Mean Time to Repair. See MTTR Megabit. See Mb. Megabyte. See MB. memory failure events 7-26 merge-sort E-8
Index-7
Index
numerics disk usage 9-2 nwIfChanged event type 7-12 nz definition of E-9 directory 1-3, 1-4 user 1-2, 1-4 nz directory 1-3 NZ_BNR_MGR_PORT environment variable 2-13 NZ_CLIENT_MGR_PORT environment variable 2-13 NZ_DATABASE, environment variable 10-13 NZ_DBMS_PORT environment variable 2-13 NZ_HOST, environment variable 2-14 NZ_PASSWORD, environment variable 2-15 NZ_USER, environment variable 2-14 NzAdmin Tool color indicators 3-13 definition of E-9 installing 2-4 introduction 3-10 nzadmin program 2-5 using hyperlinks 3-15 viewing, distribution 9-8, 9-11 NzAdmin tools uninstalling 2-6 nzbackup command command syntax 10-10 description 3-2, A-1, A-6 examples 10-14, 10-15 nzcontents command description 3-2, A-1, A-7 example 6-2, A-36 nzconvert command 3-2, A-1 nzconvertsyscase command A-55 nzdbg command A-54 nzDbosSpill, description 6-17 nzds command 3-2, A-2 description A-8 nzdumpcat command A-54 nzdumpmem command A-54 nzdumpschema command A-54 description A-57 nzdumptxjournal command A-55 nzevent command add example 7-7 adding 7-7 attributes 7-12 creating custom events 7-18 deleting 7-7 description 3-2, A-2, A-12 disabling 7-7 environment tags 7-15 generating 7-6 pre-installed event rules 7-1 setting disk thresholds 7-22 substitution tags 7-13 threshold example 7-23 nzhistcleanupdb command about 11-3 description 3-2, A-2 nzhistcleanupdb command description A-17 nzhistcreatedb command about 11-2
description 3-2, A-2 nzhistcreatedb command description A-19 nzhw command, description A-25 nzhw show command, arguments 5-2 nzinitsystem command description A-55 syntax A-58 nzload command description 3-3, A-2, A-31 nzloadcat command A-55 nzlogmerge command description A-54 syntax A-59 nzlogmerge.info command A-55 nzmakedatakit command A-55 nzpassword command 2-14, 3-3, A-2 nzpassword command, storing passwords 2-15 nzpassword, command A-31 nzpush command, description A-55 nzreclaim command A-2 description 3-3 nzresetxlog command A-55 nzresolv service 1-5 nzrestore command description 3-3, A-2, A-36 environment settings 10-25 overview 10-21 syntax 10-22 nzrev command 6-2 description 3-3, A-3, A-36 rev 6-1 nzscratch directory 1-3 nzsession command arguments 9-21 changing priority 12-21 description 3-3, A-3, A-37 examples 9-22 viewing 9-21 nzsqa command A-55 nzsql command description 3-3, A-3, A-42 managing database 3-7 managing transactions 9-22 ON_ERROR_STOP 3-9 resource control file 3-10 session history 3-9 sessions 9-21 slash commands 3-10 nzstart command arguments 6-6 description 3-3, A-3, A-42 nzstate command arguments 6-3 description 3-3, A-3 nzstats command _v_qryhist 9-28 _v_qrystat 9-28 Database Table 13-2 DBMS Group 13-3 description 3-4, A-3 Hardware Management Channel Table 13-9 Host CPU Table 13-3 Host Filesystem Table 13-4
Index-8
Index
Host Interfaces Table 13-4 Host Mgmt Channel Table 13-6 Host Network Table 13-7 Host Table 13-8 overview 13-1 Per Table Per Data Slice Table 13-10 Query History Table 13-11 Query Table 13-10 SPU Partition Table 13-12 SPU Table 13-13 System Group 13-13 Table Table 13-14 nzstop command arguments 6-6 description 3-4, A-3, A-49 example 6-6, 6-7 nzsystem command description 3-4, A-3 system configuration file A-51 nzvacuumcat, description 6-9
O
Object databases. See ODBs object privileges definition of E-9 description of 8-10 security model 8-8 ODBC definition of E-9 setting logs 8-29 ODBs E-9 offlining, system state 6-4 ok state 5-7 ON_ERROR_STOP 3-9 online state 5-7 online, system state 6-4, 6-10 Open Database Connectivity. See ODBC operators, runaway query 7-24 OrExpr event rule 7-13 organizing key 9-11 overserved group 12-13
P
pam_cracklib dictionary 8-6 pam_cracklib utilities 8-4 partition E-10 password admin user 1-2 authentication, local 8-17 clear-text 2-14 encrypted 2-14 nz user 1-2 NZ_PASSWORD 2-15 nzpassword command 2-14 specifying length 8-20 storing for Netezza users 2-15 password content controls 8-5 password expiration 8-4 PASSWORDEXPIRY setting 8-4 patch release 6-2
paused, system state 6-4 PDU E-10 Per Table Per Data Slice Table, nzstats 13-2, 13-10 permissions, backup 10-19 phantom read E-10 pingd command 4-2 plans, directory 1-4 Pluggable Authentication Module (PAM), for LDAP 8-4, 817 policy, configuring NetBackup 10-32 ports, numbers 2-13 POST E-10 postgres, description 6-10 PostgreSQL,definition of E-10 postmaster, description 6-10 Power Distribution Unit. See PDU. Power On Self Test. See POST preonline, system state 6-5 preonlining, system states 6-10 primary key E-10 primary partition E-10 primary set 5-19 prioritized query execution 12-11 about 12-19 priority assigning to jobs 12-19 example 12-21 jobs 12-11 levels 12-20 nzadmin tool A-41 privileges abort A-5 about 8-8 alter A-5 backup 10-13 client session 8-15, 8-16 create database A-4 create external table A-4 create materialized view A-4 create sequence A-4 create table 10-20 create temp table A-4 database statistic 8-15 delete A-5 displaying 8-13 drop A-5 Execute A-5 indirect 8-15 insert A-5 list A-5 log on 8-16 nzcontents A-6 nzrev A-6 nzstart A-6 nzstop A-6 object privileges 8-10 restore 10-25 select A-5 transaction 8-16 truncate A-6 update A-6 procedure, privilege 8-14 processes
Index-9
Index
displaying B-4 stopping on Linux B-5 ps command B-4 public group 1-2, 8-3 public views, system 8-29
Q
queries, short and long 12-4 query E-10 query history $hist_column_access.usage column, displaying 11-38 $hist_plan_epilog.status column, displaying 11-37 $hist_query_epilog.status column, displaying 11-37 $hist_table_access.usage column, displaying 11-37 about 11-1 alcloader process 11-7 batch directories 11-8 batches to load, finding 11-12 CONFIG-INFO file 11-8 configuration activating 11-6 altering 11-11 creating 11-5 dropping 11-12 planning 11-4 samples 11-5 showing 11-11 configuration overview 11-1 database 11-2 creating 11-3 dropping 11-4 granting access to 11-6 loading process overview 11-7 maintaining 11-3 delays in loading data 11-9 error directory 11-7 event notifications 11-13 FORMAT_COLUMN_ACCESS () function 11-38 FORMAT_PLAN_STATUS() function 11-37 FORMAT_QUERY_STATUS() function 11-37 FORMAT_TABLE_ACCESS() function 11-37 helper functions 11-36 helper functions example 11-38 latency of history data 11-2 load settings 11-8 loader settings matrix 11-8 loading area 11-7 LOADINTERVAL 11-8 LOADMAXTHRESHOLD 11-8 LOADMINTHRESHOLD 11-8 log directories 11-10 log files 11-8 staging area 11-7 stopping history collection 11-10 tables CLI usage 11-30 column access history 11-33 created session 11-24 end of query table 11-28 failed authentication attempts 11-23 log entries for operations 11-22
overflow of query string 11-29 plan history at beginning of plan 11-34 plan history at end of plan execution 11-36 schema version 11-21 session termination 11-26 source Netezza system 11-22 start of query data 11-26 state changes 11-31 table access history 11-32 tables and views 11-2 view naming conventions 11-15 views plan and session data 11-16 query data 11-15 views and user tables 11-15 query history events 7-31 Query History Table _v_qryhist 9-28 nzstats 13-2, 13-11 Query Table _v_qrystat 9-28 nzstats 13-2, 13-10
R
rack, definition of E-10 RAID E-10 random distribution, benefits 9-10 RDBMS E-10 real E-10 rebooting Linux B-3 record E-11 recoverable internal error 6-11 Red Hat 1-7 redirecting restore 10-36 referential integrity E-11 regen events 7-27 regenerate E-11 regeneration manual 5-17 mirroring 5-19 monitoring 5-18 regeneration setup failure 5-18 regenError event type 7-9 regenFault event type 7-11 relational database E-11 release descriptions 6-2 release level 6-2, B-6 remote access 1-7 resource groups, about 4-1 resource migration 4-8 resource sharing 12-2 restore A-5 examples 10-26 nzrestore 10-21 privilege 10-25 redirecting 10-36 step-by-step 10-30 syntax 10-22 restore privileges 8-10 restoring, backup 10-29 resuming, system states 6-10
Index-10
Index
rlogin, remote access 1-7 rollback, definition of E-11 root certificate 8-19 row E-11 rowid 9-3 rowset limit definition of E-11 specifying 8-27 values 8-27 rsh, remote access 1-7 runaway query events 7-24 runaway query, operators 7-24 runawayQuery event type 7-9 runCmd arguments 7-15
S
saturation E-11 sbin directory, contents 1-4 schema E-11 scsiDiskError event type 7-12 scsiPredictiveFailure event type 7-12 Secure Sockets Layer (SSL) protocols. SeeSSL. security invalid logons 8-20 managing 8-1 model 8-8 unlocking accounts 8-21 security privileges A-4 select definition of E-11 privilege 8-11, A-5 sendMail.cfg file 7-14 sendMail.cfg, event rule 1-4 sequences definition of E-11 privilege 8-15 Service Level Agreement E-11 service level planning 12-1 session E-11 sessionmgr, description 6-10 sessions definition 9-21 overview 10-19 viewing A-41 SET AUTHENTICATION command, using to set LDAP 818 SET HISTORY CONFIGURATION command 11-6 SFI, definition of E-12 share directory 1-4 postgres-specific 1-4 short query bias 12-4 settings 12-5 SHOW HISTORY CONFIGURATION command 11-11 shutdown B-3 significand E-12 Simple Network Management Protocol. See SNMP slash commands 3-10 smallint, integer type 9-2 SMART E-12 smartThreshold, event type 7-9
SMP Host E-12 snippet E-12 Snippet Processing Array See SPA Snippet Processing Unit See SPU snippet-level scheduling E-12 SNMP E-12 software version 6-1, B-6 SPA, definition of E-12 spare definition of E-12 hardware 5-6 split-brain, recovering from 4-15 SPU definition of E-12 managing 5-11 power up 6-11 SPU partition table 13-2 SPU table 13-2 SPU core events 7-34 SPU Partition Table, nzstats 13-2, 13-12 SPU Table, nzstats 13-2, 13-13 spuCore event type 7-11 SQL 1999 E-13 definition of E-13 SQL character set E-13 SQL collation E-13 SQL command CREATE TABLE AS 9-16 GENSTATS A-5 INSERT command 9-16 UPDATE command 9-16 SQL2 E-13 SQL3 E-13 SQL-92, definition of E-13 SSH, remote access 1-7 SSL about 8-21 certificate 8-21 configuration steps for LDAP 8-19 using to secure LDAP communications 8-19 SSL site certificate, for Web Admin 2-7 stage release 6-2 standby host, identifying 4-5 standby node, relocating to 4-9 startup.autoCreateDb setting D-1 startup.autoRestart setting D-1 startup.hostSwapSpaceLimit setting D-1 startup.maxConnections setting D-2 startup.maxRebootRetries setting D-2 startup.mismatchOverRide setting D-2 startup.noLock setting D-2 startup.noPad setting D-2 startup.numSpares setting D-2 startup.numSpus setting D-2 startup.overrideSpuDiskSize setting D-2 startup.overrideSpuRev setting D-2 startup.planCacheFiles setting D-2 startup.queryHistTblSize setting D-2 startup.runVirtSfi setting D-2 startup.simMode setting D-2
Index-11
Index
startup.spuSimMemoryMB setting D-2 startup.startupTimeout setting D-2 startup.stopNow setting D-2 startup.virtualDiskSize setting D-2 startupsvr, description 6-10 statistics automatic statistics 9-16 database tables 9-14 dispersion 9-16 Linux B-4 updating 9-14 statsmgr, description 6-10 statsSvr, description 6-10 stopped, system state 6-5 stored procedures, privileges 8-14 Structured Query Language. See SQL subminor release 6-2 SUDP E-13 superuser, Netezza 8-3 swap E-13 Switching Fabric Interface. See SFI Synchronous mirroring 4-2 sys, directory 1-4 system configuration files 1-4 sys/init, directory 1-4 sysHeatThreshold event type 7-10 sysmgr, description 6-10 sysmgr.checkDiskInterval setting D-3 sysmgr.devCountSpaOverheated setting D-3 sysmgr.eccCountFailover setting D-3 sysmgr.eccDurationFailover setting D-3 sysmgr.enableAutoFailover setting D-3 sysmgr.enableAutoRegen setting D-3 sysmgr.enableAutoReset setting D-3 sysmgr.enableBalanced Regen setting D-3 sysmgr.enableDiskFpgaFailover setting D-3 sysmgr.enAutoRestSpuForQdrFailure setting D-3 sysmgr.maxAggregateEventInterval setting D-4 sysmgr.maxRebootFreqPerHr setting D-4 sysmgr.numSpuPorts setting D-4 sysmgr.pausingStateTimeout setting D-4 sysmgr.pktReadCount setting D-4 sysmgr.resetTimeout setting D-5 sysmgr.sfiResetTimeout setting D-4 sysmgr.smartErrCountFailover setting D-5 sysmgr.smartErrDurationFailover, configuation file D-5 sysmgr.spuDumpTimeout setting D-5 sysmgr.spuPollReplyTimeout setting D-5 sysmgr.syncingStateTimeout setting D-5 sysmgr.testNoRegen setting D-5 sysStateChanged event type 7-8 system catalog E-13 default directory 9-1 errors B-4 logs 6-12 NzAdmin tool 3-12 system group table 13-2 views C-3 system administration, about 1-1 system administrator account 1-2 system configuration file description 6-17
nzsystem command A-51 System Group, nzstats 13-2, 13-13 system information views 8-31 system state change events 7-19 system states down 6-4 initialized 6-4 initializing 6-4, 6-10 nzstate command 6-3 offlining 6-4 online 6-4, 6-10 paused 6-4 pausing 6-5 preonline 6-5 preonlining 6-10 resuming 6-10 stopped 6-5 types 6-4 system temperature, events 7-30 system time, changing B-5 system.abortOnError setting D-10 system.allocateBuffersVirtual setting D-10 system.allowDiskHashJoin setting D-10 system.asyncSpu2HostRAW setting D-10 system.avoidSwapWDatamgrLock setting D-10 system.bcastSAW setting D-10 system.btOnError setting D-10 system.catch9752 setting D-10 system.cmdBcastNumReassembly setting D-10 system.CRCUpgraderErrorBufferLimit setting D-11 system.ctrlNumReassembly setting D-11 system.dataBcastRAW setting D-11 system.dbfs.LogBlockChanges setting D-11 system.dbfsASpaceLimit setting D-11 system.dbfsBSpaceLimit setting D-11 system.dbfsChangeLogSize setting D-11 system.dbfsErrorLogSize setting D-11 system.dbfsInUse setting D-11 system.dbfsMaxPermFiles setting D-11 system.dbfsMaxSwapGrowthPct setting D-11 system.dbfsMaxTempFiles setting D-11 system.dbfsSwapSpaceLimit setting D-11 system.dbosAggrWorkBlocks setting D-11 system.dbosSortWorkBlocks setting D-11 system.dbosWindowsAggrWorkBlocks setting D-11 system.disableBlockDataReadCRC setting D-11 system.disableBlockDataWriteCRC setting D-11 system.disableGlobalCRC setting D-11 system.disableMicroRegen setting D-12 system.disablePartialWriteRecovery setting D-12 system.disableSerialMirroring setting D-12 system.disableStrmNet setting D-12 system.disableStrmNetHost setting D-12 system.disableSwapCRC setting D-12 system.diskRewriterChunkSize setting D-12 system.diskRewriterEnabled setting D-12 system.diskRewriterFullRewritePeriod setting D-12 system.diskRewriterIdlePeriod setting D-12 system.diskRewriterRetryCount setting D-12 system.diskSmartPollInterval setting D-12 system.diskXferTimeout setting D-12 system.dumpDetail setting D-12 system.durableMirroring setting D-13
Index-12
Index
system.enableAckAggrLdrRotation setting D-13 system.enableClockSync setting D-13 system.enableJumboFrames setting D-13 system.enableMirrors setting D-13 system.enableResetLog setting D-13 system.enableSAWScheme setting D-13 system.errMgrWakeupInterval setting D-13 system.extentsPerCRCBurst setting D-13 system.failoverReadOnly setting D-13 system.fpgaBools setting D-13 system.fpgaDump setting D-13 system.fpgaFlags setting D-13 system.fpgaRecSizeIncrPct setting D-13 system.fpgaTotalBufSize setting D-13 system.funnelSAW setting D-14 system.funnelsPerNIC setting D-14 system.heatNotifyEnabled setting D-14 system.heatThresholdRearmInterval setting D-14 system.host2spuAckFrequency setting D-14 system.host2spuRAW setting D-14 system.host2spuRtxTimeout setting D-14 system.host2spuSAW setting D-14 system.host2spuSendWindow setting D-14 system.host2spuTransSkewKB setting D-14 system.hwmgrStaggerMicrosPerSpu setting D-14 system.jobSwapdAlertBlocks setting D-14 system.lockTracking setting D-14 system.maxActiveRegenBlks setting D-14 system.maxBcastMsgKB setting D-14 system.maxFlowCommChannels setting D-15 system.maxFunnelLdrKB setting D-15 system.maxRegenLoopCount setting D-15 system.maxSpringFieldSize setting D-15 system.maxSpuDistPlans setting D-15 system.maxStrmNetChannels setting D-15 system.maxStrmNetDist setting D-15 system.maxTransactions setting D-15 system.maxUnsolicitedReplies setting D-15 system.miniSpu2HostNumReassembly setting D-15 system.miniSpu2HostRAW setting D-15 system.mirroringNumReassembly setting D-15 system.mirroringRAW setting D-15 system.mirroringSAW setting D-15 system.nuclStackThreshold setting D-16 system.numNICs setting D-16 system.osnetrxOomTimeoutSecs setting D-16 system.pollInterval setting D-16 system.printSpuDbosMsgInfo setting D-16 system.realFpga setting D-16 system.recPtrMaxCfg setting D-16 system.regenAlmostDoneCount setting D-16 system.regenBadBlockEmailLimi setting D-16 system.regenBlocksPerCycle setting D-16 system.regenBreatherMs setting D-16 system.regenGenericCtrl setting D-16 system.regenMode setting D-16 system.regenOomRetryCount setting D-16 system.regenOomRetrySleepMs setting D-16 system.regenOomRetryThresholdSecs setting D-16 system.regenPriority setting D-16 system.regenRAW setting D-16 system.regenSAW setting D-16 system.regenSkipBadHeaderCheck setting D-16
system.regenTimeSlice setting D-16 system.rowIdChunkSize setting D-16 system.rtxTimeoutMillis setting D-16 system.rtxWakeupMillis setting D-17 system.secondsBetweenCRCBursts setting D-17 system.sfiCriticalTemperature setting D-17 system.sfiWarningTemperature setting D-17 system.spu2hostRAW setting D-17 system.spu2hostSAW setting D-17 system.spu2spuAckFrequency setting D-17 system.spu2spuRtxTimeout setting D-17 system.spu2spuSendWindow setting D-17 system.spu2spuTransSkewKB setting D-17 system.spuAbortBackTraceVerbosity setting D-17 system.spuAbortIfTxArrayFull setting D-17 system.spuAckThreshold setting D-17 system.spuCpuModel setting D-17 system.spuCriticalTemperature setting D-18 system.spuCtrlRAW setting D-18 system.spuDistBucketSize setting D-18 system.spuFecTxCompletionLimit setting D-18 system.spuHwClass setting D-18 system.spuJobBiasIntervalMs setting D-18 system.spuJobPrioBias setting D-18 system.spuMACMb setting D-18 system.spuMaxJobTasks setting D-18 system.spuMaxPktsOnWire setting D-18 system.spuMemoryMB setting D-18 system.spuMsgsOutstanding setting D-18 system.spuMTU setting D-18 system.spunetrxOomFatalTimeoutSecs setting D-18 system.spunetrxOomTimeoutSecs setting D-18 system.spuNonJobReservedBlocks setting D-18 system.spuPartitionSectorCountOverride setting D-19 system.spuPlanWorkBlocks setting D-19 system.spuRetransmitLoopTicks setting D-19 system.spuRetransmitResendTicks setting D-19 system.spuRetransmitTimeoutCycles setting D-19 system.spuRev setting D-19 system.spuRxDescPoolChunks setting D-19 system.spuSwapOrderMethod setting D-19 system.spuSwapPageAbandonments setting D-19 system.spuSwapSpaceConfigured setting D-19 system.spuSwapSpaceLimit setting D-19 system.spuSwapWriteRetries setting D-19 system.spuWarningTemperature setting D-19 system.tolderateOldCRC setting D-19 system.txIdChunkSize setting D-19 system.unicast2spuRAW setting D-19 system.useFpgaPrep setting D-20 system.virtabSingleMutex setting D-20 system.zoneMapJoinBytes setting D-20 system.zoneMapjoinThreshold setting D-20 system.zoneMapTableSizeThreshold setting D-20 systemStuckInState event type 7-10
T
Table Table, nzstats 13-2, 13-14 tables base tables 9-9, 9-10 definition of E-14
Index-13
Index
grooming 9-19 intra-session tables 9-9, 9-10 lock E-14 privilege 8-14 record header 9-3 special fields 9-3 table table 13-2 tuning 9-3 TB E-14 TCP/IP E-14 Telnet, remote access 1-7 temperature events hardware 7-29 system 7-30 template event rules 7-1 temporary table E-14 TFTP bootsvr 6-8 definitiion of E-14 power up 6-11 threshold disk space 7-22 example 7-23 time disk usage 9-2 time command B-7 time with time zone, data type 9-2 timeslice, definition of E-14 timestamp, temporal type 9-2 tls_cacertfile option 8-19 tls_cert option 8-19 tls_key option 8-19 tmp, directory 1-3 top command B-4 topology E-14 toporegen command, description A-55 TPC, definition E-14 transaction ID, overview 9-4 transaction objects monitoring 7-36 Transaction Processing Council. See TPC TransactionLimitEvent event 7-36 transactionLimitEvent event type 7-12 transactions definition of E-14 examples 9-22 managing 9-22 nzsql 9-22 privilege 8-16 system limit 12-21 truncate privilege 8-11, A-6
uninstalling Windows tools 2-6 UNIX Netezza clients installing 2-2 removing 2-4 unreachable state 5-7 update privilege 8-11, A-6 UPS E-14 user accounts encrypting passwords for 2-14 passwords, storing 2-15 User Datagram Protocol. See UDP user names, matching Netezza and LDAP 8-17 user privilege 8-14 useradd command B-1 users methods for managing 8-2 Netezza database 8-1 rowset limits 8-27 superuser, Netezza 8-3 unlocking 8-21 UTC E-14 UTF-8 E-14
V
vacuum analyze, see generate statistics varchar, data type 9-3 variables, environment 2-5 variant release 6-2 Veritas NetBackup 10-31 version, software 6-1 view command B-6 View, privilege 8-15 viewing sessions A-41 system logs 6-12 views _v_aggregate C-1 _v_database C-1 _v_datatype C-1 _v_function C-1 _v_group C-1 _v_groupusers C-1 _v_index C-1 _v_operator C-1 _v_qryhist 9-28 _v_qrystat 9-28 _v_relation_column C-2 _v_relation_column_def C-2 _v_sequence C-2 _v_session C-2 _v_sys_group_priv C-3 _v_sys_index C-3 _v_sys_priv C-3 _v_sys_table C-3 _v_sys_user_priv C-3 _v_sys_view C-3 _v_table C-2 _v_table_dist_map C-2 _v_table_index C-2 _v_user C-2 _v_usergroups C-2
U
UDP E-14 uname command B-6 underserved group 12-13 unfence A-5 unfence privileges 8-10 Unicode E-14 unicode collation E-14
Index-14
Index
_v_view C-2 definition of E-15 system 8-29, 8-31, C-3 voltage fault events 7-35
W
Web Admin interface directories and files 2-9 installing 2-6 server package 2-6 WildcardExpr event rule 7-13 window E-15 Windows tools 2-4 workload management about 12-1 admin user 12-9 compliance 12-13 compliance reports 12-15 features 12-2 gate keeper 12-21 GRA 12-6 overserved and underserved groups 12-13 PQE 12-19 priority 12-11 priority levels 12-20 resource percentages 12-8 resource sharing groups 12-8 SQB 12-4 workload, about 12-1
X
xinetd, remote access 1-7
Z
zone maps automatic statistics 9-16 definition of E-15 limit 9-18
Index-15
Index
Index-16