diff --git a/src/docbkx/book.xml b/src/docbkx/book.xml
index d7697765fb3..208fbf5e5c2 100644
--- a/src/docbkx/book.xml
+++ b/src/docbkx/book.xml
@@ -567,7 +567,7 @@ admin.enableTable(table);
Cardinality of ColumnFamiliesWhere multiple ColumnFamilies exist in a single table, be aware of the cardinality (i.e., number of rows).
- If ColumnFamilyA has 1000,000 rows and ColumnFamilyB has 1 billion rows, ColumnFamilyA's data will likely be spread
+ If ColumnFamilyA has 1 million rows and ColumnFamilyB has 1 billion rows, ColumnFamilyA's data will likely be spread
across many, many regions (and RegionServers). This makes mass scans for ColumnFamilyA less efficient.
diff --git a/src/docbkx/performance.xml b/src/docbkx/performance.xml
index 12b1d19d006..a8955ff21cc 100644
--- a/src/docbkx/performance.xml
+++ b/src/docbkx/performance.xml
@@ -353,6 +353,18 @@ Deferred log flush can be configured on tables via
+
+ Scan Caching in MapReduce Jobs
+ Scan settings in MapReduce jobs deserve special attention. Timeouts can result (e.g., UnknownScannerException)
+ in Map tasks if it takes longer to process a batch of records before the client goes back to the RegionServer for the
+ next set of data. This problem can occur because there is non-trivial processing occuring per row. If you process
+ rows quickly, set caching higher. If you process rows more slowly (e.g., lots of transformations per row, writes),
+ then set caching lower.
+
+ Timeouts can also happen in a non-MapReduce use case (i.e., single threaded HBase client doing a Scan), but the
+ processing that is often performed in MapReduce jobs tends to exacerbate this issue.
+
+ Scan Attribute Selection
diff --git a/src/docbkx/troubleshooting.xml b/src/docbkx/troubleshooting.xml
index 379728bbd7b..6a568233e0e 100644
--- a/src/docbkx/troubleshooting.xml
+++ b/src/docbkx/troubleshooting.xml
@@ -464,12 +464,14 @@ hadoop 17789 155 35.2 9067824 8604364 ? S<l Mar04 9855:48 /usr/java/j
For more information on the HBase client, see .
- ScannerTimeoutException
+ ScannerTimeoutException or UnknownScannerExceptionThis is thrown if the time between RPC calls from the client to RegionServer exceeds the scan timeout.
For example, if Scan.setCaching is set to 500, then there will be an RPC call to fetch the next batch of rows every 500 .next() calls on the ResultScanner
because data is being transferred in blocks of 500 rows to the client. Reducing the setCaching value may be an option, but setting this value too low makes for inefficient
processing on numbers of rows.
+ See .
+ Shell or client application throws lots of scary exceptions during normal operation