FAST Enterprise Crawler Guide

Transcription

FAST Enterprise Crawler Guide
FAST Enterprise Crawler
version:6.7
Crawler Guide
Document Number: ESP939, Document Revision: B, December 03, 2009
Copyright
Copyright © 1997-2009 by Fast Search & Transfer ASA (“FAST”). Some portions may be copyrighted
by FAST’s licensors. All rights reserved. The documentation is protected by the copyright laws of Norway,
the United States, and other countries and international treaties. No copyright notices may be removed
from the documentation. No part of this document may be reproduced, modified, copied, stored in a
retrieval system, or transmitted in any form or any means, electronic or mechanical, including
photocopying and recording, for any purpose other than the purchaser’s use, without the written
permission of FAST. Information in this documentation is subject to change without notice. The software
described in this document is furnished under a license agreement and may be used only in accordance
with the terms of the agreement.
Trademarks
FAST ESP, the FAST logos, FAST Personal Search, FAST mSearch, FAST InStream, FAST AdVisor,
FAST Marketrac, FAST ProPublish, FAST Sentimeter, FAST Scope Search, FAST Live Analytics, FAST
Contextual Insight, FAST Dynamic Merchandising, FAST SDA, FAST MetaWeb, FAST InPerspective,
NXT, FAST Unity, FAST Radar, RetrievalWare, AdMomentum, and all other FAST product names
contained herein are either registered trademarks or trademarks of Fast Search & Transfer ASA in
Norway, the United States and/or other countries. All rights reserved. This documentation is published
in the United States and/or other countries.
Sun, Sun Microsystems, the Sun Logo, all SPARC trademarks, Java, and Solaris are trademarks or
registered trademarks of Sun Microsystems, Inc. in the United States and other countries.
Netscape is a registered trademark of Netscape Communications Corporation in the United States and
other countries.
Microsoft, Windows, Visual Basic, and Internet Explorer are either registered trademarks or trademarks
of Microsoft Corporation in the United States and/or other countries.
Red Hat is a registered trademark of Red Hat, Inc.
UNIX is a registered trademark of The Open Group in the United States and other countries.
Linux is the registered trademark of Linus Torvalds in the U.S. and other countries.
AIX and IBM Classes for Unicode are registered trademarks or trademarks of International Business
Machines Corporation in the United States, other countries, or both.
HP and the names of HP products referenced herein are either registered trademarks or service marks,
or trademarks or service marks, of Hewlett-Packard Company in the United States and/or other countries.
Remedy is a registered trademark, and Magic is a trademark, of BMC Software, Inc. in the United States
and/or other countries.
XML Parser is a trademark of The Apache Software Foundation.
All other company, product, and service names are the property of their respective holders and may be
registered trademarks or trademarks in the United States and/or other countries.
Restricted Rights Legend
The documentation and accompanying software are provided to the U.S. government in a transaction
subject to the Federal Acquisition Regulations with Restricted Rights. Use, duplication, or disclosure of
the documentation and software by the government is subject to restrictions as set forth in FAR 52.227-19
Commercial Computer Software-Restricted Rights (June 1987).
Contact Us
Web Site
Please visit us at: http://www.fastsearch.com/
Contacting FAST
FAST
Cutler Lake Corporate Center
117 Kendrick Street, Suite 100
Needham, MA 02492 USA
Tel: +1 (781) 304-2400 (8:30am - 5:30pm EST)
Fax: +1 (781) 304-2410
Technical Support and Licensing Procedures
Technical support for customers with active FAST Maintenance and Support agreements, e-mail:
fasttech@microsoft.com
For obtaining FAST licenses or software, contact your FAST Account Manager or e-mail:
fastcsrv@microsoft.com
For evaluations, contact your FAST Sales Representative or FAST Sales Engineer.
Product Training
E-mail: fastuniv@microsoft.com
To access the FAST University Learning Portal, go to: http://www.fastuniversity.com/
Sales
E-mail: sales@fastsearch.com
Contents
Preface..................................................................................................ii
Copyright..................................................................................................................................ii
Contact Us...............................................................................................................................iii
Chapter 1: Introducing the FAST Enterprise Crawler.......................9
New features..........................................................................................................................10
Web concepts.........................................................................................................................10
Crawler concepts....................................................................................................................12
Enterprise Crawler Architecture.............................................................................................14
Configuring a crawl.................................................................................................................16
Where to begin?..........................................................................................................16
Where to go?...............................................................................................................17
How fast to crawl?.......................................................................................................18
How long to crawl?......................................................................................................18
Excluding pages in other ways....................................................................................19
External limits on fetching pages.................................................................................19
Removal of old content................................................................................................21
Browser Engine......................................................................................................................22
Chapter 2: Migrating the Crawler.....................................................23
Overview................................................................................................................................24
Storage overview....................................................................................................................24
Document storage.......................................................................................................24
Meta database.............................................................................................................25
Postprocess Database.................................................................................................25
Duplicate server database...........................................................................................25
Configuration and Routing Databases.........................................................................26
CrawlerGlobalDefaults.xml file considerations.......................................................................26
The Migration Process...........................................................................................................27
Chapter 3: Configuring the Enterprise Crawler..............................31
Configuration via the Administrator Interface (GUI)................................................................32
Modifying an existing crawl via the administrator interface..........................................32
Basic Collection Specific Options................................................................................33
Advanced Collection Specific Options.........................................................................35
Adaptive Crawlmode....................................................................................................49
Authentication..............................................................................................................52
Cache Sizes................................................................................................................53
5
FAST Enterprise Crawler
Crawl Mode.................................................................................................................53
Crawling Thresholds....................................................................................................54
Duplicate Server..........................................................................................................55
Feeding Destinations...................................................................................................56
Focused Crawl.............................................................................................................57
Form Based Login.......................................................................................................57
HTTP Proxies..............................................................................................................58
Link Extraction.............................................................................................................59
Logging........................................................................................................................59
POST Payload.............................................................................................................61
Postprocess.................................................................................................................61
RSS.............................................................................................................................61
Storage........................................................................................................................63
Sub Collections............................................................................................................63
Work Queue Priority....................................................................................................66
Configuration via XML Configuration Files.............................................................................67
Basic Collection Specific Options (XML).....................................................................67
Crawling thresholds.....................................................................................................87
Refresh Mode Parameters...........................................................................................89
Work Queue Priority Rules..........................................................................................89
Adaptive Parameters...................................................................................................91
HTTP Errors Parameters.............................................................................................93
Logins parameters.......................................................................................................94
Storage parameters.....................................................................................................96
Password Parameters..................................................................................................97
PostProcess Parameters.............................................................................................98
Log Parameters.........................................................................................................100
Cache Size Parameters.............................................................................................101
Link Extraction Parameters........................................................................................102
The ppdup Section....................................................................................................104
Datastore Section......................................................................................................105
Feeding destinations.................................................................................................105
RSS...........................................................................................................................107
Metadata Storage......................................................................................................108
Writing a Configuration File.......................................................................................109
Uploading a Configuration File..................................................................................110
Configuring Global Crawler Options via XML File................................................................110
CrawlerGlobalDefaults.xml options............................................................................110
Sample CrawlerGlobalDefaults.xml file.....................................................................113
Using Options.......................................................................................................................115
Setting Up Crawler Cookie Authentication.................................................................115
Implementing a Crawler Document Plugin Module....................................................118
Configuring Near Duplicate Detection.......................................................................125
Configuring SSL Certificates.....................................................................................127
Configuring a Multiple Node Crawler....................................................................................128
6
Removing the Existing Crawler..................................................................................128
Setting up a New Crawler with Existing Crawler........................................................128
Large Scale XML Crawler Configuration..............................................................................130
Node Layout..............................................................................................................130
Node Hardware.........................................................................................................131
Hardware Sizing........................................................................................................131
Ubermaster Node Requirements...............................................................................132
Duplicate Servers......................................................................................................132
Crawlers (Masters)....................................................................................................133
Configuration and Tuning...........................................................................................133
Duplicate Server Tuning.............................................................................................135
Postprocess Tuning....................................................................................................136
Crawler/Master Tuning...............................................................................................137
Maximum Number of Open Files...............................................................................141
Large Scale XML Configuration Template.................................................................141
Chapter 4: Operating the Enterprise Crawler................................147
Stopping, Suspending and Starting the Crawler..................................................................148
Starting in a Single Node Environment - administrator interface...............................148
Starting in a Single Node Environment - command line............................................148
Starting in a Multiple Node Environment - administrator interface............................148
Starting in a Multiple Node Environment - command line..........................................148
Suspending/Stopping in a Single Node Environment - administrator interface.........148
Suspending/Stopping in a Single Node Environment - command line......................149
Suspending/stopping in a Multiple Node Environment - administrator interface.......149
Suspending/stopping in a Multiple Node Environment - command line....................149
Monitoring.............................................................................................................................149
Enterprise Crawler Statistics.....................................................................................149
Backup and Restore.............................................................................................................153
Restore Crawler Without Restoring Documents........................................................154
Full Backup of Crawler Configuration and Data.........................................................154
Full restore of Crawler Configuration and Data.........................................................154
Re-processing Crawler Data Using postprocess.......................................................154
Single node crawler re-processing............................................................................155
Multiple node crawler re-processing..........................................................................156
Forced Re-crawling....................................................................................................156
Purging Excluded URIs from the Index.....................................................................156
Aborting and Resuming of a Re-process..................................................................156
Crawler Store Consistency...................................................................................................157
Verifying Docstore and Metastore Consistency.........................................................157
Rebuilding the Duplicate Server Database................................................................159
Redistributing the Duplicate Server Database.....................................................................160
Exporting and Importing Collection Specific Crawler Configuration.....................................161
Fault-Tolerance and Recovery..............................................................................................161
7
FAST Enterprise Crawler
Ubermaster................................................................................................................162
Duplicate server.........................................................................................................162
Crawler Node.............................................................................................................162
Chapter 5: Troubleshooting the Enterprise Crawler.....................163
Troubleshooting the Crawler.................................................................................................164
Reporting Issues.......................................................................................................164
Known Issues and Resolutions.................................................................................165
Chapter 6: Enterprise Crawler - reference information................169
Regular Expressions............................................................................................................170
Using Regular Expressions.......................................................................................170
Grouping Regular Expressions..................................................................................170
Substituting Regular Expressions..............................................................................171
Binaries................................................................................................................................171
crawler.......................................................................................................................171
postprocess...............................................................................................................174
ppdup.........................................................................................................................176
Tools.....................................................................................................................................178
crawleradmin.............................................................................................................178
crawlerdbtool.............................................................................................................185
crawlerconsistency....................................................................................................189
crawlerwqdump.........................................................................................................192
crawlerdbexport.........................................................................................................193
crawlerstoreimport.....................................................................................................194
Crawler Port Usage..............................................................................................................195
Log Files...............................................................................................................................196
Directory structure.....................................................................................................196
Log files and usage...................................................................................................197
Enabling all Log Files................................................................................................198
Verbose and Debug Modes.......................................................................................198
Crawler Log Messages..............................................................................................199
PostProcess Log........................................................................................................202
Crawler Fetch Logs....................................................................................................203
Crawler Fetch Log Messages....................................................................................204
Crawler Screened Log Messages.............................................................................207
Crawler Site Log Messages.......................................................................................209
8
Chapter
1
Introducing the FAST Enterprise Crawler
Topics:
•
•
•
•
•
•
New features
Web concepts
Crawler concepts
Enterprise Crawler Architecture
Configuring a crawl
Browser Engine
This chapter introduces the FAST Enterprise Crawler (EC), version 6.7, for use
with FAST ESP.
FAST Enterprise Crawler
New features
New features since EC 6.3:
•
•
•
•
Significant large-scale performance and robustness improvements. Through efficiency improvements and
the addition of new configuration variables to reduce or eliminate inter-node communications, a large-scale
web crawl of up to 2 billion documents can be supported with the crawler, with 25-30 million documents
on over 60 dedicated crawler hosts.
Multimedia enabled crawler.
Document evaluator plugin.
NTLM v1 server and digest authentication.
New features since EC 6.4:
•
Introduction of the Browser Engine, which enables more links to be extracted from:
•
•
•
•
•
•
JavaScript. By default the Browser Engine extracts most links, but the customizable preprocessors
and extractors allow even more links to be extracted.
Static Flash. By default links will be extracted from static flash (.swf) and flash video files (.flv)
IDNA support.
Authentication improvements. Full NTLM v1 support and improved form based authentication.
Operational improvements including new crawl modes and tools to verify crawler store consistency and
change the number of crawler nodes and duplicate servers.
Near duplicate detection to evaluate patterns in the content to identify duplicates.
No new features since EC 6.5 as it was never officially released.
New features since EC 6.6:
•
Comprehensive sitemap support, which includes:
•
•
•
•
•
•
•
•
•
•
•
•
•
•
Automatic detection of sitemaps, including support for robots.txt directive.
Support for storing/indexing metadata from sitemaps.
Obey sitemap access rules.
Sitemap enabling/disabling per subdomain.
Use the lastmod attribute to determine what pages require re-crawling (non-adaptive crawl mode only)
Use the priority and changefreq attributes to score documents in adaptive crawl mode.
Improved crawleradmin refetch and refeed options
Extended the crawleradmin verifyuri option to perform a more thorough verification
Passwords no longer stored or presented in plant text in exported crawler configurations
Postprocess supports auto-resume of the previous interrupted refeed
Improved flexibility in matching robots.txt user-agents through a regular expression
Configurable session cookie timeout
Support for overriding the Obey robots.txt setting in sub collections
Document plugins can now perfom limited logging to the fetch log
Web concepts
This section provides a list of definitions for terms that apply to the part of the Internet called the World Wide
Web (www).
10
Introducing the FAST Enterprise Crawler
Web server
A web server is a network application using the HyperText Transfer Protocol (HTTP) to
serve information to users. Human users utilize a client application called a browser to
request, transfer and display documents from the web server. The documents may be web
pages (encoded in HTML or XML markup languages), files stored on the web server's file
system in any number of formats (Microsoft Word or Adobe Acrobat PDF documents, JPEG
or other image files, MP3 or other audio files), or content generated dynamically based on
the user's request (e-commerce products, search results, or database lookup results).
The crawler responds to HTTP error codes. For extensive explanations of all HTTP/1.1
RFC codes, refer to the Hypertext Transfer Protocol -- HTTP/1.1 available at
http://www.ietf.org/.
Web site vs.
web server
A web site is a given hostname (for example, www.example.com), with an associated IP
address (or, sometimes, a set of IP addresses, generally if a site gets a lot of traffic), which
supports the HTTP protocol and serves content to user requests. A web server is the
hardware system corresponding to this hostname. Several web sites may share a given
web server, or even a single IP address.
Web page
A web page is the standard unit of content returned by a web server, which may be identified
by one or more URIs. It may represent the formatted output of a markup language (for
example, HTML or XML), or a document format stored on-disk (for example, Microsoft
Office, Adobe PDF, plain text), or the dynamic representation of a database or other archive.
In any case, the web server will return some header information along with the content,
describing the format of the contents, using the Internet Standard MIME type conventions.
Links
Web pages may contain references to other web pages, either on the same web server or
elsewhere in the network, called hyperlinks or simply links. These links are identified by
various internal formatting tags.
Uniform
Resource
Identifier (URI)
vs. Uniform
Resource
Locator (URL)
URI is overall namespace for identifying resources. URL is a specific type that include the
location of the resource (for example, a web page, http://www.example.com/index.html).
Encoded within this example are the network protocol (scheme, HTTP), the hostname and
implied port number, (www.example.com, port 80), and a specific path and page on that
server (/index.html). URI is the more general term, and is preferred. Extensive RFC 3986
details can be found at http://www.ietf.org/.
IDNA
Since normal DNS resolving doesn't support characters outside the ASCII scope of
characters, a hostname containing these special characters has to be translated into an
ASCII based format. This translation is defined by the Internationalizing Domain Names in
Applications (IDNA) standard.
An example of such a hostname would be www.blåbærsyltetøy.no . The DNS server
doesn't understand this name, so the host is registered as the IDN encoded version of the
host name: www.xn--blbrsyltety-y8ao3x.no. The Crawler will automatically translate these
host names to IDN encoded names before DNS lookup is performed. When working with
URIs that use special characters, please make sure the collection or the start uri files have
been stored using UTF-8 or similar encoding.
Extensive RFC 3490 details can be found at http://www.ietf.org/.
RSS
RSS is a family of web feed formats used to publish frequently updated digital content, such
as blogs, news feeds or podcasts. Users of RSS content use programs called feed readers
or aggregators. The user subscribes to a feed by supplying to their reader a link to the feed.
The reader can then check the user's subscribed feeds to see if any of those feeds have
new content since the last time it checked and if so, retrieve that content and present it to
the user.
The following RSS formats/versions are supported by the crawler:
•
RSS 0.9-2.0
11
FAST Enterprise Crawler
•
•
XML Sitemaps
ATOM 0.3 and 1.0
Channel Definition Format (CDF)
An XML Sitemap (also known as Google Sitemap) is an XML format for specifying the links
on the site, with associated meta data. This meta data includes the following per URI:
•
•
•
The priority (importance)
The change frequency
The time it as last modified
The crawler can be configured to download such sitemaps, and make use of this information
when deciding what URIs to crawl, and in what order, for a site.
In non-adaptive refresh mode the crawler uses the lastmod attribute to determine whether
a page has been modified since the last time the sitemap was retrieved. Pages that have
not been modified will not be recrawled in this crawl cycle.
In adaptive refresh mode the crawler will use the priority and changefreq attributes from
the sitemap to score (weight) a page. Thus, assuming that the sitemap has sane values,
the crawler will prioritize high priority content. The sitemap is only re-downloaded each
major cycle however.
See the Sitemap support configuration option for more information.
Crawler concepts
The crawler is a software application that gathers (or fetches) web pages from a network, typically a bounded
institutional or corporate network, but potentially the entire Internet, in a controlled and reasonably deterministic
manner.
The crawler works, in many ways, like a web browser to download content from web servers. But unlike a
browser that responds only the user's input via mouse clicking or keyboard typing, the crawler works from a
set of rules it must follow when requesting web pages, including how long to wait between requests for pages
(Request rate), and how long to wait before checking for new/updated pages (Refresh interval). For each
web page downloaded by the crawler, it makes a list of all the links to other pages, and then checks these
links against the rules for what hosts, domains, or paths it is allowed to fetch.
A brief description of the crawler's algorithm is that it will start by comparing the start URIs list against the
include and (if defined) exclude rules. Valid URIs are then requested from their web servers at a rate
determined by the specified request rate. If fetched successfully, the page is parsed for links, and information
about the page stored in the meta database, with the contents stored in the crawler store. The URIs from the
parsed links are each evaluated against the rules, fetched, and the process continues until all included content
has been gathered, or the refresh interval is complete.
Because of the many different situations in which the crawler is used, there are many different ways to adjust
its configuration. This section identifies some of the fundamental elements used to set up and control web
page collection:
12
Collection
Named set of documents to be indexed together in ESP, this also identifies the crawler's
configuration rules.
Storage
The crawler stores crawled content locally by default, to be passed to other ESP components
later. If there is too much data to store, or a one-time index build is planned, pages can be
deleted after having been indexed. It also builds a database of meta data, or details about
a web page, such as what pages link to it or if there are any duplicate copies.
Introducing the FAST Enterprise Crawler
Include rules Settings that indicate the hosts and/or URIs that may be fetched. These can be quite specific
such as a list of web servers or URIs, or general, for all the servers in one's network. It's
important to keep in mind that this only specifies what may be fetched, it does not define
where to start crawling (see start URIs list below).
Exclude rules Optional settings that prevent hosts and/or URIs from being fetched, because they would
otherwise match the include rules, but are not desired in the index.
Start URIs list
List of web pages (URIs) to be fetched first, from which additional links may be extracted,
tested against the rules, and added to work queues for subsequent fetch attempts. As each
is fetched, additional URIs on that site and others may be found. If there are URIs listed to
more sites in the start URIs list than the number of sites the crawler can connect to
simultaneously (Maximum number of concurrent sites configuration variable), then
some will remain queued until a site completes crawling, at which point a new site can be
processed.
The start URIs list is sometimes referred to as a seed URIs list or simply seed list.
Refresh
interval
Length of time the crawler will work before re-crawling a site to see if new or modified pages
exist. The behavior of the crawler during this period depends upon the refresh mode. If the
crawler is busy it will have work queues of pages yet to be fetched; the contents of the
existing work queues may either be kept and crawled during the next refresh cycle, or it may
be erased (scratched). In either case the start URIs are also added to the work queue.
In the adaptive mode the overall refresh interval is called the major cycle. The major cycle
is subdivided into multiple minor cycles, with goals and limits regarding the number of pages
to be revisited. This interval may be quite short, measured in hours or minutes, for "fresh"
data like news stories, but is more typically set as a number of days.
The refresh interval is sometimes referred to as the crawl cycle, refresh cycle or simply
refresh.
Request rate
The amount of time the crawler will "wait" after fetching a document before attempting another
fetch from the same web site. For flexibility, different rates (variable delay) can be specified
for different times of day, or days of the week. Setting this value very low can cause problems,
as it increases the activity of both the web sites and the crawler system, along with the
network links between them.
The request rate is sometimes referred to as the page request delay, request delay or
delay.
Concurrent
sites
The crawler is capable of crawling a large number of unique web sites, however only a
limited number of these can be crawled concurrently at any one time. Normally, the crawler
will crawl a site to completion before continuing on the next site. You can however limit the
amount of documents crawled from a single site by several means, see Excluding or limiting
documents below. This can be used to ensure the crawler eventually gets time to crawl all
the web sites it is configured to.
Crawl speed
Sometimes also referred to as crawl rate this is rate at which documents are fetched from
the web sites for a given collection. The highest possible crawl rate can be calculated from
the number of concurrent sites divided by the request rate. For example, if crawling 50
web sites with request rate of 10 (10 seconds "delay" between each fetch) the total maximum
achievable crawl rate will be 5 documents per second. However, if the network or web sites
are slow the actual crawl rate may be less.
Excluding or
Because the ultimate goal of crawling is indexing the textual content of web pages rather
limiting
than viewing a fully detailed web page (as with a browser), the standard configuration of the
documents
crawler includes some exceptions to the rules of what to fetch. A common example is
graphical content; JPEG, GIF and bitmap files are all excluded.
13
FAST Enterprise Crawler
There are several other controls that can be set to limit downloaded content. A per-page
size limit can be set, with another option to control what happens when the size limit is
exceeded (drop the page, or truncate it at the size limit). Another option, Maximum
documents per site, limits the number of pages downloaded from a given web site; helpful
if a large number of sites is being surveyed, and too many pages fetched from a "deep" site
would limit the resources available and starve other sites.
Level or hops This value indicates how many links have been followed from a start URI (Level 0) to reach
the current page. It is used in evaluating a crawl in which a DEPTH value has been specified.
For example, if the start URI http://www.example.com/index.html links to /sitemap.html
on the same site, from which a link to
http://www.example.com/test/setting/000/output_listing/three.txt is extracted,
this latter URI will be Level 2. The number of path elements is not considered in determining
the Level value. If you are running a DEPTH:0 crawl, the start URIs will be crawled, but
redirects and frame links will also be allowed. To strictly enforce a start URI only crawl,
specify DEPTH:-1 (minus-one).
Feed/refeed
The crawler will send fetched pages to FAST ESP in batches to be indexed, updated or
deleted, a process known as feeding. In normal operation it will automatically maintain the
synchronization between what pages exist on web sites and what pages are available in
the index.
Under some circumstances it may be necessary to rebuild the collection in the index, or
make major (bulk) changes in the contents. For example, a large number of deletions of
sites or pages no longer desired, or significant changes in the processing pipeline would
both require resending data to FAST ESP. In this case the crawler can be shut down and
postprocess run manually, a process known as re-feeding. After restarting the crawler, it will
continue to keep the index updated based on new pages fetched, or deleted pages
discovered.
Duplicate
documents
A web document may in some cases be represented by more than a single URI. In order to
avoid indexing the same document multiple times a mechanism known as duplicate detection
is used to ensure that only one copy of each unique document is indexed.
The crawler supports two ways of identifying such duplicates. The first method is to strip all
HTML markup and white space from the document, and then compute an MD5 checksum
of the resulting content. For non-HTML content such as PDFs the MD5 checksum is generated
directly from the binary content. Any documents sharing the same checksum are duplicate.
A variation on this method is the near duplicate detection, refer to the Configuring Near
Duplicate Detection on page 125 chapter for more information.
The set of documents with different URIs classified as duplicates will be indexed as one
document in the index, but the field 'urls' will contain multiple URIs pointing to this document.
Note: The crawler's duplicate handling will only apply within collections, not across.
Enterprise Crawler Architecture
The Enterprise Crawler is typically a component within a FAST ESP installation, started and stopped by the
Node Controller (nctrl). Internally the crawler is organized as a collection of processes and logical entities,
which in most cases run on a single machine. Distributing the processes across multiple hosts is supported,
allowing the crawler to gather and process a larger number of documents from numerous web sites.
Table 1: Crawler Processes
14
Introducing the FAST Enterprise Crawler
Binary
Function
crawler
Master/Ubermaster
uberslave
Uberslave/Slave
postprocess
Postprocess
ppdup
Duplicate Server
crawlerfs
File Server
In a single node installation the primary process is known as the master, and is implemented in the crawler
binary. It has several tasks, including resolving DNS names to addresses, maintaining the collection
configurations, and other "global" jobs. It also allocates sites to one of the uberslave processes.
The master is started (or stopped) by the node controller, and is responsible for starting and stopping the
other crawler processes. These include the uberslave processes (two by default), each of which creates
multiple slave entities.
The uberslave is responsible for creating the per-site work queues and databases; a slave is allocated to a
single site at any given time, and is responsible for fetching pages, directly or through a proxy, computing
the checksum of the page's content, storing the page to disk, and associated activities such as logging in to
protected sites.
The postprocess maintains a database of document content checksums, to determine duplicates (more
than one URI corresponding to the same data content), and is responsible for feeding batches of documents
to FAST ESP. Small documents are sent directly to the document processing pipelines, but larger documents
are sent with only a reference to the document; the file server process is responsible for supplying the
document contents to any pipeline stage that requests it.
Figure 1: Single Node Crawler Architecture
When the number of web sites, or total number of pages to be crawled, is large, the crawler can be scaled
up by distributing the processes across multiple hosts. In this configuration some additional processes are
required. An ubermaster is added, which takes on the role of DNS name/address resolution, centralized
logging, and routing URIs to the appropriate master node. Each master node continues to have a postprocess
locally, but each of these must now submit URI checksums to the duplicate server, which maintains a global
database of URIs and content checksums.
15
FAST Enterprise Crawler
Figure 2: Multiple Node Crawler Architecture
Refer to the FAST ESP Product Overview Guide, Basic Concepts chapter for FAST ESP search engine
concepts.
Configuring a crawl
The purpose of the crawler is to fetch the web pages that are desired for the index, so that users can search
for and find the information they need. This section introduces how to limit and guide the crawler in selecting
web pages to fetch and index, and describes the alternatives for what to do once the refresh interval has
completed.
In building an index it is important to include documents that have useful information that people need to find,
but it is also critical to exclude content that is repetitive or otherwise less useful. For example, the automated
pages of an on-line calendar system, with one page per day (typically empty), stretching off into the distant
future may not be useful. Keep this in mind when setting up what the crawler will, and will NOT, fetch and
process.
At a minimum, a crawl is defined by two key issues: where to begin, and where to go; also important are
determining how fast to crawl, and for how long.
Where to begin?
The start URIs list provides the initial set of URIs to web sites/pages for the crawler to consider. As each is
fetched it generates additional URIs to that site and other sites.
If there are URIs listed to more sites in the start URIs list than the number of sites the crawler can connect
to simultaneously (Maximum number of concurrent sites), then some remain pending until a site completes
crawling, at which point a new site can be processed. To prevent site starvation, the setting of Maximum
documents before interleaving can force a different site to be scheduled after the specified value of pages
are fetched.
16
Introducing the FAST Enterprise Crawler
Note: This can be expensive with regard to queue structure and the possibility of overflowing file system
limits. It is recommended that you thoroughly consider the implications on web scale crawls before
implementing this feature.
Where to go?
The first factor to consider is what web sites should be crawled. If given no limitations, no rules to restrict it,
the crawler will consider ANY URI to be valid. For most indexing projects, this is too much data.
Generally, an index is being built for a limited number of known web sites, identified by their DNS domains
or, more specifically, hostnames. For these sites, one or more start URIs is identified, giving the crawler a
starting point within the web site. An include rule corresponding to the start URI can be quite specific, for
example, an EXACT match for www.example.org, or it can be more general to match all websites in a given
DNS domain, for example, any hostname matching the SUFFIX .example.com.
Figure 3: Configuring a Crawl
A crawl configured with these include rules, and a start URI to match each one, would attempt to download,
store, and index all the pages available within the large circles shown in the illustration, corresponding to the
www.example.com network and the www.example.org web site.
It is often the case, though, that general rules such as these have specific exemptions, special cases of
servers or documents that must not be indexed. Consider the host hidden.example.com in Site A containing
documents that are not useful to the general public, or are otherwise deemed to be unworthy of indexing. To
prevent any pages from this site being fetched, the crawler can be configured with a rule to exclude from
consideration any URI with the EXACT hostname hidden.example.com. Another possibility is that only files
from a particular part of the web site should be avoided; in such a case an Exclude URI rule could be entered,
for example, any URI matching the PREFIX http://hidden.example.com/forbidden_fruit/.
As the crawler fetches pages and looks through them for new URIs to crawl, it will evaluate each candidate
URI against its configured rules. If a URI matches either an Include Hostname or Include URI filter rule, while
NOT matching an Exclude Hostname or Exclude URI filter rule, then it is considered eligible for further
processing, and possibly fetching.
17
FAST Enterprise Crawler
Note:
The semantics of URI and hostname inclusion rules have changed since ESP 5.0 (EC 6.3). In previous
ESP releases these two rule types were evaluated as an AND operation, meaning that a URI has to
match both rules (when rules are defined). As of ESP 5.1 and later (EC 6.6 and up), the rules processing
has changed to an OR operator, meaning a URI now only needs to match one of the two rule types.
Existing crawler configurations migrating from EC 6.3 must be updated, by removing or adjusting the
hostname include rules that overlap with the URI include rules.
Within a given site, you can configure the crawler to gather all pages (a FULL crawl), or limits can be set on
either the depth of the crawl (how many levels of links are followed), or an overall limit on the number of
pages allowed per site can be set (Maximum documents per site).
How fast to crawl?
Perhaps the key variable that affects how much work the crawler, the network, and the remote web sites
must do is the page Request rate. This value is determined by the delay setting, which indicates how long
the crawler should wait, after fetching a page, before requesting the next one.
For each active site, the overall page request rate will be a function of the Delay, the Outstanding page
requests setting, and the response time of the web site returning requested pages.
The crawler's overall download rate depends on how many active sites are busy. The number of uberslaves
per node can be modified, with a default of two and a maximum of eight.
When crawling remote sites that are not part of the same organization running the crawl, using the default
delay value of 60 seconds (or higher) is appropriate, so as not to burden the web site from which pages are
being requested. For crawlers within the same organization/network, lower values may be used, though note
that using very low values (for example, less than 5 seconds) can be stressful on the systems involved.
How long to crawl?
The Refresh interval determines the overall crawl cycle length; the period of time over which a crawl should
run without revisiting a site to see if new or modified pages exist.
Picking an appropriate interval depends on the amount of data to be fetched (which depends both on the
number of web sites, and how many web pages each contains) and the update rate or freshness of the web
sites.
In some cases, there are many web sites with very static/stable data, and a few that are updated frequently;
these can be configured as either separate collections, or given distinct settings through the use of a sub
collection.
The behavior of the crawler at the end of the crawl cycle depends upon the Refresh mode setting, the Refresh
when idle setting, and the current level of activity.
If the refresh cycle is long enough that all sites have been completely crawled, and the refresh when idle
parameter is "no", the crawler will remain idle until the refresh interval ends. If the refresh when idle parameter
is "yes", a new cycle will be started immediately. In the next cycle, the start URIs list is followed as in the first
cycle.
On the other hand, if the crawler is still busy, it will have work queues of pages yet to be fetched; in the default
setting (scratch), the work queues are erased, and the cycles begin "from scratch", just as in the first cycle.
Other options keep any existing work queues, and specify that the start URIs are to be placed at the end of
the work queue list (append), or at the front (prepend).
In the adaptive mode, the major cycle is subdivided into multiple micro cycles, with goals and limits regarding
the number of pages to be revisited in each of these. It works by maintaining a scaled score for each page
it retrieves, and this score is used to determine if a document should be re-crawled multiple times within a
major cycle. This mode is mainly useful when crawling large bodies of data. For instance, if a site that is being
crawled contains several million pages it can take, say, a month to completely crawl the site. If the "top" of
18
Introducing the FAST Enterprise Crawler
the site changes frequently and contains high quality information it may be useful for these pages to be
crawled more frequently than once a month. When in adaptive mode, the crawler will do exactly that.
Excluding pages in other ways
Because the ultimate goal of crawling in FAST ESP is indexing the textual content of web pages, rather than
viewing a fully detailed web page (as with a browser), the standard configuration of the crawler includes some
exceptions to the rules of what to fetch.
A common example is graphical content; JPEG, GIF and bitmap files are excluded. Links to audio or video
content are typically excluded to avoid downloading large amounts of content with no text content, although
special multimedia crawls may choose to include this content for further processing.
These restrictions can be implemented using either filename extensions (for example, any file that ends with
".jpg"), or via the Internet standard MIME type (for example, "image/jpeg"). Note that a MIME type screening
requires the crawler to actually fetch part of the document whereas an extension exclude can be performed
without any network access.
There are several other controls that can be set to limit downloaded content. A per-page size limit can be
set, with another option to control what happens when the size limit is exceeded (drop the page, or truncate
it at the size limit). Another option limits the number of pages downloaded from a given web site, helpful if a
large number of sites is being surveyed, and too many pages fetched from a "deep" site would limit the
resources available and starve other sites. It is also an option to exclude pages based on the header information
returned by web servers as part of the HTTP protocol.
External limits on fetching pages
Not every page that meets the crawler's configured rule set will be successfully fetched. In many cases, a
"trivial" crawl configured with a single start URI and a rule including just that one site will start, then suddenly
stop without any pages having been fetched.
This is generally an issue when the site itself has signaled that it does not wish to be crawled. This section
summarizes the ways that pages are NOT successfully crawled, and discuss how to recognize this situation.
The first fact to consider is that not all pages exist! Documents can be removed from a web server, and due
to the distributed nature of the web the links pointing to it may never disappear entirely. If such a "dead" link
is provided to the crawler, by either harvesting it off a fetched page or listed as a start URI, it will result in an
HTTP "404" error being returned by the remote web server, indicating "File Not Found". The HTTP status
codes are logged in the Crawler Fetch Logs.
Login Control
One common mechanism for limiting access to pages, by either crawlers or browsers, is to require a login.
Refer to Setting Up Crawler Cookie Authentication for more information.
Robots Control
Because the crawler (and programs similar to it, known collectively as "spiders" or "robots") collects web
pages automatically, repetitively fetching pages from a web site, some techniques have been developed to
give webmasters a measure of control over what can be fetched, and what pages can or cannot ultimately
be indexed. This section will review these techniques, the site-wide robots.txt file, and the per-page robots
META tags.
The primary tool available to webmasters is the Robots Exclusion Standard (http://www.robotstxt.org), or
more commonly known as the robots.txt standard. This was the first technique developed to organize the
growing number of web crawlers, and is a commonly implemented method of restricting, or even prohibiting,
crawlers from downloading pages. The way it works is that before a crawler fetches any page from a web
site, it should first request the page /robots.txt. If the file doesn't exist, there are no restrictions on crawling
documents from that server. If the file does exist, the crawler must download it and interpret the rules found
there. A webmaster can choose to list rules specific to the FAST crawler, in which case the robots.txt file
19
FAST Enterprise Crawler
would have an User-agent entry that matches what the crawler sends to identify itself, normally "FAST
Enterprise Crawler 6", though in fact any string matching any prefix of this, such as "User-agent: fast",
would be considered a match. In the most common case the webmaster can indicate that every crawler,
"User-agent: *", is restricted from gathering any pages on the site, via the rule "Disallow: /". Any site
blocked in this way is off-limits from crawling, unless the crawler is explicitly configured to override the block.
This should only be done with the knowledge and permission of the webmaster. The Crawler Screened
Log, which should be enabled for test crawls, would list any site blocked in this way with the entry DENY
ROBOTS.
The crawler supports some non-standard extensions to the robots.txt protocol. The directives are described
in the following table:
Table 2: robots.txt Directives
Extension
Comments
Allow:
This directive can override a Disallow: directive for a
particular file or directory tree.
Disallow:
This directive is defined to be used with path prefixes (for
example, "/samples/music/" would block any files from
that directory), some sites specify particular file types to
avoid(only excluding the extensions), such as Disallow:
/*.pdf$, and the crawler obeys these entries.
Crawl-delay: 120
This directive specifies the number of seconds to delay
between page requests. If the crawler is configured with
the Obey robots.txt crawl delay setting enabled (set to
Yes/True), this value will override the collection-wide Delay
setting for this site.
Example:
User-agent: *
Crawl-delay: 5
Disallow: /files
Disallow: /search
Disallow: /book/print
Allow: /files/ovation.txt
Another tool that can be used to modify the behavior of visiting crawlers is known as robots META tags. Unlike
the robots.txt file, which provides guidance for the entire web site, robots META tags can be embedded
within any HTML web page, within the "head" section. For a META tag of name "robots", the content value
will indicate the actions to take, or to avoid. While a page without such tags will be parsed to find new URIs
before being indexed, the possible settings can prevent either or both of these actions by a crawler. In the
following example, the page is being effectively blocked from further processing by any crawler that downloads
it.
Table 3: Robots META Tags Settings
20
Value
Crawler Action
index
Accept the page contents for indexing. (Default)
noindex
Do not index the contents of this page.
follow
Parse the page for links (URIs) to other pages (Default)
nofollow
Do not follow any links (URIs) embedded in this page
all
All actions permitted (equivalent to "index, follow")
none
No further processing permitted (equivalent to
"noindex,nofollow")
Introducing the FAST Enterprise Crawler
Example:
<html>
<head>
<meta name="robots" content="noindex,nofollow">
<meta name="description" content="This page ....">
<title>...</title>
</head>
.
.
.
<html>
Removal of old content
Over time the content on web sites change. Documents, and sometimes entire web sites, disappear and the
crawler must be able to detect this. At the same time, web sites may also be unavailable for periods, and the
crawler must be able to differentiate between these two scenarios.
The crawler has two main methods of detecting removed content, which should be removed from the index.
These two methods are broken links and document expiry.
As the crawler follows links from documents it will inevitably come across a number of links that are not valid,
i.e. the web server does not return a document but instead an HTTP error code. In some cases the web
server may not even exist any more. If the document is currently in the crawler document store, i.e. it has
been previously crawled, the crawler will take an appropriate action to either delete the document or retry the
fetch later.
The following table shows various HTTP codes and how they are handled by default. The action is configurable
per collection.
Table 4: HTTP error handling
Error
Action taken
400-499
Delete document immediately.
500-599
Delete document on 10th failed fetch attempt.
Fetch timeout
Delete document on 3rd failed fetch attempt.
Network error
Delete document on 3rd failed fetch attempt. First retry is performed immediately.
Internal error
Keep the document.
The method of detecting dead links described above works fine as long as the crawler locates links leading
to the removed content. It is also sufficient in the adaptive refresh mode, since the crawler will create a work
queue internally of all URIs it has previously seen and use that for re-crawling.
However when not using adaptive refresh, a second method is necessary in order to correctly handle situations
where portions of a site, or perhaps the entire web site, has disappeared from the web. In this case, the
crawler will most likely not discover links leading to each separate document. The method used in this case
is that of document expiry, usually referred to as DB switch in the crawler.
The crawler keeps track internally of all documents seen every refresh cycle. It is therefore able to create a
list of documents not seen for the last X cycles, where X is defined as the DB switch interval. Under the
assumption that the crawler is able to completely re-crawl every web site every crawl cycle, these documents
therefore no longer exist on the web servers. The action taken by the crawler on these documents is dependent
on the DB switch delete option. The default value of this option is No which instructs the crawler to not delete
them immediately, but rather place them on the work queue to verify that they are indeed removed from the
web sites in question. Every document found to be irretrievable is subsequently deleted. This is the
recommended setting, however it is also possible to instruct the crawler to immediately discard these
documents.
21
FAST Enterprise Crawler
Care should be taken when adjusting the DB switch interval and especially DB switch delete options.
Setting the former too low and using a brief refresh cycle can lead to a situation where the crawler incorrectly
interprets large numbers of documents as candidates for deletion. If then the DB switch delete option is set
to yes it is entirely possible for the crawler to accidentally delete a large portion of the crawler store and index.
Browser Engine
The Browser Engine is a stand alone component which is used by the Enterprise Crawler to extract information
from JavaScript and Flash files. The flow from the crawler to the Browser Engine and back is explained below.
Normal processing
If the crawler detects a document containing one or more JavaScript or Flash files and the corresponding
crawler option is enabled, the crawler submits the document to a Browser Engine for processing.
When the Browser Engine receives the request, it picks a thread from its pool of threads and assigns the
task to it.
If the file is a Flash file, it is parsed for links. However, if the document contains JavaScript, the Browser
Engine parses it, creates a DOM (document object model) tree and executes all inline JavaScript code. The
DOM tree is then passed to a configurable pipeline within the Browser Engine. This pipeline constructs a
HTML document, extracts cookies, generates a document checksum, simulate user interaction and extracts
links. Finally the data is returned to the crawler.
Some documents processed by the Browser Engine require external documents (dependencies), such as
scripts and frames. The Browser Engine will request these dependencies from the crawler, which in turn will
retrieve these as soon as possible. However, in order to reduce web server load the crawler still obeys the
configured request rate for each of these dependencies. Once the dependency is resolved a replay is sent
back to the Browser Engine. In other words the crawler will function as a download proxy for the Browser
Engine.
The crawler stores the processed HTML document, and sends it to the indexer. The crawler will also follow
links from the generated HTML document, provided the URIs are permitted according to the crawler
configuration.
Overloading
If the Browser Engine has no available capacity when receiving a processing request, it attempts to queue
the request. When the queue is full, the request is denied. The crawler automatically detects this situation
and will attempt to send the request to another Browser Engine, if one is available. If there are no others
available then the crawler uses an exponential back-off algorithm before resending the request, thus reducing
the load on the Browser Engine. This means that for each failed request it will wait a bit longer before trying
again. There is no upper limit on the number of retries.
A request to the Browser Engine is counted towards the maximum number of concurrent requests for the
web site. The maximum number of pending requests to the Browser Engines are thus limited by this
configuration option.
22
Chapter
2
Migrating the Crawler
Topics:
•
•
•
•
Overview
Storage overview
CrawlerGlobalDefaults.xml file
considerations
The Migration Process
FAST Data Search (FDS) 4.1 and FAST ESP 5.0, and related products, included
version 6.3 of the Enterprise Crawler (EC 6.3). If you are migrating an installation
of a previous release, and need to preserve the crawler data store, this chapter
outlines the necessary procedure. Refer to the FAST ESP Migration Guide for
additional overall migration information.
FAST Enterprise Crawler
Overview
FAST Data Search (FDS) 4.1, FAST ESP 5.0 and related products, included version 6.3 of the Enterprise
Crawler (EC 6.3). If you are migrating an installation from these releases, and need to preserve the crawler
data store, this chapter outlines the necessary procedure. Upgrading from FAST ESP 5.1 or 5.2 can be done
simply by preserving the crawler's data directory, as there are no changes to the storage backend between
EC 6.6 and EC 6.7. Refer to the FAST ESP Migration Guide for additional overall migration information.
The EC 6.7 document storage is backwards compatible with that of EC 6.3 and EC 6.4. but the meta data
store of EC 6.3 must be converted to be readable by the new version. More specifically, the meta data and
configuration databases have new options or formats, to which existing data must be adapted. The document
storage can be retained in the same format, or the format can be changed from flatfile to bstore with the
migration tool.
The overall migration process consists of stopping the EC 6.3 crawler, so that its data becomes stable, then
running an export tool in that installation to prepare the metadata for migration. In the new EC 6.7 installation,
an import tool is run that can read the EC 6.3 databases and exported metadata, and copy, create, or recreate
all necessary files.
Note:
The semantics of URI and hostname inclusion rules have changed since ESP 5.0 (EC 6.3). In previous
ESP releases these two rule types were evaluated as an AND, meaning that a URI has to match both
rules (when rules are defined). As of ESP 5.1 and later (EC 6.6 and up), the rules processing has changed
to an OR operator, meaning a URI now only needs to match one of the two rule types.
For example, an older configuration for fetching pages with the prefix http://www.example.com/public
would specify two rules:
•
•
include_domains: www.example.com (exact)
include_uris: http://www.example.com/public/ (prefix)
The first rule is no longer needed, and if not removed would allow any URI from that host to be fetched,
not only those from the /public path. Some configurations may be much more complex than this simple
example, and require careful adjustment in order to restrict URIs to the same limits as before. Contact
FAST Support for assistance in reviewing your configuration, if in doubt.
Existing crawler configurations migrating from EC 6.3 must be manually updated, by removing or
adjusting the hostname include rules that overlap with URI include rules.
Note: While the EC 6.4 configuration and database are compatible with EC 6.7, and do not require
special processing to convert them to an intermediate format, the import tool should still be used to copy
the old installation to the new location. The one special case that requires a conversion is when the EC
6.4 installation uses the non-standard ppdup_format value "hashlog". The migration tool will recognize
this case when copying an EC 6.4 installation, and automatically perform the conversion.
Storage overview
The crawler storage that is converted as part of the migration process is described in some detail in the
following sections.
Document storage
In a typical crawler installation, all downloaded documents are stored on disk, and the content is retained
even after having been sent to the search engine.
24
Migrating the Crawler
The two datastore formats supported in an EC 6.3 installation are flatfile and bstore. In the flatfile method
each downloaded URI is stored directly in the file system, with a base64 encoding of the URI used as the
filename. While this can be expensive in terms of disk usage, it does allow obsolete documents to be deleted
immediately.The alternative, bstore (block file storage), is more efficient in file system usage, writing documents
into internally indexed 16MB files, though these also require additional processing overhead in terms of
compaction.
Either bstore or flatfile may be specified when starting the import tool, allowing an installation to transition
from one format to another. If a new storage format is not specified, the setting in the configuration database
will be retained. Note that if your old data storage is in flatfile format, the migration process will be slower
than migrating a bstore data storage. It is suggested to specify the new crawler store to be in bstore format.
In either case, the number of clusters, that is the number of subdirectories across which the data is spread,
with a default value of eight, cannot be modified during migration.
The original document storage will not be touched in the export operation. During the import operation,
documents will be read from the old storage, and stored at its new location in the new format, one by one.
Again, the original version of the storage will not be modified.
Path: $FASTSEARCH/data/crawler/store/<collection>/data/<cluster>
Meta database
The meta databases contain meta information about all URIs visited by the crawler. Typical meta information
for a URI would include document storage location, content type, outgoing links, document checksum, referrers,
HTTP headers, and/or last modified date.
The metadata store consists of all the information available to it about the URIs that it is, or has been,
crawling. This information is organized into multiple databases that store the URIs and details about them,
primarily the metadata database and the postprocess database. If a given URI has been successfully
crawled, the metadata will also contain a reference to the document storage, a separate area where the
actual contents of the downloaded page is kept on disk, available to be fed to the search engine. The job of
the migration tool is to transfer, and if necessary update or convert, the crawler store from an earlier crawler
version so that it can be used by EC 6.7.
During the export operation, all the meta databases will be dumped to an intermediary format and placed in
the same directory as the original databases. The dumped versions of the databases will be given the same
filenames as the original databases, with the suffix .dumped_nn, where nn goes from 0 to the total number
of dump files. In the import operation, all the dumped postprocess databases are loaded and stored, one by
one, in the new postprocess database format. Optionally, each dump file can be deleted from the disk after
processing.
Path: $FASTSEARCH/data/crawler/store/<collection>/db/<cluster>/
Postprocess Database
The postprocess (PP) databases contain a limited amount of metadata for each unique checksum produced
by the postprocess process. For each item stored, it contains the checksum, the owner URI, duplicate URIs,
and redirects URIs.
During the import operation, all the EC 6.3 postprocess databases are copied to the new postprocess database
directory.
Path: $FASTSEARCH/data/crawler/store/<collection>/PP/csum/
Duplicate server database
Duplicate servers are only used in multiple node crawler setups. They are used to perform duplicate detection
across crawler nodes.
The duplicate server database format is unchanged between versions EC 6.3 and EC 6.7. In the import
operation, each database file is copied to the new duplicate server storage location.
25
FAST Enterprise Crawler
Path: $FASTSEARCH/data/crawler/ppdup/
Configuration and Routing Databases
The configuration database contains all the crawler-options set in a collection specification.
The difference between EC 6.3 and EC 6.4-6.7 is the removal of several obsolete options listed in the table
below:
Table 5: Obsolete Database Options
Option
Type
Comment
starturis (database cache size)
integer
Start URI database removed for 6.4
and later versions
starturis_usedb
boolean
Start URI database removed for 6.4
and later versions
Compressdbs
boolean
All databases compressed in 6.4 and
later versions
When the configuration database is imported, the database will be read and all valid options will be used.
Two potential modifications may also be made. If a proxy definition exists, it will be converted from a string
to a list element (as EC 6.6 and 6.7 supports multiple proxies), and if the data storage format is changed (via
import tool command line option) that configuration setting is updated.
Path: $FASTSEARCH/data/crawler/config/ (for crawler nodes)
Path: $FASTSEARCH/data/crawler/config_um/ (for ubermasters)
The routing database will be migrated on an ubermaster, in addition to the configuration database.The routing
database is not important in a single node installation, however in a multiple node installation, the routing
database defines to which crawler node each site is assigned.
Note:
The semantics of URI and hostname inclusion rules have changed since ESP 5.0 (EC 6.3). In previous
ESP releases these two rule types were evaluated as an AND, meaning that a URI has to match both
rules (when rules are defined). As of ESP 5.1 and later (EC 6.6 and up), the rules processing has changed
to an OR operator, meaning a URI now only needs to match one of the rule types.
For example, an older configuration for fetching pages with the prefix http://www.example.com/public
would specify two rules:
•
•
include_domains: www.example.com (exact)
include_uris: http://www.example.com/public/ (prefix)
The first rule is no longer needed, and if not removed would allow any URI from that host to be fetched,
not only those from the /public path. Note that more complex rules
Existing crawler configurations migrating from EC 6.3 must be manually updated, by removing the
hostname include rules that overlap with URI include rules.
Note: Be sure to manually copy any text or XML configuration files that might be used in the installation,
located outside of the data/config file system, such as a start_uri_files listing.
CrawlerGlobalDefaults.xml file considerations
If you are using a CrawlerGlobalDefaults.xml file in your configuration, note that some options have been
restructured from separate options in EC 6.3 into values within options and possibly renamed in EC 6.7.
There are no such changes between EC 6.6 and 6.7.
26
Migrating the Crawler
The following tables list options that have been restructured for the EC 6.7 CrawlerGlobalDefaults.xml
file as well as how they were identified in the EC 6.3 version of this file. You will need to manually edit the
CrawlerGlobalDefaults.xml file to use the new options.
Table 6: Domain Name System (DNS) Options Changes
EC 6.7 Option
EC 6.7 Description
dns
Refer to CrawlerGlobalDefaults.xml options on page 110 for
detailed dns descriptions. Valid values:
EC 6.3 Option
min_rate
MinDNSRate
max_rate
MaxDNSRate
max_retries
MaxDNSRetries
timeout
DNSTimeout
min_ttl
DNSMinTTL
db_cachesize
DNSCachesize
Table 7: Feeding Options Changes
EC 6.7 Option
EC 6.7 Description
feeding
Refer to CrawlerGlobalDefaults.xml options on page 110 for
detailed feeding descriptions. Valid values for the FDS
feeding options related to postprocess and its behavior
when submitting data to DataSearch are:
EC 6.3 Option
priority
DSPriority
feeder_threads
Not available
max_outstanding
DSMaxOutstanding
max_cb_timeout
DSMaxCBTimeout
max_batch_size
Not available
fs_threshold
Not available
The Migration Process
The migration process consists of running two separate programs; the export tool, and the import tool. The
export tool is run in the EC 6.3 environment and the import tool is run in the EC 6.7 environment. If migrating
an EC 6.4 installation, only the import tool need be run from the EC 6.7 environment. This proceedure is not
neccessary when going from EC 6.6 to 6.7.
•
•
The export tool dumps all of the EC 6.3 databases to an intermediate data format on disk. The files will
be placed alongside the original databases, named with the suffix .dumped_nn.
The import tool loads these dump files one by one, creates new databases and migrates the document
storage, and a new 6.7 crawler store will be created. This also includes the document store.
Note: Ensure that you have sufficient disk space to migrate your crawler store. This process requires
significant amounts of free disk space, both to hold the intermediate format, and to write the new (6.7)
formatted data. The migration tool does not remove the old crawler store, and the new crawler store
consumes approximately the same amour of disk space as the old one. Note that changing formats, for
example, bstore to flatfile, may result in an increase in disk usage.
To migrate the crawler:
1. Stop all crawler processes. Crawler processes include ubermaster, crawler, ppdup, and postprocess.
27
FAST Enterprise Crawler
$FASTSEARCH/bin/nctrl stop crawler
Make sure the FASTSEARCH environment variable points to the old ESP installation (the one being
migrated from).
2. Backup the crawler store, or as a minimum, backup the configuration database and files.
3. In an EC 6.3 installation, start the export tool. This example uses a crawler node with collection named
CollectionName:
$FASTSEARCH/bin/crawlerdbexport -m export -d /home/fast/esp50/data/crawler/ -g
CollectionName
Make sure the FASTSEARCH environment variable points to the old installation (the one being migrated
from).
Observe the log messages which are output by the export tool to monitor processing progress. If you are
running FAST ESP, the log messages will also appear under Logs in the administrator interface. Specifying
the "-l debug" option will give more detailed information, but is not necessary in most cases. If no error
messages are displayed, the export operation was successful. Skip this step if you are migrating an EC
6.4 installation.
Note: It is recommended to always redirect the stdout and stderr output of this tool to a log file on
disk. Additionally, on UNIX use either screen or nohup in order to prevent the tool from terminating
in case the session is disconnected.
4. Set the FASTSEARCH environment variable to correspond to the new ESP installation.
Refer to the FAST ESP Operations Guide, Chapter 1 for information on setting up the correct environment.
It is advisable to start the crawler briefly in the new ESP installation, to verify that it is operating correctly,
and then shut it down to prepare for migration.
5. Create all crawler collections in the new ESP installation, but leave data sources set to None:
a) Select Create Collection from the Collection Overview screen and the Description screen is
displayed.
b) Enter the Name of the collection to be migrated (matching the crawler collection name exactly), and
optional text for a description. This restores the original collection specification in the administrator
interface; when you start the crawler, the configuration will be loaded automatically and the crawl will
continue.
c) Proceed through the remaining steps to create a collection. Refer to the Creating a Basic Web Collection
in the Configuration Guide for a detailed procedure.
d) Leave the Data Source set to None, we will add the crawler once the collection has been migrated
below. Click submit.
6. Run the import tool.
$FASTSEARCH/bin/crawlerstoreimport -m import -d /home/fast/esp50/data/crawler/ -g
CollectionName -t master -n /home/fast/esp51/data/crawler/
Make sure the FASTSEARCH environment variable points to the new ESP installation (the one being
migrating to).
Observe the log messages which are output by the import tool to monitor processing progress. If you are
running FAST ESP, the log messages will also appear under Logs in the administrator interface. If no
error messages are displayed, the import operation was successful.
Note: In addition to migrating the crawler store, the import tool outputs statistics, sites, URIs and the
collection to separate files in the directory: $FASTSEARCH/data/crawler/migrationstats. Once
more, it is recommended to always redirect the stdout and stderr output of this tool to a log file on
disk. Additionally, on UNIX use either screen or nohup in order to prevent the tool from terminating
in case the session is disconnected.
28
Migrating the Crawler
7. Start the crawler from the administrator interface or the console.
8. Associate the crawler with the collection in the FAST ESP administrator interface:
a) Select Edit Collection from the Collection Overview screen and the Collection Details screen is
displayed.
b) Select Edit Data Sources from the Collection Details screen and the Edit Collection screen is
displayed.
c) When you identify the crawler as a Data Source, carefully read through the collection specification to
make sure everything is correct. Click submit.
9. To get the migrated documents into the new FAST ESP installation, you must run postprocess refeed,
which requires the crawler to be shut down. Stop the crawler:
$FASTSEARCH/bin/nctrl stop crawler
10. To start the refeed, enter the following command:
$FASTSEARCH/bin/postprocess -R CollectionName -d $FASTSEARCH/data/crawler/
11. When the feeding has finished, check the logs to make sure the refeed was successful. Restart the crawler:
$FASTSEARCH/bin/nctrl start crawler
12. Shut down the old FAST ESP installation.
Note: If this migration process is terminated during processing, you must repeat the entire procedure.
That is, delete all dump files and the new data directory generated by the tool. To delete all dumps, you
may run any of the tools with the deldumps option. When this cleanup process has finished, you must
manually delete the new data directory from the disk. Upon completion, repeat the entire migration
procedure. Contact FAST Technical Support for assistance.
Note: If only a subset of collections are migrated to the new version, the undesired collections will still
be listed in the new configuration database, even though no data or metadata for the collection has been
transferred. These lingering references must be deleted with the command crawleradmin -d
oldCollection prior to starting the crawler in the new ESP installation.
29
Chapter
3
Configuring the Enterprise Crawler
Topics:
•
•
•
•
•
•
Configuration via the
Administrator Interface (GUI)
Configuration via XML
Configuration Files
Configuring Global Crawler
Options via XML File
Using Options
Configuring a Multiple Node
Crawler
Large Scale XML Crawler
Configuration
This chapter describes how to limit and guide the crawler in selecting web pages
to fetch and index, and describes the alternatives for what to do once the refresh
interval has completed. It also describes how to modify an existing web data
source, and how to configure and tune a large scale distributed crawler.
FAST Enterprise Crawler
Configuration via the Administrator Interface (GUI)
Crawl collections may be configured using the administrator graphical user interface (GUI) or by using an
XML based file. The administrator interface includes access to most of the crawler options. However, some
options are only available using XML.
Modifying an existing crawl via the administrator interface
Complete this procedure to modify an existing crawl collection.
1. From the Collection Overview screen, click the Edit button for the collection you want to modify. The
following example selects collection1.
Note: The + Add Document function is not directly connected to the crawler, but rather attempts to
add the specified document directly to the index. This may cause problems if the document already
exists in the index and the crawler has found one or more duplicates to this document. In this case
the submitted document may appear as a duplicate in the Index because the crawler is not involved
in adding the document, so duplicate detection is not performed.
2. Click the Edit Data Sources button in the Control Panel and the following screen is displayed:
3. Click the Edit icon and the Edit Data Source Setup screen is displayed:
32
Configuring the Enterprise Crawler
4. Work through the basic and advanced options making modifications as necessary.
a) To add information, highlight or type information into the text box on the left, then click the
button and the selection is added to the text box on the right.
b) To remove information, highlight the information in the text box on the right, then click the
button and the selected text is removed.
add
remove
5. Click Submit and the Edit Collection collection1 Action screen is displayed. The modified data source
crawler is now installed.
6. Click ok and you are returned to the Edit Collection collection1 Configuration screen. The configuration
is now complete. This screen lists the name, description, pipeline, index, and data source information you
have configured for collection1.
7. Click ok and you are returned to the Collection Overview screen.
Basic Collection Specific Options
The following table discusses the Basic collection specific options.
Table 8: Basic collection specific options
Option
Start URIs
Description
Enter start URIs in the Start URIs box. There is also a Start URI files option, which if
specified must be an absolute path to a file existing on the crawler node. The format of
the file is a text file containing URIs, separated by newlines.
These options defines a set of URIs from which to start crawling. At least one URI must
be defined before any crawling can start. If the URI points to the root of a web site then
make sure the URI ends with a slash (/).
33
FAST Enterprise Crawler
Option
Description
As URIs are added, exact hostname include filters are automatically generated and added
to the list of allowed hosts in the Hostname include filters field. For example, if adding
the URI http://www.example.com/ then all documents from the web site at
www.example.com will be crawled.
Note: If the crawl includes any IDNA hostnames, they must be input using UTF-8
characters, and not in the DNS encoded format.
Hostname include filters
Specify filters in the Hostname include filters field to specify the hostnames (web sites)
to include in the crawl. Possible filter types are:
•
•
•
•
•
•
Exact - matches the identical hostname
File - identifies a local (to the crawler host) file containing include and/or exclude rules
for the configuration. Note that in a multiple node configuration, the file must be present
on all crawler hosts, in the same location.
IPmask - matches IP addresses of hostnames against specified dotted-quad or CIDR
expression.
Prefix - matches the given hostname prefix (for example, "www" matches
"www.example.com")
Regexp - matches the given hostname against the specified regular expression in
order from left to right
Suffix - matches the given hostname suffix (for example, "com" matches
"www.example.com")
This option specifies which hostnames (web sites) to be crawled. When a new web site
is found during a crawl, its hostname is checked against this set of rules. If it matches,
the web site is crawled. If no hostname or URI include filters (see below) are specified
then all web sites are allowed unless explicitly excluded (see below).
If rules are specified, a hostname must match at least one of these filters in order to be
crawled. For better crawler performance, use prefix, suffix or exact rules when possible
instead of regular expressions.
Note: If the crawl includes any IDNA hostnames, they must be input using UTF-8
characters, and not in the DNS encoded format.
Hostname exclude filters
Specify filters in the Hostname exclude filters field to exclude a specific set of hostnames
(web sites) from the crawl. The possible filter types are the same as for the Hostname
include filters.
This option specifies hosts you do not want to be crawled. If a hostname matches a filter
in this list, the web site will not be crawled. If no setting is given, no sites are excluded.
For better crawler performance, use prefix, suffix or exact rules when possible instead of
regular expressions.
Note: If the crawl includes any IDNA hostnames, they must be input using UTF-8
characters, and not in the DNS encoded format.
Request rate
Select one of the options in the Request rate drop-down menu; then select the rate in
seconds.
This option specifies how often (the delay between each request) the crawler should
access a single web site when crawling.
Default: 60 seconds
Note: FAST license terms do not allow a more frequent request rate setting than
60 seconds for external sites unless an agreement exists between the customer and
the external site.
34
Configuring the Enterprise Crawler
Option
Refresh interval
Description
Specify the interval at which a single web site is scheduled for re-crawling in the Refresh
interval field.
The crawler retrieves documents from web servers. Since documents on web servers
frequently change, are added or removed, the crawler must periodically crawl a site over
again to reflect this. In the default crawler configuration, this refresh interval is one day
(1440 minutes), meaning that the crawler will start over crawling a site every 24 hours.
Since characteristics of web sites may differ, and customers may want to handle changes
differently, the action performed at the time of refresh is also configurable, via the Refresh
modesetting.
Default: 1440 minutes
Advanced Collection Specific Options
This table describes the options in the advanced section of the administrator interface.
Table 9: Overall Advanced Collection Specific Options
Option
URI include filters
Description
This option specifies rules on which URIs may be crawled. Leave this setting empty in
order to allow all URIs, unless those excluded by other filters. The possible filter types
are the same as for the Hostname include filters.
The URI include filters field and the URI exclude filters field examine the complete URI
(http://www.example.com/path.html) so the filter must include everything in the
URI, and not just the path.
An empty list of include filters will allow any URI, as long as it is allowed by the hostname
include/exclude rules. For better crawler performance, use prefix, suffix or exact rules
when possible instead of regular expressions.
Note:
The semantics of URI and hostname inclusion rules have changed since ESP 5.0
(EC 6.3). In previous ESP releases these two rule types were evaluated as an AND,
meaning that a URI has to match both rules (when rules are defined). As of ESP 5.1
and later (EC 6.6 and up), the rules processing has changed to an OR operator,
meaning a URI now only needs to match one of the two rule types.
Existing crawler configurations migrating from EC 6.3 must be manually updated,
by removing or adjusting the hostname include rules that overlap with URI include
rules.
If the crawl includes any IDNA hostnames, they must be input using UTF-8 characters,
and not in the DNS encoded format.
URI exclude filters
This option specifies which URIs you do not want to be crawled. If a URI matches one
listed in the set, it will not be crawled. The possible filter types are the same as for the
Hostname include filters.
Note:
If the crawl includes any IDNA hostnames, they must be input using UTF-8 characters,
and not in the DNS encoded format.
Allowed schemes
This option specifies which URI protocols (schemes) the crawler should follow. Select the
protocol(s) you want to use from the drop-down menu.
Valid schemes: http, https, ftp and multimedia formats MMS, RTSP.
35
FAST Enterprise Crawler
Option
Description
Note: MMS and RTSP for multimedia crawl is supported via MM proxy.
Default: http, https
MIME types
This option specifies which MIME types will be downloaded from a site. If the document
header MIME type is different than specified here, then the document is not downloaded.
Select a MIME type you want to download from the drop-down menu. You can manually
enter additional MIME types directly as well.
That the crawler supports wildcard expansion of an entire field (only), for example
*/example, text/* or */*, but not appl/ms* is allowed. No other regular expressions
are supported.
Note: When adding additional MIME types beyond the two default types make sure
the corresponding file name extensions are not listed in the Extension excludes
list.
Default: text/html, text/plain
MIME types to search for
links
This option specifies MIME types of documents that the crawler should attempt to extract
links from. If not already listed in the default list, type in a MIME type you want to search
for links.
This option differs from the MIME types option in that the MIME types to search for
links denotes which documents should be inspected for links to crawl further, whereas
the latter indicates all formats the crawler should retrieve. In effect, MIME types is always
a superset of MIME types to search for links.
Note: Wildcard on type and subtype is allowed. For instance, text/* or */html
are valid. No other regular expressions are supported. Furthermore, the link extraction
within the crawler only works on textual markup documents, hence you should not
specify any binary document formats.
Default: text/vnd.wap.wml, text/wml, text/x-wap.wml, x-application/wml,
text/html, text/x-hdml
Extension excludes
This option specifies a list of suffixes (file name extensions) to be excluded from the crawl.
The extensions are suffix string matched with the path of the URIs, after first stripping
away any query portion. URIs that match the indicated file extensions will not be crawled.
If not already listed in the default list, type in the link extensions you want to be excluded
from the crawl. This option is commonly used to avoid unnecessary bandwidth usage
through the early exclusion of unwanted content, such as images.
Default: .jpg, .jpeg, .ico, .tif, .png, .bmp, .gif, .wmf, .avi, .mpg, .wmv, .wma,
.ram, .asx, .asf, .mp3, .wav, .ogg, .zip, .gz, .vmarc, .z, .tar, .iso, .img,
.rpm, .cab, .rar, .ace, .swf, .exe, .java, .jar, .prz, .wrl, .midr, .css, .ps,
.ttf, .mso
URI rewrite rules
This option specifies rewrite rules that allows the crawler to rewrite special URI patterns.
A rewrite rule is a grouped match regular expression and an expression that denotes how
the matched pattern should be rewritten. The rewrite expression can have references to
numbered groups in the match regexp, using regexp repetition.
URI rewrites are applied as the URIs are parsed out from the documents during crawling.
No rewriting occurs during re-feeding.
If you add URI rewrites after you have crawled the URIs you wanted to rewrite, you will
have to wait X (dbswitch) refresh cycles before they are fully removed from the index (they
are not crawled anymore). The rewritten ones are added in place as they are crawled. In
other words, there will be a time period in which both the rewritten and the not-rewritten
URIs may be in the index. Running postprocess refeed will not help, however you may
manually delete the URIs using the crawleradmin tool.
36
Configuring the Enterprise Crawler
Option
Description
Since URIs are rewritten as they are parsed out of the documents, adding new URI rewrites
would in some cases seem to not take immediate effect. The reason for this is that if the
crawler already has a work queue full of URIs that are not rewritten, it must empty the
work queue before it can begin to crawl the URIs affected by the rewrite rules.
The format is:
<separator><matched pattern><separator><replacement
string><separator>
The separator can be any single non-whitespace character, but it is important that the
separator is selected so that it does not occur in either the matched pattern or the
replacement string. The separator is given explicit as the first character of each rule.
This example is useful if a website generates new session IDs each time it is crawled
(resulting in an infinite number of links over time), but that pages will be displayed correctly
without this session ID.
@(.*[&?])session_id=.*?(&|$)(.*)@\1\3@
The @-character is the separator.
Considering the URI
http://example.com/dynamic.php?par1=val1&session_id=123456789&par2=val2
the rewrite rule above would rewrite the URI to
http://example.com/dynamic.php?par1=val1&par2=val2
Default: empty
Start URI files
This option specifies a list of one or more Start URI files for the collection to be configured.
Each file must be an absolute path/filename on the crawler node.
A Start URI file is specified as the absolute path to a text file (for example,
C:\starturifile.txt). The format of the files is one URI per line.
All entries in the start URI files must match the Hostname include filters or the URI
include filters or they will not be crawled.
Default: empty
Mirror site files
Map file of primary/secondary servers for a site.
This parameter is a list of mirror site files for the specified web site (hostname). The file
format is a plain text, whitespace-separated list of hostnames, with the preferred (primary)
hostname listed first.
Format example:
www.fast.no fast.no
www.example.com example.com
mirror.example.com
Note: In a multiple node configuration, the file must be available on all masters.
Default: empty
Extra HTTP Headers
This option specifies any additional headers to send to each HTTP GET request to identify
the crawler. When crawling public sites not owned by the FAST ESP customer, the HTTP
header must include a User-Agent string which must contain information that can identify
the customer, as well as basic contact information (email or web address).
Format: <header field>:<header value>
37
FAST Enterprise Crawler
Option
Description
Specifying an invalid value may prevent documents from being crawled and prevent you
from viewing/editing your configuration.
The recommended User-Agent string when crawling public web content is <Customer
name> Crawler (email address / WWW address). User agent information
(company and E-mail) suitable for intranet crawling is by default added during installation
of FAST ESP.
Default: User-Agent: FAST Enterprise Crawler 6 used by <example.com>
(user@example.com)
Refresh mode
These refresh modes determine the actions taken by the crawler when a refresh occurs.
Although no refreshes occur when the crawler is stopped, the time spent is still taken into
consideration when calculating the time of the next refresh. Thus, if the refresh period is
set to two days and the crawler is stopped after one day and restarted the next day, it will
then refresh immediately since two days have elapsed.
Refresh is on a per site (single hostname) basis. Even though Start URIs are fed at a
specific (refresh) interval by the master, each site keeps a record of the last time it was
refreshed. Since sites are scheduled randomly based on available resources/URIs, the
site refreshes quickly get desynchronized with the master Start URI feeding interval.
Refresh modes other than Scratch and Adaptive do not erase any existing queues at
the time of refresh. If the site(s) being crawled generate an infinite amount of URIs, or the
crawl is very loosely restricted, this may lead to the crawler work queues growing infinitely.
Valid modes:
•
•
•
•
•
Append - the Start-URIs are added to the end of the crawler work queue at the start
of every refresh. If there are URIs in the queue, Start URIs are appended and will not
be crawled until those before them in the queue have been crawled.
Prepend - the Start URIs are added to the beginning of the crawler work queue at
every refresh. However, URIs extracted from the documents downloaded from the
Start URIs will still be appended at the end of the queue.
Scratch - the work queue is truncated at every refresh before the Start URIs are
appended. This mode discards all outstanding work on each refresh event. It is useful
when crawling sites with dynamic content that produce an infinite number of links.
This is useful when sites generate an infinite number of links, as sometimes seen for
sites with dynamic content.
Soft - if the work queue is not empty at the end of a refresh period, the crawler will
continue crawling into the next refresh period. A server will not be refreshed until the
work queue is empty. This mode allows the crawler to ignore the refresh event for a
site if it is not idle. This allows large sites to be crawled in conjunction with smaller
sites, and the smaller sites can be refreshed more often than the larger sites.
Adaptive - build work queue according to scoring of URIs and limits set by adaptive
section parameters.
Default: Scratch
Automatically refresh when
This option allows you to specify whether the crawler automatically should trigger a new
idle
refresh cycle when the crawler goes idle (all websites are finished crawling) in the current
refresh cycle.
Select Yesto automatically refresh when idle.
Select No to wait the entire refresh cycle length.
Default: No
Note: This option cannot be used with a multi node crawler.
38
Configuring the Enterprise Crawler
Option
Max concurrent sites
Description
This option allows you to limit the maximum number of sites being crawled concurrently.
The value of this option, together with the request rate, controls the aggregated crawl-rate
for your collection. A request rate of 1 document every 60 seconds, crawling 128 sites
concurrently yields a theoretical crawl-rate of about 2 (128/60) documents per second.
This option also impacts CPU usage and memory consumption; the more sites crawled
concurrently, the more CPU and memory will be used. It is recommended that values
higher than 2048 is used cautiously.
In a distributed setup, the value applies per crawler node.
Default: 128
Max document count per
site
This option sets the maximum amount of documents (web pages) to download from a
web site per refresh cycle. When this limit is reached any remaining URIs queued for the
site will be erased, and crawling of the site will go idle.
Note: The option only restricts the per-cycle count of documents, not the number
of unique documents across cycles. Therefore it's possible for a web site to exceed
this number in stored documents if the documents found each cycle changes. Over
time, the excess documents will however be removed by the document expiry
functionality (DB switch interval setting).
Default: 1000000
Max document size
This option sets the maximum size of a single document retrieved from any site in a
collection. If this limit is exceeded, the remaining documents are discarded or truncated
to the indicated maximum size (see the Discard or truncate option).
If you have large documents (for example, PDF files) on your site, and want to index
complete documents, make sure that this option is set high enough to handle the largest
documents in the collection.
Default: 5000000 bytes
Discard or truncate
This option discards or truncates documents exceeding the maximum document count
size determined in the previous entry.
It is not recommended to use the truncate option except for text document collections.
Valid values: Discard, Truncate
Default: Discard
Checksum cut-off
When crawling multimedia content through a multimedia proxy (schemes MMS or RTSP),
use this setting to adjust how the crawler determines whether a document has been
modified or not. Rather than downloading the entire document, only the number of bytes
specified in this setting will be transferred and the checksum calculated on that initial
portion of the file. Only if the checksum of the initial bytes have changed is the entire
document downloaded.
This saves bandwidth after the initial crawl cycle, and reduces the load on other system
and network resources as well. A setting of 0 will disable this feature (checksum always
computed on entire document).
Default: 0
Fetch timeout
This setting specifies the time, in seconds, that the download of a single document is
allowed to spend, before being aborted.
Set this value higher if you expect to download large documents from slow servers, and
you observe high average download times in the crawler statistics reported by the
crawleradmin tool.
39
FAST Enterprise Crawler
Option
Description
Valid values: Positive integer
Default: 300 seconds
Obey robots.txt
A robots.txt file is a standardized way for web sites to direct a crawler (for example,
to not crawl certain paths or pages on the site). If the file exists it must be located on the
root of the web site, e.g. http://www.example.com/robots.txt, and contain a set
of Allow/Disallow directives.
This setting specifies whether or not the crawler should follow the directives in robots.txt
files when found.
If you do not control the site(s) being crawled, it is recommended that you use the default
setting and obey these files.
Select Yes to obey robots.txt directives.
Select No to ignore robots.txt directives.
Default: Yes
Check meta robots
A meta robots tag is a standardized way for web authors and administrators to direct the
crawler not to follow links or to save content from a particular page; it indicates whether
or not to follow the directives in the meta-robots tag (noindex or nofollow).
This option allows you to specify whether or not the crawler should follow such rules. If
you do not control the site(s) being crawled, it is recommended that you use the default
setting.
Select Yes to obey meta robots tags.
Select No to ignore meta robots tags.
Example (HTML):
<META name="robots" content="noindex,nofollow">
Default: Yes
Ignore robots on timeout
Before crawling a site, the crawler will attempt to retrieve a robots.txt file from the
server that describes areas of the site that should not be crawled.
If you do not control the site being crawled, it is recommended that you use the default
setting.
This option specifies what action the crawler should take in the event that it is unable to
retrieve the robots.txt file due to a timeout, unexpected HTTP error code (other than
404) or similar. If set to ignore then the crawler will proceed to crawl the site as if no
robots.txt exists, otherwise the web site in question will not be crawled.
Select Yesto obey robots on timeout.
Select No to ignore robots on timeout.
Default: No
Ignore robots auth sites
This option allows you to control whether the crawler should crawl sites returning 401/403
Authorization Required for their robots.txt from the crawl. The robots.txt standard
lists this behavior as a hint for a crawler to ignore the web site altogether. However,
incorrect configuration of web servers is widespread and can lead to a site being
erroneously excluded from the crawl. Enabling this option makes the crawler ignore such
indications and crawl the site anyway.
Default: Yes
40
Configuring the Enterprise Crawler
Option
Obey robots.txt crawl delay
Description
This parameter indicates whether or not to follow the Crawl-delay directive in robots.txt
files. In a site's robots.txt file, this non-standard directive may be specified (e.g.
Crawl-Delay: 120, where the numerical value is the number of seconds to delay
between page requests. If this setting is enabled, this value will override the collection-wide
request rate (delay) setting for this web site.
Default: No
Robots refresh interval
This option allows you to specify how often (in seconds) the crawler will re-download the
robots.txt file from sites, in order to check if it has changed. Note that the robots.txt
file may be retrieved less often if the site is not crawling continuously. the refresh interval
of robots.txt files.The time period is on a per site basis and after it expires the robots.txt
file will be downloaded again and the rules will be updated.
Reduce this setting to pick up robots changes more quickly, at the expense of network
bandwidth and additional web server requests.
Default: 86400 seconds (24 hours)
Robots timeout
Before crawling a site, the crawler will attempt to retrieve a robots.txt file from the
server that describes areas of the site that should not be crawled.
This option allows you to specify the timeout to apply when attempting to retrieve
robots.txt files. Set this value high if you expect to have comparably slow interactions
requesting robots.txt.
Default: 300
Near duplicate detection
This option indicates whether or not to use the near duplicate detection scheme. This
option can be specified per sub collection.
Refer to Configuring Near Duplicate Detection on page 125 for more information.
Default: No (disabled)
Perform duplicate
detection?
This parameter indicates whether document duplicate detection should be enabled or not.
Default: Yes
Use HTTP/1.1
This option allows you to specify whether you want to use HTTP 1.1 or HTTP 1.0 requests
when retrieving web data. HTTP/1.1 is required for the crawler to accept compressed
documents from the server (the Accept Compression option) and enable ETag support
(Send If-Modified-Since option).
Select Yes to crawl using HTTP/1.1.
Select No to crawl using HTTP/1.0.
When using cookie authentication there may be instances where HTTP/1.1 is not supported
and you should select No.
Default: Yes
Send If-Modified-Since
If-Modified-Since headers allow bandwidth to be saved, as the web server only will
send a document if the document has changed since the last time the crawler retrieved
it. Also, if web servers report an ETag associated with a document, the crawler will set
the If-None-Match header when this setting and HTTP/1.1 is enabled.
Select Yes to send If-Modified-Since headers.
Select No to not send If-Modified-Since headers.
Web servers may give incorrect information whether or not a document has been modified
since the last time the crawler retrieved it. In those instances select No to allow the crawler
41
FAST Enterprise Crawler
Option
Description
to decide whether or not the document has been modified instead of the web server, at
the expense of increased bandwidth usage.
Default: Yes
Accept compression
Specify whether the crawler should use the Accept-Encoding header, thus accepting
that the documents are compressed at the web server before returned to the crawler. This
may save bandwidth.
This option only applies if HTTP/1.1 is in use.
Select Yes to accept compressed content.
Select No to not accept compressed content.
Default: Yes
Send/receive cookies
This feature enables limited support for cookies in the crawler, which might enable crawling
cookie-based sessions for a site. Some limitations apply, mainly that cookies will only be
visible across web sites handled within the same uberslave process.
Note: Note that this feature is unrelated to cookie support as described in the Form
Based Login on page 57 section.
Select Yes to enable cookie support.
Select No to disable cookie support.
Default: No
Extract links from
duplicates
Even though two documents have duplicate content, they may have different links. The
reason for this is that all markup, including links, is stripped from the document prior to
generating a checksums for use by the duplicate detection algorithm.
This option lets you specify whether or not you want the crawler to extract links from
documents detected as duplicates. If enabled, you may get an increased amount of
duplicate links in the URI-queues. If duplicate documents contain duplicate links then you
can disable this parameter.
Note: Even though duplicate URIs exist on the work queues, a single URI is only
downloaded once each refresh cycle.
Select Yes to extract links from documents that are duplicates.
Select No to not extract links from documents that are duplicates.
Default: No
Macromedia Flash support
Select Yes to enable retrieval of Adobe Flash files, and limited link extraction within these.
The flash files are indexed as separate files within the searchable index.
Select No to disable Adobe Flash support.
You may also want to enable JavaScript support, as many web servers only provide Flash
content to clients that support JavaScript.
Note: Flash processing is resource intensive and should not be enabled for large
crawls.
Note: Processing Macromedia Flash files requires an available Browser Engine.
Please refer to the FAST ESP Browser Engine Guide for more information.
Default: No
42
Configuring the Enterprise Crawler
Option
Sitemap support
Description
Enabling this option allows the crawler to detect and parse sitemaps. The crawler support
sitemap and sitemap index files as defined by the specification at
http://www.sitemaps.org/protocol.php.
The crawler uses the 'lastmod' attribute in a sitemap to see if a page has been modified
since the last time the sitemap was retrieved. Pages that have not been modified will not
be recrawled. An exception to this is if the collection uses adaptive refresh mode. In
adaptive refresh mode the crawler will use the 'priority' and 'changefreq' attributes of a
sitemap in order to determine how often a page should be crawled. For more information
see Adaptive Crawlmode on page 49.
Custom tags found in sitemaps are stored in the crawlers meta database and can be
submitted to document processing.
Note: Most sitemaps are specified in robots.txt. Thus, 'obey robots.txt' should be
enabled in order to get the best result.
Default: No
JavaScript support
Select Yes to enable JavaScript support. The crawler will execute JavaScripts embedded
within HTML documents, as well as retrieve and execute external JavaScripts.
Select No to disable JavaScript support.
Note: JavaScript processing is resource intensive and should not be enabled for
large crawls.
Note: Processing JavaScript requires an available Browser Engine.
Please refer to the FAST ESP Browser Engine Guide for more information.
Default: No
JavaScript keep original
HTML
Specify whether to submit the original HTML document, or the HTML resulting from the
JavaScript parsing, to document processing for indexing.
When parsing a HTML document the Browser Engine executes all inlined and external
JavaScripts, and thereby all document.write() statements, and includes these in its
HTML output. By default it is this resulting document that is indexed. However it is possible
to use this feature to limit the Browser Engine to link extraction only.
This option has no effect if JavaScript crawling is not enabled
Default: No
JavaScript request rate
Specify the request rate (delay) in seconds to be used when retrieving external JavaScripts
referenced from a HTML document. By default this rate is the same as the normal request
rate, but it may be set lower to speed up crawling of documents containing JavaScripts.
To specify the default value leave the option blank.
This option has no effect if JavaScript crawling is not enabled
Default: Empty
FTP passive mode
This option determines if the FTP server (active) or the crawler (passive) should set up
the data connection between the crawler and the server. Passive mode is recommended,
and is required when crawling FTP content from behind a firewall.
Select Yes to crawl ftp sites in passive mode.
Select No to crawl ftp sites in active mode.
Default: Yes
43
FAST Enterprise Crawler
Option
FTP search for links
Description
This option determines whether or not the crawler should run documents retrieved from
an FTP server through the link parser to extract any links contained.
Select Yes to search FTP documents for links.
Select No to not search FTP documents for links.
Default: Yes
Include meta in csum
The crawler differentiates between content and META tags when detecting duplicates
and detecting whether a document has been changed.
Select Yes and the crawler will detect changes in META tags in addition to the document
content. This means that only documents with identical content and META tags are treated
as duplicates.
Select No and the crawler will detect changes in content only. This means that documents
with the same content is treated as duplicates even if the META tags are different.
Default: No
Sort URI query params
Example: If http://example.com/?a=1&b=2 is really the same URI as
http://example.com/?b=2&a=1, then the URIs will be rewritten to be the same when
this option is enabled. If not, the two URIs most likely will be screened as duplicates. The
problem arises if the two URIs are crawled at different times, and the page has changed
during the time of which the first one was crawled. In this case you can end up with both
URIs in the index.
Select Yes to enable sorting of URI query parameters.
Select No to disable sorting of URI query parameters.
Default: No
Enforce request rate per IP
This option allows you to control whether the crawler should enforce the request rate on
a per IP basis.
If enabled, a maximum of 10 sites sharing the same IP will be crawled in parallel.
Additionally, at most Max pending requests will be issued to this IP in parallel. This prevents
overloading the server(s) that host these sites.
If disabled, sites sharing the same IP will be treated as unique sites, each hit with the
configured request rate.
Default: Yes
Enforce MIME type
detection
This option allows you to decide whether or not the crawler should run its own MIME type
detection on documents. In most cases web servers return the MIME type of documents
when they are downloaded, as part of the HTTP header.
If this option is enabled, documents will get tagged with the MIME type that looks most
accurate; either the one received from the web server or the result of the crawlers
determination.
Default: No (disabled)
Send logs to Ubermaster
If enabled (as by default), all logging is sent to the ubermaster host for storage, as well
as stored locally. In large multiple node configurations it can be disabled to reduce
inter-node communications, reducing resource utilization, at the expense of having to
check log files on individual masters.
Default: Yes (enabled)
Note: This option only applies to multi node crawlers
44
Configuring the Enterprise Crawler
Option
META refresh is redirect
Description
This option allows you to specify whether the crawler should treat META refresh URIs as
HTTP redirects. Use together with META refresh threshold option which lets you specify
the upper threshold of this option.
Default: Yes
META refresh threshold
This option allows you to specify the upper limit on the refresh time for which a META
refresh URI is considered a redirect (The META refresh is redirect option must be
enabled.)
Example: Setting this option to 3 will make the crawler treat every META refresh URI with
a refresh of 3 seconds or lower as a redirect URI.
Default: 3 seconds
DB switch interval
Specify the number of cycles a document is allowed to exist without having been seen
by the crawler, before expiring. When a document expires, the action taken is determined
by the DB switch delete setting.
The age of a document is not affected by force re-fetches; only cycles where the crawler
refreshes normally (by itself) increases the document's age if not found.
This mechanism is used by the crawler to be able to purge documents that are no longer
linked to from the index. It is not used to detect dead links such as documents returning
an error code, e.g. 404.
This check is performed at the beginning of each refresh cycle individually for each site.
A similar check is performed for sites that have not been seen at the start of each collection
level refresh
Valid values: Positive integer
Default: 5
Note: Setting this value very low, e.g 1-2, combined with a DB switch delete setting
of Yes can result in documents being incorrectly identified as expired and deleted
very suddenly.
DB switch delete
The crawler will at regular intervals perform an update of its internal database of retrieved
documents, to detect documents that the crawler has not seen for DB switch interval
number of refresh cycles. This option determines what to do with these documents; they
can either be deleted right away or put in the work queue for a retrieval attempt to make
certain they are actually removed from the web server.
Select Yes to delete documents immediately.
Select No to verify that the documents no longer exist on the web server before deleting
them.
Default: No
Note: This setting should normally be left at the default setting of No in order to
avoid situations where the crawler may incorrectly believe that a set of documents
have been deleted and immediately deletes them from the crawler store and index
Workqueue filter
When this feature is enabled, the crawler will associate a Bloom filter with its work queues,
thereby reducing the degree of duplicates that go onto the queue. This way the queues
will grow more slowly and therefore use less disk I/O and space, plus save memory since
Bloom filters are very memory efficient. The drawback with Bloom filters is that there is a
very low probability of false positives, which means that there is a theoretical chance may
lose some URIs that would be crawled if work queue filters were disabled. Disable this
feature if this risk is a problem and added disk overhead is not problematic.
Select Yes to enable use of Bloom filters with work queues.
45
FAST Enterprise Crawler
Option
Description
Select No to disable use of Bloom filters with work queues.
Default: Yes
Master/Ubermaster filter
This parameter enables a Bloom filter to screen links transferred between masters and
the ubermaster. The value is the size of the filter, specifying the number of bits allocated,
which should be between 10 and 20 times the number of URIs to be screened.
Note that enabling this setting with a positive integer value disables the crosslinks cache.
It is recommended that you turn on this filter for large crawls; recommended value is
500000000 (500 megabit).
Default: 0 (disabled)
Master/Slave filter
When this feature is enabled, the crawler slave processes use a Bloom filter in the
communication channel with the master process, which reduces Inter Process
Communication (IPC) and memory overhead. The drawback with Bloom filters is that
there is a non-zero chance of false positives, which may cause URIs to be lost by the
crawler. Use this feature if this risk is not a concern and there is CPU and memory
contention on the crawler nodes.
It is recommended that you turn on this filter for large crawls; recommended value is
50000000 (50 megabit).
Valid values: Zero or positive integer
Default: 0 (filter is disabled)
Max docs before
interleaving
The crawler will by default crawl a site to exhaustion. However, the crawler can be
configured to crawl "batches" of documents from sites at a time, thereby interleaving
between sites. This option allows you to specify how many documents you want to be
crawled from a server consecutively before the crawler interleaves and starts crawling
other servers. The crawler will then return to crawling the former server as resources free
up.
Valid values: No value (empty) or positive integer
Default: empty (disabled)
Note: Since this feature will stop crawling web sites without fully emptying their work
queues on disk first it may lead to excessive amounts of work queue directories/files
on large scale crawls. This can impact crawler performance, if the underlying file
system is not able to handle it properly.
Max referrer links
This option specifies the maximum number of referrer levels the crawler will track for each
URI. As this feature is quite performance intensitive the setting should no longer be used,
instead the Web Analyzer should be queried to extract this information.
It is recommended that you contact FAST Solution Services if you still decide to modify
the default setting.
Valid values: Positive integer
Default: 0
Max pending requests
Specify the maximum number of concurrent (outstanding) HTTP requests to a single site
at any given time.
The crawler may make overlapping requests to a site, and this setting determines the
maximum degree of this overlapping. If you do not control the site(s) being crawled, it is
recommended that you use the default setting. Keep in mind that regardless of this setting
the crawler will not issue requests to a single web site more often than specified by the
Request rate setting.
46
Configuring the Enterprise Crawler
Option
Description
Valid values: Positive integer
Default: 2
Max pending
proxy-requests
Proxy open connection limit.
This parameter specifies a limit on the number of outstanding open connections per HTTP
proxy, per uberslave process in the configuration.
Valid values: Positive integer
Default: 2147483647
Max redirects
This option allows you to specify the maximum number redirects that should be followed
from an URI.
Example: http://example.com/path redirecting to http://example.com/path2
will be counted as 1.
Default: 10
Max URI recursion
This option allows you to specify the maximum number of times a pattern is allowed
appended to an URIs successors.
Example: http://example.com/path/ linking to
http://example.com/path/path/ will be counted as 1.
A value of 0 disables the test.
Default: 5
Max backoff count/delay
Together these options control the adaptive algorithm by which a site experiencing
connection failures (for example, network errors, timeouts, HTTP 503 "Server Unavailable"
errors) are contacted less frequently. For each consecutive instance of these errors, the
inter-request delay for that site is incremented by the initial delay setting (Request rate
setting):
Increasing delay = current delay + delay
The maximum delay for a site will be the Max backoff delay setting. If the number of
failures reaches Max backoff count, crawling of the site will become idle.
Should the network issues affecting the site be resolved, the internal backoff counter will
start decreasing, with the inter-request delay lowered on each successful document fetch
by half:
Decreasing delay = current delay / 2
This continues until the original delay (Request rate setting) is reached.
Default: Max backoff count = 50; Max backoff delay = 600
SSL key/certificate file
This option sets the filename for the file containing your client SSL key and certificate.
Type in a path and filename; the path and filename must be an absolute path on the
crawler node.
Example: /etc/ssl/key.pem
Default: empty
Note: This option is not necessary to specify in order to crawl HTTPS web sites. It
is only required if the web site requires the crawler to identify itself using a client
certificate
Document evaluator plugin
Specify a user-written Python module to be used for processing fetched documents and
(optionally) URI redirections.
47
FAST Enterprise Crawler
Option
Description
The value specifies the python class module, ending with your class name. The crawler
splits on the last '.' separator and converts this to the Python equivalent "from <module>
import <class>". The source file should be located relative to $PYTHONPATH, which for
FDS installations corresponds to ${FASTSEARCH}/lib/python2.3/.
Refer to Implementing a Crawler Document Plugin Module on page 118 for more information.
Variable request rate
This option allows you to specify specific time slots when you want to use a higher or
lower request rate than the main setting. Time slots are specified as ending and starting
points, and cannot overlap. Time slot start and endpoints are specified with day of week
and time of day (optionally with minute resolution).
Note that no two time slots can have the same delay values. Each variable must be unique,
for example, 2.0, 2.1, and so forth.
You can also enter the value Suspend in the Delay field that will suspend the crawler so
that there is no crawling for the time span specified.
Example time slots crawling at 60 second delay during weekends and no crawling during
weekdays:
•
•
Time span: Fri:23.59-Sun:23.59 Delay: 60
Time span: Mon:00-Fri:23 Delay: Suspend
Note: Entering very long delays (above 600 seconds) is not recommended as it may
cause problems with sites requiring authentication. To suspend crawling for a period
always use the Suspend value.
HTTP errors
This option allows you to specify how the crawler handles various HTTP response codes
and errors. It is recommended that you contact FAST Solution Services if you decide to
modify the default setting.
The following actions that can be configured for each condition:
•
•
•
KEEP - no action is taken, the document is not deleted
DELETE[:X] - the document is deleted if the error condition persists over X retries. X
refers to the number of refresh cycles the same error condition occurs, until the
document should be considered deleted. If X is unspecified or 0, the document is
deleted immediately.
RETRY[:X] - X refers to the number of retries within the same refresh cycle that should
be attempted before giving up.
A DELETE:3, RETRY:1, would thus attempt to fetch a document with this error condition
2x every refresh, and after 3 refreshes, if the document at some time was stored and
added to the index, it will be deleted.
The protocol response codes are divided into separate protocol response codes as general
client-side errors (4xx) and general server-side errors (5xx). Behavior for individual 400/500
errors can also be specified.
There are three classes of non-protocol errors that can be configured:
•
•
•
ttl - specifies handling for connections that time out
net - specifies handling for network/socket-level errors
int - specifies handling for other internal errors
Example: To delete a document after consecutive 3 retries for an HTTP 503 error, enter
503 in the Error box, and DELETE:3, RETRY: 1 in the Value box, then click on the
right arrow.
FTP errors
48
This option is the equivalent of the HTTP errors for FTP errors.
Configuring the Enterprise Crawler
Option
Description
Example: To delete a document after consecutive 3 retries for an FTP 550 error, enter
550 in the Error box, and DELETE:3, RETRY: 1 in the Value box, then click on the
right arrow.
FTP accounts
This option allows you to specify a number of FTP accounts required for crawling FTP
URIs. If unspecified for a site, the default anonymous user will be used. Specify the
hostname of the FTP site in the Hostname box, and the username and password in the
Credentials box.
The format of the Credentials is:
<USERNAME>:<PASSWORD>
Example (Credentials): myuser:secretpassword
Crawl sites if login fails
This parameter allows you to specify whether you want the crawler to continue crawling
a site after a configured login specification has failed, or not.
Select Yesto attempt crawling of the site regardless.
Select No to disallow crawling of the site.
Default: No
Domain clustering
In a web scale crawl it is possible to optimize the crawler to take advantage of locality in
the web link structure. Sub domains on the same domain tend to link more internally than
externally, just as a site would have mostly interlinks. The domain clustering option enables
clustering of sites on the same domain (for example, *.example.net) on the same master
node and the same storage cluster (and thus uberslave process).
This option also affects clustering within a single node, where all sites clustered in the
same domain will be handled by the same uberslave process. This ensures cookies (if
Send/receive cookies is enabled) can be used across a domain within the crawler.
Default: No
Note: This option is automatically turned on for multi node crawls by the ubermaster.
Adaptive Crawlmode
This section describes the adaptive scheduling options. Note that this parameter is only applicable if the
Refresh mode is set to adaptive.
Note: Extensive testing is strongly recommended before production use, to insure that desired pages
and sites are properly represented in the index.
Table 10: Adaptive Crawlmode Options
Option
Minor Refresh count
Description
Number of minor cycles within the major cycle.
A minor cycle is sometimes referred to as a micro cycle.
Refresh quota
Ratio of existing URIs re-crawled to new (unseen) URIs, expressed as percentage.
As long as the crawler has sufficient URIs of both types, this ratio is used. However, if it
runs out of URIs of either type it will crawl only the other type from then on until refresh
kicks in, or the site reaches some other limit (e.g. maximum document count for the cycle).
High value => re-crawling old content (recommended)
49
FAST Enterprise Crawler
Option
Description
Low value => prefer fresh content
Minor Refresh Min
Coverage
Minimum number of URIs from a site to be crawled in minor cycle.
Used to guarantee some coverage for small sites.
Minor Refresh Max
Coverage
Limit percentage of site re-crawled within minor cycle.
Ensures small sites do not crawl fully each minor cycle, starving large sites.
When configuring this option have the number of minor cycles in mind. With e.g. 4 minor
cycles this option should be 25% or higher, to ensure the entire site is re-crawled over
the course of a major cycle.
If the crawler detects that this value is set too low it may increase it internally.
URI length weight
Each URI is scored against a set of rules to determine its crawl rank value. The crawl
rank value is used to determine the importance of the particular URI, and hence the
frequency at which it is re-crawled (from at most once every minor cycle to only once
every major cycle).
Each rule is assigned a weight to determine its contribution towards the total rank value.
Higher weights produce higher rank contribution. A weight of 0 disables a rule altogether.
The URI length scoring rule is based on number of slashes (/) in URI path. The document
receives the maximum score if there is only a single slash, down to no score for 10 slashes
or more.
Increase this setting to boost the priority of URIs with few levels (slashes in path).
Default weight: 1.0
Valid Range: 0.0-2^32
URI depth weight
The URI depth score is based on number of link "hops" to this URI. Max score for none
(for example, start URI), no score for 10 or more.
Use this setting to boost the priority of URIs linked closely from the top pages.
Default weight: 1.0
Valid Range: 0.0-2^32
Landing page weight
The landing page score awards a bonus score if the URI is determined to be a "landing
page". A landing page is defined as any URI who's path ends in one of the following: /,
index.html, index.htm, index.php, index.jsp, index.asp, default.asp,
default.html, default.htm.
Any URI with query parameters receives no score.
Use this option to boost landing pages.
.
Default weight: 1.0
Valid Range: 0.0-2^32
Markup document weight
50
The markup document score awards a bonus score if the document at the URI is
determined to be a "markup" page. A markup page is a document whose MIME type
matches one of the MIME types listed in the MIME types to search for links.
Configuring the Enterprise Crawler
Option
Description
This option is used to give preference to more dynamic content as opposed to static
document types such as PDF, Word, etc.
Default weight: 1.0
Valid Range: 0.0-2^32
Change history weight
The change history scores a document on the basis of how often it changes over time.
This is done by the crawler by keeping track of whether a document has changed, or
remains unchanged, as it is re-downloaded. An estimate is then made on how likely this
document is to have changed the next time.
Use this option to boost pages that change more frequently, compared to static
non-changing pages.
Default weight: 10.0
Valid Range: 0.0-2^32
Sitemap weight
The sitemap score is based is based on metadata found in sitemaps. The score is
calculated by multiplying the value of the changefreq parameter with the priority parameter
of a sitemap.
Use this option to boost pages that are defined in sitemaps.
Default weight: 10.0
Valid Range: 0.0-2^32
Changefreq always value
This value is used to map the changefreq string value "always" in sitemaps to a numerical
value.
Default weight: 1.0
Valid Range: 0.0-2^32
Changefreq hourly value
This value is used to map the changefreq string value "hourly" in sitemaps to a numerical
value.
Default weight: 0.64
Valid Range: 0.0-2^32
Changefreq daily value
This value is used to map the changefreq string value "daily" in sitemaps to a numerical
value.
Default weight: 0.32
Valid Range: 0.0-2^32
Changefreq weekly value
This value is used to map the changefreq string value "weekly" in sitemaps to a numerical
value.
Default weight: 0.16
Valid Range: 0.0-2^32
Changefreq monthly value
This value is used to map the changefreq string value "monthly" in sitemaps to a numerical
value.
Default weight: 0.08
51
FAST Enterprise Crawler
Option
Description
Valid Range: 0.0-2^32
Changefreq yearly value
This value is used to map the changefreq string value "yearly" in sitemaps to a numerical
value.
Default weight: 0.04
Valid Range: 0.0-2^32
Changefreq never value
This value is used to map the changefreq string value "never" in sitemaps to a numerical
value.
Default weight: 0.0
Valid Range: 0.0-2^32
Changefreq default value
This value is assigned to all documents that have no changefreq attribute set in a sitemap.
Default weight: 0.16
Valid Range: 0.0-2^32
Authentication
This section of the Advanced Data Sources screen allows you to configure authentication credentials for
Basic, NTLM v1 or Digest schemes.
Note: After an Authentication item has been added, it cannot be modified. To modify an existing item,
save it under a new name and delete the old one.
Table 11: Authentication Options
Option
URI Prefix or Realm
Description
An identifier based on either a URI prefix or authentication realm. The corresponding
credentials (Username, Password, and optionally Domain) will be used in an authentication
attempt if either:
•
•
Username
Password
Domain
Authentication scheme
A URI matches the URI prefix string from left-to-right
The specified Realm matches the value returned by the web server in a
401/Unauthorized response
Specify the username to use for the login attempt. This value will be sent to every URI
that matches the specified URI prefix or realm.
Specify the password to use for authentication attempts. This value will be sent to every
URI that matches the specified prefix or realm.
Specify the domain value to use for authentication attempts. This value is optional.
Specify the scheme to use in authentication attempts. If auto is specified, the crawler
selects one on its own.
Note: If authentication fails, crawling of the site will stop.
52
Configuring the Enterprise Crawler
Cache Sizes
It is recommended that you contact FAST Solution Services before changing any of the Cachesizes options.
The default selections are shown in the following screen. The options with empty defaults are automatically
adjusted by the crawler
Figure 4: Cache Size Options
Crawl Mode
This table describes the advanced options that apply to the Crawl mode.
Table 12: Crawl Mode Options
Option
Crawl mode
Description
Select how web sites in the collection should be crawled from the Crawl mode drop-down
menu. Highlight the type to be used.
Possible modes are:
•
•
Full - use if you want the crawler to crawls through all levels on a site.
Level - use to indicate the depth of the crawl as defined in the Max Levels option.
The start level is the level of the start URI specified in the Start URI files.
The crawler assumes that all cross-site links are valid links and will follow these links until
it reaches the number of levels specified in Max Levels. If the crawler crawls two sites
that are closely interlinked, it may crawl both sites entirely, despite the given maximum
level. You can prevent this by either:
•
•
Limiting the included domains in Hostname Includes
Selecting No in the Follow cross-site URIs
Default: Full
Max levels
This option allows you to specify the maximum number of levels to crawl from a server.
The crawler considers all cross-links to be valid and follows all cross-links the same amount
of levels. If the sites you are crawling are heavily cross-linked, you may crawl entire sites.
This option only applies when the Crawl mode option is set to Level. If unspecified, a
Level Crawl mode will default to Max level 0.
Example: 1 (the crawler crawls only the URI named in the Start URI files and any links
from the Start URI)
Default: empty
53
FAST Enterprise Crawler
Option
Description
Note: Frame links, JavaScripts and redirects do not increase the level counter,
therefore even a depth 0 crawl may follow these links. In this case it is possible to
specify the depth as -1 instead, this will not follow any links.
Follow cross-site URIs
This option allows you to select whether the crawler is to follow cross-site URIs from one
web site to another.
Select Yes and the crawler will follow any links leading from the start URI sites as long
as they fulfill the Hostname include filters criteria.
Select No and the crawler will only follow "local" links with the same web site. It will not
follow links from one web site to another even if the site is included by the Hostname
include rules.
Default: Yes
Note: If cross-site link following is turned of it is necessary that each site to be
crawled has an entry in the start URIs list.
Note: The crawler treats a single hostname as a single web site, hence it will identify
example.com and www.example.com as two different web sites, even though they
may appear the same to the user.
Follow cross-site redirects
Specifies whether or not to follow external redirects from one web site to another.
Default: Yes
Reset crawl level
This option allows you to select whether the crawler is to reset the crawl level when
crawling cross-site.
Select Yes to enable the crawler to reset the crawl level when leaving the start URI sites
and crawling sites leading from there. The crawl mode will be reset to default (Crawl mode
= Full).
Select No to ensure that the crawler will not reset the crawl level, and the crawl mode and
level set for the start URIs will also apply for external sites.
Default: No
Crawling Thresholds
This option allows you to specify certain threshold limits for the crawler. When these limits are exceeded, the
crawler will enter a special mode called refresh (not to be confused with the now removed refresh mode called
refresh). The refresh crawl mode will make the crawler only crawl URIs that previously has been crawled.
Figure 5: Crawling Thresholds
The following table describes the crawling thresholds to be set
Table 13: Crawling Threshold Options
54
Configuring the Enterprise Crawler
Option
Disk free percentage
Description
This option allows you to specify, as a percentage, the amount of free disk space
that must be available for the crawler to operate in normal crawl mode. If the
disk free percentage drops below this limit, the crawler enters the refresh crawl
mode.
While in the refresh crawl mode only documents previously seen will be
re-crawled, no new documents will be downloaded.
Default: 0% (0 == disabled)
Disk free percentage slack
This option allows you to specify, as a percentage, a slack to the disk free
threshold defined by the Disk free percentage. By setting this option, you create
a buffer zone above the disk free threshold. While the current free disk space
remains in this zone, the crawler will not change the crawl mode back to normal.
This prevents the crawler from switching back and forth between the crawl modes
when the percentage of free disk space is close to the value specified by the
Disk free percentage option. When the available disk space percentage rises
above disk_free+disk_free_slack, the crawler will change back to normal crawl
mode.
Default: 3%
Maximum documents
This option allows you to specify, in number of documents, the number of stored
documents in the collection that will trigger the crawler to enter the refresh crawl
mode.
While in the refresh crawl mode only documents previously seen will be
re-crawled, no new documents will be downloaded.
Default: 0 documents (0 == disabled)
Note: The threshold specified is not an exact limit, as the statistics reporting
is somewhat delayed compared to the crawling.
Note: This option should not be confused with Max document count per
site option.
Maximum documents slack
This option allows you to specify the number of documents which should act as
a buffer zone between normal mode and refresh mode. The option is related to
the Maximum documents setting. Whenever the refresh mode is activated
because the number of documents has exceeded the maximum, a buffer zone
is created between the maximum documents and maximum documents-maximum
documents slack. The crawler will not change back to normal mode while within
the buffer zone.This prevents the crawler from switching back and forth between
the crawl modes when the number of docs is close to the Maximum documents
value.
Default: 1000 documents
Duplicate Server
This section of the Advanced Data Sources screen allows you to configure the Duplicate Server settings.
Table 14: Duplicate Server Options
55
FAST Enterprise Crawler
Option
Database format
Description
Specify the storage format to use for the duplicate server databases. Available formats
are:
•
•
•
Database Cachesize
Database stripe size
Nightly compaction?
Gigabase DB
Memory hash
Disk hash
Specify the size of the cache of the duplicate server databases. If the database format is
a hash format, the cache size specifies the initial size of the hash.
Specify the # of stripes to use for the duplicate server databases.
Specify whether nightly compaction should be enabled for the duplicate server databases.
Note: If no duplicate server setting is specified, defaults, or values given on the duplicate server command
line are used.
Feeding Destinations
This table describes the options available for custom document feeding destinations. It is possible to submit
document to a collection by another name, multiple collections and even another ESP installation. If no
destinations are specified the default is to feed into a collection by the same name in the current ESP
installation.
Table 15: Feeding Destination Options
Option
Name
Description
This parameter specifies a unique name that must be given for the feeding destination
you are configuring. The name can later be used in order to specify a destination for
refeeds.
This field is required.
Target collection
This parameter specifies the ESP collection name to feed documents into. Normally this
is the same as the collection name, unless you wish to feed into another collection. Ensure
that the collection already exists on the ESP installation designated by Destination first.
Each feeding desintation you specify maps to a single collection, thus to feed the same
crawl into multiple collections you need to specify multiple feeding destinations. It is also
possible for multiple crawler collections to feed into the same target collection.
This field is required.
Destination
This parameter specifies an ESP installation to feed to. The available ESP destinations
are listed in the feeding section of the crawler's global configuration file, normally
$FASTSEARCH/etc/CrawlerGlobalDefaults.xml. The XML file contains a list of
named destinations, each with a list of content distributors.
If no destinations are explicitly listed in the XML file you may specify "default" here, and
the crawler will feed into the current ESP installation. This current ESP installation is that
which is specified by $FASTSEARCH/etc/contentdistributor.cfg.
This field is required, may be "default" unless the global XML file has been altered.
Pause ESP feeding
56
This option specifies whether or not the crawler should pause document feeding to FAST
ESP. When paused, the feed will be written to stable storage on a queue.
Configuring the Enterprise Crawler
Option
Description
Note that the value of this setting can be changed via the crawleradmin tool options,
--suspendfeed/--resumefeed.
Default: no
Primary
This parameter controls whether this feeding destination is considered a primary or
secondary destination. Only the primary destination is allowed to act on callback information
from the document feeding chain, secondary feeders are only permitted to log callbacks.
Exactly one feeding destination must be specified as primary.
This field is required.
Focused Crawl
This table describes the options to configure Language focused crawling
Table 16: Focused Crawl Options
Option
Languages
Description
This option allows you to specify a list of languages that documents must match to be
stored and indexed by FAST ESP. The crawler will only follow non-focused documents
to a maximum depth set by the Focus depth option.
Languages should be specified either as a two letter ISO-639-1 code, or the single word
equivalent.
Examples: english, en, german, de.
Focus depth
This option allows you to specify how many levels the crawler should follow links from
URIs not matching the specified language of the crawl.
For example, if you are doing an English only crawl, with a focus depth of 2, the URI chain
would look like this (focus depth in parenthesis, "-" means no depth assigned):
English(-) -> French(2) ->French(1) -> English(1) -> English(1)
->German (0)
In the example above, the crawler will not follow links from the last URI in the chain as
the specified depth has been reached.
Hostname exclude filters
Use this parameter to specify certain domains where language focus should not apply.
For example, if performing e.g. a Spanish crawl it is possible to exclude the top level
domain .es from the language focus checks, thereby crawling all of .es regardless of the
language on individual pages.
The format is the same as the Hostname exclude filters in the basic collection options.
Form Based Login
The crawler can crawl sites that rely on HTTP cookie authentication for access control of web pages.
Configuring the crawler to perform cookie authentication does however require a fair bit of insight in the details
of how the authentication scheme works and may take some trial and error to get correct.
Studying the HTML or JavaScript source of the login page and HTTP protocol traces of a browser login
session can be very helpful. Tools that perform such tasks are freely available, including the packet sniffer
Ethereal (http://www.ethereal.com/).
Note: When secure transport (HTTPS) is used, packet sniffing in general cannot be used, and some
type of application level debugging tool must be used. We recommend the LiveHTTPHeaders utility
(http://livehttpheaders.mozdev.org/) for the Mozilla browser.
57
FAST Enterprise Crawler
Note: Login Specification does not allow empty values. If you need to crawl cookie authenticated sites
with empty values, contact FAST Technical Support for detailed instructions.
Table 17: Form Based Login Options
Option
Name
Preload
HTML form
Form scheme
Description
Required: Specify a unique name for the login specification you are configuring.
Optional: URI to fetch (in order to receive a cookie) before proceeding to the authentication
form. May or may not be necessary, depending on how the authentication for that site
works.
Optional: URI to the HTML page containing the login form. Used by the Autofill option. If
not specified, the crawler will assume the HTML page is specified by the Form action
option.
Optional: Type of scheme used for login.
Valid values: http, https
Default: http
Form site
Form action
Form method
The hostname of the login form URI.
The path/file of the login form URI.
The HTTP action of the form.
Valid values: GET, POST
Default: GET
Autofill
Re-login if failed?
Form parameters
Login sites
TTL
Whether the crawler should download the HTML page, parse it, identify which form you're
trying to log into by matching parameter names, and merge it with any specified form
parameters you may have specified in the Form parameters option.
Whether the crawler after a failed login should attempt to re-login to the web site after
TTL seconds. During this time, the web site will be kept active within the crawler, thus
occupying one available site resource.
The credentials as a sequence of key, value parameters the form requires for a successful
log on. These are typically different from form to form, and must be deduced by looking
at the HTML source of the form. In general, only user-visible (via the browser) variables
need be specified, e.g. username and password, or equivalent. The crawler will fetch the
login form and read any "hidden" variables that must be sent when the form is submitted.
If a variable and value are specified in the parameters section, this will override any value
read from the form by the crawler.
List of sites (i.e. hostnames) that should log into this form before being crawled.
Number of seconds before the crawler should re-authenticate itself.
HTTP Proxies
This topic specifies one or more proxy addresses to use for all HTTP/HTTPS communication.
58
Configuring the Enterprise Crawler
Table 18: HTTP Proxy Options
Option
Name
Host
Port
Description
Name of proxy.
Hostname of proxy.
Port number of proxy.
Default port: 3128
User
Password
Registered HTTP Proxies
Username.
Password.
List of registered HTTP proxy names.
Link Extraction
This topic describes the advanced options available that apply to Link Extraction. These options allow you
to specify which HTML tags to extract links from, including whether or not to extract links from within comments
or JavaScript code (applies only when the proper JavaScript support is turned off).
The following display shows the default values for the various Link Extraction parameters.
Figure 6: Link Extraction Options
Logging
This section describes the advanced options available that apply to Logging. The different logs can be enabled
or disabled by selecting text or none respectively.
Table 19: Logging Options
59
FAST Enterprise Crawler
Option
Document fetch log
Description
This log contains detailed information about every retrieved document. It contains status
on whether the retrieval was a success, or if not, what went wrong. It will also tell you if
the document was excluded after being downloaded, for instance if it was not of the correct
document type.
Inspecting this log is very useful if you suspect that your data should have been crawled
but was not, or vice versa. It should be the first place to look after examining the crawler
debugs for errors and warnings.
Default location:
$FASTSEARCH/var/log/crawler/fetch/<collection name>/<date>.log
Default: text
Site log
The site log contains information about all sites being crawled in a collection, for instance
when the crawler starts/stops crawling a site, as well as the time of refresh events.
Examining this log can be useful when debugging site-wide issues, as this log is
comparable to the fetch log only on a site basis.
Default location:
$FASTSEARCH/var/log/crawler/site/<collection name>/<date>.log
Default: text
Postprocess log
This log contains a report of all documents, modifications or deletions sent to the FAST
ESP indexing pipeline, and the outcome of these operations.
Default location:
$FASTSEARCH/var/log/crawler/PP/<collection name>/<date>.log
Default: text
Header log
This log contains all HTTP headers send and received from the HTTP servers when
documents are retrieved, and can be used for debugging purposes of your setup. This
log is essential when debugging authentication related issues, but should be turned off
for normal crawling.
Default location for every web site crawled:
$FASTSEARCH/var/log/crawler/header/<collection name>/<5 first chars
of hostname>/<hostname>/<date>.log
Default: none
Screened log
This log contains all URIs that are not attempted retrieved for any reason, including not
falling within the scope of the configured include/exclude filters, robots.txt exclusion and
so forth. This log is useful if you feel that content that should be crawled is not being
crawled. As this is a very high volume log it should be turned off for normal crawling.
Default location:
$FASTSEARCH/var/log/crawler/screened/<collection name>/<date>.log
Default: none
Data Search feed log
This log contains all URIs that have been submitted to document processing and their
status. The log contain error messages reported by document processing stages and is
the first place to look if a document is not in the index.
Default location:
$FASTSEARCH/var/log/crawler/dsfeed/<collection name>/<date>.log
Default: text
60
Configuring the Enterprise Crawler
Option
Adaptive Scheduler log
Description
Logs adaptive rank score of documents, for debugging purposes only.
Default location:
$FASTSEARCH/var/log/crawler/scheduler/<collection name>/<date>.log
Default: none
POST Payload
This section of the Advanced Data Sources screen allows you to configure POST payloads
Table 20: POST Payload Options
Option
URI prefix
Payload
Description
Specify a URI or URI prefix. Every URI that matches the URI or prefix will have the below
associated Payload submitted to it using the HTTP POST method. A URI prefix must be
indicated by the string prefix:, followed by the URI string to match. A URI alone will be
used for an exact match.
Specify the payload to be submitted by the HTTP POST method to every URI that matches
the given URI prefix specified above.
Postprocess
It is recommended that you contact FAST Solution Services before changing any of the postprocess options.
The default selections are shown in the following screen. The options with empty defaults are automatically
adjusted by the crawler.
Figure 7: Postprocess Options
RSS
This topic describes the parameters for RSS crawling.
Note: Extensive testing is strongly recommended before production use, to insure that desired processing
patterns are attained.
Table 21: RSS Options
61
FAST Enterprise Crawler
Option
RSS start URIs
Description
This option allows you to specify a list of RSS start URIs for the collection to be configured.
RSS documents (feeds) are treated a bit different than other documents by the crawler.
First, RSS feeds typically contain links to articles and meta data which describes the
articles. When the crawler parses these feeds, it will associate the metadata in the feeds
with the articles they point to.This meta data will be sent to the processing pipeline together
with the articles, and a RSS pipeline stage can be used to make this information
searchable. Second, links found in RSS feeds will be tagged with a force flag. Thus, the
crawler will crawl these links as soon as allowed (it will obey the collection's delay rate),
and they will be crawled regardless if it they have been crawled already in this crawl cycle.
Example: http://www.example.com/rss.xml
Default: Not mandatory
RSS start URI files
This parameter requires you to specify a list of RSS start URI files for the collection to be
configured. This option is not mandatory. The format of the files is one URI per line.
Example: C:\MyDirectory\rss_starturis.txt (Windows) or /home/user/rss_starturis.txt (UNIX).
Default: Not mandatory
Discover new RSS feeds?
This parameter allows you to specify if the crawler should attempt to find new RSS feeds.
If this option is not set, only feeds specified in the RSS start URIs and/or the RSS start
URIs files sections will be treated as feeds.
Default: no
Follow links from HTML?
This option allows you to specify if the crawler should follow links from HTML documents,
which is the normal crawler behavior. If this option is disabled, the crawler will only crawl
one hop away from a feed. Disable this option if you only want to crawl feeds and
documents referenced by feeds.
Default: yes
Ignore include/exclude
rules?
Use this option to specify if the crawler should crawl all documents referenced by feeds,
regardless of being valid according to the collection's include/exclude rules.
Default: no
Index RSS feeds?
This parameter allows you to specify if the crawler should send the RSS feed documents
to the processing pipeline. Regardless of this option, meta data from RSS feeds will be
sent to the processing pipeline together with the articles they link to.
Default: no
Max age for links in feeds
This parameter allows you to specify the maximum age (in minutes) for a link in an RSS
document. Expired links will be deleted if the 'Delete expired' option is enabled. 0 disables
this option.
Default: 0 (disabled)
Max articles per feed
This parameter allows you to specify the maximum number of links the crawler will
remember for a feed. The list of links found in a feed will be treated in a FIFO manner.
When links get pushed out of the list, they will be deleted if the 'Delete expired' option is
set. 0 disables this option.
Default: 128
62
Configuring the Enterprise Crawler
Option
Delete expired articles?
Description
This option allows you to specify if the crawler should delete articles when they expire.
An article (link) will expire when it is affected by either 'Max articles per feed' or 'Max age
for links in feeds'.
Default: no
Storage
It is recommended that you contact FAST Solution Services before changing any of the Storage options. The
default selections are shown in the following screen. The options with empty defaults are automatically
adjusted by the crawler.
Figure 8: Storage Options
Sub Collections
This topic describes how to define and configure Sub Collections in the crawler. Sub Collections is a mechanism
that allows subsets of a collection to be specified differently in the crawler. An example is if a collection spans
across several sites, and one wish to crawl a particular site or set of sites to be crawled more aggressively.
In such a case, one can define a Sub Collection that includes this site and set a different request rate on that
Sub Collection.
Sub Collections should be considered as a separate work queue that is treated differently than the main
collection queue. Note that Sub Collections can span several sites, or a particular subset of a site. The Sub
Collection Hostname include/exclude filters and URI include/exclude filters determine what will be included
in a Sub Collection; the filters have the same semantics found in the Data Source Basic Options and Data
Source Advanced Options respectively.
Note that whatever does not fall within a Sub Collection automatically falls within the main collection. Also
note that what falls within a Sub Collection cannot be excluded in the main collection; it must be a subset.
Sub Collections must be given their own start URI or start URI file. The options that are set for Sub Collections
will contain the same semantics as those in the main collection; Sub Collection settings override main collection
settings. One or more of the following settings are mandatory:
•
•
•
Hostname/URI include/exclude filters
Start URI files/Start URIs
Name
The remaining settings are optional.
63
FAST Enterprise Crawler
Figure 9: Sub Collection Basic Options
Figure 10: Sub Collection Crawl Mode Options
Figure 11: Sub Collection RSS Options
64
Configuring the Enterprise Crawler
Figure 12: Sub Collection Advanced Options
Creating a new Sub Collection
Fill in the proper values in the fields for the Sub Collection. If values are already filled in, click New to get a
blank template. Fill in the mandatory values, and click Add.
Note: If a different Sub Collection has been viewed earlier, some options may not change. Make sure
all options are correct before selecting Add.
Modifying an existing Sub Collection
Select the Sub Collection you wish to add in the Installed items select box, then click View. Modify the
applicable settings. Before saving, select the same Sub Collection in the Installed Sub Collections box.
Click Delete. Click Add.
65
FAST Enterprise Crawler
Removing an existing Sub Collection
Select the Sub Collection you wish to remove in the Installed Sub Collections box, then click Delete.
Work Queue Priority
This topic describes the work queue priority parameter, which allows you to specify how many priority levels
you want the work queue to consist of, and various rules and methods for how to insert and extract entries
from the work queue.
Note: Extensive testing is strongly recommended before production use, to insure that desired processing
patterns are attained.
Table 22: Work Queue Priority Options
Option
Workqueue levels
Description
This option allows you to specify the number of priority levels you want the crawler work
queue to have.
Note: If this value is ever decreased in value (e.g. from 3 to 1), the on-disk storage
for the work queues must be deleted manually to recover the disk space.
Default: 1
Default queue
This option allows you to specify the default priority level for extracting and inserting URIs
from/to the work queue.
Default: 1
Start URI priority
This option allows you to specify the priority level for URIs coming from the start URIs
and start URI files options.
Default: 1
Pop Scheme
This option allows you to specify which method you want the crawler to use when extracting
URIs from the work queue.
Valid values:
•
rr - extract URIs from the priority levels in a round-robin fashion.
•
wrr - extract URIs from the priority levels in a iweighted round-robin fashion. The
weights are based on their respective share setting per priority level. Basically URIs
are extracted from the queue with the highest share value; when all shares are 0 the
shares are reset to their original settings.
pri - extract URIs from the priority levels in a priority fashion by always extracting
from the highest priority level if there still are entries available (1 being the highest).
default- same as wrr.
•
•
When using multiple work queue levels it's recommended to use either the wrr or pri pop
scheme.
Default: default
Put Scheme
This option allows you to specify which method you want the crawler to use when inserting
the URIs into the work queue.
Valid values:
•
66
default - always insert URIs with default priority level.
Configuring the Enterprise Crawler
Option
Description
•
include - insert URIs with the priority level defined by the includes specified for every
priority level. If no includes match, the default priority level will be used.
Default: default
Queue - Hostname include
These options allow you to specify a set of include rules for each priority level to be used
filters Queue - URI include
when utilizing the include Put scheme of inserting entries to queue.
filters
Queue - Share
This option allows you to specify a share or weight for each queue to be used when utilizing
the wrr Pop scheme of extracting entries in the work queue.
Configuration via XML Configuration Files
The crawler may be configured using an XML based file format. This format allows you to manage files in a
text based environment to create/manage multiple collections as well as automate configuration changes.
Furthermore, a few advanced features are only available in the XML format.
Basic Collection Specific Options (XML)
This section discusses the parameters available on a per collection basis should you decide to configure the
crawler using an XML configuration file.
To add or update a collection in the crawler from an XML file, use the following command:
$FASTSEARCH/bin/crawleradmin -f <XML file path>
Substitute <XML file path> with the full path to the XML file.
Note: Removing a section from the XML configuration and submitting that configuration while keeping
the section intact is necessary for proper updating. For example, if you want to delete the existing
include_uris section, you should not completely delete that section from the XML file. You should add
an empty include_uris section in the XML file before importing the changes. This behavior allows
partial configs to be submitted in order to change a specific option while keeping the remaining
configuration intact.
Table 23: XML Configuration File Parameters
Parameter
info
Description
Collection information.
Parameter specifies a string that can contain general-purpose information.
<attrib name="info" type="string"> Test crawl for .no
domains on W2k </ attrib>
fetch_timeout
URI fetch timeout in seconds.
The maximum period of time allowed for downloading a document. Set this value
high if you expect to download large documents from slow servers.
Default: 300
<attrib name="fetch_timeout" type="integer"> 300 </attrib>
67
FAST Enterprise Crawler
Parameter
allowed_types
Description
Allowed document MIME types.
Only download documents of the indicated MIME type(s). The MIME types
specified here is included in the accept-header of each GET request that is sent.
Note that some servers can return incorrect MIME types.
Note that the format supports wildcard expansion of an entire field only, for
example, */example, text/* or */*, but not appl/ms*. No other regular
expression is supported.
<attrib name="allowed_types" type="list-string">
<member> text/html</member>
<member>application/msword </member>
</attrib>
force_mimetype_detection
Force MIME type detection on documents.
This option allows you to decide whether or not the crawler should run its own
MIME type detection on documents. In most cases web servers return the MIME
type of documents when they are downloaded, as part of the HTTP header.
If this option is enabled, documents will get tagged with the MIME type that looks
most accurate; either the one received from the web server or the result of the
crawlers determination.
Default: no (disabled)
<attrib name="force_mimetype_detection" type="boolean"> no
</attrib>
allowed_schemes
Allowed schemes.
Specify which URI schemes to allow.
Valid schemes are: HTTP, HTTPS and FTP and multimedia formats MMS and
RTSP. Note that MMS and RTSP for multimedia crawl is supported via MM
proxy.
<attrib name="allowed_schemes" type=list-string">
<member> http </member>
<member> https </member>
<member> ftp </member>
</attrib>
ftp_acct
FTP accounts.
Specify FTP accounts for crawling FTP URIs. If no site match is found here, the
default is used.
Note that changing this value may result in previously accessible content to be
(eventually) deleted from the index.
68
Configuring the Enterprise Crawler
Parameter
Description
Default: anonymous
<section name="ftp_acct">
<attrib name="ftp.mysite.com" type="string"> user:pass
</attrib>
</section>
ftp_passive
FTP passive mode.
Use FTP passive mode for retrieval from FTP sites.
Default: yes
<attrib name="ftp_passive" type="boolean"> yes </attrib>
domain_clustering
Route hosts from the same domain to the same slave.
If enabled in a multiple node configuration, sites from the same domain (for
example, www.example.com and forums.example.com) will also be routed
to the same master node.
Default: no (disabled) for single node and yes (enabled) for multiple node
<attrib name="domain_clustering" type="boolean"> yes
</attrib>
max_inter_docs
Maximum number of docs before interleaving site.
The crawler will by default crawl a site to exhaustion, or until the maximum
number of documents per site is reached. However, the crawler can be configured
to crawl "batches" of documents from sites at a time, thereby interleaving between
sites. This parameter allows you to specify how many documents you want to
be crawled from a server consecutively before the crawler interleaves and starts
crawling other servers. The crawler will then return to crawling the former server
as resources free up.
Valid values: No value (empty) or positive integer
Default: empty (disabled)
Example:
<attrib name="max_inter_docs" type="integer"> 3000 </attrib>
max_redirects
Maximum number of redirects to follow.
This parameter allows you to specify the maximum number redirects that should
be followed from an URI. For example, http://example.com/path redirecting
to http://example.com/path2 will be counted as 1.
Default: 10
<attrib name="max_redirects" type="integer"> 10 </attrib>
near_duplicate_detection
Enable near duplication detection algorithm.
The near_duplicate_detection parameter is boolean, with values true or
false, indicating whether or not to use the near duplicate detection scheme. The
69
FAST Enterprise Crawler
Parameter
Description
near_duplicate_detection parameter can be used per domain
(sub-domain). It is disabled (false) by default.
Default: no
<attrib name="near_duplicate_detection" type="boolean"> no
</attrib>
Refer to Configuring Near Duplicate Detection for more information.
max_uri_recursion
Screen for recursive patterns in new URIs.
Use this parameter to check for repeating patterns in URIs, compared to their
referrers, with repetitions beyond the specified being dropped. For example,
http://www.example.com/wile linking to
http://www.example.com/wile/wile is a repetition of 1 element.
A value of 0 disables the test.
Default: 5
<attrib name="max_uri_recursion" type="integer"> 5 </attrib>
focused
Language focused crawl (optional).
Use this parameter to specify options to focus your crawl.
languages: Use this parameter to specify a list of languages that documents
must match to be stored and sent to FAST ESP. Documents that do not match
the languages will follow a configured amount (depth) of levels before traversing
stops.Those domains excluded from the language focused crawl are still eligible
for the main crawl. Languages should be specified according to ISO-639-1.
The depth and exclude_domains settings are used to limit the crawl:
depth: Use this parameter to specify the number of levels to follow
documents that do not match the language specification.
exclude_domains: Use this parameter to exclude certain domains from
which language focus should not apply. Format is the same as the
exclude_domains option in the collection configuration. Note that domains
will be crawled regardless of their language; they will be excluded from the
language check, but not excluded from the crawl.
<section name="focused">
<attrib name="depth" type="integer"> 3 </attrib>
<section name="exclude_domains">
<attrib name="suffix" type="list-string">
<member> .tv </member>
</attrib>
</section>
<attrib name="languages" type="list-string">
<member> norwegian </member>
<member> no </member>
<member> nb </member>
<member> nn </member>
<member> se </member>
</attrib>
</section>
ftp_searchlinks
70
FTP search for links.
Configuring the Enterprise Crawler
Parameter
Description
Specify if you want the crawler to search the documents downloaded from FTP
for links.
Default: yes
<attrib name="ftp_searchlinks" type="boolean"> yes </member>
use_javascript
Enable JavaScript support.
Specify if you want to enable JavaScript support in the crawler. If enabled, the
crawler will download, parse/execute and extract links from any external
JavaScript.
Note: JavaScript processing is resource intensive and should not be
enabled for large crawls.
Note: Processing JavaScript requires an available Browser Engine.
For more information, please refer to the FAST ESP Browser Engine Guide.
Default: no
<attrib name="use_javascript" type="boolean"> no </attrib>
javascript_keep_html
Specify whether to submit the original HTML document, or the HTML resulting
from the JavaScript parsing, to document processing for indexing.
When parsing a HTML document the Browser Engine executes all inlined and
external JavaScripts, and thereby all document.write() statements, and
includes these in its HTML output. By default it is this resulting document that
is indexed. However it is possible to use this feature to limit the Browser Engine
to link extraction only.
This option has no effect if JavaScript crawling is not enabled
Default: no
<attrib name="javascript_keep_html" type="boolean"> no
</attrib>
javascript_delay
Specify the delay (in seconds) to be used when retrieving external JavaScripts
referenced from a HTML document. The default (specified as an empty value)
is the same as the normal crawl delay, but it may be useful to set it lower to
speed up crawling of documents containing JavaScripts.
This option has no effect if JavaScript crawling is not enabled
Default: empty
<attrib name="javascript_delay" type="real"> 60 </attrib>
exclude_headers
Exclude headers.
71
FAST Enterprise Crawler
Parameter
Description
Specify which documents that you want to be excluded by identifying the
document HTTP header fields. First specify the header name, then one or more
regular expressions for the header value.
<section name="exclude_headers">
<attrib name="Server" type="list-string">
<member> webserverexample1.* </member>
<member> webserverexample2.* </member>
</attrib>
</section>
exclude_exts
Exclude extensions.
Specify which documents you want to be excluded by identifying the document
extensions. The extensions will be suffix string matched with the path of the
URIs.
<attrib name="exclude_exts" type="list-string">
<member> .gif </member>
<member> .jpg </member>
</attrib>
use_http_1_1
Use HTTP/1.1.
Specify whether the crawler should use HTTP/1.1 or not (HTTP/1.0). HTTP/1.1
is required for the crawler to accept compressed documents from the server
(accept_compression) and enable ETag support (if_modified_since
must be checked).
Default: yes (to crawl using HTTP/1.1)
<attrib name="use_http_1_1" type="boolean"> no </attrib>
accept_compression
Accept compression.
Specify whether the crawler should use the Accept-Encoding header, thus
accepting that the documents are compressed at the web server before returned
to the crawler.
Default: yes
Only applicable if use_http_1_1 is enabled.
<attrib name="accept_compression" type="boolean"> no
</attrib>
dbswitch
DB switch interval.
Specify the number of cycles a document is allowed to complete before being
deleted. When the DB interval is complete, the action taken on these deleted
documents is determined by the dbswitch_delete parameter.
Setting this value very low, such as to 1, can result in documents being deleted
very suddenly.
72
Configuring the Enterprise Crawler
Parameter
Description
This parameter is not affected by force re-fetches; only cycles where the crawler
refreshes normally (by itself) increases the document's cycle number count.
<attrib name="dbswitch" type="integer"> 5 </attrib>
dbswitch_delete
DB switch delete.
The crawler will at regular intervals perform an update of its internal database
of retrieved documents, to detect documents that may be removed from the web
servers. This option determines what to do with these remaining documents;
they can either be deleted right away or put in the work queue for retrieval to
make certain they are actually removed.
A dbswitch check occurs at the start of a refresh cycle, independently for each
site.
If set to yes, then documents found to be too old are deleted immediately. If set
to no, then documents are scheduled for a re-retrieval and only deleted if they
no longer exist on the server.
Default: no
<attrib name="dbswitch_delete" type="boolean"> yes </attrib>
html_redir_is_redir
Treat META refresh HTTP tag contents as an HTTP redirect.
Use this parameter in conjunction with html_redir_thresh to allow the
crawler to treat META refresh tags inside HTML documents as if they were true
HTTP redirects. When enabled the document containing the META refresh will
not itself be indexed.
Default: yes
<attrib name="html_redir_is_redir" type="boolean"> yes
</attrib>
html_redir_thresh
Upper bound for META refresh tag delay.
Use this parameter in conjunction with html_redir_is_redir to specify the
number of seconds delay (threshold) which are allowed for the tag to be
considered a redirect. Anything less than this number is treated as a redirect,
other values are treated as a link (and the document itself is indexed also).
Default: 3
<attrib name="html_redir_thresh" type="integer"> 3 </attrib>
robots_ttl
Robots time to live.
Specifies how often (in seconds) the crawler will re-download the robots.txt file
from sites, in order to check if it has changed. Note that the robots.txt file may
be retrieved less often if the site is not crawling continuously.
73
FAST Enterprise Crawler
Parameter
Description
Default: 86400 (24 hours)
<attrib name="robots_ttl" type="integer"> 86400 </attrib>
enable_flash
Extract links from flash files.
If enabled, extract links from Adobe Flash (.swf) files.
You may also want to enable JavaScript support, as many web servers only
provide Flash content to clients that support JavaScript.
Note: Flash processing is resource intensive and should not be enabled
for large crawls.
Note: Processing Macromedia Flash files requires an available Browser
Engine.
For more information, please refer to the FAST ESP Browser Engine Guide.
Default: no
<attrib name="enable_flash" type="boolean"> no </attrib>
use_sitemaps
Extract links and metadata from sitmap files.
Enabling this option allows the crawler to detect and parse sitemaps. The crawler
support sitemap and sitemap index files as defined by the specification at
http://www.sitemaps.org/protocol.php.
The crawler uses the 'lastmod' attribute in a sitemap to see if a page has been
modified since the last time the sitemap was retrieved. Pages that have not been
modified will not be recrawled. An exception to this is if the collection uses
adaptive refresh mode. In adaptive refresh mode the crawler will use the 'priority'
and 'changefreq' attributes of a sitemap in order to determine how often a page
should be crawled. For more information see Adaptive Parameters on page 91.
Custom tags found in sitemaps are stored in the crawlers meta database and
can be submitted to document processing.
Note: Most sitemaps are specified in robots.txt. Thus, 'robots' should be
enabled in order to get the best result.
Default: No
<attrib name="use_sitemaps" type="boolean">
no </attrib>
max_reflinks
Maximum referrer links.
Specify the maximum number of referrer links to store per URI (redirects
excluded).
Note: This value can have a major impact on crawler performance.
74
Configuring the Enterprise Crawler
Parameter
Description
Default: 0
<attrib name="max_reflinks" type="integer"> 0 </attrib>
max_pending
Maximum number of concurrent requests per site.
Specify the maximum number of concurrent (outstanding) HTTP requests to a
site at any given time.
Default: 2
<attrib name="max_pending" type="integer"> 8 </attrib>
robots_auth_ignore
Ignore robots.txt authentication errors.
Specify whether or not the crawler should ignore robots.txt if an HTTP 40x
authentication error is returned by the server. If disabled the crawler will not
crawl the site in question at this time.
This option allows you to control whether the crawler should crawl sites returning
401/403 Authorization Required for their robots.txt from the crawl. The robots
standard lists this behavior as a hint for the spider to ignore the site altogether.
However, incorrect configuration of web servers is widespread and can lead to
a site being erroneously excluded from the crawl. Enabling this option makes
the crawler ignore such indications and crawl the site anyway.
Default: yes
<attrib name="robots_auth_ignore" type="boolean"> yes
</attrib>
robots_tout_ignore
Ignore robots.txt timeout.
Specify whether or not the crawler should ignore the robots.txt rules if the request
for this file times out.
Before crawling a site, the crawler will request the robots.txt file from the server,
according to the rules for limiting what areas of a site may be crawled. According
to these rules, if the request for this file times out the entire site should be
considered off-limits to the crawler.
Setting this parameter to yes indicates that the robots.txt rules should be ignored,
and the site crawled. Keep this option set to no if you do not control the site
being crawled.
Default: no
<attrib name="robots_tout_ignore" type="boolean"> no
</attrib>
rewrite_rules
Rewrite rules.
Specify a number of rewrite rules that rewrite certain URIs. Typical usage is to
rewrite URIs with session-ids by removing the session-id part. Sed-type format.
Separator character is the first one encountered, in this example "@".
<attrib name="rewrite_rules" type="list-string">
<member>
<![CDATA[@(.*/servlet/.*[&?])r=.*?(&|$)(.*)@\1\3@ ]]>
</member>
<member> <![CDATA[@(.*);jsessionid=.*?(\?.*|$)@\1\2@
75
FAST Enterprise Crawler
Parameter
Description
]]> </member>
</attrib>
extract_links_from_dupes
Extract links from duplicates.
Even though two documents have duplicate contents, they may have different
links. Specify whether or not you want the crawler to extract links from duplicates.
If enabled, you may get duplicate links in the URI-queues. If duplicate documents
contain duplicate links then you can disable this parameter.
Default: no
<attrib name="extract_links_from_dupes" type="boolean">
no </attrib>
use_meta_csum
Include HTML META tag contents in checksum.
Specify if you want the crawler to include the contents (values) of HTML META
tags when generating the document checksum used for duplicate detection.
Use this to find changes in the document META tags.
Default: no
<attrib name="use_meta_csum" type="boolean">no</attrib>
csum_cut_off
Checksum cut-off limit.
When crawling multimedia content through a multimedia proxy (schemes MMS
or RTSP), use this setting to determine if a document has been modified. Rather
than downloading an entire document, only the number of bytes specified in this
setting will be transferred and the checksum calculated on that initial portion of
the file. This saves bandwidth after the initial crawl cycle, and reduces the load
on other system and network resources as well.
Default: 0 (disabled)
<attrib name="csum_cut_off" type="integer">0</attrib>
if_modified_since
Send If-Modified-Since header.
Specify if you want the crawler to send If-Modified-Since headers.
Default: yes
<attrib name="if_modified_since" type="boolean"> yes
</attrib>
use_cookies
Use cookies.
Specify if you want the crawler to store/send cookies received in HTTP headers.
This feature is automatically enabled for sites that use a login, but can also be
turned on globally through this option.
Default: no
<attrib name="use_cookies" type="boolean"> no </attrib>
uri_search_mime
Document MIME types to extract links from.
This option specifies MIME types that should be searched for links. If not already
listed in the default list, type in a MIME type you want to search for links.
76
Configuring the Enterprise Crawler
Parameter
Description
Note that wildcard on type and subtype is allowed. For instance, text/* or
*/html are valid. No other regular expression is supported.
<attrib name="uri_search_mime" type="list-string">
<member> text/html </member>
<member> text/plain </member>
</attrib>
variable_delay
Variable request rate.
Specify time slots when you want to use a higher or lower request rate (delay)
than the main setting. Time slots are specified as ending and starting points,
and cannot overlap. Time slot start and endpoints are specified with day of week
and time of day (optionally with minute resolution).
You can also enter the value suspend in the delay field that will suspend the
crawler so that there is no crawling for the time span specified.
<section name="variable_delay">
<!-- Crawl with delay 20 Wednesdays -->
<attrib name="Wed:00-Wed:23" type="string">20 </attrib>
<!-- Crawl with delay 2 during weekends -->
<attrib name="Sat:08.00-Sun:20.30"
type="string">2</attrib>
<!-- Dont crawl Mondays -->
<attrib name="Mon:00-Mon:23"
type="string">suspend</attrib>
</section>
site_clusters
Explicit site clustering.
Specify if you want to override normal routing of sites and force certain sites to
be on the same uberslave. This is useful when cookies/login is enabled, since
cookies are global only within an uberslave. Also if you know certain sites are
closely interlinked you can reduce internal communication by clustering them.
<section name="site_clusters">
<attrib name="mycluster" type="list-string">
<member> site1.example.com </member>
<member> site2.example.com </member>
<member> site3.example.com </member>
</attrib>
</section>
refresh_mode
workqueue_priority
Refer to Refresh Mode Parameters on page 89 for option information.
Refer to Work Queue Priority Rules on page 89 for option information.
adaptive
Refer to Adaptive Parameters on page 91 for option information.
max_backoff_counter and
max_backoff_delay
Maximum connection error backoff counter.
and
Maximum connection error backoff delay.
77
FAST Enterprise Crawler
Parameter
Description
Together these options control the adaptive algorithm by which a site
experiencing connection failures (for example, network errors, timeouts, HTTP
503 "Server Unavailable" errors) are contacted less frequently. For each
consecutive instance of these errors, the inter-request delay for that site is
incremented by the initial delay setting (delay setting):
Increasing delay = current delay + delay
The maximum delay for a site will be the max_backoff_delay setting. If the
number of failures reaches max_backoff_counter, crawling of the site will
become idle.
Should the network issues affecting the site be resolved, the internal backoff
counter will start decreasing, with the inter-request delay lowered on each
successful document fetch by half:
Decreasing delay = current delay / 2
This continues until the original delay (delay setting) is reached.
Default:
<attrib name="max_backoff_counter" type="integer"> 50
</attrib>
<attrib name="max_backoff_delay" type="integer"> 600
</attrib>
http_errors
ftp_errors
Refer to HTTP Errors Parameters on page 93 for option information.
FTP error handling.
Specify how various response codes and error conditions are handled for FTP
URIs. Same XML structure as the http_errors section.
Logins
storage
delay
Refer to Logins parameters on page 94 for option information.
Refer to Storage parameters on page 96 for option information.
Delay between document requests (request rate).
This option specifies how often (the delay between each request) the crawler
should access a single web site when crawling.
<attrib name="delay" type="real"> 60.0 </attrib>
Note: FAST license terms do not allow a more frequent request rate setting
than 60 seconds for external sites unless an agreement exists between the
customer and the external site.
refresh
Refresh interval.
refresh_mode
<attrib name="refresh" type="real"> 1440 </attrib>
The crawler retrieves documents from web servers. Since documents on web
servers frequently change, are added or removed, the crawler must periodically
crawl a site over again to reflect this. In the default crawler configuration, this
78
Configuring the Enterprise Crawler
Parameter
Description
refresh interval is one day (1440 minutes), meaning that the crawler will start
over crawling a site every 24 hours.
Since characteristics of web sites may differ, and customers may want to handle
changes differently, the action performed at the time of refresh is also
configurable, via the refresh_mode
<attrib name="refresh" type="real"> 1440 </attrib>
robots
Respect robot directives.
This parameter indicates whether or not to follow the directives in robots.txt files.
<attrib name="robots" type="boolean"> yes </attrib>
include_domains
Sites included in crawl.
This parameter is a set of rules of which a hostname must match at least one
in order to be crawled. An empty section matches all domains.
Note: This setting is a primary control over the pages included in the crawl
(and index), and should not be changed without care.
Valid rules types are:
prefix: Matches the given sitename prefix (for example, www matches
www.example.net, but not download.example.net)
exact: Matches the exact sitename
file: Identifies a local (to the crawler host) file containing include and/or
exclude rules for the configuration. Note that in a multiple node configuration,
the file must be present on all crawler hosts, in the same location.
suffix: Matches the given sitename suffix (for example, com matches
www.example.com)
regexp: Matches the given sitename against the specified regular expression
(left to right).
IP mask: Matches IP addresses of sites against specified dotted-quad or
CIDR expression.
<section name="include_domains">
<attrib name="suffix" type="list-string">
<member> example.net </member>
<member> example.com </member>
</attrib>
<attrib name="regexp" type="list-string">
<member> .*\.alltheweb\.com </member>
</attrib>
</section>
exclude_domains
Sites excluded from crawl.
This parameter is a set of rules of which a hostname must not match any rules
in order to be crawled. An empty section matches no domains (allowing all to
be crawled). Syntax is identical to include_domains parameter with only the
section name being different.
Note: This setting is a primary control over the pages included in the crawl
(and index), and should not be changed without care.
79
FAST Enterprise Crawler
Parameter
include_uris
Description
Included URIs.
This parameter is a set of rules of which a URI must match at least one rule in
order to be crawled. An empty section matches all URIs. Syntax is identical to
include_domains parameter with only the section name being different.
Note: This setting is a primary control over the pages included in the crawl
(and index), and should not be changed without care.
Note:
The semantics of URI and hostname inclusion rules have changed since
ESP 5.0 (EC 6.3). In previous ESP releases these two rule types were
evaluated as an AND, meaning that a URI has to match both rules (when
rules are defined). As of ESP 5.1 and later (EC 6.6 up), the rules processing
has changed to an OR operator, meaning a URI now only needs to match
one of the two rule types.
For example, an older configuration for fetching pages with the prefix
http://www.example.com/public would specify two rules:
•
•
include_domains: www.example.com (exact)
include_uris: http://www.example.com/public/ (prefix)
The first rule is no longer needed, and if not removed would allow any URI
from that host to be fetched, not only those from the /public path. Some
configurations may be much more complex than this simple example, and
require careful adjustment in order to restrict URIs to the same limits as
before. Contact Contact Us on page iii for assistance in reviewing your
configuration, if in doubt.
Existing crawler configurations migrating from EC 6.3 must be manually
updated, by removing or adjusting the hostname include rules that overlap
with URI include rules.
exclude_uris
Excluded URIs.
This parameter is a set of rules of which a URI must not match any rules in order
to be crawled. An empty section matches no URIs (allowing all to be crawled).
Syntax is identical to include_domains with only the section name being
different.
Note: This setting is a primary control over the pages included in the crawl
(and index), and should not be changed without care.
start_uris
Start URIs for the collection.
This parameter is a list of start URIs for the specified collection. The crawler
needs either start_uris or start_uri_files specified to start crawling.
Note: If your crawl includes any IDNA domain names, you should enter
them using UTF-8 characters, and not in the DNS encoded format.
<attrib name="start_uris" type="list-string">
<member> http://www.example.com/ </member>
<member> http://example.øl.no/ </member>
</attrib>
80
Configuring the Enterprise Crawler
Parameter
start_uri_files
Description
Start URI files for the collection.
This parameter is a list of start URI files for the specified collection. The file
format is plain text with one URI per line. The crawler needs either start_uris
or start_uri_files specified to start crawling.
Note: In a multiple node configuration, the file must be available on all
masters.
<attrib name="start_urifiles" type="list-string">
<member> urifile.txt </member>
<member> urifile2.txt </member>
</attrib>
mirror_site_files
Map file of primary/secondary servers for a site.
This parameter is a list of mirror site files for the specified domain. The file format
is a plain text, whitespace-separated list of sites, with the preferred (primary)
name listed first.
Note: In a multiple node configuration, the file must be available on all
masters.
<attrib name="mirror_site_files" type="list-string">
<member> mirror_mappings.txt </member>
</attrib>
max_sites
Maximum number of concurrent sites.
This parameter limits the maximum number of sites that can be handled
concurrently by this crawler node.
This value applies per crawler node in a distributed setup.
Note: This value can have a major impact on system resource usage.
<attrib name="max_sites" type="integer"> 128 </attrib>
proxy
Proxy address.
This parameter specifies a proxy to redirect all HTTP communication. The proxy
can be specified in the format:
(http://)?(user:pass@)?hostname(:port)?
Default port: 3128
<attrib name="proxy" type="list-string">
<member> proxy1.example.com:3128 </member>
<member> proxyB.example.com:8080 </member>
</attrib>
proxy_max_pending
Proxy open connection limit.
81
FAST Enterprise Crawler
Parameter
Description
This parameter specifies a limit on the number of outstanding open connections
per proxy, per uberslave in the configuration.
<attrib name="proxy_max_pending" type="integer"> 8 </attrib>
passwd
document_plugin
Refer to Password Parameters on page 97 for option information.
Specify user-defined document/redirect processing program.
Specify a user-written Python module to be used for processing fetched
documents and (optionally) URI redirections.
The value specifies the python class module, ending with your class name. The
crawler splits on the last '.' separator and converts this to the Python equivalent
"from <module> import <class>". The source file should be located
relative to $PYTHONPATH, which for FDS installations corresponds to
${FASTSEARCH}/lib/python2.3/.
<attrib name="document_plugin" type="string">
tests.plugins.plugins.helloworld</attrib>
Refer to Implementing a Crawler Document Plugin Module on page 118 for more
information.
headers
List of additional HTTP headers to send.
List of additional headers to add to the request sent to the web servers. Typically
this is used to specify a user-agent header.
<attrib name="headers" type="list-string">
<member> User-agent: FAST Enterprise Crawler 6 </member>
</attrib>
cut_off
Maximum document size in bytes.
This parameter limits the maximum size of documents. Document s larger than
the specified number of bytes will be truncated or discarded (refer to truncate
setting).
Default: no cut-off
<attrib name="cut_off" type="integer"> 100000000 </attrib>
truncate
Truncate/discard docs exceeding cut-off.
This parameter specifies the action taken when a document exceeds the specified
cut-off threshold. A value of "yes" truncates the document at that size and a
value of "no" discards the document entirely.
Default: yes
<attrib name="truncate" type="boolean"> yes </attrib>
diffcheck
Duplicate screening.
This parameter indicates whether or not duplicate screening should be performed.
<attrib name="diffcheck" type="boolean"> yes </attrib>
82
Configuring the Enterprise Crawler
Parameter
check_meta_robots
Description
Inspect META robots directive.
This parameter indicates whether or not to follow the directives given in the
META robots tag (noindex or nofollow).
<attrib name="check_meta_robots" type="boolean"> yes
</attrib>
obey_robots_delay
Respect robots.txt crawl-delay directive.
This parameter indicates whether or not to follow the crawl-delay directive in
robots.txt files. In a site's robots.txt file, the non-standard directive
Crawl-delay: 120 may be specified, where the numerical value is the number
of seconds to delay between page requests. If this setting is enabled, this value
will override the collection-wide delay setting for this site.
<attrib name="obey_robots_delay" type="boolean"> no
</attrib>
key_file
SSL key file.
An SSL key file to use for HTTPS connections.
Note: In a multiple node configuration, the file must be on all masters.
<attrib name="key_file" type="string"> key.pem </attrib>
cert_file
SSL cert file.
An SSL certificate file to use for HTTPS connections.
Note: In a multiple node configuration, the file must be on all masters.
<attrib name="cert_file" type="string"> cert.pem </attrib>
max_doc
Maximum number of documents
This parameter indicates the maximum amount of documents to download from
a web site.
<attrib name="max_doc" type="integer"> 5000 </attrib>
enforce_delay_per_ip
Limit requests per target IP address.
Use this parameter to force the crawler to limit requests (per the delay setting)
to web servers whose names map to a shared IP address.
Default: yes
<attrib name="enforce_delay_per_ip" type="boolean"> yes
</attrib>
wqfilter
Enable work queue Bloom filter.
This parameter enables filtering that screens duplicate URI entries from the
per-site work queues. Sizing of the filter is automatic.
Default: yes
<attrib name="wqfilter" type="boolean"> yes </attrib>
83
FAST Enterprise Crawler
Parameter
smfilter
Description
Slave/Master Bloom filter.
This parameter enables a Bloom filter to screen URI links transferred between
slaves and master. The value is the size of the filter, specifying the number of
bits allocated, which should be between 10 and 20 times the number of URIs
to be screened.
It is recommended that you turn on this filter for large crawls; recommended
value is 50000000 (50 megabit).
Default: 0
<attrib name="smfilter" type="integer"> 0 </attrib>
mufilter
Master/Ubermaster Bloom filter.
This parameter enables a Bloom filter to screen URI links transferred between
masters and the ubermaster. The value is the size of the filter, specifying the
number of bits allocated, which should be between 10 and 20 times the number
of URIs to be screened.
Note: Enabling this setting with a positive integer value disables the
crosslinks cache.
It is recommended that you turn on this filter for large crawls; recommended
value is 500000000 (500 megabit).
Default: 0 (disabled)
<attrib name="mufilter" type="integer"> 0 </attrib>
umlogs
Ubermaster log file consolidation.
If enabled (as by default), all logging is sent to the ubermaster host for storage.
In large multiple node configurations it can be disabled to reduce inter-node
communications, reducing resource utilization, at the expense of having to check
log files on individual masters.
<attrib name="umlogs" type="boolean"> yes </attrib>
crawlmode
Specify crawl mode.
This parameter indicates the crawl mode that should be applied to a collection.
Note: This setting is the primary control over the pages included in the
crawl (and index) and should not be changed without care.
The following settings exist:
mode: Specifies either FULL or DEPTH:# (where # is the maximum number
of levels to crawl from the start URIs). Default: FULL
fwdlinks: Specifies whether or not to follow external links from servers.
Default: yes
fwdredirects: Specifies whether or not to follow external redirects received
from servers. Default: yes
84
Configuring the Enterprise Crawler
Parameter
Description
reset_level: Specifies whether or not to reset level counter when following
external links. Doing so will result in a deeper crawl and you will generally
want this set to "no" when doing a DEPTH crawl. Default: yes
<section name="crawlmode">
<attrib name="mode" type="string"> DEPTH:1 </attrib>
<attrib name="fwdlinks" type="boolean"> yes </attrib>
<attrib name="reset_level" type="boolean"> no </attrib>
</section>
Master
Master Crawler node inclusion.
In a multiple node crawler setup, each instance of this parameter specifies a
crawler node to include in the crawl. The following example specifies use of the
crawler node named "crawler_node_1":
<Master name="crawler_node1"> </Master>
It is possible to override "global" FAST ESP parameters for a crawler node by
including "local" values of the parameters within the <Master> tag:
<Master name="crawler_node1"> <attrib name="delay"
type="integer">60 </attrib> </Master>
It is possible to specify "local" values for all "global" collection parameters. A
specific sub collection may be bound to a crawler node by including a
<subdomain> tag within the <Master> tag:
<Master name="crawler_node1">
<attrib name="subdomain" type="list-string">
<member> subdomain1 </member>
</attrib>
</Master>
Note: Having no masters specified means that whatever masters are
connected when the configuration is initially added will be used.
sort_query_params
Sort query parameters.
This parameter tells the crawler whether or not it should sort the query
parameters in URIs.
For example, http://example.com/?a=1&b=2 is really the same URI as
http://example.com/?b=2&a=1. If this parameter is enabled, then the URIs
will be rewritten to be the same. If not, the two URIs most likely will be screened
as duplicates.The problem however arises if the two URIs are crawled at different
times, and the page has changed during the time of which the first one was
crawled. In this case you can end up with both URIs in the index.
Note: Changing this setting after an initial crawl has been done might also
lead to duplicates.
<attrib name="sort_query_params" type="boolean"> no
</attrib>
post_payload
POST payload.
85
FAST Enterprise Crawler
Parameter
Description
This parameter can be used to submit data as the payload to a POST request
made to a URI matching the specified URI prefix or exact match. To specify a
URI prefix, use the label prefix:, then the leading portion of the URIs to match.
A URI alone will be tested for an exact match.
The payload value can be any data accepted by the target web server, but often
URL encoding of variables is required.
<section name="post_payload">
<attrib name="prefix:http://vault.example.com/secure"
type="string"> variable1=value1&variableB=valueB </attrib>
</section>
Note: Use of this option should be tested carefully, with header logs
enabled, to ensure expected response from remote server[s].
pp
SubDomain
Refer to PostProcess Parameters on page 98 for option information.
Specifies a sub collection (subdomain) within the collection.
Within a collection, you can specify sub collections with individual configuration
options. The following options are valid within a sub collection:
ftp_passive, allowed_schemes, include_domains, exclude_domains,
include_uris, exclude_uris, refresh, refresh_mode, use_http_1_1,
accept_compression, delay, crawlmode, cut_off, start_uris,
start_uri_files, headers, use_javascript, use_sitemaps ,
max_doc , proxy , enable_flash , rss and variable_delay.
One of either include_domains, exclude_domains, include_uris or
exclude_uris must be specified; the others are optional. This is used for
directing URI/sites to the sub collection.
The refresh parameter of a sub collection must be set lower than the refresh
rate of the main domain.
Note: The following options can only have a domain granularity:
use_javascript, enable_flash and max_doc
<SubDomain name="rabbagast">
<section name="include_uris">
<attrib name="prefix" type="list-string">
<member> http://www.example.net/index </member>
</attrib>
</section>
<attrib name="refresh" type="real"> 60.0 </attrib>
<attrib name="delay" type="real"> 10.0 </attrib>
<attrib name="start_uris" type="list-string">
<member> http://www.example.net/ </member>
</attrib>
</SubDomain>
log
cachesize
86
Refer to Log Parameters on page 100 for option information.
Refer to Cache Size Parameters on page 101 for option information.
Configuring the Enterprise Crawler
Parameter
link_extraction
robots_timeout
Description
Refer to Link Extraction Parameters on page 102 for option information.
Use this parameter to specify the maximum amount of time in seconds you want
to allow for downloading a robots.txt file.
Before crawling a site, the crawler will attempt to retrieve a robots.txt file from
the server that describes areas of the site that should not be crawled. Set this
value high if you expect to have comparably slow interactions requesting
robots.txt.
Default: 300
<attrib name="robots_timeout" type="integer"> 300 </attrib>
login_timeout
Use this parameter to specify the maximum amount of time in seconds you want
to allow for login requests.
Set this value high if you expect to have comparably slow interactions with login
requests.
Default: 300
<attrib name="login_timeout" type="integer"> 300 </attrib>
post_payload
Use this parameter to specify a data payload that will be submitted by HTTP
POST to all URIs matching the specified URI prefix.
<section name="post_payload">
<attrib name="http://www.example.com/testsubmit.php"
type="string">
randomdatahere
</attrib>
</section>
send_links_to
The parameter allows one collection to send all extracted links to another crawler
collection. This can, for instance, be useful when setting up RSS crawling. You
can do RSS crawling with a high refresh rate in one collection, and make it pass
new URIs to another collection which does normal crawling.
<attrib
name="send_links_to" type="string"> collection_name
</attrib>
Crawling thresholds
The option allows you to specify fail-safe limits for the crawler. When the limits are exceeded, the crawler
enters a mode called 'refresh', which makes sure that only URIs that have been crawled previously will be
crawled.
The following table describes the crawler thresholds to be set
Table 24: Crawler thresholds
87
FAST Enterprise Crawler
Parameter
disk_free
Description
This option allows you to specify, in percentage, the amount of free disk space
that must be available for the crawler to operate in normal crawl mode. If the
disk free percentage drops below this limit, the crawler enters the 'refresh' crawl
mode.
Default: <attrib name="disk_free" type="integer"> 0 </attrib>
(0 == disabled)
disk_free_slack
This option allows you to specify, in percentage, a slack to the disk_free
threshold. By setting this option, you create a buffer zone above the 'disk_free'
threshold. When the current free disk space is in this zone, the crawler will not
change the crawl mode back to normal. This prevents the crawler from switching
back and forth between the crawl modes when the percentage of free disk space
is close to the value specified by the 'disk_free' parameter. When the available
disk space percentage rises above disk_free + disk_free_slack, the crawler will
change back to normal crawl mode..
Default: <attrib name="disk_free_slack" type="integer"> 3
</attrib>
max_doc
This option allows you to specify, in number of documents, the number of stored
documents that will trigger the crawler to enter the 'refresh' crawl mode. Note:
the threshold specified is not an *exact* limit, as the statistics reporting is
somewhat delayed compared to the crawling.
Default: <attrib name="max_doc" type="integer"> 0 </attrib>
(0 == disabled)
Note: This option should not be confused with Max document count per
site option.
max_doc_slack
This option allows you to specify the number of documents which should act as
a buffer zone between normal mode and 'refresh' mode. The option is related
to the 'max_doc' parameter. Whenever the 'refresh' mode is activated, because
the number of documents has exceeded the 'max_doc' parameter, a buffer zone
is created between the 'max_doc' and 'max_doc'-'max_doc_slack'. The crawler
will not change back to normal mode within the buffer zone. This prevents the
crawler from switching back and forth between the crawl modes when the number
of docs is close to the 'max_doc' threshold value.
Default: <attrib name="max_doc_slack" type="integer"> 1000
</attrib>
Example:
<section name="limits">
<attrib name="disk_free" type="integer"> 0 </attrib>
<attrib name="disk_free_slack" type="integer"> 3 </attrib>
<attrib name="max_doc" type="integer"> 0 </attrib>
<attrib name="max_doc_slack" type="integer"> 1000 </attrib>
</section>
Note: This special refresh crawl mode can also be user initiated enabled with the crawleradmin tool.
88
Configuring the Enterprise Crawler
Refresh Mode Parameters
The refresh_mode allows you to specify the refresh mode of the collection.
The following table describes the valid refresh modes
Table 25: Refresh Mode Parameter Options
Option
append
prepend
scratch
Description
The Start URIs are added to the end of the crawler work queue at the start of
every refresh. If there are URIs in the queue, Start URIs are appended and will
not be crawled until those before them in the queue have been crawled.
The Start URIs are added to the beginning of the crawler work queue at every
refresh. However, URIs extracted from the documents downloaded from the
Start URIs will still be appended at the end of the queue.
The work queue is truncated at every refresh before the Start URIs are appended.
This mode discards all outstanding work on each refresh event. It is useful when
crawling sites with dynamic content that produce an infinite number of links.
Default: <attrib name="refresh_mode" type="string"> scratch
</attrib>
soft
adaptive
If the work queue is not empty at the end of a refresh period, the crawler will
continue crawling into the next refresh period. A server will not be refreshed
until the work queue is empty. This mode allows the crawler to ignore the refresh
event for a site if it is not idle. This allows large sites to be crawled in conjunction
with smaller sites, and the smaller sites can be refreshed more often than the
larger sites.
Build work queue according to scoring of URIs and limits set by adaptive section
parameters. The overall refresh period can be subdivided into multiple intervals,
and high-scoring URIs re-fetched during each interval, to maintain content
freshness while still completing deep sites.
Refresh_when_idle
This option allows you to specify whether the crawler automatically should trigger a new refresh cycle when
the crawler goes idle (all websites are finished crawling) in the current refresh cycle.
Default: <attrib name="refresh_when_idle" type="boolean"> no </attrib >
Note: This option cannot be used with a multi node crawler.
Work Queue Priority Rules
The workqueue_priority section allows you to specify how many priority levels you want the work queue
to consist of, and various rules and methods for how to insert and extract entries from the work queue.
Note: Extensive testing is strongly recommended before production use, to insure that desired processing
patterns are attained.
The following table describes the possible options:
Table 26: Work Queue Priority Parameter Options
89
FAST Enterprise Crawler
Option
levels
Description
This option allows you to specify the number of priority levels you want the
crawler work queue to have.
Note: If this value is ever decreased in value (e.g. from 3 to 1), the on-disk
storage for the work queues must be deleted manually to recover the disk
space.
Default: 1
default
This option allows you to specify the default priority level for extracting and
inserting URIs from/to the work queue.
Default: 1
start_uri_pri
This option allows you to specify the priority level for URIs coming from the
start_uris/start_uri_files option.
Default: 1
pop_scheme
This option allows you to specify which method you want the crawler to use
when extracting URIs from the work queue.
Available values are:
rr - extract URIs from the priority levels in a round-robin fashion.
wrr - extract URIs from the priority levels in a weighted round-robin fashion.
The weights are based on their respective share setting per priority level.
Basically URIs are extracted from the queue with the highest share value;
when all shares are 0 the shares are reset to their original settings.
pri - extract URIs from the priority levels in a priority fashion by always
extracting from the highest priority level if there still are entries available (1
being the highest).
default - same as wrr.
Default: default
put_scheme
This option allows you to specify which method you want the crawler to use
when inserting the URIs into the work queue.
Available values are:
default - always insert URIs with default priority level.
include - insert URIs with the priority level defined by the includes specified
for every priority level. If no includes match, the default priority level will be
used.
Default: default
For each priority level specified, you can define:
share - this value allows you to specify a share or weight for each queue
to be used when utilizing the wrr (weighted round robin) of extracting entries
the work queue.
include_domains, include_uris - these values allow you to specify a
set of inclusion rules for each priority level to be used when utilizing the
include method of inserting entries to queue.
90
Configuring the Enterprise Crawler
Work Queue Priority Parameter Example
<section name="workqueue_priority">
<!-- Define a work queue with 2 priority levels -->
<attrib name="levels" type="integer"> 2 </attrib>
<!-- Default priority level is 2. For this specific setting
it means that a URI that doesn't match the specified
includes for the queues will be inserted with priority
level 2 -->
<attrib name="default" type="integer"> 2 </attrib>
<!-- Default priority level of start URIs is 1 -->
<attrib name="start_uri_pri" type="integer"> 1 </attrib>
<!-- Use weighted round robin for extracting from the queue
according to the share specified per queue below -->
<attrib name="pop_scheme" type="string"> wrr </attrib>
<!-- Use include based insertion scheme according to the include
rules specified for each queue below -->
<attrib name="put_scheme" type="string"> include </attrib>
<!-- Settings for the first priority level queue (1) -->
<section name="1">
<!-- This queues share/weight is 10 -->
<attrib name="share" type="integer"> 10 </attrib>
<!-- These include rules defines the URIs that should
enter the 1st priority level -->
<section name="include_domains">
<attrib name="suffix" type="list-string">
<member> web005.example.net </member>
<member> web006.example.net </member>
</attrib>
</section>
</section>
<!-- Settings for the second priority level queue (2) -->
<section name="2">
<attrib name="share" type="integer"> 10 </attrib>
<section name="include_domains">
<attrib name="suffix" type="list-string">
<member> web002.example.net </member>
<member> web003.example.net </member>
</attrib>
</section>
</section>
</section>
Adaptive Parameters
The adaptive section allows you to configure adaptive scheduling options.
Note: This section is only applicable if refresh_mode is set to adaptive.
Note: Extensive testing is strongly recommended before production use, to insure that desired pages
and sites are properly represented in the index.
The following table describes the possible options:
Table 27: Adaptive Parameter Options
Option
refresh_count
refresh_quota
Description
Number of minor cycles within the major cycle.
Ratio of existing URIs re-crawled to new (unseen) URIs, expressed as
percentage.
High value = re-crawling old content
91
FAST Enterprise Crawler
Option
Description
Low value = prefer fresh content
coverage_max_pct
coverage_min
Limit percentage of site re-crawled within a minor cycle. Ensures small sites do
not crawl fully each minor cycle, starving large sites.
Minimum number of URIs from a site to be crawled in a minor cycle.
Used to guarantee some coverage for small sites.
weights
Each URI is scored against a set of rules to determine its crawl rank value. The
crawl rank value is used to determine the importance of the particular URI, and
hence the frequency at which it is re-crawled (from every micro cycle to only
once every major cycle).
Each rule is assigned a weight to determine its contribution towards the total
rank value. Higher weights produce higher rank contribution. A weight of 0
disables a rule altogether.
Adaptive Crawling Scoring Rules:
inverse_length: Based on number of slashes (/) in URI path. Max score for
1, no score for 10 or more. Default weight: 1.0
inverse_depth: Based on number of link "hops" to this URI. Max score for
none (for example, start_uri), no score for 10 or more. Default weight: 1.0
is_landing_page: Bonus score if "landing page", ends in / or index.html.
Any page with query parameters gets no score. Default weight: 1.0
is_mime_markup: Bonus score if "markup" page listed in
uri_search_mime attribute. Preference to more dynamic content (vs. PDF,
Word, other static docs). Default weight: 1.0
change_history: Scored on basis of last-modified value over time (or
estimate). Default weight: 10.0
sitemap: Score based on the metadata found in sitemaps. The score is
calculated by multiplying the value of the changefreq parameter with the
priority parameter in a sitemap. Default weight: 10.0
sitemap_weights
Sitemap entries may contain a changefreq attribute. This attribute gives a hint
on how often a page is changed. The value of this attribute is a string. This string
value is mapped to a float value in order for the adaptive scheduler to calculate
an adaptive rank. This mapping can be changed by configuring the
sitemap_weights section.
Note that in addition to the defined values a default attribute is defined.
Documents with no changefreq attribute are given the value of the default
weight for priority.
Sitemap Changefreq Weights:
always Map the changefreq value 'always' to a numerical value. Default
weight: 1.0
hourly Map the changefreq value 'hourly' to a numerical value. Default
weight: 0.64
daily Map the changefreq value 'daily' to a numerical value. Default weight:
0.32
weekly Map the changefreq value 'weekly' to a numerical value. Default
weight: 0.16
92
Configuring the Enterprise Crawler
Option
Description
monthly Map the changefreq value 'monthly' to a numerical value. Default
weight: 0.08
yearly Map the changefreq value 'yearly' to a numerical value. Default
weight: 0.04
never Map the changefreq value 'never' to a numerical value. Default weight:
0.0
default This value is assigned to all documents that have no changefreq
attribute. Default weight: 0.16
HTTP Errors Parameters
The http_errors section specifies how various response codes and error conditions are handled for HTTP(S)
URIs.
The following table describes the possible options:
Table 28: HTTP Errors Parameter Options
Option
Description
4xx or 5xx
Specify handling for all 40X or 50x HTTP response codes.
Valid options for handling individual response codes are:
"KEEP" - keep the document (leave unchanged)
"DELETE[:X]" - delete the document if the error condition occurs for X
retries. If no X value is specified deletion happens immediately.
For both of these options "RETRY[:X]" can be specified, for which the crawler
will try to download the document again X times in the same refresh period
before giving up.
Note: If different behavior is desired for a specific value within one of these
ranges, e.g. for HTTP status 503, it may be given its own handling
specification.
ttl or net or int
Specify handling for:
•
•
•
HTTP connections that time out
net (socket) errors
internal errors
HTTP Errors Parameter Example
<section name="http_errors">
<!-- 408 HTTP status code: Request Timeout -->
<attrib name="408" type="string"> KEEP </attrib>
<!-- 40x HTTP return codes: delete immediately -->
<attrib name="4xx" type="string"> DELETE </attrib>
<!-- 50x HTTP return codes: delete after 10 failed fetches, -->
<!-- retry 3 times immediately -->
93
FAST Enterprise Crawler
<attrib name="5xx" type="string"> DELETE:10, RETRY:3 </attrib>
<!-- fetch timeout: delete after 3 failed fetches -->
<attrib name="ttl" type="string"> DELETE:3 </attrib>
<!-- network error: delete after 3 failed fetches -->
<attrib name="net" type="string"> DELETE:3 </attrib>
<!-- Internal handling error (header error, etc): -->
<!-- Never delete -->
<attrib name="int" type="string"> KEEP </attrib>
</section>
Logins parameters
The Logins section allows you to configure HTML form based authentication.You can specify multiple sections
to handle different site logins, but each must have a unique name.
The following table describes the options that may be set:
Table 29: Logins Parameter Options
Option
preload
scheme
site
form
Description
Specify the full URI of a page to be fetched before attempting login form
processing. Some sites require the user to first get a cookie from some page
before proceeding with authentication. Often the Start URI for the site is an
appropriate choice for preload.
Which scheme the form you are trying to log into is using, e.g. http or https.
The hostname of the login form page.
The path to the form you are trying to log into.
Note: The three previous values, scheme + site + form make up the URI of the login form page.
action
parameters
sites
ttl
94
The action of the form (GET or POST).
The credentials as a sequence of key, value parameters the form requires for
a successful log on. These are typically different from form to form, and must
be deduced by looking at the HTML source of the form. In general, if 'autofill' is
enabled, only user-visible (via the browser) variables need be specified, e.g.
username and password, or equivalent. The crawler will fetch the HTML page
(specified in 'html_form') containing the login form and read any "hidden"
variables that must be sent when the form is submitted. If a variable and value
are specified in the parameters section, this will override any value read from
the form by the crawler.
A list of sites that should log into this form before being crawled. Note that this
is a list of hostnames, not URIs.
Time before you have to log in to the form once again, before continuing the
crawl.
Configuring the Enterprise Crawler
Option
Description
html_form
The URI to the HTML page, containing the login form. Used by the 'autofill'
option. If not specified, the crawler will assume the HTML page is specified by
the 'form' option.
autofill
Whether the crawler should download the HTML page, parse it, identify which
form you're trying to log into by matching parameter names, and merge it with
any specified form parameters you may have specified in the 'parameters' option.
Default on.
relogin_if_failed
Whether the crawler after a failed login should attempt to re-login to the web
site after 'ttl' seconds. During this time, the web site will be kept active within the
crawler, thus occupying one available site resource.
Logins Parameter Example
<Login name="mytestlogin">
<!-- Go fetch this URI first, and gather needed cookies -->
<attrib name="preload"
type="string">http://preload.companyexample.com/</attrib>
<!-- The following elements make up the login form URI and what to do
-->
<attrib name="scheme" type="string"> https </attrib>
<attrib name="site" type="string"> login.companyexample.com </attrib>
<attrib name="form" type="string"> /path/to/some/form.cgi </attrib>
<attrib name="action" type="string">POST</attrib>
<!-- Specify any necessary variables/values from the HTML login form
-->
<section name="parameters">
<attrib name="user" type="string"> username </attrib>
<attrib name="password" type="string"> password </attrib>
<attrib name="target" type="string"> sometarget </attrib>
</section>
<!-- Attempt this login before fetching from the following sites -->
<attrib name="sites" type="list-string">
<member> site1.companyexample.com </member>
<member> site2.companyexample.com </member>
</attrib>
<!-- Consider login valid for the following lifetime (in seconds) -->
<attrib name="ttl" type="integer"> 7200 </attrib>
<!-- The html page containing the login form-->
<attrib name="html_form" type="string">
http://login.companyexample.com/login.html </attrib>
<!-- Let the crawler download, parse, and fill in any missing
parameters from the html form -->
<attrib name="autofill" type="boolean"> yes </attrib>
<!-- Attempt to re-login after 'ttl' seonds if login failed -->
<attrib name="relogin_if_failed" type="boolean"> yes </attrib>
</Login>
95
FAST Enterprise Crawler
Storage parameters
The Storage parameter allows you to specify storage related options.
The following table describes the possible options.
Note: These values cannot be changed after a collection has been defined.
Table 30: Storage Parameter Options
Option
datastore
Description
Refer to Datastore Section on page 105 for more information.
Default: bstore
store_http_header
This option specifies if the received HTTP header should be stored as document
metadata. If enabled, the HTTP header will be included when the document is
submitted to the ESP document processing pipeline.
Default: yes
store_dupes
This option allows you to preserve disk space on the crawler nodes by instructing
the crawler not to store documents that are detected as duplicates at runtime
to disk. Duplicates detected by PostProcess are stored to disk initially, but will
be deleted later.
Default: no
compress
This option specifies if downloaded documents should be compressed before
stored on disk. If enabled, gzip compression will be performed.
Default: yes
compress_exclude_mime
MIME types of documents not compressed in storage.
Note that compressing multimedia documents can waste resources, as these
documents are often already compressed. Use this setting to selectively skip
compression of documents based on their MIME type, thus saving resources
both in the crawler (no unnecessary compression) and in the pipeline (no
unnecessary decompression).
remove_docs
This option allows you to preserve disk space on the crawler nodes by instructing
the crawler to remove docs on the disk after they have been processed by the
document processor.
Default: no
Note: Enabling this option will make it impossible to refeed the crawler
store at a later time (e.g. to take advantage of changes made to the
document processing pipeline) since the crawled documents are no longer
available on disk.
clusters
This option specifies how many storage clusters to use for the collection.
Default: 8
Note: In general, this value should not be modified unless so directed by
Contact Us on page iii
96
Configuring the Enterprise Crawler
Option
Description
defrag_threshold
A non-zero value specifies the threshold value, in terms used capacity, before
defragmentation is initiated for any given data storage file. When the available
capacity drops below this level the file is compacted to reclaim fragmented space
caused by previously stored documents. Database files are compacted regardless
of fragmentation.
Default: 85
The default of 85% means there must be 15% reclaimable space in the data
storage file to trigger defragmentation of a particular file. Setting this value to 0
will disable the nightly database/data compression routines.
Note: The data storage format flatfile does not become fragmented,
and this option does not apply to that format.
uri_dir
All URIs extracted from a document by an uberslave process may be stored in
a separate file on disk. This option indicates in which directory to place the URI
files. The name of a URI file is constructed by concatenating the slave process
PID with `.txt'.
Default: The default is not to generate these files (empty directory path).
Storage Parameter Example
<section name="storage">
<attrib name="uri_dir" type="string"> test/URIS </attrib>
<!-- Document store type (flatfile|bstore) -->
<attrib name="datastore" type="string"> bstore</attrib>
<!-- Compress Documents -->
<attrib name='compress' type="boolean"> yes </attrib>
<!-- Do not compress docs with the following MIME types -->
<attrib name="compress_exclude_mime" type="list-string">
<member> video/* </member>
<member> audio/* </member>
</attrib>
<!-- Store HTTP header information -->
<attrib name="store_http_header" type="boolean"> yes </attrib>
<!-- Store duplicates in storage -->
<attrib name="store_dupes" type="boolean"> no </attrib>
<!-- Support removal of documents from disk after processing -->
<attrib name="remove_docs" type="boolean"> no </attrib>
<!-- Defragment data store files with more than 100-n % fragmentation
-->
<attrib name="defrag_threshold" type="integer"> 85 </attrib>
</section>
Password Parameters
Password specification for sites/paths that require Basic Authentication.
Note: Changing the passwd value may result in previously accessible content to eventually be deleted
from the index.
Support includes basic, digest and NTLM v1 authentication.
Note: AD/Kerberos and NTLM v2 is not supported.
Credentials can be keyed on either Realm or URI.
97
FAST Enterprise Crawler
A valid URI can be used as the parameter value, in which case it serves a prefix value, as all links extracted
from the URI at its level or deeper will also utilize the authentication settings.
It is also possible to specify passwords for Realms. When a 401 Unauthorized is encountered, the crawler
attempts to locate a matching realm, and if one exists, the URI will be fetched again with corresponding
user/passwd set. As this requires two HTTP transactions for each document, it is inherently less efficient than
specifying a URI prefix.
The credentials format is: user:password:realm:scheme, though you can still use the basic format
of: user:password
Scheme can be any of the supported authentication schemes (basic, digest, ntlm) or auto in which the crawler
tries to pick one on its own.
<section name=“passwd”>
<!-- username: "bob" password: "bobsecret" domain: "mysite"
authentication scheme: "auto" -->
<attrib name=“http://www.example.net/confidential1/” type=“string”>
bob:bobsecret:mysite:auto
</attrib>
<!-- Escaping characters in the password may be necessary -->
<!-- username: "bob" password: "bob:secret\" domain: "myothersite"
authentication scheme: "basic" -->
<attrib name=“http://www.example.net/confidential2/” type=“string”>
bob:bob\:secret\\:myotherdomain:basic
</attrib>
</section>
Note: Cookie authentication requires a separate setup. Refer to the Logins Parameters for more
information.
PostProcess Parameters
The pp section configures PostProcess.
The following table describes the possible options:
Table 31: PostProcess Parameter Options
Option
dupservers
Description
This option specifies which duplicate servers should be used in a multiple node
crawler crawl. The crawler will automatically perform load-balancing between
multiple duplicate servers.
Values should be specified as hostname:port, e.g. dup01:18000
Default: none
Note: This setting can not be modified for a collection, once set.
max_dupes
This option specifies the maximum number of duplicates to record along with
the original document.
Default: 10
Note: This setting has a severe performance impact and values above
3-4 are not recommended for large scale crawls.
98
Configuring the Enterprise Crawler
Option
Description
stripe
This option specifies the PostProcess database stripe size; the number of files
to spread the available data across. A value of 1 puts everything in a single file.
Default: 1
Note: This setting can not be modified for a collection, once set.
ds_meta_info
This option identifies the meta info that the PostProcess should report to
document processing.
Available types: duplicates, redirects, referrers, intra links, interlinks.
Default: none
ds_max_ecl
This option specifies the max URI equivalence class length such as the maximum
number of duplicates, redirects or referrers to report to document processing.
Default: 10
ds_send_links
Send extracted links from document to FAST ESP for document processing.
Default: no
ds_paused
This option specifies whether or not the PostProcess should pause feeding to
FAST ESP. When paused, the feed will be written to stable storage.
Note that the value of this setting can be changed via the crawleradmin tool
options, --suspendfeed/--resumefeed.
Default: no
ecl_override
This option specifies a regular expression used to identify URIs that should go
into the URI equivalence class, even though ds_max_ecl is reached. Example:
.*index\.html$
Default: none
PostProcess Parameter Example
<section name="pp">
<attrib name="dupservers" type="list-string">
<member> node5:13000 </member>
<member> node6:13000 </member>
</attrib>
<!-- Limit recorded duplicates for large crawl -->
<attrib name="max_dupes" type="integer"> 2 </attrib>
<!-- Spread data across several files to scale -->
<attrib name="stripe" type="integer"> 8 </attrib>
<attrib name="ds_meta_info" type="list-string">
<member> duplicates </member>
</attrib>
<attrib name="ds_max_ecl" type="integer"> 10 </attrib>
<attrib name="ds_send_links" type="boolean"> yes </attrib>
<!-- Feeding enabled...can override using crawleradmin -->
<attrib name="ds_paused" type="boolean"> no </attrib>
<!-- URI Equivalence class override regexp -->
<attrib name="ecl_override" type="string"> .*index\.html$ </attrib>
</section>
99
FAST Enterprise Crawler
Log Parameters
The log section provides crawler logging options. Use this section to enable or disable various logs.
Note: The use of screened and header logs can be very useful during crawl setup and testing, but should
generally be disabled for production crawls as they can use a lot of disk space. It is sometimes necessary
to enable these when debugging specific issues.
The following table describes the possible options
Table 32: Log Parameter Options
Option
fetch
Description
Document log (collection wide) format. Logs all documents downloaded with
time stamp and response code/error values.
Values: text or none.
Default: text
postprocess
Postprocess log (collection wide) format. Logs all documents output by
postprocess with info.
Values: text, xml or none.
Default: text
header
HTTP Header exchanges log (stored per-site). Logs all header exchanges with
web servers. Useful for debugging, but should not be enabled for production
crawls.
Values: text or none.
Default: none
screened
URI allow/deny log (collection wide) format. Log URIs that are screened for
various reasons. Useful for debugging.
Values: text or none.
Default: none
scheduler
Provides details of adaptive scheduling algorithm processing.
Values: text or none.
Default: none
dsfeed
ESP document processing and indexing feed log. Logs all URIs that PostProcess
receives callbacks on with information on failure/success.
Values: text, none.
Default: text
site
Provide statistics for per-site crawl sessions.
Default: text
100
Configuring the Enterprise Crawler
Log Parameter Example
<section name="log">
<!-- The first two normally enabled -->
<attrib name="fetch" type="string"> text </attrib>
<attrib name="postprocess" type="string"> text </attrib>
<!-- These others enabled for debugging -->
<attrib name="header" type="string"> text </attrib>
<attrib name="screened" type="string"> text </attrib>
<attrib name="site" type="string"> text </attrib>
</section>
Cache Size Parameters
The cachesize section allows configuration of the crawler cache sizes. All cache sizes represent number of
entries unless otherwise noted.
The following table describes possible cache options:
Table 33: Cache Size Parameter Options
Option
duplicates
Description
Duplicate checksum cache.
Default: automatic
screened
URIs screened during crawling.
Default: automatic
smcomm
Slave/Master comm. channel.
Default: automatic
mucomm
Master/Ubermaster comm. channel.
Default: automatic
wqcache
Site work queue cache.
Default: automatic
crosslinks
Crosslinks cache (number of links).
Default: automatic
Note: Defaults for the previous parameters are auto generated based on the max_sites and delay parameters.
routetab
Routing table cache (in bytes).
Default: 1 MB
pp
PostProcess database cache (in bytes).
Default: 1 MB
101
FAST Enterprise Crawler
Option
Description
pp_pending
PostProcess pending (in bytes).
Default: 128 KB
aliases
Aliases mapping database cache (in bytes).
Default: 1 MB
Cache Size Parameter Example
<section name="cachesize">
<!-- Override automatic settings -->
<attrib name="duplicates" type="integer"> 128 </attrib>
<attrib name="screened" type="integer"> 128 </attrib>
<attrib name="smcomm" type="integer"> 128 </attrib>
<attrib name="mucomm" type="integer"> 128 </attrib>
<attrib name="wqcache" type="integer"> 4096 </attrib>
<!-- Increase for large-scale crawl -->
<attrib name="crosslinks" type="integer"> 5242880 </attrib>
<attrib name="routetab" type="integer"> 5242880 </attrib>
<attrib name="pp" type="integer"> 5242880 </attrib>
<attrib name="pp_pending" type="integer"> 1048576 </attrib>
<attrib name="aliases" type="integer"> 5242880 </attrib>
</section>
Link Extraction Parameters
Use the link_extraction section to tell the crawler which links it should follow.
The following table lists possible options:
Table 34: Cache Size Parameter Options
Option
Description
a
URIs found in anchor tags. Default: yes
action
URIs found in action tags. Example: <form
action="http://someaction.com/?submit" method="get"> Default: yes
area
URIs found in area tags (related to image maps). Example: <map
name="mymap"> <area src="http://link.com"> </map> Default: yes
comment
URIs found within comment tags. The crawler extracts links from comments by
looking for http://. Example: <!- this URI is commented away; http://old.link.com/
--> Default: yes
frame
URIs found in frame tags.
Example: <frame src="http://topframe.com/"> </frame>
Default: yes
go
URIs found in go tags. Note that go tags are a feature of the WML specification.
Example: <go href="http://link.com/">
Default: yes
102
Configuring the Enterprise Crawler
Option
img
Description
URIs found in image tags.
Example: <img src="picture.jpg">
Default: no
layer
URIs found in layer tags.
Example: <layer src="http://www.link.com/"></layer>
Default: yes
link
URIs found in link tags.
Example: <link href="http://link.com/">
Default: yes
meta
URIs found in META tags.
Example: <meta name="mymetatag" content="http://link.com/"/>
Default: yes
meta_refresh
URIs found in META refresh tags.
Example: <meta name="refresh"
content="20;URL="http://link.com/"/>
Default: yes
object
URIs found in object tags.
Example: <object data="picture.png">
Default: yes
script
URIs found within script tags.
Example: <script> variable = "http://somelink.com/" </script>
Default: yes
script_java
URIs found within script tags that are JavaScript styled.
Example: <script type="javascript">
window.location="http://somelink.com"</script>
Default: yes
style
URIs found within style tags.
Default: yes
embed
Typically used to insert links into audio files.
Default: yes
card
A link type used to define a card in a WML deck.
Default: yes
103
FAST Enterprise Crawler
Link Extraction Parameter Example
<section name="link_extraction">
<attrib name="a" type="boolean"> yes </attrib>
<attrib name="action" type="boolean"> yes </attrib>
<attrib name="area" type="boolean"> yes </attrib>
<attrib name="comment" type="boolean"> no </attrib>
<attrib name="frame" type="boolean"> yes </attrib>
<attrib name="go" type="boolean"> yes </attrib>
<attrib name="img" type="boolean"> no </attrib>
<attrib name="layer" type="boolean"> yes </attrib>
<attrib name="link" type="boolean"> yes </attrib>
<attrib name="meta" type="boolean"> yes </attrib>
<attrib name="meta_refresh" type="boolean"> yes </attrib>
<attrib name="object" type="boolean"> yes </attrib>
<attrib name="script" type="boolean"> yes </attrib>
<attrib name="script_java" type="boolean"> yes </attrib>
<attrib name="style" type="boolean"> yes </attrib>
<attrib name="embed" type="boolean"> yes </attrib>
<attrib name="card" type="boolean"> no </attrib>
</section>
The ppdup Section
Use the ppdup section to specify the duplicate server settings.
The following table lists possible options:
Table 35: Duplicate Server Options
Option
Description
format
The duplicate server database format. Available formats are:
•
•
•
gigabase
hashlog
diskhashlog
The duplicate server database cache size. If the duplicate server database
format is a hash type, the cache size specifies the initial size of the hash.
cachesize
Note: Specified in MB
stripes
The duplicate server database stripe size.
compact
Specify whether to perform nightly compaction of the duplicate server databases.
Duplicate Server Settings Example
<!-- This option allows you to configure per collection duplicate
server database settings. -->
<section name="ppdup">
<!-- The format of the duplicate server dbs -->
<attrib name="format" type="string"> hashlog </attrib>
<!-- The # of stripes of the duplicate server dbs -->
<attrib name="stripes" type="integer"> 1 </attrib>
<!-- The cache size of the duplicate server dbs - in MB -->
<attrib name="cachesize" type="integer"> 128 </attrib>
<!-- Whether to run nightly compaction of the duplicate server
dbs -->
<attrib name="compact" type="boolean"> no </attrib>
104
Configuring the Enterprise Crawler
</section>
Datastore Section
The datastore section specifies which format to use for the document data store.
The crawler normally stores a collection's documents in the directory:
$FASTSEARCH/data/crawler/store/collectionName/data/.
The following table describes possible options:
Table 36: Datastore Parameter Options
Option
Description
Option
Description
bstore
For each storage cluster that is crawled, a directory is created using the cluster
number. The directory contains:
0-N[.N] - BStore segment files. Documents are stored within numbered
files starting with '0' going up ad infinitum. After each compaction, the file is
appended with a generation identifier, e.g. 0.1 replaces 0, and 17.253
replaces 17.252. The older generation file is retained for up to 24 hours as
a read only resource for postprocess.
0-N[.N].idx - BStore segment index files. Contains the index of each of
the corresponding BStore segment files.
master_index - Contains information about all existing BStore segments.
The crawler will schedule a defragment of the data store to ensure that stale
segments are cleaned up on a daily basis.
flatfiles
The files are stored in a base64-encoded representation of the filenames. Storing
documents in this manner is more metadata intensive on the underlying file
system as each retrieved document is stored in a separate physical file, but
allows the crawler to delete old versions of documents when a new version is
retrieved from the web server.
Feeding destinations
This table describes the options available for custom document feeding destinations. It is possible to submit
document to a collection by another name, multiple collections and even another ESP installation. If no
destinations are specified the default is to feed into a collection by the same name in the current ESP
installation.
Table 37: Feeding destinations
Parameter
name
Description
This parameter specifies a unique name that must be given for the feeding
destination you are configuring. The name can later be used in order to specify
a destination for refeeds.
This field is required.
collection
This parameter specifies the ESP collection name to feed documents into.
Normally this is the same as the collection name, unless you wish to feed into
105
FAST Enterprise Crawler
Parameter
Description
another collection. Ensure that the collection already exists on the ESP
installation designated by destination first.
Each feeding desintation you specify maps to a single collection, thus to feed
the same crawl into multiple collections you need to specify multiple feeding
destinations. It is also possible for multiple crawler collections to feed into the
same target collection.
This field is required.
destination
This parameter specifies an ESP installation to feed to. The available ESP
destinations are listed in the feeding section of the crawler's global configuration
file, normally $FASTSEARCH/etc/CrawlerGlobalDefaults.xml.The XML
file contains a list of named destinations, each with a list of content distributors.
If no destinations are explicitly listed in the XML file you may specify "default"
here, and the crawler will feed into the current ESP installation. This current
ESP installation is that which is specified by
$FASTSEARCH/etc/contentdistributor.cfg.
This field is required, may be "default" unless the gloabl XML file has been
altered.
paused
This option specifies whether or not the crawler should pause document feeding
to FAST ESP. When paused, the feed will be written to stable storage on a
queue.
Note that the value of this setting can be changed via the crawleradmin tool
options, --suspendfeed/--resumefeed.
Default: no
primary
This parameter controls whether this feeding destination is considered a primary
or secondary destination. Only the primary destination is allowed to act on
callback information from the document feeding chain, secondary feeders are
only permitted to log callbacks.
Exactly one feeding destination must be specified as primary.
This field is required.
Example:
<section name="feeding">
<section name="collA">
<attrib name="collection" type="string"> collA </attrib>
<attrib name="destination" type="string"> default </attrib>
<attrib name="primary" type="boolean"> yes </attrib>
<attrib name="paused" type="boolean"> no </attrib>
</section>
<section name="collB">
<attrib name="collection" type="string"> collB </attrib>
<attrib name="destination" type="string"> default </attrib>
<attrib name="primary" type="boolean"> no </attrib>
<attrib name="paused" type="boolean"> no </attrib>
</section>
106
Configuring the Enterprise Crawler
</section>
RSS
This table describes the parameters for RSS crawling.
Note: Extensive testing is strongly recommended before production use, to insure that desired processing
patterns are attained.
Table 38: RSS Options
Parameter
start_uris
Description
This paramter allows you to specify a list of RSS start URIs for the collection to
be configured. RSS documents (feeds) are treated a bit different than other
documents by the crawler. First, RSS feeds typically contain links to articles and
meta data which describes the articles. When the crawler parses these feeds,
it will associate the metadata in the feeds with the articles they point to. This
meta data will be sent to the processing pipeline together with the articles, and
a RSS pipeline stage can be used to make this information searchable. Second,
links found in RSS feeds will be tagged with a force flag. Thus, the crawler will
crawl these links as soon as allowed (it will obey the collection's delay rate), and
they will be crawled regardless if it they have been crawled already in this crawl
cycle. Example: http://www.example.com/rss.xml
Default: Not mandatory
start_uri_files
This parameter requires you to specify a list of RSS start URI files for the
collection to be configured. This option is not mandatory. The format of the files
is one URI per line. Example: C:\MyDirectory\rss_starturis.txt (Windows) or
/home/user/rss_starturis.txt (UNIX).
Default: Not mandatory
auto_discover
This parameter allows you to specify if the crawler should attempt to find new
RSS feeds. If this option is not set, only feeds specified in the RSS start URIs
and/or the RSS start URIs files sections will be treated as feeds.
Default: no
follow_links
This parameter allows you to specify if the crawler should follow links from HTML
documents, which is the normal crawler behavior. If this option is disabled, the
crawler will only crawl one hop away from a feed. Disable this option if you only
want to crawl feeds and documents referenced by feeds.
Default: yes
ingnore_rules
Use this parameter to specify if the crawler should crawl all documents referenced
by feeds, regardless of being valid according to the collection's include/exclude
rules.
Default: no
index_feed
This parameter allows you to specify if the crawler should send the RSS feed
documents to the processing pipeline. Regardless of this option, meta data from
RSS feeds will be sent to the processing pipeline together with the articles they
link to.
107
FAST Enterprise Crawler
Parameter
Description
Default: no
max_link_age
This parameter allows you to specify the maximum age (in minutes) for a link
in an RSS document. Expired links will be deleted if the 'Delete expired' option
is enabled. 0 disables this option.
Default: 0 (disabled)
max_link_count
This parameter allows you to specify the maximum number of links the crawler
will remember for a feed. The list of links found in a feed will be treated in a FIFO
manner. When links get pushed out of the list, they will be deleted if the 'Delete
expired' option is set. 0 disables this option.
Default: 128
del_expired_links
This option allows you to specify if the crawler should delete articles when they
expire. An article (link) will expire when it is affected by either 'Max articles per
feed' or 'Max age for links in feeds'.
Default: no
Example:
<section name="rss">
<attrib name="start_uris" type="list-string">
<member> http://www.example.com/rss.xml </member>
</attrib>
<attrib name="auto_discover" type="boolean"> yes </attrib>
<attrib name="ignore_rules" type="boolean"> no </attrib>
<attrib name="index_feed" type="boolean"> yes </attrib>
<attrib name="follow_links" type="boolean"> yes </attrib>
<attrib name="max_link_age" type="integer"> 14400 </attrib>
<attrib name="max_link_count" type="integer"> 128 </attrib>
<attrib name="del_expired_links" type="boolean"> yes </attrib>
</section>
Metadata Storage
In addition to document storage being handled by the datastore section, the crawler maintains a set of data
structures on disk to do bookkeeping regarding retrieved content and content not yet retrieved. These are
maintained as databases and queues, and collectively referred to as metadata (as opposed to the actual
data retrieved).
The crawler stores a collection's site and document metadata in the directory:
$FASTSEARCH/data/crawler/store/collectionname/db/.
The following options are relevant to how the crawler handles metadata.
Site Databases
For each site from which pages are fetched, an entry is made in a site database, storing details including the
IP address, any equivalent (mirror) sites, the number of documents stored for the site.
Work Queue Files
The work queues used by the uberslave process to store URIs (and related data) waiting to be fetched are
stored on-disk in the following location and directory format.
108
Configuring the Enterprise Crawler
Location: $FASTSEARCH/data/crawler/queues/slave/collectionname/XX/YY/sitename[:port]
In addition to being organized by collection, additional layers of directory structure are introduced to avoid
file system limits. Within each collection directory, subdirectories (shown as XX and YY above) are created,
using the first 4 hexadecimal digits of the MD5 checksum of a site's name. For example, the site
www.example.com has the MD5 checksum 7c:17:67:b3:05:12:b6:00:3f:d3:c2:e6:18:a8:65:22. The created
directory path is therefore 7c/17/www.example.com.
If a site uses a port number other than the default (80 for HTTP, 443 for HTTPS), it will be included in the
sitename directory, and used in calculating the checksum.
In case of a restart of the crawler, the work queues are reloaded from disk, and the crawl continues from
where it left off.
Pending Queues
The master (or, in a multi node configuration, ubermaster) process utilizes several on-disk queues used for
storing URI and site information while DNS address resolution is being performed, and prior to a site being
assigned to an uberslave (or master, in the multi node case) for further processing. These are stored in the
following locations, organized by collection:
Location: $FASTSEARCH/data/crawler/queues/master/collectionname/
unresolved.uris
Queue for URIs waiting for site (hostname) DNS resolution
unresolved.sites
Queue for sites waiting for DNS resolution (per the configured DNS rate limits)
resolved.uris
Queue of URIs pending assignment to slave work queue, or to a master (multi node case)
Writing a Configuration File
Note: This method described should only be used when the collections (and sub collections) have been
created in the FAST ESP administrator interface.
The “collection-name” must match the name given to the collection when it was created.
The “sub collection-name” must match the name given to the sub collection when it was created.
When adding or modifying a configuration parameter, the configuration file needs only to contain the
modified configuration parameters.
The crawler configuration files are XML files with the following structure:
<?xml version="1.0"?>
<CrawlerConfig>
<DomainSpecification name="collection-name">
...
collection configuration directives
...
</DomainSpecification>
</CrawlerConfig>
When configuring a sub collection, use the following structure:
<?xml version="1.0"?>
<CrawlerConfig>
<DomainSpecification name="collection-name">
...
collection configuration directives
...
<SubDomain name="sub collection-name">
...
sub collection configuration directives
109
FAST Enterprise Crawler
...
</SubDomain>
</DomainSpecification>
</CrawlerConfig>
Uploading a Configuration File
After a configuration file has been created, it must be uploaded to the crawler. This is done via the crawleradmin
tool which is located in the $FASTSEARCH/bin directory of your FAST ESP installation.
The following command uploads the configuration to the crawler:
crawleradmin -f configuration.xml
Changes take place immediately; any errors in the configuration file will be reported.
Configuring Global Crawler Options via XML File
Many of the crawler configuration options specified at startup can also be specified in the crawler default
XML-based configuration file.
At startup, the crawler looks for this file (CrawlerGlobalDefaults.xml) at:
$FASTSEARCH/etc/CrawlerGlobalDefaults.xml
The configuration file can also be specified at startup using the -F option.
CrawlerGlobalDefaults.xml options
Table 39: CrawlerGlobalDefaults.xml options
Option
slavenumsites
Description
Number of sites per uberslave.
Use this option to specify the initial number of sites (slave instances) for an
uberslave.
Default: 1024
<attrib name="slavenumsites" type="integer"> 1024 </attrib>
dbtrace
Enable database statistics.
Use this option to specify whether or not you want to enable detailed statistics
from the databases.
Default: no
<attrib name="dbtrace" type="boolean"> no </attrib>
directio
Enable direct disk I/O.
Use this option to specify whether or not to enable (yes) direct I/O in postprocess
and duplicate server. Use only if the operating system supports this functionality.
Default: no
<attrib name="directio" type="boolean"> no </attrib>
110
Configuring the Enterprise Crawler
Option
numprocs
Description
Number of uberslave processes to start.
This value will be overridden by the -c command line option.
Default: 2
<attrib name="numprocs" type="integer"> 2 </attrib>
logfile_ttl
Log file lifetime.
This option specifies the number of days to keep old log files before deletion.
Default: 365
<attrib name="logfile_ttl" type="integer"> 365 </attrib>
store_cleanup
Time when daily storage cleanup job begins.
Format: HH:MM (24-hour clock)
Default: 04:00
<attrib name="store_cleanup" type="string"> 04:00 </attrib>
ppdup_dbformat
Duplicate server database format
Valid values: hashlog, diskhashlog or gigabase
<attrib name="ppdup_dbformat" type="string"> hashlog
</attrib>
disk_suspend_threshold
Specifies a threshold, in bytes, that when reached will make the crawler suspend
all existing collections.
Default: 500 MB
<attrib name="disk_suspend_threshold" type="real">524288000
</attrib>
disk_resume_threshold
Specifies a threshold, in bytes, that when reached will make the crawler resume
all existing collections, in the event they already have been suspended by the
'disk_suspend_threshold' option.
Default: 600 MB
<attrib name="disk_resume_threshold" type="real">629145600
</attrib>
browser_engines
List of browser engines that the crawler will use to process JavaScript and flash
extracted from html documents.
Default: none
<attrib name="browser_engines" type="list-string">
<member> <host>:<port> </member>
</attrib>
111
FAST Enterprise Crawler
Option
feeding
Description
Various feeding options for postprocess.
Valid values:
•
•
•
•
•
•
•
•
priority: ESP conent feeder priority. Note that there must be a pipeline
configured with the same priority setting. Default: 0
feeder_threads: Number of content feeder threads to start. Must only be
changed when the data/dsqueues directory is empty. Default: 1
max_cb_timeout: Maximum time to wait for callbacks in postprocess (in
seconds) when shutting down. Default: 1800
max_batch_size: Number of documents in each batch submission. Smaller
batches may be sent if not enough docs are available or if the memory size
of the batch grows too large. Default: 128
max_batch_datasize: Maximum size of a batch specified in bytes. Lower
this limit if you have trouble with procservers using too much memory.
Default: 52428800 (50 MB)
fs_threshold: Specifies the crawler file system (crawlerfs) getpath
threshold in kB. Documents larger than this value will be served using the
crawlerfs HTTP server instead of being inserted in the batch itself. Default:
128
waitfor_callback: FAST ESP 5.0 only, from ESP 5.1 this is configured
in $FASTSEARCH/etc/dsfeeder.cfg. Feeding callback to wait for.
Possible values are PROCESSED, PERSISTED and LIVE. Recovery of batches
that fail will not be available when the PROCESSED callback is chosen.
Default: PERSISTED
destinations: Specifies a set of feeding destinations. Each destination
is identified by a symbolic name and a list of associated content distrbutor
locations (host:port format).The contentdistributors for an ESP installation
can be found by looking in
$FASTSEARCH/etc/contentdistributor.cfg of that installation.When
no feeding destinations are explicitly defined the crawler will default to the
current ESP installation, and use the symbolic name "default".
Note: To make use of user specified feeding destinations they must
be referenced in the collection configuration.
dns
Domain name system (DNS) tuning options for the resolver.
This option allows various settings related to the crawler's use of the DNS as a
client. In single node installations the master calls DNS to resolve hostnames.
In a multiple node installation this job is done by the ubermaster.
Valid values:
min_rate: Minimum number of DNS requests to issue per second. Default:
5
max_rate: Maximum number of DNS requests to issue per second. Default:
100
max_retries: Maximum number of retries to issue for a failed DNS lookup.
Default: 5
timeout: DNS request timeout before retrying (in seconds). Default: 30
min_ttl: Minimum lifetime of resolved names (in seconds). Default: 21600
112
Configuring the Enterprise Crawler
Option
Description
db_cachesize: DNS database cache size setting for master; ubermaster
will use four times this value. Default: 10485760
near_duplicate_detection
Near duplicate detection tuning options.
Near duplicate detection is enabled on a per-collection basis. Near duplicate
detection primarily works for western languages.
Valid values:
min_token_size: Specifies the minimum number of characters a token
must have to be included in the lexicon. Tokens that contain fewer characters
than this value are excluded from the lexicon. Range: 0 - 2147483647.
Default: 5
max_token_size: Specifies the maximum character length for a token.
Tokens that contain more characters than this value are excluded from the
lexicon. Range: 1 - 2147483647. Default: 35
unique_tokens: Specifies the minimum number of unique tokens a lexicon
must contain in order to perform advanced duplicate detection. Below this
level the checksum is computed on the entire document. Range: 0 2147483647. Default: 10
high_freq_cut: Specifies the percentage of tokens with a high frequency
to cut from the lexicon. Range: between 0 and 1. Default: 0.1
low_freq_cut: Specifies the percentage of tokens with a low frequency
to cut from the lexicon. Range: between 0 and 1. Default: 0.2
Sample CrawlerGlobalDefaults.xml file
<?xml version="1.0"?>
<CrawlerConfig>
<GlobalConfig>
<!-- Crawler global configuration file -->
<!-- Maximum number of sites per UberSlave -->
<attrib name="slavenumsites" type="integer"> 1024 </attrib>
<!-- Enable/disable DB tracing -->
<attrib name="dbtrace" type="boolean"> no </attrib>
<!-- Enable/disable direct I/O in postprocess and duplicate server -->
<attrib name="directio" type="boolean"> no </attrib>
<!-- Number of slave processes to start -->
<attrib name="numprocs" type="integer"> 2 </attrib>
<!-- Number of days to keep log files -->
<attrib name="logfile_ttl" type="integer"> 365 </attrib>
<!-- Time of the daily storage cleanup, HH:MM (24-hour clock) -->
<attrib name="store_cleanup" type="string"> 04:00 </attrib>
<!-- Duplicate Server DB format (hashlog, diskhashlog or gigabase) -->
<attrib name="ppdup_dbformat" type="string"> hashlog </attrib>
<!-- Specifies a threshold, in bytes, that when reached will make -->
<!-- the crawler suspend all existing collections.
-->
<attrib name="disk_suspend_threshold" type="real"> 524288000 </attrib>
113
FAST Enterprise Crawler
<!-- Specifies a threshold, in bytes, that when reached will make the
-->
<!-- crawler resume all existing collections, in the event they
-->
<!-- already have been suspended by the 'disk_suspend_threshold' option. -->
<attrib name="disk_resume_threshold" type="real"> 629145600 </attrib>
<!-- List of browser engines-->
<attrib name="browser_engines" type="list-string">
<member> mymachine.fastsearch.com:14195 </member>
</attrib>
<!-- Various feeding options for postprocess -->
<section name="feeding">
<!-- Feeder priority -->
<attrib name="priority" type="integer"> 0 </attrib>
<!-- Number of content feeder threads to start. Must only -->
<!-- be changed when the data/dsqueues directory is empty -->
<attrib name="feeder_threads" type="integer"> 1 </attrib>
<!-- Maximum time to wait for callbacks in PP (in seconds) -->
<!-- when shutting down
-->
<attrib name="max_cb_timeout" type="integer"> 1800 </attrib>
<!-- The number of documents in each batch submission. Smaller -->
<!-- batches may be sent if not enough docs are available or
-->
<!-- if the memory size of the batch grows too large
-->
<attrib name="max_batch_size" type="integer"> 128 </attrib>
<!-- The maximum number of bytes in each batch submission.
-->
<!-- Default 50MB
-->
<attrib name="max_batch_datasize" type="integer"> 52428800 </attrib>
<!-- Specifies the crawlerfs getpath threshold in kB. Documents -->
<!-- larger than this value will be served using the crawlerfs -->
<!-- HTTP server instead of being inserted in the batch itself
-->
<attrib name="fs_threshold" type="integer"> 128 </attrib>
<!-- Feeding callback to wait for (ESP 5.0 only). Can be one of -->
<!-- PROCESSED, PERSISTED and LIVE. Please note that recovery
-->
<!-- of batches that fail will not be available when the
-->
<!-- PROCESSED callback is chosen
-->
<attrib name="waitfor_callback" type="string"> PERSISTED </attrib>
<!-- Content feeding destinations. Collections will by default
<!-- feed into a destination by the name "default", and this
<!-- destination should always be available. Additional
<!-- destinations may be added and referenced by collections.
<section name="destinations">
-->
-->
-->
-->
<!-- Default destination is current ESP install -->
<section name="default">
<!-- Empty list, use $FASTSEARCH/etc/contentdistributor.cfg -->
<attrib name="contentdistributors" type="list-string">
</attrib>
</section>
<!-- Sample alternate destination -->
<section name="example">
<attrib name="contentdistributors" type="list-string">
<member> hostname1:port1 </member>
<member> hostname2:port2 </member>
</attrib>
</section>
</section>
</section>
<!-- Various DNS tuning options for the resolver -->
<section name="dns">
<!-- Minimum/Lower number of DNS requests to issue per second -->
<attrib name="min_rate" type="integer"> 5 </attrib>
114
Configuring the Enterprise Crawler
<!-- Maximum/Upper number of DNS requests to issue per second -->
<attrib name="max_rate" type="integer"> 100 </attrib>
<!-- Maximum number of DNS retries to issue for a failed lookup -->
<attrib name="max_retries" type="integer"> 5 </attrib>
<!-- DNS request timeout before retrying (in seconds) -->
<attrib name="timeout" type="integer"> 30 </attrib>
<!-- Minimum lifetime of resolved names (in seconds) -->
<attrib name="min_ttl" type="integer"> 21600 </attrib>
<!-- DNS DB cache size (in bytes) for Master; an UberMaster -->
<!-- will use four times this value
-->
<attrib name="db_cachesize" type="integer"> 10485760 </attrib>
</section>
<!-- Various options for tuning the Near Duplicate Detection -->
<!-- feature, which must be enabled on a per-Collection basis -->
<section name='near_duplicate_detection'>
<!-- Minimum token size for lexicon -->
<attrib name="min_token_size" type="integer"> 5 </attrib>
<!-- Maximum token size for lexicon -->
<attrib name="max_token_size" type="integer"> 35 </attrib>
<!-- The minimum number of unique tokens required to perform
<!-- advanced duplicate detection -->
<attrib name="unique_tokens" type="integer"> 10 </attrib>
-->
<!-- High frequency cut-off for lexicon -->
<attrib name="high_freq_cut" type="real"> 0.1 </attrib>
<!-- Low frequency cut-off for lexicon -->
<attrib name="low_freq_cut" type="real"> 0.2 </attrib>
</section>
</GlobalConfig>
</CrawlerConfig>
Using Options
This section provides information on how to set up various crawler configuration options.
Setting Up Crawler Cookie Authentication
This section describes how to set up the Enterprise Crawler to do forms based authentication, which is
sometimes referred to as cookie authentication.
Login page
To configure the crawler for forms based authentication, it is first necessary to understand the process of a
user logging in to the site using a browser. A common mechanism is that a request for a specific (or "target")
URI causes the browser to instead be directed to a page containing a login form, into which username and
password values must be entered. After entering valid values, the data is submitted to the web server using
an HTTP POST request, and once authenticated the browser is redirected back to the original target page.
1. Open the web browser.
2. Point the browser to the page where you want the crawler to log in. The following shows a sample login
page:
115
FAST Enterprise Crawler
HTML Login Form
The following shows a sample HTML source view of the login form (with excess HTML source removed):
1: <form method="POST" name="login" action="/path/to/form.cgi">
2:
<input type="text" name="username" size="20">
3:
<input type="password" name="password" size="20">
4:
<input type="hidden" name="redirURI" value="/">
5:
<input type="submit" value="Login" name="show">
6:
<input type="reset" value="Reset" name="B2">
7: </form>
The information shown here can be used to configure the crawler to login to this site successfully.
HTML Login Form Descriptions
This example assumes the login page is found by going to http://mysecuresite.example.com. To browse
the site, log in with the Full name demo and Password demon.
Line 1: The method of the form is “POST”, and the action is “/path/to/form.cgi”. The form variables are
posted to that URI.
Line 2: The form needs a parameter named “username”. (This is the login page entry named Full name).
Note that the “username” parameter is not a general parameter, the username as well as the “password”
parameter can be any name. This is individual to each and every form, even though most people name their
variables/parameters something that can be associated with this parameter value.
Line 3: The form needs a parameter named “password”. (This is the login page entry named Password).
Line 4: The form needs a parameter named “redirURI” set. Note that this parameter is hidden, and thus not
shown when viewing the page in the browser. In general, this type of hidden parameter need not be specified
in the crawler's configuration, as the crawler will read the form itself and determine the names and values of
hidden variables.
Line 5: This line describes the Login button on the login page. There are no variables to extract from here
since the button is of type submit, which means that the browser should submit the form when the button is
pressed.
Line 6: This line describes the Reset button on the login page. There are no variables to extract from here
since the button is of type reset, which means that the browser should clear all input fields when the button
is pushed.
Crawler Login Form
The following shows a sample crawler login:
1: <Login name="mytestlogin">
2:
<attrib name="preload" type="string">http://site.com/</attrib>
3:
<attrib name="scheme" type="string"> https </attrib>
4:
<attrib name="site" type="string"> mysecuresite.example.com </attrib>
5:
<attrib name="form" type="string"> /path/to/form.cgi </attrib>
6:
<attrib name="action" type="string">POST</attrib>
7:
<section name="parameters">
8:
<attrib name="user" type="string"> username </attrib>
9:
<attrib name="password" type="string"> password </attrib>
10:
</section>
116
Configuring the Enterprise Crawler
11:
<attrib name="sites" type="list-string">
12:
<member> site1.example.com </member>
13:
<member> site2.example.com </member>
14:
</attrib>
15:
<attrib name="ttl" type="integer"> 7200 </attrib>
16: </Login>
Crawler Login Form Descriptions
Configure the crawler login specification by filling in the necessary values for the crawler configuration.
Line 1: The login name must be unique. All login specifications must have different names). This sample
uses the name “mytestlogin”.
Line 2: The preload step is not needed for this form, and is an optional parameter. If a target URI is used in
the browser login (i.e. in order to set initial cookie values, this URI should be used as the value of the preload
attribute, to force the crawler to fetch this page before attempting login.
Note: Lines 3, 4, and 5 (scheme+site+form) together make up the URI of the login form page: , e.g.
http://mysecuresite.example.com/path/to/form.cgi
Line 3: The “scheme” of the page this URI was found on was “http”. Note that some forms may be found on
HTTP sites, but the URI in the form action, may be absolute and point to an HTTPS site instead. For this
example the form action URI was relative, so it will have the same scheme as the form URI. The “scheme”
field is optional; if not set, “http” is assumed.
Line 4: The site (or hostname) of the web server on which the form URI resides. In this sample, the site is
“mysecuresite.example.com”.
Line 5: The actual form we are logging into is the form specified in the form action described in Line 1 of the
HTML login form. In this sample action=“/path/to/form.cgi”.
Line 6: The method of the form was found to be “POST”.
Lines 7+: Use the “parameters” section to describe the HTML login form. For this sample we need username
and password. These credentials are a sequence of key, value parameters the form requires for a successful
log on, differ from form to form, and must be deduced by looking at the HTML source of the form. In general,
only user-visible (via the browser) variables need be specified, e.g. username and password, or equivalent.
The crawler will fetch the login form and read any "hidden" variables that must be sent when the form is
submitted. If a variable and value are specified in the parameters section, this will override any value read
from the form by the crawler.
<section name="parameters">
<attrib name="username" type="string"> demo </attrib>
<attrib name="password" type="string"> demon </attrib>
</section>
Lines 12+: Use the “sites” section to identify every site that needs to login to the login form before starting
to crawl. This sample lists two sites, site1.example.com and site2.example.com. When the crawler begins
to crawl either of these sites, it will log in with the specified options before fetching pages.
<attrib name="sites" type="list-string">
<member> site1.example.com </member>
<member> site2.example.com </member>
</attrib>
Line 16: The time to live (ttl) variable is optional, and the sample login page does not produce any time
limited cookies so it is not included in this description. Some forms may set expire times on the cookies they
return, and require credentials to be verified after a period of time. For such forms you may specify a ttl value,
specifying the number of seconds until the crawler logs in again.
117
FAST Enterprise Crawler
Confirming Successful Login
The crawler will attempt login for each of the sites listed, and can generally be considered to have done so
successfully if it proceeds to crawl the site's Start URI and other pages linked to from it. The fetch log would
show this successful pattern, as in the following example.
2007-07-19-22:42:36
form)[TestLogin]
2007-07-19-22:42:36
form)[TestLogin]
2007-07-19-22:42:39
2007-07-19-22:42:42
200 NEW
http://www.example.com/index.php (Reading login
200 NEW
http://www.example.com/login.php (Submitting login
200 NEW
200 NEW
http://www.example.com/
http://www.example.com/faq.php
The site log should also show the status of the authentication attempt.
2007-07-19-22:42:35
2007-07-19-22:42:35
Authentication
2007-07-19-22:42:36
Authentication
2007-07-19-22:42:36
www.example.com
STARTCRAWL
LOGIN
N/A
GET
www.example.com
www.example.com
Performing
LOGIN
POST
www.example.com
Performing
LOGGEDIN
N/A
www.example.com
Through
A failure to log in will be indicated by a lack of crawling the site extensively, as shown in the fetch log. More
detailed information would be written to the crawler log file, especially in DEBUG mode. You can contact FAST
Support for further troubleshooting details.
Implementing a Crawler Document Plugin Module
This section describes how to create a python plugin module in order to provide an additional means of control
over the internal processing of fetched documents after they have been downloaded and initial processing
completed. The scope of work performed by the plugin can vary widely, ranging from a read only analyzer
to very complex processing of each document, and can include the rejection of documents from the crawl.
Overview
To implement the plugin, as a minimum you need a Python class that defines a process() call that takes
one argument, and a document object provided by the crawler.
An optional process_redirect() call may also be specified to evaluate redirections received in the course
of following links. A basic implementation of a plugin is as follows
class mycrawlerplugin:
def process(self, doc):
# XXX: Activity1.
def process_redirect(self, doc):
# XXX: Activity2.
The document object is an internal crawler data structure, and has a fixed set of attributes that you can utilize
and modify in your processing call. Note that only a subset of the attributes can be modified; any changes
will have an effect on subsequent crawler behavior.
The process() call is invoked for each document that is processed for links within the crawler, that is those
whose MIME type matches the MIME-types to search for links option.
The process_redirect() call is invoked whenever the crawler encounters a redirect response from a server.
That is, whenever the server returns ordinary redirect response codes (HTTP response codes 301 or 302)
or when an HTML META "refresh" is encountered and is evaluated as a redirect according to the configuration
settings.
118
Configuring the Enterprise Crawler
Configuring the Crawler
Configure the crawler to use your plugin with the Document evaluator plugin option. Note that only one
plugin can be active at a time per collection. The format for the option is:
tests.plugins.plugins.helloworld
The format specifies the python class module, ending with your class name. The crawler splits on the last '.'
separator and converts this to the Python equivalent "from <module> import <class>".
Note: Whenever you create a python module in a separate directory, you need to have an empty
__init__.py file to be able to import it. This is a Python requirement, and failure to do so will result in
error messages in the crawler.log file.
The module must be available relative to the PYTHONPATH environment variable. For example, the file structure
on disk of this sample plugin configuration is tests/plugins/plugins.py, which contains the class
helloworld().
If used within an an existing FAST ESP installation this would be relative to:
${FASTSEARCH}/lib/python2.3/
Note that only documents that are searched for links, that is matching the MIME types of the uri_search_mime
option are subject to processing by the defined document plugin.
Modifying Document Object Options
Each URI downloaded by the crawler is processed internally to determine the values of various attributes,
which are made available to the plugin as a "document" object. The following tables describe the "document"
options for the process() and process_redirect() calls.
Table 40: process () Options
Option
store_document [integer]
Description
This option specifies whether or not to store the current document.
Valid values: 0 (no), 1 (yes)
Documents that are not stored (option set to 0) will be logged in the fetch log
as:
2006-04-19-14:53:42 200 IGNORED <URI> Excluded:
plugin_document
focus_crawl [integer]
This option specifies whether or not the current document is out of focus.
Valid values: 0 (no), 1 (yes)
Example: To have an effect on the focus of the crawl, a focus section with a
depth attribute must be defined in the collection configuration.
<section name="focused">
<attrib name="depth" type="integer"> 2 </attrib>
</section>
links [list]
This option contains all the URIs the crawler link parser was able to pull out of
this document. The list consists of tuples for each link. A tuple contains either
three or five objects. A five-tuple entry contains:
uritype - type of URI as defined by pydocinfo (eg. pydocinfo.URI_A)
119
FAST Enterprise Crawler
Option
Description
uriflag - attribute flag for URI.
uri - the original URI
uricomp - the parsed version of the URI as output by
pyuriparse.uriparse(<uri>)
metadata - dictionary containing the meta data that should be
associated/tagged with this URI (optional)
A three-tuple entry contains:
uritype - type of URI as defined by pydocinfo (eg. pydocinfo.URI_A)
uri - the original URI
uricomp - the parsed version of the URI as output by
pyuriparse.uriparse(<uri>)
Note: Be sure to keep the same format.
If you do not want any links to be followed from the current document, set this
attribute to an empty list.
cookies [list]
Use this option to add any additional cookies your module wants to set to the
crawler cookie store.
The cookies document attribute is always an empty list from the crawler.
Format Example (valid HTTP Set-Cookie header):
Set-Cookie: <cookie>
data [string]
csum [string]
This option contains the data of the current document.
This option contains the checksum of the current document.
Valid values: string of length 16 bytes
referrer_data [dictionary]
The referrer_data attribute contains the meta data which the parent document
has appended to this URI. For instance, with RSS feeds the meta data from the
RSS feed is forwarded with each URI found in the feed.
Note that the meta data is forwarded automatically if the URI is a redirect.
extra_data [dictionary]
destination [list(2)]
This attribute can be used to store additional meta data with this document,
which will also be sent to the processing pipeline. The docproc example below
shows how to extract this data in the pipeline.
This attribute can be used to set the feeding destination of the current document.
The list should contain 2 items [<destination>:<collection>].
<destination> refers to the pre-defined destination targets in your
GlobalCrawlerConfig.xml file.
<collection> refers to an existing collection on the target system.
errmsg [string]
120
This attribute can be used to set a short description on why the current document
was excluded due to being out of focus (focus_crawl = 1) or not being stored
(store_document = 0) that will be output to the crawler fetch log.
Configuring the Enterprise Crawler
Option
Description
The errmsg will be prefixed by "document_plugin:" and appended to the
documents fetch log entry.
Table 41: process_redirect () Options
Option
Description
links [list]
This option is the same as the links [list] option in the process() call,
but with the restriction that it contains only a single tuple entry. This tuple contains
the URI that the redirect refers to. If this tuple is modified, then the crawler will
use the updated location as target for the redirect.
store_document [integer]
This option controls whether or not the redirect URI set in the links option should
be followed.
Valid values: 0 (no), 1 (yes)
Documents that are not stored (option set to 0) will be logged in the fetch log
as:
2006-04-19-14:53:42 200 IGNORED <URI> Excluded:
plugin_document
Note: When store_document is set to 0, no further processing of the
redirect will take place, and any modifications to the links or cookies
attributes are ignored.
cookies [list]
Use this option to add any additional cookies your module wants to set to the
crawler cookie store.
The cookies document attribute is always an empty list from the crawler.
Format Example (valid HTTP Set-Cookie header):
Set-Cookie: <cookie>
errmsg [string]
This attribute can be used to set a short description on why the current document
was excluded due to or not being stored (store_document = 0) that will be output
to the crawler fetch log.
The errmsg will be prefixed by "document_plugin:" and appended to the
documents fetch log entry.
Static Document Object Options
The following document object attributes are included the plugin, but should not be changed.They are available
in both process() and process_redirect().
Table 42: Static process () and process_redirect() Attributes
Attribute
site [string]
ip [string]
uri [string]
Description
This attribute contains the site/hostname of the current document.
This attribute contains the IP of the site/hostname of the current document.
This attribute contains the URI of the current document.
121
FAST Enterprise Crawler
Attribute
Description
header [string]
referrer [string]
This attribute contains the HTTP headers of the current document.
This attribute contains the referrer of the current document.
Note: Empty referrer means the current document was a start-URI.
collection [string]
mimetype [string]
encoding [string]
redirtrail [list]
This attribute contains the name of the collection the current document belongs
to.
process() only.This attribute contains the MIME type of the current document.
This attribute contains the auto-detected character encoding of the current
document.
process_redirect() only. This attribute is a list that contains all the URIs
of preceding redirects that were performed prior to the current one. Each URI
is a two-tuple that contains:
uri referring redirect URI
flags - flag internal to the crawler
is_rss [boolean]
is_sitemap [boolean]
This attribute informs if the crawler has identified the document as an RSS feed.
This attribute tells if the crawler has identified the document as a sitemap or
sitemap index.
Hello world
Processing class that prints 'hello world' for every document that is put through.
class helloworld:
def __init__(self):
pass
def process(self, doc):
print "hello world"
Focus crawl
Processing class that focuses the crawl based on whether or not the content contains
'fast'. Note that this requires the global focus depth to be set in the configuration.
class focusonfast:
def __init__(self):
# Regexp matching the string 'fast'
self.re = re.compile(".*?fast", re.I)
def process(self, doc):
if not self.re.match(doc.data):
# Change the focus crawl option of this document
doc.focus_crawl = 1
122
Configuring the Enterprise Crawler
Lowercase all URIs
Processing class that lowercases the path of every URI (ref windows webservers that are
case-insensitive. Note that this requires that all URIs input to the crawler (for example
start-uris/crawleradmin -u) are also in lowercased form.
class lowercase:
def process(self, doc):
newlinks = []
# Handle no links
if not doc.links:
return
for uritype, uri, uricomp in doc.links:
# Parse uri into its 7-part components
# lowercase path, params, query and fragment part of URI
newuri = pyuriparse.uriunparse([
uricomp[pyuriparse.URI_SCHEME],
uricomp[pyuriparse.URI_NETLOC],
uricomp[pyuriparse.URI_PATH].lower(),
uricomp[pyuriparse.URI_PARAMS].lower(),
uricomp[pyuriparse.URI_QUERY].lower(),
uricomp[pyuriparse.URI_FRAGMENT].lower(),
uricomp[pyuriparse.URI_USERPASS]])
newuricomp = pyuriparse.uriparse(newuri)
print "Before:", uri
print "After:", newuri
newlinks.append((uritype, newuri, newuricomp))
# Change the links associated with this document doc.links =
newlinks
Add text
Processing class that inserts ‘good’ at the beginning and end of the document.
class prefixsandpostfix:
def process(self, doc):
# Modify content of this document
doc.data = 'good' + doc.data + 'good'
Modify Checksum
Processing class that duplicates every document by modifying the checksum.
class duplicate:
def process(self, doc):
# Modify checksum of all docs to a x 16
doc.csum = 'a' * 16
Add cookie
Processing class that adds a cookie to the crawler cookie store for every document.
class cookieextenter:
def process(self, doc):
# Set a cookie for the hostname of the current URI
uricomp = pyuriparse.uriparse(doc.uri)
domain = uricomp[pyuriparse.URI_NETLOC].split(".", 1)
doc.cookies = ['Set-Cookie: BogusCookie=f00bar; path=/; domain=.%s'
%\domain[1]]
123
FAST Enterprise Crawler
Exclude links
Processing class that parses the document for links and anchortext, and based on anchor
text of the links excludes bad links associated with apache directory listings, and so forth.
class directorylistingdetector:
class myparser(htmllib.HTMLParser):
def __init__(self, formatter):
self.links = {}
self.currenthref = None
htmllib.HTMLParser.__init__(self, formatter)
def anchor_bgn(self, href, name, type):
if not href in self.links:
self.links[href] = ''
self.currenthref = href
self.save_bgn()
def anchor_end(self,):
if self.currenthref is not None:
self.links[self.currenthref] = self.save_end()
self.currenthref = None
def reset(self):
self.links = {}
htmllib.HTMLParser.reset(self)
def __init__(self):
self.parser = self.myparser(formatter.NullFormatter())
self.ignorelist = ( "parent directory", "name", "last modified",
"size", "description", "../")
def process(self, doc):
self.parser.reset()
self.parser.feed(doc.data)
existinglinks = map(lambda x: x[1], doc.links)
for link in self.parser.links:
normlink = self.normalize_link(doc.uri, link)
idx = existinglinks.index(normlink)
if idx < 0:
# XXX: Crawler didn't find this link, ignore it
print "Ignoring %s, mismatch with crawler" % link
continue
if self.parser.links[link].lower() in self.ignorelist:
# The link should not be followed, ignore
print "Ignoring %s, anchor text=%s" % \
(link,self.parser.links[link])
doc.links.pop(idx)
existinglinks.pop(idx)
continue
def normalize_link(self, baseuri, uri):
return pyuriparse.urijoin(baseuri, uri)
Extra data
Processing class that adds text to the extra_data parameter for each document.
class addMeta:
def process(self, doc):
doc.extra_data = "Extra data"
124
Configuring the Enterprise Crawler
Docproc stage for extra_data
Docproc example that extracts the extra_data parameter set by a crawler plugin and adds
it to the document attribute "generic3"
class CrawlerPluginProcessor(Processor.Processor):
def Process(self, docid, document):
extra_data = document.GetValue('extra_data', None)
if extra_data:
plugin_data = extra_data.get("docplugin", None)
if plugin_data is not None:
document.Set("generic3", plugin_data)
else:
return ProcessorStatus.OK_NoChange
return ProcessorStatus.OK
Configuring Near Duplicate Detection
The default duplicate detection scheme in the crawler strips format tags from each new document and then
creates a checksum based on the remaining content. If another document exists with the same checksum,
that document is identified as a duplicate.
This approach may sometimes be too rigid. There are many documents that are not exactly identical, but are
perceived to contain the same content by the user. For example, two documents might have the same body
of text but be marked with different timestamps. Or, a document could have been copied but missed some
characters, a copy-and-paste mistake. Since these documents are not exactly identical they are not registered
as duplicates by the crawler. A near duplicate detection algorithm curbs this issue. This section describes
how the near duplicate detection scheme works and how it can be used in the crawler.
Overview
Once the crawler retrieves a new document, it is parsed into a token stream and its markup code and
punctuation are removed. Individual words (tokens) are separated by splitting the remaining content on
whitespace and punctuation (a rudimentary tokenizer). If a new token is shorter or longer than some predefined
values, then the token is discarded. Otherwise the token is lower cased and added to a lexicon, or collection
of words.
Note: Since CJK languages do not separate tokens by space, the text appears as a set of large continuous
tokens. Note that since languages such as Chinese, Japanese, Korean (CJK) and Thai have no means
of separating tokens without a more complex algorithm involved such characters will be extracted as a
set of large continuous tokens. Consequently, most of the detected tokens in such documents are
discarded.
When parsing is done, the constructed lexicon is trimmed. The most and least frequent tokens are removed
from the lexicon. The goal of this process is to retain only the significant tokens in the lexicon. By removing
the most frequent tokens the algorithm tries to get rid of the most common words in a language, for example,
'the', 'for', etc. And by removing infrequent tokens it tries to get rid of timestamps, tokens with spelling mistakes,
and so forth.
If the lexicon contains enough tokens then a digest string is constructed by traversing the original document
for tokens that are in the lexicon. If a token is in the document and in the lexicon the token is added to the
digest string. Once the entire document has been traversed, the digest is used to generate a signature
checksum. However, if the trimmed lexicon does not have enough tokens, a checksum will be constructed
from the entire document without format tags - just as in the existing duplicate detection scheme. As in the
default scheme, documents with the same checksum are defined as duplicates.
125
FAST Enterprise Crawler
Configuring the Crawler
The crawler is able to modify the behavior of its duplicate detection with the Near duplicate detection
option(AW). The variable can also be set in the collection specification:
<attrib name="near_duplicate_detection" type="boolean"> yes </attrib>
Next, there are global options located in the $FASTSEARCH/etc/CrawlerGlobalDefaults.xml file that can
be set. Changing these parameters will result in a different digest and consequently generate a different
signature for the document. Refer to CrawlerGlobalDefaults.xml options on page 110 for options information.
It is not recommended that you modify these parameters after the crawl has started.
<attrib
<attrib
<attrib
<attrib
<attrib
name="max_token_size" type="integer"> 35 </attrib>
name="min_token_size" type="integer"> 5 </attrib>
name="high_freq_cut" type="real"> 0.1 </attrib>
name="low_freq_cut" type="real"> 0.2 </attrib>
name="unique_tokens" type="integer"> 10 </attrib>
Near Duplicate Detection Example
Original Document text:
The current version of the Enterprise Crawler (EC) has a duplicate detection algorithm that strips format tags
from each new document, and then creates a checksum based on the remaining content. If another document
exists with the same checksum, that document is identified as a duplicate.
CrawlerGlobalDefaults configuration:
<attrib
<attrib
<attrib
<attrib
<attrib
name="max_token_size" type="integer"> 35 </attrib>
name="min_token_size" type="integer"> 4 </attrib>
name="high_freq_cut" type="real"> 0.1 </attrib>
name="low_freq_cut" type="real"> 0.2 </attrib>
name="unique_tokens" type="integer"> 10 </attrib>
The previous configuration and document text yield the following adjustments to the full lexicon of 25 tokens.
Note that the cutoff percentages as computed against the full token list are rounded down to the nearest
whole number, and that terms of equal frequency are ordered alphabetically before trimming. As can be seen
in the following, the low frequency tokens trimmed are those from the end of the alphabet.
•
Removed due to high_freq_cut:
Remove top 2 words (10% of 25 words is 2) in reverse alphabetical order (document, that)
•
Token
Frequency
document
3
that
2
Removed due to low_freq_cut:
Remove bottom 4 words (20% of 25 words is 4) in reverse alphabetical order (with, version, then, tags)
•
126
Token
Frequency
tags
1
then
1
version
1
with
1
The final trimmed lexicon meets the threshold limit of 10 tokens, and contains the following terms:
Configuring the Enterprise Crawler
•
Token
Frequency
checksum
2
duplicate
2
algorithm
1
another
1
based
1
content
1
crawler
1
creates
1
current
1
detection
1
each
1
enterprise
1
exists
1
format
1
from
1
identified
1
remaining
1
same
1
strips
1
Based on this the digest string, ordered according to the word order of the original document, would read:
currententerprisecrawlerduplicatedetectionalgorithmstripsformatfromeac
hcreateschecksumbasedremainingcontentanotherexistssamechecksumi
dentifiedduplicate
The checksum is then computed on this digest string, and is associated with the original fetched document.
Configuring SSL Certificates
In most cases no special configuration is necessary for the crawler to fetch from SSL protected sites (https).
In some cases it is necessary to enable Cookie support in the crawler. If a full SSL certificate chain must be
presented to the web server, use the following procedure to prepare the files.
Please follow the steps below to set up a certificate chain to support a client certificate in the crawler.
This is only required when using client certificates and when the client certificate itself cannot be directly
verified by the server without the complete certificate chain up to the trusted CA being attached.
1. Copy all certificates (including intermediate certificates) into the PEM certificate file specified for the crawler.
This is done with all other certificates at the beginning of the file with the root CA certificate last (no key
copied into file)
2. Encode the certificate file in PKCS#7 format using the command: openssl crl2pkcs7 -nocrl -certfile
file_with_certs -out combined.pem
Note: The key point is the use of the PKCS#7 format for the certificate file specified to the crawler.
127
FAST Enterprise Crawler
3. Specify the combined.pem file in the crawler certificate file configuration option.
Configuring a Multiple Node Crawler
The distributed crawler consists of one ubermaster process, one or more duplicate servers and one or more
subordinate crawler (master) processes. The ubermaster controls all work going on in the crawler, and
presents itself as a single data source in the FAST ESP administrator interface.
Before you begin you should decide:
•
•
What nodes should run the ubermaster, duplicate server(s) and master(s) processes.
If you are removing the existing crawler or setting up the new crawler so that it does not interfere with the
existing crawler. Go to Removing the Existing Crawler on page 128 if you are removing the existing crawler;
go to Setting up a New Crawler with Existing Crawler on page 128 if you are setting up a new crawler while
keeping the existing crawler.
Removing the Existing Crawler
If you are removing the existing crawler and replacing it with a new crawler configuration, complete this
procedure.
To remove the existing crawler:
1. On all nodes that run crawler processes (assuming the processes are named crawler), run the command:
$FASTSEARCH/bin/nctrl stop crawler
2. On the node running the ubermaster process, run the command: $FASTSEARCH/bin/nctrl stop
ubermaster
3. Stop the nctrl process with the command: $FASTSEARCH/bin/nctrl stop nctrl. On Windows it is
neccessary to stop the FAST ESP Service instead.
4. Remove the crawler process from the startorder list in $FASTSEARCH/etc/NodeConf.xml.
5. Remove the crawler process from $FASTSEARCH/etc/NodeState.xml.
6. Start the nctrl process by running the command: $FASTSEARCH/bin/nctrl start. On Windows this can
be done by starting the FAST ESP Service instead.
7. On the node running the ubermaster process, run the command: $FASTSEARCH/bin/nctrl start
ubermaster.
8. On all nodes that run crawler processes (assuming the processes are named crawler), run the command:
$FASTSEARCH/bin/nctrl start crawler.
Setting up a New Crawler with Existing Crawler
If you are setting up the new crawler as a separate data source so that it does not interfere with the existing
crawler, complete this procedure.
1. Modify the $FASTSEARCH/etc/NodeConf.xml files on the different nodes. Existing crawler entries in the
file on your FAST ESP installation file can be used as templates.
2. When several crawler components are run on the same node, be they multiple instances of single node
crawlers or several components of a multiple node crawler, always make sure that the following parameters
do not overlap:
-P (the port number used to communicate with the process)
-d (the data directory designated to the process)
-L (the log directory designated to that process)
128
Configuring the Enterprise Crawler
Port numbers should be sufficiently far apart to avoid interference; incrementing by 100 per process should
be sufficient. Always inspect the existing entries in the NodeConf.xml file to ensure the port numbers do
not overlap with those allocated to other processes.
3. Add an ubermaster.
An example of an ubermaster process entry is as follows:
<process name="ubermaster" description="Master Crawler">
<start>
<executable>crawler</executable>
<parameters>-P $PORT -U -o -d
$FASTSEARCH/data/crawler_um -L $FASTSEARCH/var/log/crawler_um</parameters>
<port base="1000" increment="1000" count="1"/>
</start>
<outfile>ubermaster.scrap</outfile>
<limits>
<minimum_disk>1000</minimum_disk>
</limits>
</process>
Note the -U parameter, then add <proc>ubermaster</proc> to the global startorder list near the top of the
$FASTSEARCH/etc/NodeConf.xml file.
4. Add a subordinate master.
An example of a subordinate master entry is as follows:
<process name="master" description="Subordinate Crawler">
<start>
<executable>crawler</executable>
<parameters>-P $PORT -S
<ubermaster_host>:14000 -o -d $FASTSEARCH/data/crawler -L
$FASTSEARCH/var/log/crawler</parameters>
<port base="1100" increment="1000" count="1"/>
</start>
<outfile>master.scrap</outfile>
<limits>
<minimum_disk>1000</minimum_disk>
</limits>
</process>
A <proc>master </proc> should be added to the startorder list in the $FASTSEARCH/etc/NodeConf.xml
file.
5. Add a duplicate server.
The duplicate server can be set up in a number of different ways, including striped and replicated modes,
but a simple standalone set up is as follows:
<process name="dupserver" description="Duplicate server">
<start>
<executable>ppdup</executable>
<parameters>-P $PORT -I <Symbolic ID></parameters>
<port base="1900" increment="1" count="1"/>
</start>
<outfile>dupserver.scrap</outfile>
<limits>
<minimum_disk>1000</minimum_disk>
</limits>
</process>
The ppdup binary must be added to the configuration in the FAST ESP administrator interface with a
host:port location (available in the advanced mode). Note that the ppdup does not have an -L parameter.
Refer to Crawler/Master Tuning for information about cache size and storage tuning
129
FAST Enterprise Crawler
A <proc>dupserver</proc> should be added to the startorder list in the $FASTSEARCH/etc/NodeConf.xml
file.
6. Start the new crawler: $FASTSEARCH/bin/nctrl reloadcfg
7. Start the different processes on the relevant nodes in the following order:
$FASTSEARCH/bin/nctrl start ubermaster
$FASTSEARCH/bin/nctrl start dupserver
$FASTSEARCH/bin/nctrl start master (on all master nodes)
8. To verify the new configuration:
a) Check the ubermaster logs to verify all masters are connected and that there are no conflicts, for
example, conflicts in -I names.
b) Check to make sure the ubermaster appears as a Data Source in the FAST ESP administrator interface
You can add collections by either using the FAST ESP administrator interface or by uploading the crawler
XML specifications with the following command:
$FASTSEARCH/bin/crawleradmin -C <ubermaster hostname>:<ubermaster portnumber> -f <path
to xml specification>
If you are uploading a web scale crawl, it is recommended that you add the collection with the Large Scale
XML Configuration Template on page 141.
9. Refeed collections with postprocess.
Re-feeding collections in a multiple node crawler is similar to performing it in a single node crawler, with
some exceptions.
Before starting the refeed make sure the duplicate server(s) are running. The master(s) must be stopped
on the node(s) you wish to refeed, the ubermaster as well as masters on other nodes may continue to
run.
$FASTSEARCH/bin/postprocess -R "*"
Large Scale XML Crawler Configuration
This section provides information on how to configure and tune a large scale distributed crawler.
Node Layout
A large scale installation of the crawler consists of three different components:
•
•
•
One Ubermaster (UM),
One or more Duplicate servers (DS) and
Multiple Crawlers. Each crawler consists of a master process, multiple uberslave processes and a single
postprocess.
A typical 10 node layout may look like this (each square represents a server):
130
Configuring the Enterprise Crawler
Figure 13:
This configuration offers both duplicate server fault tolerance and load balancing.
Node Hardware
The following items (in prioritized order) should be considered when planning hardware:
1. Disk I/O performance
2. Amount of memory
3. CPU performance and dual vs. single processor
Typical disk setup involves either RAID 0 or RAID 5 with a minimum of four drives. RAID 0 offers better
performance, but no fault tolerance. RAID 5 has substantial penalty on write performance. Other options
include RAID 0+1 (or RAID 1+0).
When running with a replicated duplicate server setup, it may be that a non-fault tolerant setup (for example,
RAID 0) is the best alternative for the duplicate server nodes, with all other nodes on a fault tolerant storage
(RAID 5).
Memory usage is very dependent on the cache configuration used, but both the duplicate server and
postprocess (on each crawler node) can take advantage of large amounts for database caching purposes.
CPU performance is much less important, and depends mainly on the configuration settings used. This is
discussed in more detail in the Configuration and Tuning section.
Hardware Sizing
Due to the I/O-bound nature of crawling, the hardware sizing should be based primarily on hard disk capacity
and performance.
To calculate the disk usage of the crawler nodes, the following needs to be accounted for.
•
•
•
•
Crawled data (each doc compressed individually by default)
Meta data structures
Postprocess duplicate database
Crawl and feed queues
Assuming an average compressed document size of 20kB (30kB if also crawling PDF and Office documents),
2kB meta data per document (includes HTTP header) and 500 bytes per URI in the duplicate DB we can
calculate the disk space requirements for a single node. Note however that the document sizes (20kB and
30kB) are estimates, and depends largely on what is being crawled and also the document size cut-off
specified in the configuration.
Adding 30% slack on top to account for wasted space in the data structures, log files, queues etc we get the
following guide line table.
131
FAST Enterprise Crawler
Document
Data size (HTML only)
Data size (HTML, PDF, Word++)
10M
290GB
420GB
20M
585GB
845GB
30M
880GB
1.3TB
The rule of thumb is that a node should not be holding more than 20-30M documents, as performance may
degrade too much from that point on.
The disk usage of the duplicate servers will be similar to that of the postprocess duplicate database. However,
keep in mind that using replication (which is recommended) doubles the disk usage as each node holds a
mirror of its peer node's dataset.
Ubermaster Node Requirements
The UM can either run on a separate node or share a node with one of the duplicate servers. Place the UM
on a dedicated node for large installations (20 masters and up).
Memory usage
100-500MB
CPU usage
Moderate to high depending on number of masters
Disk I/O
Moderate to high depending on number of masters
Disk usage
Minimal
There are no global tuning parameters for this component.
Duplicate Servers
The duplicate server processes serve as the backbone of a multiple node crawler setup and care should be
taken when configuring since they may be difficult to reconfigure at a later stage.
Memory usage
70MB and up (tunable)
CPU usage
Minimal
Disk I/O
Heavy during first cycle, moderate on subsequent cycles
Disk usage
Moderate
Non-replicated Mode
A simple duplicate server layout involves one or more duplicate server processes in a non-replicated mode.
The advantage of this approach is the increased performance offered, with the drawback of no replication in
case of failure (loss of data). It should therefore only be used if the underlying disk system is fault tolerant
(and preferably more so than RAID 5).
For each duplicate server set up this way you must also add it to the duplicate servers configuration section
for each collection. Refer to ppdup for options information.
Two node (striped) example, running on servers node1 and node2 with symbolic IDs dup1 and dup2:
node1: ./ppdup -P 14900 -I dup1
node2: ./ppdup -P 14900 -I dup2
Replicated Mode
The duplicate server can be replicated in two ways; dedicated replica and cross-replication.
132
Configuring the Enterprise Crawler
The dedicated replica mode works by setting up a second duplicate server that acts only as a replica with
no direct communication with postprocess, only its duplicate server primary. Both processes in the following
example use the same ID.
Dedicated replica example, running on two nodes:
node1: ./ppdup -P 14900 -I dup1 -R node2:14901
node2: ./ppdup -P 14900 -I dup1 -r 14901
An alternative means of getting both replication and load balancing is to use the cross-replication mode.
In this setup each duplicate server acts as both primary and replica for another duplicate server.
Cross replication example running on two nodes:
node1: ./ppdup -P 14900 -I dup1 -R node2:14901 -r 14901
node2: ./ppdup -P 14900 -I dup2 -R node1:14901 -r 14901
While it may seem that the last setup is preferable to a combined striped and replicated setup, it is not.
Separating primary and replica into two processes has two distinct advantages; it allows the processes to
use more memory for caching (max process size on RHEL3 is about 2.8GB) as well as placing the I/O and
CPU tasks somewhat in parallel (the duplicate server uses blocking I/O).
Crawlers (Masters)
Memory usage
512MB and up (tunable)
CPU usage
Moderate to high, configuration dependent
Disk I/O
Heavy
Disk usage
High
There are no global tuning parameters for this component.
Configuration and Tuning
When planning a large scale deployment configuration, first consider the number of collections and their
sizes.
An ideal large scale setup consists of a single collection, possibly with a few sub collections. Having multiple
smaller collections on a multiple node crawler is generally not desired, especially if they fit on single node
crawler. In this case it is better to set up one or several single node crawlers to handle the small collections.
If you have to have multiple collections on a multiple node crawler, keep in mind that many tunable parameters
such as cache sizes are configured per collection so they can add up for each collection. Furthermore, certain
parameters are applied individually to each collection, but may only be configured through one global setting.
This does not fit well with having both small and large collections on the same multiple node crawler and is
generally not recommended.
However, there are advantages to having multiple collections as opposed to one collection with sub collections.
Individual collections make management easier, including configuration updates, re-feeds, and scratching.
Having many sub collections add overhead since each URI must be checked against the include rules of
each sub collection until a match, if any, is found.
The best advice is to first divide your data into whatever logical collections make the most sense. If the setup
calls for a mix of large and small collections (for example, web and news crawls) then it is advisable to place
the small collections on a separate single node crawler. The remaining collections should generally be larger
than what a single node could handle and it therefore makes sense to run them either separately or as a
single collection on the multiple node crawler.
Include /Exclude Rules
The crawler uses a set of include and exclude rules to limit and control what is to be crawled.
133
FAST Enterprise Crawler
In a small scale setting the performance considerations are few as there are generally a limited number of
rules. However, in a large scale setting there may be tens of thousands of rules and care must be taken when
selecting these. It is important to keep in mind that every URI extracted by the crawler is checked against
some or all of these rules.
The least expensive rules are the exact match hostname rules. Checking a URI against these involve a single
hash table lookup, so the performance is the same regardless of the number of URIs. Memory usage depends
on the number of rules.
The suffix and prefix hostname includes are also generally inexpensive, as they are also implemented using
hash structures. By dividing the URIs into subsets based on their lengths we get at most n lookups (where n
is the number of different lengths), rather than one lookup per rule. While more expensive than the exact
match rule, it is dependent on the number of unique lengths and not the number of rules.
The regexp type rule should be avoided if at all possible. In general it will only be necessary as a URI rule,
not a hostname rule. It is best to check with the crawler team if you have any questions regarding this.
Note: One common pitfall is to use either a suffix URI rule or a regexp URI rule to exclude certain
filename extensions. The former will fail if the URI contains for example, query parameters and the latter
consumes much more CPU than it needs to. To exclude certain file extensions you should use the
exclude_exts config option.
Tip: Using exclude rules can potentially speed up the checks. Since exclude rules are applied first, you
could for example, exclude all top level domains you do not wish to crawl.
Includes and sub collections - When setting up sub collections it is vital to keep in mind that they are subsets
of the main collection. Therefore, any URIs for the sub collection must match the include/exclude rules of the
main collection first, and then the relevant sub collection.
URI Seed Files
It is necessary to specify one or more Start URIs for any size crawl, but it is not necessarily true that a large
crawl requires a long list of Start URIs.
Because the web is heavily interconnected, with links from site to site, you can usually start at a single URI
(preferably a page with many external URIs) and allow the crawler to gather links and add sites to the crawl
from there. This works well if your goal is to crawl a top-level domain, such as the .no domain. Adding
numerous seeds will do little to improve or focus your crawl.
However, if you do not wish to crawl an entire top-level domain, but rather selected sites only, then a seed
list is useful.You also need to either be restrictive in the sites crawled (using include/exclude rules), or disable
the following of cross site URIs altogether. If you do neither, then use a small seed list.
Restricting the Size of the Crawl
There are several techniques for restricting the size of your crawl. When setting up a large scale crawl, you
often have requirements based on the number of URIs you would like in your index or how much data you
should handle.
The crawler has several configuration options that can restrict the size of a crawl, taken alone or together:
•
•
•
•
Limit number of documents per site
Specify maximum crawl depth per site
Set a maximum number of documents per collection
Require minimum free disk space limit
The max_docs option specifies the maximum number of documents to retrieve per site per refresh cycle. This
is useful to limit the crawling of deep (or perhaps endlessly recursive) sites. Keep in mind that this counter is
reset per refresh, so that over time the total number of documents might exceed this limit, though documents
not seen for a number of refresh cycles will be recognized and deleted, as described in the dbswitch
configuration option.
134
Configuring the Enterprise Crawler
An another configuration setting that can be used in conjunction with the attribute described above (or on its
own) is level crawling. By specifying a crawlmode depth limitation, you can ensure that the crawler only follows
links a certain number of hops from the Start URI for each site. This avoids the deep internal portions of a
site.
The amount of time spent crawling and the aggressiveness of the crawl are major factors in determining the
volume of fetched documents. The configuration options refresh, max_sites and delay also play a major
role. The crawler will fetch at most refresh * 60 * ( max_sites / delay ) URIs during a single refresh
cycle. For multi node crawls this figure is per master node. Together with a refresh_mode set to scratch or
adaptive this limits the number of documents that will be indexed.
Note: No other refresh_mode value should be used for large-scale crawls, due to potentially large disk
usage requirements.
Keep in mind that subsequent refresh cycles may not fetch the exact same links as before, due to various
reasons including the fact that web pages (and their links) change, the structure of the web changes, and
network latencies change. If scratch refresh mode is used then the index may fluctuate slightly in size.
However, as URIs not fetched for some time are deleted it should be fairly stable once the configuration is
set. With refresh mode set to adaptive it will use the existing set of URIs in the crawler store as the basis
for re-crawling, but some new content will also be crawled.
The limits options allow you to specify threshold limits for the total number of documents and for the free
disk space. If exceeded, the crawler enters a "refreshing" crawl mode, so that it will only crawl URIs that have
been previously fetched. For each limit, one also has to specify a slack value, indicating the lower resource
limit that must be reached before the crawler returns to its normal crawl mode.
Duplicate Server Tuning
Two different storage formats are supported in EC 6.7, GigaBASE and hashlog. Hashlog is recommended
for most installations. However, if you have a lot of small collections (less than 10M each) then using GigaBASE
may also work very well.
GigaBASE
The original format is based on GigaBASE and consists of a set of striped databases.
The main motivation behind the striping is two-fold; decrease the size of database files on disk and reduce
depths of the B-trees within the databases. Reducing the database size through striping may have a limited
effect on the B-tree depths once the databases grow too large.
The following table can be used as a guideline for selecting an appropriate GigaBASE stripe size. Keep in
mind that the document count number relates to the number of documents (or rather document checksums)
stored on this particular duplicate server. A load balanced setup will thus have total_count/ds_instances
documents in a single duplicate server. Dedicated duplicate server replicas are not included in the ds_instances
count.
Document
Stripes
25M
2
50M
4
100M
8
In addition to stripe size you can also tune the GigaBASE cache size. The value given will be divided among
the stripes such that a cache size of 1GB will consume approximately 1GB of memory. If cross-replication is
used the memory usage will be twice the specified cache size. The rule of thumb when selecting a cache
size is to use as much memory as you can afford, as long as the process does not exceed the maximum
process size allowed by the operating system.
135
FAST Enterprise Crawler
Hashlog
The newer format (the default format) is called hashlog and combines a hash (either disk or memory based)
with a log structure. The advantage of a hash compared to a B-tree structure is that lookups in a hash are
O(1) whereas a B-tree has O(log n). This means that as the data structure grows larger the hash is much
more suitable.
A disk based hash is selected by specifying "diskhashlog" as the format. The initial size of the hash (in MB)
can be specified by the cache size option. In this mode each read/write results in 1 seek. This is suitable for
very large structures where it is not feasible to hold the entire hash in memory.
To select a memory based hash, specify the maximum amount of memory to be used with the cache size
option and use the format "hashlog". If the amount of data exceeds the capacity the hash will automatically
rehash to disk. The following formula calculates approximately how many elements the memory hash will
hold:
capacity = memory / (12 * 1.3)
This yields the following approximate table:
Memory Reserved
Documents
100M
~6.5M
500M
~33M
1.0GB
~68M
1.5GB
~100M
In addition to the hash a structured log is also used. Reads from the log require a single seek (bringing us
up to 2 seeks for disk hash and 1 for memory hash). However, due to its nature the log grows in size even
when replacing old elements. To counter this, the duplicate server has a built-in nightly compaction where
the most fragmented log file is compacted. During this time the duplicate server will be unavailable. It does
not affect crawling performance, but will delay any processing in postprocess during that time.
Disk Hash vs. Memory Hash
Note: If sufficient memory is available, a memory hash will give significant performance advantages.
Keep in mind that every collection that uses the duplicate server will allocate a memory hash of the same
size (regardless of the size of the collection), so this affects the memory hash size that can be used. This
makes it impractical to use a memory hash if the collections differ greatly in size. In this case the best
solution is to setup multiple duplicate servers, with memory hash, on the same node, for instance one
duplicate server for a large collection and one duplicate server for the small/medium collections.
Furthermore, the summation of all the cache sizes should not exceed the total amount of available
physical memory on a node.
Note: When using a disk based hash larger than 10M it is generally recommended to turn off the automatic
compaction feature in the duplicate server. Compaction of such disk based hashes can take many hours,
and is best performed manually using the crawlerdbtool. This compaction can be turned off using the -N
command line option passed to the duplicate server.
Postprocess Tuning
"PostProcess" (PP) performs duplicate checking for a single node and feeds data through document processing
to the indexer. Please note that in a multi-node crawler environment, the "duplicate server" handles cross-node
duplicate checking.
136
Configuring the Enterprise Crawler
Tuning duplicate checking
Duplicate checking within a single node requires a database which consists of all the unique checksums
"owned" by the node. The checksums map to a set of URIs (the URI equivalence class) from which one URI
is designated the owner URI and the rest duplicate URIs. Some additional meta information is also stored.
The parameters listed below are available for this purpose, and are tunable per collection in the configuration.
The options are specified in the "postprocess" section of the configuration, unless otherwise noted.
Postprocess
Parameter
Description
dupservers
Must be set to a list of primary duplicate servers.
max_dupes
Determines the maximum number of duplicate URIs corresponding to each checksum. This
setting has a severe performance impact and values above 3-4 are not recommended for large
scale crawls.
stripe
Please refer to the hashlog/GigaBASE discussion in the Duplicate Server Tuning section. A
stripe size of 4 is typical in most cases. Note that for GigaBASE storage the amount of memory
used by caching is defined as the postprocess cache size multiplied by the number of stripes.
ds_paused
Allows you to pause feeding to document processing and indexing. Useful if you would like to
crawl first and index later. Can also be controlled with the --suspendfeed and the resumefeed
crawleradmin option, but the value in the configuration overrides it if you feed.
ds_max_ecl
Maximum number of URIs in the equivalence class that is sent to document processing for
indexing. The value should be set to the same value as max_dupes.
pp (in cache size
section)
Specifies the amount of memory allocated to the checksum database cache for the collection.
For GigaBASE this is the database cache *per stripe*, and for Hashlog it is the memory hash
size. The value should be high (for example, 512MB or more for a 25M node), but keep in mind
that this setting is separate per collection and that they add up. Use the most memory on the
large collections.
Tuning postprocess feeding
By default crawlerfs in postprocess is run using a single thread. In order to increase the throughput, it is
possible to configure multiple crawlerfs processes and multiple DocumentRetriever processes in the ESP
document processing pipeline. This may significantly speed up the processing.
If you need to accomplish this task, please contact FAST support.
Crawler/Master Tuning
The following sections outline the various parameters that should be modified for large scale crawls.
Storage and Storage Tuning
The following storage section attributes should be tuned. The remaining storage parameters should be left
at default values (for example, not included in XML at all).
The crawler performs large amounts of network and file I/O, and the number of available file descriptors can
be a limiting factor, and lead to errors. Insure that sufficient file descriptors are available by running the limit
(or ulimit) command from the account under which the crawler runs. If the value is too low (below 2048),
increase the hard limit for descriptors to 8096 (8K). Check the operating system administrator documentation
for details on doing so; it may be sufficient to run the limit/ulimit command as superuser, or a system resource
configuration file might need to be modified, perhaps requiring a system reboot.
137
FAST Enterprise Crawler
Storage Parameter
Description
store_http_header
Can be disabled if you know that it will not be needed in the processing pipeline
(it is sent in the 'http_header' attribute). Disabling saves some disk space in the
databases and may give a slight performance boost.
remove_docs
Enabling this option will delete documents from disk once they have been feed
to document processing and indexing. Disabled by default.
Note: Re-feeding the crawler store will not be possible with this option
enabled. Therefore, this mode should only be enabled for stable and
well-tested installations.
Cache Size Tuning
The crawler automatically tunes certain cache sizes based on what it perceives as the size of your crawl.
The main factors are the number of active sites and the delay value.
The following caches are automatically tuned, and they should not be included in your XML configuration
(and if they do they must have blank values):
•
•
•
•
•
screened
smcomm
mucomm
wqcache
crosslinks
Refer to Cache Size Parameters on page 101 for additional information including parameter defaults.The only
cache parameter to be configured is the postprocess (pp) cache which was previously discussed in the
Postprocess Tuning on page 136 section.You may also use a larger cache size for the routetab and aliases
cache if you crawl a lot of sites, especially multiple node crawls. The pp, routetab and aliases caches are
all GigaBASE caches specified in bytes.
Log Tuning
Less logging means improved performance. However, it also means that is becomes more difficult to debug
issues. Note that only some of the logs have large impact on the performance.
In order of resource consumption you should adhere to the following recommendation:
•
•
•
•
•
•
•
DNS log: Should always be enabled.
Screened log: Must be disabled!
Site log: Should always be enabled.
Fetch log: Should always be enabled.
Postprocess log: Should be disabled unless you use it.
DSFeed log: Should always be enabled.
Scheduler log: Should be disabled unless you use it.
General Tuning
fetch_timeout, robots_timeout, Default is 300 seconds, increase if you experience more timeouts than expected
(could be caused by bandwidth shapers)
login_timeout
138
use_http_1_1
Enable to take advantage of content compression and If-Modified-Since, both
saving bandwidth.
accept_compression
Enables the remote HTTP server to compress the document if desired before
sending. Few servers actually do this, but some do and it will save bandwidth.
robots
Always adhere to robots.txt when doing large scale crawls.
Configuring the Enterprise Crawler
refresh_mode
A large scale crawl should always use 'scratch' (default) or 'adaptive'.
If you need to crawl everything, then you should initially set the 'refresh' to a
high value. Once you know the time required for an entire cycle, you can tune
it. If it is not possible to crawl everything within your time limit, you need to reduce
the 'refresh' and/or use the 'max_doc' option to reduce the number of documents
to download from each site.
Note: The option to automatically refresh when idle is not available for
multi node crawler setups.
max_sites
Together with the delay option this controls the maximum theoretical crawl speed
you will be able to obtain. For example, a max_sites of 2000 and a delay of 60
will give you 2000/60 = 33 docs/sec. Please note that this value is *per node*
so with 10 crawler nodes this would translate into 20000 max_sites total and
333 docs/sec.
In practice you seldom get that close to the theoretical speed, and it also depends
greatly on there being enough sites to crawl at any one time. To monitor your
crawler with regard to the actual rate use crawleradmin -c and look at the "Active
sites" count.
headers
While this setting can be used to specify arbitrary HTTP headers, it is usually
used for only the crawler 'User-Agent'. The user agent header must specify a
"name" for the crawler as well as contact information, either in the form of a web
page and/or e-mail address. For example "User-Agent: YourCompany Crawler
(crawler at yourcompany dot com)"
cut_off
Should be adjusted depending on the type of documents to be crawled. For
example, PDFs and Word documents tend to be larger than HTML documents
for example.
max_doc
This setting can be important when tuning the size of the crawl, as it limits the
number of documents retrieved per site.Typical values might be in the 2000-5000
range. Can also be specified for sub collections if and only if the sub collections
are only defined using hostname rules and not any URI rules.
check_meta_robots
META robots tags should be adhered to when doing a web scale crawl.
html_redir_is_redir/html_redir_thresh
The 'html_redir_is_redir' option lets the crawler treat META refresh tags inside
HTML documents as if they were true HTTP redirects. When enabled the
document containing the META refresh will not itself be indexed.
The 'html_redir_thresh' option specifies the number of seconds delay which are
allowed for the tag to be considered a redirect. Anything less than this number
is treated as a redirect, other values are just treated as a link (and the document
itself is indexed also).
dbswitch/dbswitch_delete
The 'dbswitch' option specifies the number of refreshes a given URI is allowed
to stay in the index without being seen again by the crawler. URIs that have not
been seen for this amount of refreshes will either be deleted or added to the
queue for re-crawl, depending on the 'dbswitch_delete' option.
This option should never be less than 2 and preferably at least 3. For example
a in a 30 day cycle crawl with a dbswitch of 3 any given URI may remain unseen
for 3 cycles before being removed/scheduled. Keep in mind that if the crawler
was stopped for 30 days the cycles would still progress.
One common method of limiting the amount of dead links in the index is to use
what is known as a dead links crawler. The idea is to use click-through tracking
to actively re-crawl the search results clicked on by users. Not only will the
crawler quickly discover pages that have disappeared, but freshness for
frequently clicked pages are also improved.
139
FAST Enterprise Crawler
wqfilter/smfilter/mufilter
These options decide whether to use a Bloom filter to weed out duplicate URIs
before queuing in the slave ('wqfilter') and sending URIs from the slave to the
master ('smfilter'). The former is a yes/no option and the size of the filter is
calculated based on the max_docs setting and a very low probability of false
positives. For large scale crawls this should definitely be on to reduce the number
of duplicates in the queue.
The 'smfilter' is specified by a capacity value, typically 50000000 (50M). The
filter is automatically purged whenever it reaches a certain saturation, so there
should be a very low probability of false positives. The default is off (0), but the
50M size should definitely be used for large crawls.
The 'mufilter' is a similar filter present in the master and ubermaster. It should
be even larger, typically 500000000 (500M) for wide crawls to prevent overloading
the ubermaster with links.
max_reflinks
Must be set to 0 (the default value) for large-scale crawls, to disable the crawler
from storing a list of URIs that link to each document. Disabling this reduces
memory and disk usage within the crawler. The equivalent functionality is
implemented by the WebAnalyzer component of FAST ESP.
max_pending
This option limits the number of concurrent requests allowed to a single site.
For a large scale crawl with 60 seconds delay it should probably be set to 1 or
2 (the only time you would have more than one request would be if the first took
more than 60 seconds to complete).
extract_links_from_dupes
Since duplicates generally link to more duplicates this option should be turned
off, whether the crawl is large or small.
if_modified_since
Controls whether to send 'If-Modified-Since' requests, significantly reducing the
bandwidth use subsequent crawl cycles. Should always be on for wide crawls.
use_cookies
The cookie support is intended for small intranet crawls and should always be
disabled for large scale crawls. If you require cookie support for certain sites it
may be best to place them in a separate collection, rather than enabling this
feature for the entire crawl.
rewrite_rules
Rewrite rules can be used to rewrite links parsed out of documents by applying
regular expression and repeating captured text. This implies that all rewrite rules
are attempted applied for every link, and it can therefore be very expensive in
terms of CPU usage depending on the number of rules and their complexity. It
is therefore advised to limit the amount of rewrite rules for large scale crawls.
use_javascript and
enable_flash
For performance reasons it is highly recommended to disable JavaScript and
flash crawling for large crawls. If you require JavaScript and/or flash support,
you should only enable it for a limited set of sites. You need to put these sites
into a separate collection.
Note: Enabling any of these options also requires that one or more Browser
Engines be configured. For more information, please refer to the FAST
ESP Browser Engine Guide.
domain_clustering
In a web scale crawl it is possible to optimize the crawler to take advantage of
locality in the web link structure. Sub domains on the same domain tend to link
more internally than externally, just as a site would have mostly interlinks. The
domain clustering option enables clustering of sites on the same domain (for
example, *.example.net) on the same master node and the same storage
cluster (and thus uberslave process). For web crawls this feature should always
be enabled.
Note: This option is automatically turned on for multi node crawls by the
ubermaster
140
Configuring the Enterprise Crawler
Maximum Number of Open Files
If you plan to do a large scale crawl you should increase the maximum number of open files (default 1024).
This change is done in etc/NodeConf.xml. For example, to change from:
<resourcelimits>
<limit name="core" soft="unlimited"/>
<limit name="nofile" soft="1024"/>
</resourcelimits>
to
<resourcelimits>
<limit name="core" soft="unlimited"/>
<limit name="nofile" soft="4096"/>
</resourcelimits>
Note that this will only set the soft limit. In order for this to work the system hard limit must also be set to the
same value or higher.
Large Scale XML Configuration Template
The following shows a largescale.xml collection configuration template.
largescale.xml crawler collection configuration template
<?xml version="1.0"?>
<CrawlerConfig>
<!-- Template -->
<DomainSpecification name="LARGESCALE">
<!-<!-<!-<!--
Crawler Identification
Modify the following options to identify the collections
and the crawler. Make sure you specify valid contact
information.
-->
-->
-->
-->
<attrib name="info" type="string">
Sample LARGESCALE crawler config
</attrib>
<!-- Extra HTTP Headers -->
<attrib name="headers" type="list-string">
<member>
User-agent: COMPANYNAME Crawler (email address / WWW address)
</member>
</attrib>
<!-- General options
<!-- The following options are general options tuned for large
<!-- scale crawling. You generally do not need to modify these
-->
-->
-->
<!-- Adhere to robots.txt rules -->
<attrib name="robots" type="boolean"> yes </attrib>
<!-- Adhere to meta robots tags in html headers -->
<attrib name="" type="boolean"> yes </attrib>
<!-- Adhere to crawl delay specified in robots.txt -->
<attrib name="obey_robots_delay" type="boolean"> no </attrib>
<!-- Don't track referrer links, as this is done in the -->
<!-- pipeline by the WebAnalyzer component -->
<attrib name="max_reflinks" type="integer"> 0 </attrib>
<!-- Only have one outstanding request per site at any one time -->
<attrib name="max_pending" type="integer"> 1 </attrib>
<!-- Keep hostnames of the same DNS domain within one slave -->
<attrib name="domain_clustering" type="boolean"> yes </attrib>
141
FAST Enterprise Crawler
<!-- Maximum time for the retrieval of a single document -->
<attrib name="fetch_timeout" type="integer"> 300 </attrib>
<!--- Support HTML redirects -->
<attrib name="html_redir_is_redir" type="boolean"> yes </attrib>
<!-- Anything with delay 3 and lower is treated as a redirect -->
<attrib name="html_redir_thresh" type="integer"> 3 </attrib>
<!-- Enable near duplicate detection -->
<attrib name="near_duplicate_detection" type="boolean"> no </attrib>
<!-- Only log retrievals, not postprocess activity -->
<section name="log">
<attrib name="fetch" type="string"> text </attrib>
<attrib name="postprocess" type="string"> none </attrib>
</section>
<!-- Do not extract and follow links from duplicates -->
<attrib name="extract_links_from_dupes" type="boolean"> no </attrib>
<!-- Do not store duplicates, use a block-type storage, and
compress documents on disk -->
<section name="storage">
<attrib name="store_dupes" type="boolean"> no </attrib>
<attrib name="datastore" type="string"> bstore </attrib>
<attrib name="compress" type="boolean"> yes </attrib>
</section>
<!-- Do not retry retrieval of documents for common errors -->
<section name="http_errors">
<attrib name="4xx" type="string"> DELETE </attrib>
<attrib name="5xx" type="string"> DELETE </attrib>
<attrib name="ttl" type="string"> DELETE:3 </attrib>
<attrib name="net" type="string"> DELETE:3, RETRY:1 </attrib>
<attrib name="int" type="string"> KEEP </attrib>
</section>
<!-- Rate and size options
<!-- The following options tune the crawler rate and refresh
<!-- cycle settings. Modify as desired.
-->
-->
-->
<!-- Only retrieve one document per minute -->
<attrib name="delay" type="real"> 60 </attrib>
<!-- Length of crawl cycle is 10 days (expressed in minutes) -->
<attrib name="refresh" type="real"> 14400 </attrib>
<!-- Available refresh modes: scratch (default), adaptive, soft, -->
<!-- append and prepend.
-->
<attrib name="refresh_mode" type="string"> scratch </attrib>
<!-- Let three cycles pass before cleaning out URIs not found -->
<attrib name="dbswitch" type="integer"> 3 </attrib>
<!-- Crawl Mode -->
<section name="crawlmode">
<!-- Crawl depth (use DEPTH:n to do level crawling) -->
<attrib name="mode" type="string"> FULL </attrib>
<!-- Follow interlinks -->
<attrib name="fwdlinks" type="boolean"> yes </attrib>
<!-- Reset crawl level when following interlinks -->
<attrib name="reset_level" type="boolean"> no </attrib>
</section>
<!-- Let each master crawl this many sites simultaneously -->
<attrib name="max_sites" type="integer"> 6144 </attrib>
<!-- Maximum size of a document -->
<attrib name="cut_off" type="integer"> 500000 </attrib>
<!-- Maximum number of bytes to use in checksum (0 == disable) -->
142
Configuring the Enterprise Crawler
<attrib name="csum_cut_off" type="integer"> 0 </attrib>
<!-- Maximum number of documents to retrieve from one site -->
<attrib name="max_doc" type="integer"> 5000 </attrib>
<!-- Enable HTTP version 1.1 to enable accept_compression -->
<attrib name="use_http_1_1" type="boolean"> yes </attrib>
<!-- Accept compressed documents from web servers, you
have more cpu than bandwidth -->
<attrib name="accept_compression" type="boolean"> yes </attrib>
<!-- Performance tuning options
-->
<!-- Sizes of various caches -->
<section name="cachesize">
<!-- UberMaster and Master routing tables cache (in bytes) -->
<attrib name="routetab" type="integer"> 4194304 </attrib>
<!-- PostProcess checksum database (per stripe) cache (in bytes)
-->
<attrib name="pp" type="integer"> 268435456 </attrib>
</section>
<!-- Slave work queue bloom filter enabled -->
<attrib name="wqfilter" type="boolean"> yes </attrib>
<!-- Slave -> Master bloom filter with capacity 50M -->
<attrib name="smfilter" type="integer"> 50000000 </attrib>
<!-- Master/UberMaster bloom filter with capacity 500M -->
<attrib name="mufilter" type="integer"> 500000000 </attrib>
<!-- Adaptive Scheduling. To enable un comment this section and -->
<!-- change 'refresh_mode' to 'adaptive'
-->
<section name="adaptive">
<!-- Number of "micro" refresh cycle within a full refresh -->
<attrib name="refresh_count" type="integer"> 4 </attrib>
<!-- Ratio (in percent) of rescheduled URIs vs. new (unseen) -->
<!-- URIs scheduled. - ->
<attrib name="refresh_quota" type="integer"> 98 </attrib>
<!-- The maximum percentage of a site to reschedule during a -->
<!-- "micro" refresh cycle.
-->
<attrib name="coverage_max_pct" type="integer"> 25 </attrib>
<!-- The minimum number of URIs on a site to reschedule
<!-- during a refresh cycle "micro" refresh cycle.
<attrib name="coverage_min" type="integer"> 10 </attrib>
-->
-->
<!-- Ranking weights. Each scoring criteria adds a score between
-->
<!-- 0.0 and 1.0 which is then multiplied with the associated
-->
<!-- weight below. Use a weight of 0 to disable a scorer
-->
<section name="weights">
<!-- Score based on the number of /'es (segments) in the -->
<!-- URI. Max score with one, no score with 10 or more
-->
<attrib name="inverse_length" type="real"> 1.0 </attrib>
<!-- Score based on the number of link "levels" down to -->
<!-- this URI. Max score with none, no score with >= 10 -->
<attrib name="inverse_depth" type="real"> 1.0 </attrib>
<!-- Score added if URI is determined as a "landing page" -->
<!-- defined as e.g. ending in "/" or "index.html". URIs
-->
<!-- with query parameters are not given score
-->
<attrib name="is_landing_page" type="real"> 1.0 </attrib>
143
FAST Enterprise Crawler
<!-- Score added if URI points to a markup document as
-->
<!-- defined by the "uri_search_mime" option. Assumption
-->
<!-- being that such content changes more often than e.g. -->
<!-- "static" Word or PDF documents.
-->
<attrib name="is_mime_markup" type="real"> 1.0 </attrib>
<!-- Score based on change history tracked over time by
-->
<!-- using an estimator based on last modified date given -->
<!-- by the web server. If no modified date returned then -->
<!-- one is estimated (based on whether the document has
-->
<!-- changed or not).
-->
<attrib name="change_history" type="real"> 10.0 </attrib>
</section>
</section>
<!-- PostProcess options
<!-- Duplicate servers must be specified also. Feeding is
<!-- initially suspended below, can be turned on if desired.
-->
-->
-->
<section name="pp">
<!-- Use 4 database stripes -->
<attrib name="stripe" type="integer"> 4 </attrib>
<!-- Only track up to four duplicates for any document -->
<attrib name="max_dupes" type="integer"> 4 </attrib>
<!-- The address of the duplicate server -->
<attrib name="dupservers" type="list-string">
<member> HOSTNAME1:PORT </member>
<member> HOSTNAME2:PORT </member>
</attrib>
<!-- report only bare minimum of meta info to ESP/FDS -->
<attrib name="ds_meta_info" type="list-string">
<member> duplicates </member>
<member> redirects </member>
</attrib>
<!-- Feeding to ESP/FDS suspended -->
<attrib name="ds_paused" type="boolean"> yes </attrib>
</section>
<!-<!-<!-<!-<!--
Inclusion and exclusion
The following section sets up what content to crawl and
not to crawl. Do not use regular expression rules unless
absolutely necessary as they have a significant impact
on performance.
-->
-->
-->
-->
-->
<!-- Only crawl http (ie, don't crawl https/ftp -->
<attrib name="allowed_schemes" type="list-string">
<member> http </member>
</attrib>
<!-- Allow these MIME types to be retrieved -->
<attrib name="allowed_types" type="list-string">
<member> text/html </member>
<member> text/plain </member>
<member> text/asp </member>
<member> text/x-server-parsed-html </member>
</attrib>
<!-- List of included domains (may be regexp,prefix,suffix, exact)
-->
<section name="include_domains">
144
Configuring the Enterprise Crawler
<attrib name="exact" type="list-string">
</attrib>
<attrib name="prefix" type="list-string">
</attrib>
<attrib name="suffix" type="list-string">
</attrib>
</section>
<!-- List of excluded domains (may be regexp,prefix,suffix, exact)
-->
<section name="exclude_domains">
<attrib name="exact" type="list-string">
</attrib>
<attrib name="prefix" type="list-string">
</attrib>
<attrib name="suffix" type="list-string">
</attrib>
</section>
<!-- List of excluded URIs (may be regexp,prefix,suffix, exact) -->
<section name="exclude_uris">
<attrib name="exact" type="list-string">
</attrib>
<attrib name="prefix" type="list-string">
</attrib>
<attrib name="suffix" type="list-string">
</attrib>
</section>
<!-- List of included URIs (may be regexp,prefix,suffix, exact) -->
<section name="include_uris">
<attrib name="exact" type="list-string">
</attrib>
<attrib name="prefix" type="list-string">
</attrib>
<attrib name="suffix" type="list-string">
</attrib>
</section>
<!-- Exclude these filename extensions -->
<attrib name="exclude_exts" type="list-string">
<member> .jpg </member>
<member> .jpeg </member>
<member> .ico </member>
<member> .tif </member>
<member> .png </member>
<member> .bmp </member>
<member> .gif </member>
<member> .avi </member>
<member> .mpg </member>
<member> .wmv </member>
<member> .wma </member>
<member> .ram </member>
<member> .asx </member>
<member> .asf </member>
<member> .mp3 </member>
<member> .wav </member>
<member> .ogg </member>
<member> .zip </member>
<member> .gz </member>
<member> .vmarc </member>
<member> .z </member>
<member> .tar </member>
<member> .swf </member>
<member> .exe </member>
<member> .java </member>
<member> .jar </member>
<member> .prz </member>
<member> .wrl </member>
145
FAST Enterprise Crawler
<member>
<member>
<member>
<member>
<member>
<member>
<member>
<member>
<member>
<member>
<member>
<member>
<member>
<member>
</attrib>
.midr </member>
.css </member>
.ps </member>
.ttf </member>
.xml </member>
.mso </member>
.rdf </member>
.rss </member>
.cab </member>
.xsl </member>
.rar </member>
.wmf </member>
.ace </member>
.rar </member>
<!-- List of start URIs -->
<attrib name="start_uris" type="list-string">
<member> INSERT START URI HERE </member>
</attrib>
<!-- List of start URI files -->
<attrib name="start_uri_files" type="list-string">
<member> INSERT START URI FILE HERE</member>
</attrib>
</DomainSpecification>
</CrawlerConfig>
146
Chapter
4
Operating the Enterprise Crawler
Topics:
•
•
•
•
•
•
•
Stopping, Suspending and
Starting the Crawler
Monitoring
Backup and Restore
Crawler Store Consistency
Redistributing the Duplicate
Server Database
Exporting and Importing
Collection Specific Crawler
Configuration
Fault-Tolerance and Recovery
The crawler runs as an integrated component within FAST ESP, monitored by
the node controller (nctrl) and started/stopped via the administrator interface or
the nctrl command.
FAST Enterprise Crawler
Stopping, Suspending and Starting the Crawler
Stopping, suspending and starting the crawler can be executed from the administrator interface or from the
command line and differs depending on your environment.
Starting in a Single Node Environment - administrator interface
In a single node environment, to start the crawler from the administrator interface:
1. Select System Management on the navigation bar.
2. Locate the Enterprise Crawler on the Installed module list - Module name. Select the Start symbol to
start the crawler.
Starting in a Single Node Environment - command line
Use the nctrl tool to start the crawler from the command line.
Refer to the nctrl Tool appendix in the FAST ESP Operations Guide for nctrl usage information.
Run the following command to start the crawler:
1. $FASTSEARCH/bin/nctrl start crawler
Starting in a Multiple Node Environment - administrator interface
In a multiple node environment, the ubermaster processes must be started up first, followed by individual
crawler processes.
In a multiple node environment, to start the crawler from the administrator interface:
1. Select System Management on the navigation bar.
2. Locate the ubermaster process, and select the Start symbol.
3. For all crawler processes, select the Start symbol.
Starting in a Multiple Node Environment - command line
In a multiple node environment, the ubermaster processes must be started up first, followed by individual
crawler processes. Use the nctrl tool to start the crawler from the command line.
Refer to the nctrl Tool appendix in the FAST ESP Operations Guide for nctrl usage information.
To start the crawler from the command line:
1. On the node running the ubermaster process, run the command: $FASTSEARCH/bin/nctrl start crawler
2. On all nodes that run crawler processes (assuming the processes are named crawler), run the command:
$FASTSEARCH/bin/nctrl start crawler
Suspending/Stopping in a Single Node Environment - administrator interface
The crawler is stopped (if running) and started when a configuration is updated. There is also a start/stop
button for an existing crawler.
In a single node environment, to stop the crawler from the administrator interface:
1. Select System Management on the navigation bar.
148
Operating the Enterprise Crawler
2. Locate the Enterprise Crawler on the Installed module list - Module name. Select the Stop symbol to
stop the crawler.
Suspending/Stopping in a Single Node Environment - command line
Use the nctrl tool to stop the crawler from the command line.
Refer to the nctrl Tool appendix in the FAST ESP Operations Guide for nctrl usage information.
Run the following command to stop the crawler:
1. $FASTSEARCH/bin/nctrl stop crawler
Suspending/stopping in a Multiple Node Environment - administrator interface
In a multiple node environment, the individual crawler processes must be shut down first, followed by the
ubermaster processes.
In a multiple node environment, to stop the crawler from the administrator interface:
1. Select System Management on the navigation bar.
2. For all crawler processes, select the Stop symbol.
3. Locate the ubermaster process, and select the Stop symbol.
The crawler will not stop completely before all outstanding content batches have been successfully submitted
to FAST ESP and received by the indexer nodes. Monitor the crawler submit queue by waiting until the
$FASTSEARCH/data/crawler/dsqueues folder (on the node running the crawler) is empty.
Suspending/stopping in a Multiple Node Environment - command line
In a multiple node environment, the individual crawler processes must be shut down first, followed by the
ubermaster processes. Use the nctrl tool to stop the crawler from the command line.
Refer to the nctrl Tool appendix in the FAST ESP Operations Guide for nctrl usage information.
To stop the crawler from the command line:
1. On all nodes that run crawler processes (assuming the processes are named crawler), run the command:
$FASTSEARCH/bin/nctrl stop crawler
2. On the node running the ubermaster process, run the command: $FASTSEARCH/bin/nctrl stop crawler
The crawler will not stop completely before all outstanding content batches have been successfully submitted
to FAST ESP and received by the indexer nodes. Monitor the crawler submit queue by waiting until the
$FASTSEARCH/data/crawler/dsqueues folder (on the node running the crawler) is empty.
Monitoring
While the crawler is running, you can use the FAST ESP administrator interface or the crawleradmin tool to
monitor and manage the crawler.
Refer to the FAST ESP Configuration Guide for information about the administrator interface.
Enterprise Crawler Statistics
A detailed overview of statistics for each of the collections configured in the Enterprise Crawler is available
in the FAST ESP administrator interface.
149
FAST Enterprise Crawler
Navigating to the Data Sources tab will list all the available Enterprise Crawlers installed. For each Enterprise
Crawler choosing List Collections will display all the collections associated with the particular Enterprise
Crawler instance.
For each collection there are a number of available options:
Configuration - List the configured settings for the collection.
Fetch log - See the last 5 minutes from the collection fetch log for the collection.
Site log - See the last 5 minutes of the collection site log for the collection.
Site statistics - View detailed statistics for a single web site in the collection. Input the web site you want to
view detailed statistics for and choose Lookup.
Note: Only web sites that have already been crawled can be viewed for statistics.
Table 43: Site statistics for <web site> in collection <collection>
Name
Description
Status
The current crawl status for this web site.
Possible values are:
Crawling - The web site is currently being crawled.
Idle - The web site is not being crawl at the moment.
Document Store
The number of documents in the crawler store for this web site.
Statistics age
The time since the last statistics update.
Last URI
The last URI crawled for this web site-
Queue Length
The current size of this web sites workqueue.
For a description of the detailed statistics of a web site. See viewing detailed statistics about collection below.
Statistiscs - View detailed statistics about collection.
Table 44: Overall Collection Statistics
Name
Description
Crawl status
Displays the current crawl status of the crawler.
Possible values are:
Crawling, X sites active - The collection is crawling, X web sites are currently
active.
Idle - The collection is idle, no web sites are currently active.
Suspended - The collection is suspended.
Feed Status
Possible values are:
Feeding - The collection is currently feeding the content to ESP.
Queueing - The collection is currently queueing content to disk and feeding to ESP is
suspended.
150
Cycle Progress (%)
The current collection refresh cycle progress. Calculated based on time until next refresh.
Time until refresh
The time until next refresh for this collection.
Stored Documents
The number of documents the crawler has stored.
Operating the Enterprise Crawler
Name
Description
Unique Documents
The number of unique documents the crawler has stored.
Document Rate
The current rate at which documents are downloaded.
In Bandwidth
The current inbound bandwidth the crawler is utilizing.
Statistics Updated
The time since the last statistics update.
The Status for all collections link will display a summary of all the collections and some of their most interesting
statistics.
The Detailed Statistics link will display detailed statistics for the previous and the current crawl cycle, as well
as the total for all crawl cycles.
Table 45: Detailed Collection Statistics
Processing Status
Description
Processed
The number of requested documents by the crawler.
Downloaded
The number of downloaded documents by the crawler.
Stored
The number of documents stored by the crawler.
Modified
The number of documents stored that were modified.
Unchanged
The number of documents that were unchanged.
Deleted
The number of documents that were deleted by the crawler.
Postprocess statistics
Description
ADD operations
The number of ADD operations sent to ESP.
DEL operations
The number of DEL(ete) operations sent to ESP.
MOD operations
The number of MOD(ified) operations sent to ESP.
Note: MODs are in reality sent as ADDs.
URLSChange operations
The number of URLSChange operations sent to ESP. URLSChanges contains updates
on the URIs equivalence class.
Total Operations
The total number of operations overall.
Successful operations
The number of successful operations overall.
Failed operations
The number of failed operations overall.
Operation rate
The rate, in operations per second, at which operations are sent to ESP.
Network
Description
Document Rate
The rate, in documents per seoncd, at which documents are downloaded.
In Bandwidth
The current inbound bandwidth the crawler is utilizing.
Out Bandwidth
The current outbound bandwidth the crawler is utilizing.
Downloaded bytes
The total number of bytes the crawler has downloaded.
Sent bytes
The total number of bytes the crawler has sent.
Average Document Size
The average document size of the documents the crawler has downloaded.
Max Document Size
The maximum document size of the documents the crawler has downloaded.
151
FAST Enterprise Crawler
152
Network
Description
Download Time
The accumulated time used to download documents.
Average Download Time
The average time to download a document.
Maximum Download Time
The maximum time to download a document.
Mime Types
Description
<type>"/"<subtype>
A breakdown of the various Mime Types of the documents downloaded by the crawler.
URIs Skipped
Description
NoFollow
URIs skipped due to link tag having a rel="NoFollow" attribute.
Scheme
URIs skipped due to not matching the collection Allowed Schemes setting.
Robots
URIs skipped due to being excluded by robots.txt.
Domain
URIs skipped due to not matching the collection domain include/exclude filters.
URI
URIs skipped due to not matching the collection URI include/exclude filters.
Out of Focus
URIs skipped due to being out of focus from the collection Focus crawl settings.
Depth
URIs skipped due to being out of the collection Crawl Mode depth settings.
M/U Cache
URIs skipped due to being screened by internal caches.
Documents Skipped
Description
MIME Type
Document skipped due to not matching the collection MIME-Types setting.
Header Exclude
Document skipped due to matching the collection Header Excludes setting.
Too Large
Document skipped due to exceeding the collection Maximum Document Size setting.
NoIndex RSS
Document skipped due to the collection RSS setting Index RSS documents?.
HTTP Header
Document skipped due to errors with HTTP header.
Encoding
Document skipped due to problems with the document encoding. Typically problems with
compressed content.
Chunk Error
Document skipped due to problems with chunked encoding. Failure to de-chunk content.
Incomplete
Document skipped due to being incomplete. The webserver did not return the complete
document as indicated by the HTTP header.
No 30x Target
Document skipped due to not having a redirect target.
Connect Error
Document skipped due to failure to connect() to the remote web server.
Connect Timeout
Document skipped due to the to connect() to the remote web server timed out.
Timeout
Document skipped due to it using longer time to download than the Fetch Timeout setting.
Network Error
Document skipped due to various network errors.
NoIndex
Document skipped due to containing a META robots No Index tag.
Checksum Cache
Document skipped due to being screened by the run-time checksum cache used for
duplicate detection.
Other Error
Document skipped due to other reasons.
Document Plugin
Document skipped by the user specified document plugin.
Empty Document
Document skipped due to being 0 bytes.
Operating the Enterprise Crawler
Protocol Response Codes Description
<Response Code>
<Response Info >
A breakdown of the various protocol response codes received by the crawler.
DNS Statistics (global)
Description
DNSRequests
Number of issued DNS requests.
DNSResponses
Number of received DNS responses.
DNSRetries
Number of issued DNS request retries.
DNSTimeout
Number of issued DNS requests that timed out.
DNS Statistics (global)
Description
<Response code>
A breakdown of the DNS response codes received by the crawler.
Possible responses are:
NOERROR - The DNS server returned no error (hostname resolved).
NXDOMAIN - The domain name referenced in the query does not exist (hostname did not
resolve).
FORMERR - The DNS server was unable to interpret the query.
SERVFAIL - The DNS server was unable to process this query due to a problem on the
server side.
NOTIMP - The DNS server does not support the requested query.
REFUSED - The DNS server refused to perform the specified operation.
NOANSWER - The DNS rescord received from the DNS server did not contain an ANSWER
section.
PARTANSWER - The DNS record received from the DNS server contained only a partial
ANSWER section.
TIMEOUT - The DNS request timed out.
UNKNOWN - An unknown DNS reply packet was received.
Backup and Restore
Crawler configuration is primarily concerned with collection specific settings. Backup of the crawler configuration
will ensure that the crawler can be reconstructed to a state with an identical setup, but without knowledge of
any documents.
The crawler configuration is located in: $FASTSEARCH/data/crawler/config/config.hashdb
To backup the configuration, stop the crawler, then save this file.
It is also possible to export/import collection specific crawler configuration in XML format using the
crawleradmin tool. This is not necessary for pure backup needs (as the config.hashdb file includes all the
collection specific information, including statistics on previously gathered pages). However, if a collection is
to be completely recreated from scratch, having been deleted both from the crawler and the search engine,
the XML-formatted settings should be used to recreate the collection, rather than using a restored crawler
configuration database.
Refer to the FAST ESP Operations Guide for overall system backup and restore information.
153
FAST Enterprise Crawler
Restore Crawler Without Restoring Documents
To restore a node to the backed up configuration without restoring the documents:
1. Install the node according to the overall procedures in the Installing Nodes from an Install Profile chapter
in the FAST ESP Operations Guide.
2. Restart the crawler.
3. Reload the backed up XML configuration file: $FASTSEARCH/bin/crawleradmin -f <configuration
filename>
Full Backup of Crawler Configuration and Data
Backing up the crawler configuration only ensures that all information about individual collections and the
setup of the crawler itself can be restored, but will trigger the sometimes unacceptable overhead of having
to crawl and reprocess all documents over again. To be able to recover without this overhead, a full backup
of the crawler is needed.
To perform a full backup:
1. Stop the crawler: $FASTSEARCH/bin/nctrl stop crawler
2. Backup the complete directory on all nodes involved in crawling: $FASTSEARCH/data/crawler
Note: Be sure to back up the duplicate server; this process often runs on a separate node from the
crawler.
3. If keeping log files is desired, backup the log file directory. This is for reference only, and is not needed
to get the system backup.
$FASTSEARCH/var/log/crawler
Full restore of Crawler Configuration and Data
To perform a full restore:
1. Install the node according to the overall procedures in the Installing Nodes from an Install Profile chapter
in the FAST ESP Operations Guide.
2. Make sure the crawler is not running, then restore the backed up directory on each node to be restored:
$FASTSEARCH/data/crawler
3. Start the crawler.
The crawler will start re-crawling from the point where it was backed up, and according to the restored
configuration.
Re-processing Crawler Data Using postprocess
This topic describes how to re-process the crawler data of one or several collections into the document
processing pipeline without starting a re-crawl.
The crawler stores the crawl data into meta storage and document storage. The metadata consists of a set
of databases mapping URIs to their associated metadata (such as crawl time, MIME type, checksum, document
storage location, and so forth.). The crawler uses a pool of database clusters (usually 8) which in turn consist
of a set of meta databases (one site databases and multiple URI segment databases).
Reprocessing the contents of collections involves the following process. Note that this is a somewhat simplified
description of the actual inner workings of postprocess. Steps 1 and 2 run in parallel, and as step 1 is usually
significantly faster, it also completes before step 2.
154
Operating the Enterprise Crawler
1. Meta databases are traversed site by site, and extract the URIs with associated document data on disk.
Each site, along with the number of URIs stored in the meta database, is logged as traversal of that site
commences. The number of URIs may therefore include duplicates.
For each URI that is extracted, duplicate detection is performed by a lookup for the associated checksum
in the postprocess database. If the checksum does not exist (new/changed document) or the checksum
is associated with the current URI, then the document is accepted as a unique document; otherwise it is
treated as a duplicate.
2. Unique (non-duplicate) documents are queued for submission to document processing.
3. All documents due for submission are placed in a queue in $FASTSEARCH/data/crawler/dsqueues.
Postprocess now serves the document processors from this queue, and terminates once all documents
have been consumed. The duration of this phase is dictated by the capacity of the document processing
subsystem.
If you have a configuration scenario with the crawler on a separate node you may experience a recovery
situation where index data has been lost (when running single-row indexer). If the crawler node is fully
operative, it is recommended to perform a full re-processing of crawled documents. This can be
time-consuming, but may be the only way to ensure full recovery of documents submitted after the last backup.
Single node crawler re-processing
1. Stop the crawler: $FASTSEARCH/bin/nctrl stop crawler
2. Delete the content of $FASTSEARCH/data/crawler/dsqueues.
Only perform this step if you are re-feeding all your collections, otherwise you may lose content scheduled
for submission for other collections.
3. Run the postprocess program in manual mode, using the -R (refeed) option:
To do this:
Use this command:
Re-process a single collection
$FASTSEARCH/bin/postprocess -R
<collectionname>
Re-process all collections, use an asterisk (*) with
quotes instead of a <collectionname>
$FASTSEARCH/bin/postprocess -R "*"
Re-process a single site by using the -r /<site> option $FASTSEARCH/bin/postprocess -R
<collectionname> -r <site>
On UNIX make sure you either run postprocess in a screen, or use the nohup command, to ensure
postprocess runs to completion. It is also considered a good practice to redirect stdout and stderr to a log
file.
4. Allow postprocess to finish running until all content has been queued and submitted.
When postprocess has completed the processing, the following message is displayed:
Waiting for ESP to process remaining data...Hit CTRL+C to abort
If you want to start crawling immediately, then it is safe to shutdown postprocess, since it has identified
and enqueued all documents due for processing, as long as the crawler is later restarted so that the
processing of the remaining documents can be serviced. The remaining documents will eventually be
processed before processing any newly crawled data. Otherwise, postprocess will eventually shut down
itself when all documents has been processed. Press Ctrl+C, or send the process SIGINT if it is running
in the background. Alternatively let postprocess run to completion and it will exit by itself.
5. Start the crawler: $FASTSEARCH/bin/nctrl start crawler.
155
FAST Enterprise Crawler
Multiple node crawler re-processing
Re-processing the crawl data on a multiple node crawler is similar to the single node scenario, except that a
multiple node crawl will include one or more duplicate servers. These must be running when executing
postprocess.
For more information on multiple node crawler setup, contact FAST Solution Services.
Forced Re-crawling
The procedure in section Re-processing Crawler Data Using postprocess on page 154 assumes that the
crawler database is correct. This implies that it will only re-process all already crawled documents to FAST
ESP. In case of a single-node failure or crawler node failure the last documents fetched by the crawler (after
last backup) will be lost. In this case you must instead perform a full re-crawl of all the collections. This will
then re-fetch the remaining documents, assuming they are retrievable. In some cases documents may have
disappeared from web servers, but still be present in the index. If this is the case these documents will have
to be manually removed from the index.
Use the following command to force a full re-crawl of a given collection:
1. crawleradmin -F <collection>
2. Repeat the command for each collection in the system
This will then ensure that all documents crawled after the last backup will be re-fetched. Note that the re-crawl
may take a reasonable amount of time before finished, but the index will be fully operative in the meantime.
Purging Excluded URIs from the Index
Normally postprocess will not check the validity of the URIs it processes, as this has already been done by
the crawler during crawling. However, there are times when the include/exclude rules are altered and it is
necessary to remove content that is no longer allowed (but was previously allowed) by the configuration.
This can be accomplished by using the (uppercase) -X option. It will cause postprocess to traverse the meta
databases as usual, but rather than processing the contents it will delete the contents that no longer match
the configuration include and exclude rules.The contents that match are simply ignored, unless the (lowercase)
-x option is also specified, in which case this content will be re-processed at the same time.
Use the following command to remove excluded content from both the index and crawler store:
1. $FASTSEARCH/bin/postprocess -R <collectionname> -X
The -X and -x options as described above assume that the crawler has already been updated with the new
include/exclude rules. If you have the configuration in XML format, but have not yet uploaded the configuration
you can use the -u <XML config> option to tell postprocess to update the rules directly from the XML file
(and store them in the crawlers persistent configuration database).
Finally, the option -b instructs postprocess to re-check each URI against the robots.txt file for the
corresponding server. The check uses the currently stored robots.txt file, rather than download a new one.
The behavior for a URI that is no longer allowed for crawling by the robots.txt file is the same as if it had
been excluded by the configuration.
Aborting and Resuming of a Re-process
To pause/stop postprocess while it is re-processing and then to resume postprocess, you can use one of the
following procedures.
156
Operating the Enterprise Crawler
Aborting and Resuming of a Re-process - scenario 1
1. Stop postprocess after it has traversed all meta databases.
When postprocess has completed the processing, the following message is displayed:
Waiting for ESP to process remaining data...Hit CTRL+C to abort
This log message indicates that the traversing of the meta databases has finished, and the only remaining
task is to submit all the queued data to FAST ESP, and wait for it to finish processing callbacks.
2. Press Ctrl+C or send SIGINT.
3. To resume postprocess refeed, use: $FASTSEARCH/bin/postprocess -R <collectionname> -f
Aborting and Resuming of a Re-process - scenario 2
1. Stop postprocess after it has traversed all meta databases.
When postprocess has completed the processing, the following message is displayed:
Waiting for ESP to process remaining data...Hit CTRL+C to abort
If this message is not displayed in the log then postprocess has not finished traversal, and is still logging the
following message:
"Processing site: <site> (16 URIs)"
To resume postprocessing after stopping postprocess in this condition, you must use the -r <site> (resume
after <site>) option in combination with the -R <collections> option. To determine which site to resume, inspect
the postprocess logs and find the site which was logged before the last Processing site log entry.
For example, if the last two Processing site messages in the postprocess log are:
Processing site: SiteA (X URIs)
Processing site: SiteB (Y URIs)
Start postprocess with -r SiteA to make sure that it will traverse the remaining sites. Since the log message
is output before the site is traversed, this will ensure that SiteB is completely traversed.
Crawler Store Consistency
A consistency tool is included with the crawler to verify, and if necessary repair consistency issues in the
crawler store.
The following sections describe how to use the consistency tool.
Verifying Docstore and Metastore Consistency
The following steps will first verify (and if necessary repair) the consistency between the document store and
metadata store, and then perform the same verification between the verified metadata store and postprocess
checksum database. In case the tool removes documents we also ask it to keep the statistics in sync.
The logs will be placed in a directory named after todays date under
$FASTSEARCH/var/log/crawler/consistency. Make sure this directory exists before running the tool.
In a multi node crawler setup these steps should be performed on all master nodes. Additionally you may
also specify that the tool should verify the correct routing of sites to masters (details below).
1. Stop the crawler: $FASTSEARCH/bin/nctrl stop crawler. Verify that all crawler processes has exited
before proceeding to the next step.
157
FAST Enterprise Crawler
2. Run the command: $FASTSEARCH/bin/postprocess -R mytestcol -f . This will ensure there is no
remaining documents to be fed to the indexer.
[2007-09-12
[2007-09-12
Hit CTRL+C
[2007-09-12
11:58:39] INFO
11:58:39] INFO
to abort
11:58:39] INFO
systemmsg Feeding existing dsqueues only..
systemmsg Waiting for ESP to process remaining data...
systemmsg PostProcess Refeed exiting
3. (Optional) Copy routing table from the ubermaster node.
Note: This step only applies to multi node crawlers and is only necessary if you wish to verify the
correct master routing of all sites. The routing table database can be found as
$FASTSEARCH/data/crawler/config_um/mytestcoll/routetab.hashdb on the ubermaster and
should overwrite $FASTSEARCH/data/crawler/config/mytestcoll/routetab.hashdb on the master nodes.
4. Create the directory $FASTSEARCH/var/log/crawler/consistency
The tool will create a sub directory inside this directory, in this example 20070912, where it will place the
output logs in a separate directory per collection checked. The path to the output directory is logged by
the tool on startup.
5. Run the command: $FASTSEARCH/bin/crawlerconsistency -C mytestcoll -M
doccheck,metacheck,updatestat -O $FASTSEARCH/var/log/crawler/consistency
Note: Ensure that you do not insert any space between the modes listed in the -M option. If the tool
is being run on a master in a multi node crawler you may also add the routecheck mode.
6. Examine the output and log files generated.
[2007-09-11 16:23:10] INFO
systemmsg Started EC Consistency Checker 6.7 (PID:
21542)
[2007-09-11 16:23:10] INFO
systemmsg Copyright (c) 2008 FAST, A Microsoft(R)
Subsidiary
[2007-09-11 16:23:10] INFO
systemmsg Data directory: $FASTSEARCH/data/crawler
[2007-09-11 16:23:10] INFO
systemmsg 1 collections specified
[2007-09-11 16:23:10] INFO
systemmsg Mode(s): doccheck, metacheck, updatestat
[2007-09-11 16:23:10] INFO
systemmsg Output directory:
$FASTSEARCH/var/log/consistency/20070912
[2007-09-11 16:23:10] INFO
mytestcoll Going to work on collection mytestcoll..
[2007-09-11 16:23:12] INFO
mytestcoll Completed docstore check of collection
mytestcoll in 1.6 seconds
[2007-09-11 16:23:12] INFO
mytestcoll ## Processed sites : 5 (2.50 per second)
[2007-09-11 16:23:12] INFO
mytestcoll ## Processed URIs : 5119 (2559.50 per
second)
[2007-09-11 16:23:12] INFO
mytestcoll ## OK URIs
: 5119
[2007-09-11 16:23:12] INFO
mytestcoll ## Deleted URIs
: 0
[2007-09-11 16:23:12] INFO
mytestcoll Document count in statistics left unchanged
[2007-09-11 16:23:12] INFO
mytestcoll Processing 5119 checksums (all clusters)..
[2007-09-11 16:23:14] INFO
mytestcoll Completed metastore check of collection
mytestcoll in 1.8 seconds
[2007-09-11 16:23:14] INFO
mytestcoll ## Processed csums : 5119 (2559.50 per
second)
[2007-09-11 16:23:14] INFO
mytestcoll ## OK csums
: 5119
[2007-09-11 16:23:14] INFO
mytestcoll ## Deleted csums
: 0
[2007-09-11 16:23:14] INFO
mytestcoll Finished work on collection mytestcoll
[2007-09-11 16:23:14] INFO
systemmsg Done
In the example output above all URIs and checksums were found to be ok. If this was not the case then
a mytestcol_deleted.txt file will contain the URIs deleted. Additionally if a mytestcol_refeed.txt file was
generated then the URIs listed here should be re-fed using postprocess (next step).
7. Run the command: $FASTSEARCH/bin/postprocess -R mytestcol -i <path to
mytestcol_refeed.txt>
158
Operating the Enterprise Crawler
Note: This step is only required in order to update the URI equivalence class of the listed URIs.
8. Start the crawler: $FASTSEARCH/bin/nctrl start crawler.
Rebuilding the Duplicate Server Database
This section explains the steps necessary to rebuild the duplicate server database, based on the contents of
the postprocess database present on each master. It only applies to multi node crawlers, as single node
crawlers doe not require a duplicate server. Prior to performing this task it is recommended to run the
consistency tool as outlined in the previous section first to ensure each node is in a consistent state.
As part of this operation a set of log files will be generated and placed in a directory named after todays date
under $FASTSEARCH/var/log/crawler/consistency. Make sure this directory exists before running the
tool.
To successfully rebuild the duplicate server databases it is vital that these steps be run on all master nodes.
The crawler must not be restarted until all nodes have successfully completed the execution of the tool.
1. Stop the crawler: $FASTSEARCH/bin/nctrl stop crawler. Verify that all crawler processes has exited
before proceeding to the next step. Perform this step on each master before proceeding to the next step.
2. Run the command: $FASTSEARCH/bin/postprocess -R mytestcol -f . This will ensure there is no
remaining documents to be fed to the indexer. Perform this step on each master before proceeding to the
next step.
3. Stop the duplicate server processes. Wait until the processes have completed shutting down before moving
to the next step. Depending on your configuration this may take several minutes
4. Delete the per-collection duplicate server databases. These databases are usually located under
$FASTSEARCH/data/crawler/ppdup/<collection> and should be deleted prior to running this tool to
ensure there will not be "orphan" checksums recorded in the database.
5. Start the duplicate server processes.
6. Create the directory $FASTSEARCH/var/log/crawler/consistency. The tool will create a sub directory
inside this directory, in this example 20070912, where it will place the output logs in a separate directory
per collection rebuilt. The path to the output directory is logged by the tool on startup.
7. Run the command: $FASTSEARCH/bin/crawlerconsistency -C mytestcoll -M ppduprebuild -O
$FASTSEARCH/var/log/crawler/consistency
Note: This command will usually take several hours to complete. Progress information is logged
regularly, but only applies per collection. Hence if you are processing multiple collections the
subsequent collections are not accounted for in the reported ETA.
8. Examine the output and log files generated.
[2007-09-11 09:17:12] INFO
systemmsg Started EC Consistency Checker 6.7 (PID:
18622)
[2007-09-11 09:17:12] INFO
systemmsg Copyright (c) 2008 FAST, A Microsoft(R)
Subsidiary
[2007-09-11 09:17:12] INFO
systemmsg Data directory: $FASTSEARCH/data/crawler/
[2007-09-11 09:17:12] INFO
systemmsg No collections specified, defaulting to all
collections (2 found)
[2007-09-11 09:17:12] INFO
systemmsg Mode(s): ppduprebuild
[2007-09-11 09:17:12] INFO
systemmsg Connected to Duplicate Server at
dupserver01:11100
[2007-09-11 09:17:13] INFO
systemmsg Output directory:
$FASTSEARCH/var/log/consistency/20070912
[2007-09-11 09:17:13] INFO
mytestcoll Going to work on collection mytestcoll..
[2007-09-11 09:17:13] INFO
mytestcoll Processing 5299429 checksums (all clusters)..
[2007-09-11 09:17:14] INFO
systemmsg Received config ACK -> connection state OK
.....
159
FAST Enterprise Crawler
[2007-09-11
mytestcoll:
[2007-09-11
second)
[2007-09-11
[2007-09-11
[2007-09-11
12:01:21] INFO
mytestcoll Duplicate Server rebuild status for
12:01:21] INFO
mytestcoll ## Processed csums : 5299429 (477.98 per
12:01:21] INFO
12:01:21] INFO
12:01:21] INFO
mytestcoll ## OK csums
: 5299429
mytestcoll ## Deleted csums
: 0
mytestcoll ## Misrouted csums : 0
9. Start the crawler: $FASTSEARCH/bin/nctrl start crawler
Redistributing the Duplicate Server Database
This section explains the steps necessary to change the number of duplicate servers used by a collection in
a multi node crawler setup. It only applies to multi node crawlers, as single node crawlers doe not require a
duplicate server. Prior to performing this task it is recommended to run a consistency check on the crawler
store. Refer to Verifying Docstore and Metastore Consistency on page 157 for more information.
1. Stop the crawler: $FASTSEARCH/bin/nctrl stop crawler. Perform this step on each master as well as
the ubermaster before proceeding to the next step.
Note: Verify that all crawler processes has exited before proceeding to the next step.
2. Run the following command on each master node: $FASTSEARCH/bin/postprocess -R mytestcol -f
. This will ensure there is no remaining documents to be fed to the indexer.
3. Stop the duplicate server processes. Wait until the processes have completed shutting down before moving
to the next step.
Note: Depending on your configuration this may take several minutes
4. Delete the per-collection duplicate server databases. These databases are usually located under
$FASTSEARCH/data/crawler/ppdup/<collection> and should be deleted prior to running this tool to
ensure there will not be "orphan" checksums recorded in the database.
5. Create a partial XML configuration in order to specify a new set of duplicate servers.
The following is an example XML configuration file for three duplicate servers. You should also specify
appropriate duplicate server settings for the collection at this time.
<?xml version="1.0"?>
<CrawlerConfig>
<DomainSpecification name="mytestcoll">
<section name="pp">
<attrib name="dupservers" type="list-string">
<member> dupserver1:14200 </member>
<member> dupserver2:14200 </member>
<member> dupserver3:14200 </member>
</attrib>
</section>
<section name="ppdup">
<attrib name="format" type="string"> hashlog </attrib>
<attrib name="stripes" type="integer"> 1 </attrib>
<attrib name="cachesize" type="integer">512 </attrib>
<attrib name="compact" type="boolean"> yes </attrib>
</section>
</DomainSpecification>
</CrawlerConfig>
160
Operating the Enterprise Crawler
Note: Make sure the collection name in the XML file matches the name of the collection you wish to
update.
6. Update the configuration on the ubermaster node with the command $FASTSEARCH/bin/crawleradmin
-f <path to XML file> -o $FASTSEARCH/data/crawler/config_um --forceoptions=dupservers.
The --forceoptions argument allows the command to override the dupserver option which is normally not
changeable.
7. Update the configuration on each master node with the command $FASTSEARCH/bin/crawleradmin -f
<path to XML file> -o $FASTSEARCH/data/crawler/config --forceoptions=dupservers
8. Start the duplicate server processes.
9. Rebuild the duplicate server. Refer to Rebuilding the Duplicate Server Database on page 159 for more
information.
Exporting and Importing Collection Specific Crawler Configuration
The basic collection data is backed up (exported) and restored (imported) using the procedure described in
the System Configuration Backup and Recovery section in the Operations Guide. This, however, does not
include the data source configuration for the crawler.
The crawler configuration can be set and read from the administrator interface, but it is also possible to
export/import the crawler setup of a particular collection to XML format using the crawleradmin tool.
If you intend to create a new collection using an exported crawler configuration, note the following:
•
The collection must be created prior to importing the crawler configuration. Create the collection in the
normal way using the administrator interface but do not select a crawler as this will import a default
configuration from the administrator interface into the crawler. The effect of this is that some options in
the XML configuration will not be able to take effect. Specifically:
1. Create collection in the administrator interface but do not select a Data Source
2. Import the XML configuration into crawler using crawleradmin.
3. Edit the collection in the administrator interface to select the crawler. Select Edit Data Sources and
add the crawler. Click ok on Edit Collection screen and again on the Collections Details screen.
Refer to the FAST ESP Configuration Guide, Basic Setup chapter for additional details on how to create
a collection and integrate the crawler through the FAST ESP administrator interface.
•
Use the same name for the collection in the new system as the old system. The collection name is given
by the content of the exported crawler configuration file. The collection name is also implicitly used within
the configuration file, for example, related to folder names within the crawler folder structure.
Note: If you want to use a different name for the new collection, you must change all references to
the collection name within the exported XML file prior to importing it using crawleradmin -f.
•
In a multiple node crawler, the crawleradmin tool must always be run on the main crawler node (the node
running the ubermaster process) to ensure that all nodes are updated.
Fault-Tolerance and Recovery
To increase fault-tolerance, the crawler may be configured to replicate the state of various components. The
following sections describe how state is replicated in the different components, and how state may be recovered
should an error occur.
161
FAST Enterprise Crawler
Ubermaster
The ubermaster will incrementally replicate the information in its routing tables (the mapping of sites to masters)
for a specific collection to all crawler nodes associated with that collection.
If an ubermaster database is lost or becomes corrupted, the databases will be reconstructed automatically
upon restarting the ubermaster. If the ubermaster enters a recovery mode it will query crawler nodes in that
collection for their routing tables, which they will send back in batches. While in recovery mode, the ubermaster
will accept URIs from crawler nodes, but will not distribute new sites to crawler nodes until recovery is complete
for that collection.
Duplicate server
A duplicate server may be configured to replicate the state of another duplicate server.
By starting the with the –R option, a duplicate server is configured to incrementally replicate its state:
$FASTSEARCH/bin/ppdup –p <port> -R <host:port> -I <my_ID>
where <host:port> specifies the address of the target duplicate server and <my_id> specifies a symbolic
identifier for the duplicate server. The target duplicate server will store replicated state in its working directory
under a directory with the name <my_ID>>.
Conversely, a duplicate server is configured to replicate the state of another duplicate server by starting with
the –r option:
$FASTSEARCH/bin/ppdup –p <port> -r <port>
When replication is activated, communication between a postprocess process and a duplicate server has
transactional semantics. The duplicate server(s) performing replication on behalf of other duplicate servers
may be used actively by postprocesses. The state of a duplicate server may be reconstructed by manually
copying replicated state from the appropriate directory on the target duplicate server.
Crawler Node
There is no support for replicating the state stored on a crawler node. However, the crawler node state, if
lost, will eventually be reconstructed by re-crawling the set of sites assigned to the node. In the course of
crawling, the ubermaster will route URIs to the crawler, and from this the crawler node will gradually reconstruct
its state with respect to crawled documents (assuming all documents are still available on the web servers).
The postprocess databases on a crawler node will similarly recover over time, as each processed document
will be checked against the duplicate server(s) in the installation. This will permit the URI checksum tables
to be rebuilt, but it may not result in the same set of URI equivalences (duplicates) as had been previously
indexed, leading to some unnecessary updates being sent to the search engine.
162
Chapter
5
Troubleshooting the Enterprise Crawler
Topics:
•
Troubleshooting the Crawler
This chapter describes how to troubleshoot problems you may encounter when
using the crawler.
FAST Enterprise Crawler
Troubleshooting the Crawler
This topic describes how to troubleshoot problems you may encounter when using the crawler.
General Guidelines
•
Inspect logs
The crawler logs a wide range of useful information, and these logs should always be inspected whenever
a perceived error or misconfiguration occurs. These include the crawler log which logs overall crawler
status messages and exceptional conditions, the fetch log which logs all attempted retrievals of documents,
the screened log which logs all documents that are not attempted retrieved, the postprocess log, which
logs the status of data feeding to FAST ESP and the site and header logs. By default, all these logs but
the screened logs are enabled.
•
Raise log level
The level of detail in the crawler log of the crawler is governed by the –l <level> option in the crawleradmin
tool. Restarting the crawler with a given parameter propagates this setting to all components.
•
Inspect traffic trace of crawler network activity
This can either be done by using a network packet trace utility such as ethereal or tcpdump on the crawler
node, or by crawling through a proxy and inspecting the traffic passing through it. Both of these have
shortcomings when encrypted transport such as HTTPS, is used.
•
Inspect browser traffic
If a particular behavior is expected from the crawler, a trace as suggested above can be examined alongside
one generated by a web browser. For web browsers, client side debugging can be used to bypass the
encryption for HTTPS. An example of such a utility is LiveHTTPHeaders (http://livehttpheaders.mozdev.org/
). This is particularly useful when debugging cookie authentication schemes.
Additional Information
Reporting Issues
Here is a list of important information to gather in order to get a fast and complete support response.
When reporting operational issues, the following list of information is critical in providing a fast and complete
response:
•
Crawler version
Which version of the crawler you are running and, if applicable, which hotfixes to the crawler have been
applied.
•
Platform
Which operating system/platform you are running on.
•
FAST ESP version
Which version of FAST ESP you are running the crawler against.
•
Crawler configuration
All applicable <collection> configurations in XML format, as output by crawleradmin -G <collection>
•
Crawler log files
All applicable <collection> crawler log files (fetch, pp, header, screened, dsfeed, site - as a minimum,
fetch and dsfeed). These files are located in $FASTSEARCH/var/log/crawler/.
•
164
Crawler log files
Troubleshooting the Enterprise Crawler
All available crawler.log* and any associated .scrap files. For multiple node installations, include
dupserver.scrap.* (or equivalent). These files are located in $FASTSEARCH/var/log/crawler/.
Known Issues and Resolutions
This section provides resolutions to known issues for the crawler.
#1: The crawler has
problems reaching
the license server or
allocating a valid
license.
A valid license served by the license manager (lmgrd) generates a log entry similar
to the following in $FASTSEARCH/var/log/lmgrd/lmgrd.scrap file:
hh:mm:ss (FASTSRCH) OUT:"FastDataSearchCrawler"
fastrt@crawl01.mysite.com
If the crawler is having problems either reaching the license server (which may be
on a remote node in a multiple node FAST ESP installation) or allocating a valid
license, it will issue an error (Message A), and try a total of 3 times before exiting
(Message B):
Message A: "Unable to check out FLEXlm license. Server may be down or
too many instances of the crawler are running. Retrying.
Message B: "Unable to check out FLEXlm license. Shutting down. Contact
Fast Search &Transfer (http://www.fastsearch.com/) for a new license."
Please contact FAST Support for any licensing issues.
#2: How do I display,
To display the collection configuration, type the command:
save, or import the
configuration for a
bin/crawleradmin -G <collection>
collection in XML
You can save this collection configuration by redirecting or saving it to a file. To
format?
import a configuration from a file, type the command:
bin/crawleradmin -f <filename>
#3: Postprocess
reports that it is
unable to obtain a
database lock.
The crawler is running on the system. If you stopped it, check the logs to make sure
that the process has stopped. You may have to kill it manually if it still exists.
#4: The crawler does
The following areas can be checked:
not fetch pages.
• Verify the Start URIs list against the configured rules.
Check the screened log.
Check the URIs individually using the crawleradmin tool and the --verifyuri
option:
# crawleradmin --verifyuri <collection>:<start URI>
•
•
•
•
If a site specified in the Start URIs list (or otherwise permitted under the rules)
is not being crawled, it may be due to a robots.txt file on the remote web
server. This is a mechanism that gives webmasters the ability to block access
to content from some or all web crawlers. To check with a browser, request page
http://<site>/robots.txt. If it does not exist, the web server should return
the HTTP status 404, Not Found, in the crawler fetch log.
Check the DNS log in case the server does not resolve.
Check proxy if one is used.
Check log file.
165
FAST Enterprise Crawler
If there are no clear errors, yet some pages are not being crawled, it may be due
to the refresh cycle being too short to complete the crawl. Refer to Resolution #5:
for resolution.
#5: Some documents
Check your refresh interval (default = 1440 minutes) and refresh mode (default =
are never crawled.
scratch). If the interval is too short, some of the documents may never be crawled
(depending on the refresh mode). You need to either increase the refresh interval
or change the refresh mode of the crawler. The Refresh interval and Refresh
mode can be changed from Edit Collection in the administrator interface. Note
that the Refresh when idle option allows an idle crawl to start a new cycle
immediately without waiting for the next scheduled refresh.
All refresh modes include inserting the start URIs into to work queue. The work
queue is the queue from where the crawler retrieves URIs. Refer to Refresh Mode
Parameters on page 89 for valid refresh modes.
If there are no clear errors, refer to Resolution #4: for additional checks.
#6: How do I back up
Make a backup copy of the $FASTSEARCH/data/crawler/ folder. Complete the
the content retrieved
procedure described in Backup and Restore on page 153.
by the crawler?
#7: Some documents
Since the DB switch delete is set to off by default, no documents will be deleted
get deleted from the
unless they are irretrievable. Check to see if the DB switch delete has been turned
index.
on.
There may also be a problem if the DB switch delete is on and the refresh interval
is set too low. If so, then it is possible that the internal queue of your crawler is so
large that certain documents do not get refreshed (or re-visited) by the crawler. If
that is the case, you need to either change the mode of your crawler or increase
the refresh rate or both.
#8: Documents are
not removed when I
change the exclude
rules and refresh the
collection.
If you make changes to your configuration, only the configuration will be refreshed,
not the collection. Collection refreshes are only triggered by time since the last
refresh or by using the Force Re-fetch option.
1. In order to remove documents instantly, stop the crawler from System
Management. With a multiple node crawler, it is recommended that you stop all
instances of crawler and ubermaster. Do not stop the duplicate server as this is
required in order to run any postprocess refeed commands.
2. Run postprocess manually with the (uppercase) -X option (together with -R). By
using the -X option, all URIs in the crawlerstore will be traversed and compared
to the spec. URIs matching any excludes will then be deleted. Issue the command:
$FASTSEARCH/bin/postprocess -R <collection> -X
Note that to reprocess and delete documents that have been excluded by the
configuration, you only need the -X (uppercase) switch as shown in this example.
If you decide to add the -x (lowercase) switch, then everything else will be
re-processed in addition to the verification and removal of excluded content.
3. Allow postprocess to finish running until all content has been queued and
submitted.
Note that it may take some time after postprocess exits before documents are
fully removed from the index.
166
Troubleshooting the Enterprise Crawler
#9: The crawler uses
If system resources are being overwhelmed because of the scale of the crawl being
a lot of resources,
run, the ideal solutions are to:
what can I do?
• Ensure the correct configuration and caches
• Add hardware resources
• Reduce crawler impact
Refer to Configuring a Multiple Node Crawler on page 128 and Large Scale XML
Crawler Configuration on page 130 for additional information.
If configurations are correct, and it is not possible to add resources, then the next
step is to try to reduce the impact of the crawl, either by reducing the scope of the
crawl or by slowing the pace of the crawl. There are no definite answers to this
issue. Go through your configuration and determine if you can:
•
Suspend postprocess feeding of documents to FAST ESP:
By default crawled pages are stored on disk, then fed to FAST ESP concurrently
with the crawling of additional pages. By suspending the feeding of documents
to FAST ESP, additional resources are made available to the crawling processes,
thereby increasing their efficiency. Once the crawl is complete, feeding can be
resumed to build the collection in the index. The commands to perform these
tasks are:
# crawleradmin --suspendfeed <collection>
# crawleradmin --resumefeed <collection>
•
Reduce the overall load on the crawler host by:
•
•
•
•
•
•
•
•
increasing cache sizes, especially the postprocess cache size.
reducing the number of complex include/exclude rules and rewrites.
focusing the crawl on fewer sites/servers (include/exclude
domain/URIspaths).
crawling fewer web sites at a given time by reducing Max concurrent sites
(if I/O is overloaded then lowering this value may help increase performance).
using an equivalent number of uberslaves to CPUs (or even more, up to 8,
for large scale crawls).
lowering the frequency of page requests (request_rate, delay).
lengthening the overall update cycle (refresh_interval).
limiting the crawling schedule: (variable_delay).
Depending on your answers, tune these parameters accordingly.
#10: I cannot locate
Documents are kept a maximum time period of:
all the documents in
my index.
dbswitch x refresh
Where dbswitch denotes the number of crawl cycles a previously fetched document
is allowed to remain unseen by the crawler. If this limit is reached, the
dbswitch-delete parameter will decide what happens to the document. If
dbswitch-delete is set to yes, the document will be deleted, and if it is set to no,
it will be scheduled for an explicit download check. If this check fails, the document
will be removed. There are three approaches to avoid this situation:
1. Make sure all documents covered by the collection are crawled within the refresh
period.
167
FAST Enterprise Crawler
2. Set refresh_mode = scratch (default). All work queue will be emptied when
a refresh starts, and the crawler starts from scratch.
3. Set dbswitch-delete = no (default).
#11: The crawler
To create a successful login configuration the goal to is to have the crawler behave
cookie authentication
in a similar way to what a user and browser does when logging into the web site.
login does not work.
In order to achieve this you can:
•
•
Inspect traffic traces between the browser and server.
Pay attention to the order in which pages are retrieved, what HTTP method is
used, when the credentials are posted and what other variables are set.
Available tools to do this are:
•
•
•
Mozilla LiveHTTPHeaders plugin which lets you see the http headers exchanged
(even over encrypted transport as in https).
Charles web proxy (shareware) which acts as a proxy and lets you inspect
headers and bodies both as a tree and as a trace.
Basic tools like tcpdump or ethereal can also be used. Note that only
LiveHTTPHeaders will help you when https is used.
Remember to erase your browser's cache and cookies before obtaining a trace.
Refer to Setting Up Crawler Cookie Authentication on page 115 for details in setting
up the crawler cookie authentication; see the section Form Based Login on page
57 for additional information about setting up a forms-based login.
#12: The Browser
You should start by tuning the Browser Engine. Please refer to the FAST ESP
Engine gets
Browser Engine Guide
overloaded and sites
get suspended.
In order to solve the problem you may need to tune the EC configuration. By
decreasing the max_sites setting and/or increasing the delay, the number of
documents sent from the EC to the Browser Engine may be reduced. The side effect
is that the crawl speed may decrease. However, as the EC will start suspending
sites if the Browser Engines get overloaded, the speed may not necessarily decrease.
If this still does not solve the problem, you need to reduce the number of sites that
use JavaScript and/or Flash processing. This is done by:
1. Disable JavaScript and/or Flash options in the main crawl collection.
2. Exclude the sites where you want to use JavaScript and/or Flash from the main
collection.
3. Create a new collection.
4. Activate JavaScript and/or Flash in the new collection.
5. Specify the sites that you want crawled using JavaScript/Flash in the new
collection.
168
Chapter
6
Enterprise Crawler - reference information
Topics:
•
•
•
•
•
Regular Expressions
Binaries
Tools
Crawler Port Usage
Log Files
This chapter contains reference information for the Enterprise Crawler for the
various binaries and tools. You will also find information about regular
expressions, log files and ports.
FAST Enterprise Crawler
Regular Expressions
Certain entries in the FAST ESP administrator interface collection specific screens request the use of regular
expressions (regexp).
Using Regular Expressions
The following tables describe terminology used in this appendix.
Table 46: Collection Specific Options Definitions
Term
Definition
URI
Uniform Resource Identifier - commonly known as a link and identifies a resource
on the web.
Example: http://subdomain.example.com/
Domain
The domain/server portion of the URI - in the previous URI example, the Domain
is the subdomain.example.com/.
Path
The path portion of the URI. For example, for the URI
http://subdomain.example.com/shop, the path portion is /shop.
Note: All patterns in the crawler are matched from the beginning of the line, unless specified otherwise
Character
Definition
.
Matches any character.
*
Repetition of the character 0 or more times.
$
End of string.
\
Escape characters that have a special meaning.
.*\.gif$
Matches every string ending in .gif.
.*/a/path/.*
Matches any string with /a/path/ in the middle of the expression.
.*\.example\.com
All servers in the domain .example.com will be crawled.
.*\.server\.com
Matches any characters (string) followed by .server.com.
Grouping Regular Expressions
If the crawler needs to be configured with rewrite rules, as described in the URI rewrite rules entry in Table
5-1, then Perl-style grouping must be used.
Grouping defines a regular expression as a set of sub-patterns organized into groups. A group is denoted by
a sub-pattern enclosed in parenthesis.
Example: If you want to capture the As and Cs in groups for the string:
AABBCC
then enclose the patterns for the As and Cs in parenthesis as shown in the following regular expression:
(A*)B*(C*)
170
Enterprise Crawler - reference information
Substituting Regular Expressions
To perform regular expression substitution, you need a regular expression that is to be matched and a
replacement string that should replace the matched text.
The replacement string can contain back references to groups defined in the regular expression. With back
references, the text matched by the group is used in the replacement. Back references are simply backslashes
followed by an integer denoting the ordinal number of the group in the regular expression.
Example: Using the regular expression described in the previous example, the following replacement string:
\1XX\2
rewrites the string AABBCC to AAXXCC.
Binaries
The following sections describe the major Enterprise Crawler programs and the options and parameters they
support.
crawler
The crawler binary is the master process, responsible for starting all other crawler processes. It also serves
as the ubermaster process in a multiple node crawler installation. In addition to initialization of data directories
and log files, the crawler is responsible for several centralized functions, including maintenance of the
configuration database, handling communications with other FAST ESP components, resolving and caching
hostnames and IP addresses, and routing sites to uberslave processes.
Binary: $FASTSEARCH/bin/crawler [options]
Table 47: crawler options
Basic options
-h
Description
Show usage information.
Use this option to print a list with short description of the various options that
are available.
-P [<hostname>:]
<crawlerbaseport>
Use this option to specify an alternative crawler base port (XML-RPC interface).
This option is useful if several instances of the crawler run on the same node.
<hostname>: Set bind address for XML-RPC interfaces (optional). This field can
be either a hostname or an explicit IP address. An actual IP address can also
be used as some hosts have multiple IP addresses.
<crawlerbaseport>: Set start of port number range that can be used by crawler.
Default: 14000 9000
Note that uberslave processes will allocate ports from <port number>+10 and
up. Furthermore, a specific interface to bind to can be specified.
-d <path>
Data storage directory.
Use this option to store crawl data, runtime configuration and logs in
subdirectories in the specified directory.
Default: If the FAST environment variable is set then the default path is
$FASTSEARCH/data/crawler; otherwise the default path is data.
171
FAST Enterprise Crawler
Basic options
Description
-f <file>
Specify collection(s).
Use this option to specify the location of an XML file containing one or more
collections. Read the contents of the file and start crawling the specified
collection(s).The crawler will parse the contents of this file, add or update the
collections contained within and start crawling.
-c <number>
Use this option to specify the number of uberslave processes to start.
For larger crawls a process count of 8 is recommended. For larger crawls a
process count equal to or greater than the number of CPUs is recommended.
A maximum of 8 processes is supported. The number of processes should be
equal to or less than the number of clusters defined in the collection specification.
Default: 2
-v or -V
Advanced options
-D <number>
This option prints the crawler version identifier and exits.
Description
Maximum DNS requests per second.
The crawler has a built-in DNS lookup facility that may be
configured to communicate with one or more DNS servers
to perform DNS lookups. Use this option to limit the number
of DNS requests per second that the crawler will send to
the DNS server(s).
The DNS resolver will automatically decrease the lookup
rate if it detects that the DNS server is unable to handle the
currently used rate. The actual rates can be seen in the
collection statistics output.
Default:100 requests
-F <file>
Specify the crawler global configuration file.
Use this option to specify the location of an XML file
containing the crawler global configuration. A crawler global
configuration file is XML based and may contain default
values for all command line options.
Note that no command line switches may be specified in
this configuration file. Also note that the crawler processes
the command line switches in order. For example, if you
use the -D option in ./crawler -F
CrawlerGlobalDefaults.xml, the -D 20 will override
any DNS request rate settings specified in the file. The
crawler will on startup look for a startup file of default
configuration settings.
This option first attempts to locate the
CrawlerGlobalDefaults.xml in the current directory.
If not found it looks in $FASTSEARCH/etc directory.
-n
Shutdown crawler when idle.
Use this option to signal that a crawler node should exit
when it is idle.
172
Enterprise Crawler - reference information
Advanced options
Description
This option requires the refresh setting in a collection to be
higher than the time required to crawl the entire collection.
Default: disabled
Logging options
-L <path>
Description
Log storage directory.
Use this option to store crawler specific logs in sub
directories of the specified directory.
Default: If the FAST environment variable is set then the
default path is $FASTSEARCH/var/log/crawler;
otherwise the default path is data/log.
-q
Disable verbose logging.
Use this option to log CRITICAL, ERROR and WARNING log
messages.
-l <level>
Log level.
Use this option to specify the log level. This can be one of
the following preset log levels:
debug, verbose, info, warning, error
Data search integration options
-o
Description
DataSearch mode.
Use this option when running the crawler in a FAST
DataSearch or ESP setting.
-i
Ignore Config Server.
Continue running even if the Config Server component is
unreachable. Do not exit if Config Server cannot be reached.
-p
Publish Corba interface.
Publish this address/interface for postprocess CORBA
interfaces if enabled.
Note: Applies to FDS 4.x only.
Multiple node options
-U
Description
Run as ubermaster in a multiple node setup.
Start crawler as an ubermaster. Subordinate masters
connect to the XML-RPC port by specifying the -S option.
-S <ubermaster_host:port>
Run as master in a multiple node setup.
173
FAST Enterprise Crawler
Multiple node options
Description
Start crawler as subordinate (master) to another crawler
(ubermaster). The <host:port> specifies the address of
the ubermaster.
Example: uber1.examplecrawl.net:27000
-s
Survival mode.
This option indicates that the subordinate master in a
distributed setup should stay alive and try reconnecting to
the ubermaster until a successful connection is made. This
option only applies to the master.
-I <ID>
Symbolic name of crawler node.
It is not normally necessary to use this option. In a multiple
node crawler setup, each crawler node must be assigned
a unique symbolic name, to be used in collection
configurations when defining which crawler nodes to include
in a crawl. This option only applies to the master. The default
value is auto generated, and stored in the configuration
database. If the option is used, and an alternative value is
specified, this need only be done the first time the crawler
is started.
Environment variables
FASTSEARCH_DNS
Description
The crawler will automatically attempt to detect the available
DNS server(s). However, it is also possible to override the
servers with this environment variable. The value of
FASTSEARCH_DNS should be a semicolon separated list of
DNS server IP addresses.
Example: FASTSEARCH_DNS="10.0.1.33;10.0.1.34"
An empty string may also be specified to force the use of
the gethostbyname() API, rather than speaking directly with
the DNS server(s).
Example: FASTSEARCH_DNS=""
postprocess
Postprocess is used by the crawler to perform duplicate detection and document submissions to FAST ESP.
It is, like the uberslave processes, automatically started with the crawler. The postprocess binary may also
be run as stand alone - when the crawler is not running - to manually refeed documents in one or more
collections.
Postprocess is responsible for submission of new, modified and deleted documents as they are encountered
by the crawler during a crawl. Before submission each document is checked against the duplicate database,
unless duplicate detection is turned off. A URI equivalence class for each unique checksum is also maintained
by postprocess, and updates to this class are submitted to FAST ESP in the form of changes to the 'urls'
field. Only one document in a set of duplicates will be submitted and the rest will be part of the URI equivalence
class.
In addition to document submission, postprocess also outputs to the postprocess log. Refer to Log files and
usage on page 197 for a description of the postprocess log.
174
Enterprise Crawler - reference information
Binary: $FASTSEARCH/bin/postprocess [options]
Table 48: postprocess options
General options
-h or --help
Description
Show usage information.
Use this option to print a list with short description of the various options that
are available.
-l <level>
Use this option to specify the log level. This can be one of the following preset
log levels:
debug, verbose, info, warning, error
-P [<addr>:]<port number>
Postprocess port.
<port number> Set start of port number range that can be used by postprocess
(default value is crawlerbaseport + 6).
An optional IP address may be specified (by hostname or value).
Default port: 9006
-U <file>
Use the crawler global default configuration file.
This option first attempts to locate the CrawlerGlobalDefaults.xml in the
current directory. If not found it looks in $FASTSEARCH/etc directory. Conflicting
options specified on the command line override the values in the configuration
file if given.
-d <path>
Data storage directory.
Use this option to store crawl data, runtime configuration and logs in
subdirectories in the specified directory.
Default: $FASTSEARCH/data/crawler
-R <collections>
Re-feed collections.
Re-feed all documents to ESP even if documents have been added before.
Specify <collections> as either a single collection or a comma separated
list of collections (with no whitespace).
Specify '*' to refeed all. Be sure to use the quote signs surrounding the asterisk,
otherwise the shell will expand it.
Refeed mode (-R) Only
Description
Note: You must stop the crawler before working in the refeed mode. Otherwise, postprocess will report a busy
socket.
-r <sitename>
Resume re-feeding after the specified site (hostname0).
This option may not be used at the same time as -s.
Note: Specifying the special keyword @auto for
<sitename> will make postprocess attempt to auto
resume traversal from where your last refeed left off.
175
FAST Enterprise Crawler
Refeed mode (-R) Only
Description
-s <sitename>
Process only the specified sitename (hostname0).
This option may not be used at the same time as -r.
-x (lowercase x)
Process all permitted URIs.
Include all URIs matching the current collection
include/exclude rules, while ignoring URIs that do not match.
This is useful when also using the -u option to specify an
updated collection specification XML file.
-X (uppercase X)
Issue delete for excluded URIs.
Issues deletes for URIs that do not match the collection
specification includes/excludes.
All other URIs are ignored, unless combined with -x to also
process all permitted URIs.
This option is useful when -u is specified.
-b
Apply robots.txt exclusion to processing.
Let -x and -X options apply to robots.txt exclusion as well.
-u <file>
Update includes/excludes from file.
Updates the include and exclude regexps loaded from the
configuration database with those from the specified
collection specification XML file.
-f
Resume feeding existing dsqueues data.
-k <destination>:<collection>
Override the feeding section specified in the collection
configuration by specifying a destination (one specified in
$FASTSEARCH/etc/CrawlerGlobalDefaults.xml)
and a collection name.
Alternatively specify the symbolic name of a feeding target
as defined in the collection configuration, which then
automatically maps down to feeding destination and
collection name.
ppdup
In a multiple node crawler installation, a duplicate server is needed to provide a centralized duplicate detection
function for each of the master/postprocessor hosts. The duplicate server can be configured using the ppdup
binary.
Binary: $FASTSEARCH/bin/ppdup [options]
Table 49: ppdup options
Option
-h
Description
Show usage information.
Use this option to print a list with short description of the various options that
are available.
176
Enterprise Crawler - reference information
Option
-l <level>
Description
Use this option to specify the log level. This can be one of the following preset
log levels:
debug, verbose, info, warning, error
-I <identifier>
Symbolic duplicate server identifier.
Use this option to assign a symbolic name to the duplicate server. This name
is used when the state of the duplicate server is replicated by another duplicate
server.
-P [<addr>:]<port number>
Port and optional interface.
This option specifies the port to which postprocesses communicate to the
Duplicate-Server in a multiple node setup.
-r <port>
Replication service port.
This option enables "replica mode" for the duplicate server. The duplicate server
will listen for incoming replication requests on the specified port.
-R <host:port>
Address of replication server.
This option specifies the address of the duplicate server that should replicate
the duplicate server state. The hostname specified must correspond to a server
running the duplicate server with the -r option with the specified port.
-d <path>
Set current working data directory.
This option specifies the working directory for the duplicate server.
Default: If the FAST environment variable is set then the default path is
$FASTSEARCH/data/crawler/ppdup; otherwise the default path is data.
-c <cache size>
Database cache size or hash size.
When a storage format of "hashlog" is selected (see -S option) this value
determines the size of the memory hash allocated. If the number of documents
stored into the hash exceeds the available capacity the hash will automatically
be converted into a disk hash and resized (2x increments).
If a storage format of "diskhashlog" is selected the value determines the initial
size of the hash on disk. For each overflow (whenever capacity is exceeded)
the hash is resized, as described above.
When the storage format is "gigabase" the value specifies the amount of memory
to reserve for database caches.
Note that this value is per collection. If multiple collections are used then each
collection will allocate the specified amount of cache/memory/disk. Furthermore,
if the duplicate server is being run as both a primary and a replica then twice
the resources will be consumed.
Default: 64
-s <stripes>
Number of stripes.
This option sets the number of stripes (separate files) that will be used by the
duplicate server databases.
177
FAST Enterprise Crawler
Option
Description
Default: 1
-D
Direct I/O.
This option specifies that the duplicate server should enable direct I/O for its
databases.
Enable only if supported by the operating system.
-S
This option specifies which database storage format to use.
<hashlog|diskhashlog|gigabase>
The "hashlog" format will initially allocate a memory based hash structure with
a data log on disk. The size of the memory hash is specified by the -c option
described separately. If the hash overflows it will automatically be converted
into a "diskhashlog".
The "diskhashlog" format is similar, but a disk based hash structure and the
"gigabase" format is a database structure on disk.
Default: hashlog
-N
-F
Disable nightly compaction of duplicate server databases.
Specify the crawler global configuration file.
Use this option to specify the location of an XML file containing the crawler global
configuration. A crawler global configuration file is XML based and may contain
default values for all command line options.
Note that no command line switches may be specified in this configuration file.
Also note that the crawler processes the command line switches in order. For
example, if you use the -D option in ./crawler -F
CrawlerGlobalDefaults.xml, the -D 20 will override any DNS request
rate settings specified in the file. The crawler will on startup look for a startup
file of default configuration settings.
This option first attempts to locate the CrawlerGlobalDefaults.xml in the
current directory. If not found it looks in $FASTSEARCH/etc directory.
-v or -V
Print version ID.
This option prints the ppdup version identifier.
Tools
The Enterprise Crawler has a suite of related tools that can be used to perform tasks ranging from quite
general to extremely specific. Care should be exercised before using any of these programs, and backing up
data is always a prudent consideration.
crawleradmin
The crawleradmin tool is used for configuring (XML configs), monitoring (statistics and various other calls)
and managing (seeding, forcing of refreshing, reprocessing, suspending/resuming crawl/feed).
Tool: $FASTSEARCH/bin/crawleradmin: option [options]
Table 50: crawleradmin return codes
178
Enterprise Crawler - reference information
Return code
0
1
2
3
4
5
6
10
11
Description
Command successfully executed.
An error occured. See error text for more details.
Command line error. An unrecognized command was specified, or the arguments
were incorrectly formatted.
The collection specified on the command line does not exist.
The command failed because it requires the crawler to be stopped and the
--offline or -o flag to be specified.
An error was encountered attempting to read a file, or some other I/O operation
failed. See error text for more details.
Statistics is not yet available for the specified collection/site.
An error was reported by the master. See error text for details.
A socket error was encountered trying to connect to the master.
Table 51: crawleradmin options
General options
Description
--crawlernode <hostname:port>
Manage crawler at the specified hostname and port.
or -C hostnameport
Default: localhost:14000
<hostname:port>
--offline or -o <configdir>
Work in offline mode; crawler is stopped.
Offline mode assumes the default configuration directory,
$FASTSEARCH/data/crawler/config or just data/config if the
FASTSEARCH environment variable is not set.
This option can be used together with the following options:
-a, -d, -c, -q, -G, -f, -d, --getdata and --verifyuri
-l <log level>
Specify log level.
Use this option to specify the log level. This can be one of the following preset
log levels:
debug, verbose, info, warning, error
--help or -h
Print usage information.
Use this option to print a list with short description of the various options that
are available.
Crawler configuration options
--addconfig <file> or -f <file>
Description
Add or update collection configuration(s) from the specified
XML file.
179
FAST Enterprise Crawler
Crawler configuration options
Description
--collectionconfig <collection> or -g
<collection>
Display the configuration for the specified collection.
--getcollection <collection> or -G
<collection>
--delcollection <collection> or -d
<collection>
Output the XML configuration for the specified collection to
stdout. Redirect the stdout output to a file to save the
configuration.
Delete collection (including all crawler storage).
Note that this has no effect on FDS/ESP collection
configuration elements such as pipeline or index.
Crawler control options
--shutdown or -x
Description
Shutdown the crawler.
Do not use this option when integrated with FAST ESP, as
nctrl will restart crawler. Use nctrl stop crawler
instead.
--suspendcollection <collection> or -s
<collection>
--resumecollection <collection> or -r
<collection>
--suspendfeed <collection>[:targets]
--resumefeed <collection>[targets]
--enable-refreshing-crawlmode <collection>
--disable-refreshing-crawlmode <collection>
Suspend (pause) crawling of <collection>. Feeding will
continue if there are documents in the feed queue.
Resume crawling of <collection>.
Suspend (pause) FAST ESP feeding for <collection>.
Optionally specify a comma separated list of feeding targets
(symbolic names found in the collection configuration).
Resume FAST ESP feeding for <collection>, optionally the
specified feeding targets.
Enable the 'refresh' crawl mode for the specified collection.
When enabled, the crawler will only crawl/refresh URIs that
previously have been crawled.
Disable the 'refresh' crawl mode for the specified collection,
and resume to normal crawl mode.
URI submission, refetching and refeeding
Description
-adduri <collection>:<URI> or -u
<collection>:<URI>
Append specified <URI> to <collection> work queue.
Can be combined with the --force flag to prepend the
URIs and crawl them immediately.
-addurifile <collection>:<file>
Append all URIs from the specified <file> to <collection>
work queue.
Can be combined with the --force flag to prepend the
URIs and crawl them immediately.
--refetch <collection> or -F <collection>
180
Force re-fetch of <collection>.
Enterprise Crawler - reference information
URI submission, refetching and refeeding
Description
This will cause the crawler to erase all existing work queues
(regardless of refresh mode) and clear all caches, start a
new crawl cycle and place all known start URIs on the work
queue. This will not increment the counter used for orphan
detection (dbswitch) unlike normal refreshes.
--refetchuri <collection>:<URI> or -F
<collection>:<URI>
Force re-fetch of <URI> in <collection>.
The URI does not need to be previously crawled. However,
it must fall within the include/exclude rules for the
<collection>. This also (as a side effect) triggers crawling
of the site to which the URI belongs (unless this site has
already been crawled in this refresh period).
--refetchsite <collection>:<URI>
--force
--feed
--refeedsite <collection>:<web site>
Force re-fetch of site from <URI> in <collection>.
Used with
--adduri/addurifile/refetchuri/refetchsite
to make sure the URI gets attention immediately (by
potentially preempting active sites).
Used with --refetchuri and --refetchsiteto also
have the URIs refed to FAST ESP indexing, regardless of
whether the documents have changed.
Refeed all documents in the crawler store for <web site>
to FAST ESP indexing.
This is equivalent to running postprocess refeed on a single
site, but does not require stopping the crawler. Due to the
implementation of this feature, it is advisable to limit the
amount of concurrent re-feeds at run time to prevent
overloading the crawler.
The URIs you refeed end up in a high priority queue. This
means it doesn't have to wait for other docs currently waiting
to be fed to the ESP. Feeding to the ESP will be done from
both the high priority queue and the normal priority queue
at the same time, so there might be a little delay before the
document is visible in the search.
--refeeduri <collection>:<URI>
--refeedprefix <prefix>
--refeedtarget <destination>:<collection>
Refeed the specified URI from the crawler store to FAST
ESP indexing. See --refeedsite above for more information.
Specify a URI prefix (including scheme) that URIs must
match to be re-fed. Only applicable with the --refeedsite
option.
Specify a feeding destination and collection to which the
specified refeed command will feed URIS to.
Only applicable with the --refeedsite option.
181
FAST Enterprise Crawler
Preempting, blacklisting and deletion
Description
--preemptsite <collection>:<web site> or -p
<collection>:<web site>
Preempt crawling of site <web site> in <collection>.
--blacklist <collection>:<web site>:<time>
--unblacklist <collection>:<web site>
--deletesite <collection>:<web site>
--deluri <collection>:<URI>
--delurifile <collection>:<file>
Statistics options
--collstats <collection> or -q <collection>
--collstatsquiet <collection> or -Q
<collection>
--statistics or -c
Blacklist <web site> from crawling in <collection> for <time>
seconds.
Remove blacklisting of <web site> in <collection>.
Delete <web site> in <collection> from crawler.
Delete <URI> in <collection>.
Delete URIs in <file> from <collection>.
Description
Display crawl statistics for <collection>.
Display abbreviated version of crawl statistics for
<collection>.
Display crawl statistics.
Refer to crawleradmin statistics on page 183 for more
information.
--sitestats <collection>:<web site>
--cycle (1,~)
Monitoring options
Statistics for <web site> in <collection>.
Combine with any/all of the Statistics options listed in this
table to display statistics for the specified refresh cycle. Use
all to merge all refresh cycles. Default is current cycle.
Description
Note: id equals all or host:number or number.
--status
--nodestatus
--active or -a
--numslaves or -n
--slavestatus <id> or -S <id>
--numactiveslaves <id> or -N <id>
--sites <id> or -t <id>
182
Display status for all collections.
Display status (per node) for all collections.
Display all active collection names.
Display the number of sites currently being crawled.
Show site status for uberslave process <id>.
Show number of active sites for uberslave process <id>.
List sites currently being crawled by uberslave <id>.
Enterprise Crawler - reference information
Monitoring options
Description
--starturistat
Display feeding status of start URI files.
Debugging options
Description
--verifyuri <collection>:<URI>
Output information if an <URI> can be crawled and indexed
in the <collection>. This option checks against the following
crawler parameters: include_uris, include_domains,
exclude_uris, exclude_domains, allowed_schemes,
allowed_types, force_mimetype_detection, rewrite_rules,
robots, max_redirects, refresh_redir_as_redir,
max_uri_recursion, search_mimetype and
check_meta_robots. Note that there still may be reasons
why an URI is not crawled, e.g. DEPTH or due to an URI
being dropped by a crawler document plugin.
crawleradmin statistics
Running crawleradmin -c provides statistics for all collections active in the crawler. Directing a statistics
lookup to the administrator interface of the ubermaster will produce aggregated statistics for all crawler nodes.
Statistics for a specific node in a multiple node crawler setup may be produced by directing the lookup to the
administrator interface of the particular node. The following provides a sample statistics output:
Brief statistics for collection <collection>
============================================
All cycles
==========
Running time
Average document rate
Downloaded (tot/stored/mod/del)
Document store (tot/unique)
Document sizes (avg/max)
:
:
:
:
:
20.21:29:38
44.69 dps
80,687,225 URIs / 41,886,951 / 10,702,819 / 6,186,202
24,997,930 URIs / ~24,254,800
24.14 kB / 488.28 kB
Current cycle (57)
==================
Running time
Stats updated
Status
Progress
Document rate (curr/avg)
In bandwidth (curr/avg/tot)
:
:
:
:
:
:
01:46:40
22.6s ago
Crawling, 4,482 sites active
26.9%
51.66 dps / 42.88 dps
6.28 Mbps / 5.38 Mbps / 4.01 GB
Downloaded (tot/stored/mod/del) : 274,451 URIs / 101,831 / 49,743 / 15,156
Download times (avg/max/acc)
: 19.7s / 07:37 / 59.11:56:00
DNS overview
-----------Requests (tot/retries/timeouts) : 2,192,245 / 206,290 / 134,132
Request rate (curr/avg/limit)
: 0.8 rps / 1.2 rps / 75 rps
crawleradmin examples
The following examples show some of the crawleradmin options being used for the collection named
mytestcoll.
183
FAST Enterprise Crawler
Extract crawler XML configuration
To get crawler configuration file information:
$FASTSEARCH/bin/crawleradmin -G mytestcoll > mytestcoll.xml
Note that the name of the configuration file (mytestcoll.xml in this example) does not
need to be the same as the collection name. When restoring the collection the actual name
of the collection is given by the name of the DomainSpecification element in the
configuration file.
Add/update crawler XML configuration
To restore or update a collection configuration from a saved file:
$FASTSEARCH/bin/crawleradmin -f mytestcoll.xml
Delete collection from crawler only
To remove a collection from the crawler's configuration, and delete the stored data:
$FASTSEARCH/bin/crawleradmin -d mytestcoll
Note that this command has no effect on the collection in the index.
Crawler collection statistics
To display collection statistics:
$FASTSEARCH/bin/crawleradmin -Q mytestcoll
Replace uppercase Q with lowercase Q for more details.
Force re-crawling of a site
To force a re-crawl (re-fetch) a site:
$FASTSEARCH/bin/crawleradmin --refetchsite mytestcoll:www.example.com
Force re-crawling a single URI
To re-crawl a specific URI immediately:
$FASTSEARCH/bin/crawleradmin --refetchuri
mytestcoll:http://www.example.com/test_pages/x1.html --force
Force re-crawling and refeeding a single URI
To re-crawl and refeed a specific URI immediately:
$FASTSEARCH/bin/crawleradmin --refetchuri
mytestcoll:http://www.example.com/test_pages/x1.html --force --feed
Refeed a site while crawling
To refeed a site to ESP for processing and indexing:
$FASTSEARCH/bin/crawleradmin --refeedsite mytestcoll:www.example.com
You can also specify a different feeding destination on the command line:
$FASTSEARCH/bin/crawleradmin --refeedsite mytestcoll:www.example.com
--refeedtarget otheresp:mytestcoll
184
Enterprise Crawler - reference information
Suspending/resuming crawling
To suspend the crawling of a collection:
$FASTSEARCH/bin/crawleradmin --suspendcollection mytestcoll
To resume crawling use --resumecollection.
Suspending/resuming content feeding
To suspend the content feed to ESP processing and indexing:
$FASTSEARCH/bin/crawleradmin --suspendfeed mytestcoll
If the collection has multiple destinations specified in the configuration, you can suspend
an individual destination by doing:
$FASTSEARCH/bin/crawleradmin --suspendfeed mytestcoll:mydest
To resume feeding use --resumefeed.
crawlerdbtool
The crawlerdbtool lists all documents/URLs that the crawler knows about for each collection.
To use:
1. Stop the crawler:
$FASTSEARCH/bin/nctrl stop crawler
2. On the crawler node, run this command:
crawlerdbtool -m list -d datasearch/data/crawler/store/test/db/ -S all
Table 52: crawlerdbtool Options
Option
-m <mode>
Description
Operation mode.
Valid modes:
check - Report corrupt databases only.
repair - Attempt repair of corrupt databases by copying elements to new
databases. New databases are verified before they replace the corrupt
databases.
delete - Delete corrupt databases.
compact - Compacts a database (specify filename or directory) or document
store cluster (specify cluster directory).
list - Outputs all keys in a database.
count - Counts the number of keys in a database.
view - View an entry in a database based on the key specified with -k. If
none specified then all keys are output.
viewraw - As above but without any formatting.
export - Export a database to marshalled data.
import - Imports a database from marshalled data.
analyze - Analyzes a meta database.
pphl2gb - Convert a postprocess checksum database from hashlog to
gigabase format.
Default: check
185
FAST Enterprise Crawler
Option
Description
-d <dir>
Specifies the directory/file to process. Must be specified except in 'align' mode.
The -f option below is ignored if a file is specified.
-f <filemask>
Specifies the filemask/wildcard to work on. Can be repeated.
Default: *
-c <cachesize>
Specify the cache size (in bytes) to be used when opening databases.
Default: 8388608
-s <frequency>
Database sync frequency during repair. Specifies the number of operations
between each sync. A value of 1 will sync after each operation.
Default: 10
-t <timeout>
Specify a timeout in seconds after which a database check/repair process is
terminated. child is assumed dead and killed. The database will be assumed
corrupt beyond repair and will be deleted.
Caution: Use with caution.
Default: none
-k <key>
Only applicable in view mode. Specifies the database key to view.
-K <key>
Same as -k, but assumes key is repaired and will call eval() on it before using.
Use this for checksums.
-i <intermediate format>
Only applicable in import/export mode. The selected format will be exported to
or imported from.
Valid formats:
marshal - fast space-efficient format
pickle - version and platform independent format
Default: marshal
-S <site>
Specify a site to apply the current mode to. Use this for inspecting meta
databases. If site is "all", all sites will be traversed. If site is "list" all sites will be
listed.
crawlerdbtool examples
Note: Before running the crawlerdbtool make sure the crawler is stopped, as the tool cannot be run
concurrently.
List documents from a server
The command to list all documents crawled from a server within a collection would be:
crawlerdbtool -m list -d datasearch/data/crawler/store/test/db/ -S
web001.example.net
186
Enterprise Crawler - reference information
where web001.example.net is the server, and test is the name of the collection.
Output:
'http://web001.example.net/Island/To.html'
'http://web001.example.net/in/and.html'
'http://web001.example.net/For/3).html'
'http://web001.example.net/for/services.html'
List sites from a collection
To list all known sites within a collection, use the command:
crawlerdbtool -m list -d datasearch/data/crawler/store/test/db/ -S all
Output:
web001.example.net
web000.example.net
URI statistics for a collection
To list statistics for all URIs crawled within a collection, use the command:
crawlerdbtool -m analyze -d datasearch/data/crawler/store/test/db/ -S all
Output: same as Example #3 showed for entire collection.
URI statistics for a server
To get statistics for URIs crawled from a specific server within a collection, use the
command:
crawlerdbtool -m analyze -d datasearch/data/crawler/store/test/db/ -S
web001.example.net
Output:
Enterprise Crawler 6.7 - DB Check Utility
Copyright (c) 2008 FAST, A Microsoft(R) Subsidiary
Current options are:
- Mode
: analyze
- Timeout
: None
- Directory : datasearch/data/crawler/store/test/db/
- File masks : *
- Cachesize : 8388608
Site Report
=================================================
Document and URIs
Avg. Doc Size
Data Volume
JavaScript URIs
Redirect URIs
Total URIs
Unique CSUMs
:
:
:
:
:
:
2.06 kB
18.43 MB
0
0
9141
9126
Mime-Types
187
FAST Enterprise Crawler
text/html : 9141
List URIs (keys) from a database
To list the URIs (or sites) within a given database file, use the list option as in the following
command:
crawlerdbtool -m list -d data/store/example/db/1/0.metadb2
'http://www.example.com/'
'http://www.example.com/maps.html'
'http://www.example.com/bart/bart.jsm'
'http://www.example.com/metro/metro.jsm'
'http://www.example.com/planimeter/planimeter.jsm'
'http://www.example.com/comments/'
'http://www.example.com/software/'
'http://www.example.com/software/micro_httpd/'
'http://www.example.com/software/mini_httpd/'
'http://www.example.com/software/thttpd/'
'http://www.example.com/software/spfmilter/'
'http://www.example.com/software/pbmplus/'
'http://www.example.com/software/globe/'
'http://www.example.com/software/phoon/'
'http://www.example.com/javascript/MapUtils.jsm'
'http://www.example.com/software/saytime/'
'http://www.example.com/javascript/Utils.jsm'
Success
View record of a specific database key
The output of the previous command provides the keys to the data stored within each
database. This can be specified with the -k option in view mode, to see all details
associated with that URI or site, as in the following examples.
crawlerdbtool -m view -d data/store/example/db/1/0.metadb2 -k
'http://www.example.com/maps.html'
key (meta): 'http://www.example.com/maps.html'
MIME type
Crawl time
Errors
Compression
Parent
State flag
Checksum
:
:
:
:
:
:
:
text/html
2006-12-21 18:54:09
None
deflate
None
0
c2f963f3b56e1495abad9c8b89ab41f5
Change history : (0, 0, 0, 1166723649)
Links : http://mapper.example.com/
http://mapper.example.com/ http://www.example.com/
http://www.example.com/
http://www.example.com/GeoRSS/ http://www.example.com/GeoRSS/
http://www.example.com/bart/ http://www.example.com/bart/
http://www.example.com/javascript/ http://www.example.com/javascript/
http://www.example.com/jef/ggs/ http://www.example.com/jef/ggs/
http://www.example.com/jef/hotsprings/
http://www.example.com/jef/hotsprings/
http://www.example.com/jef/outlines/
http://www.example.com/jef/outlines/
http://www.example.com/jef/paris_forts/
188
Enterprise Crawler - reference information
http://www.example.com/jef/paris_forts/
http://www.example.com/jef/transpac2005/
http://www.example.com/jef/transpac2005/
http://www.example.com/mailto/?id=wa
http://www.example.com/mailto/?id=wa
http://www.example.com/mailto/wa.gif
http://www.example.com/mailto/wa.gif
http://www.example.com/metro/ http://www.example.com/metro/
http://www.example.com/planimeter/ http://www.example.com/planimeter/
http://www.example.com/resources/images/atom_ani.gif
http://www.example.com/resources/images/atom_ani.gif
http://www.google.com/apis/maps/ http://www.google.com/apis/maps/
Maxdoc counter : 2
Last-Modified : Tue, 11 Apr 2006 13:35:18
GMT
Epoch
ETag
Flags
Previous Checksum
Referrers
:
:
:
:
:
0
None
0
None
http://www.example.com/ :
Fileinfo : ('example/data/1', 1217,
65539)
HTTP header : HTTP/1.1 200 OK
Server: thttpd/2.26 ??apr2004
Content-Type: text/html; charset=iso-8859-1
Date: Thu, 21 Dec 2006 17:54:07 GMT
Last-Modified: Tue, 11 Apr 2006 13:35:18 GMT
Accept-Ranges: bytes
Connection: close
Content-Length: 4068
Adaptive epoch (upper) : 0
Adaptive rank : 7920
Level (min/current/max) : (1, 1, 1)
# crawlerdbtool -m view -d data/store/example/db/1/site.metadb2
Site: 'www.example.com'
Internal ID : 0
Hostname : www.example.com
Alias : None
Adaptive data :
awo : (12, 0)
awe : 2
Epoch details :
Last refresh (upper)
Clean epoch
Last refresh
Previous adaptive epoch
Epoch
Epoch (upper)
Subdomain list
IP address
Mirrors
Last seen
Segment number
Maxdoc limit
:
:
:
:
:
:
:
:
:
:
:
:
2007-01-09 17:34:49
2
2007-01-09 17:34:49
0
2
0
empty
192.168.178.28
None
0
0
0
crawlerconsistency
The consistency tool is used for verifying and repairing the consistency of the crawler document and meta
data structures on disk.
189
FAST Enterprise Crawler
The consistency tool has two main uses. It can be used as a preventive measure to verify and maintain
internal crawler store consistency, but also as part of recovering a damaged crawler store. The tool will detect,
and by default also attempt to repair, the following inconsistencies:
•
•
•
•
•
Documents referenced in meta databases, but not found in the document store
Invalid documents in the document store
Unreferenced documents in the document store (requires docrebuild mode)
Duplicate database checksums not found in meta databases
Multiple checksums assigned to the same URI in the duplicate database
The above list of inconsistencies are automatically corrected by running the tool in the doccheck or docrebuild
mode, followed by the metacheck mode. Any URIs found to be non-consistent will be output to a log file (see
below), and a delete operation will also be issued to the indexer (can be disabled) to ensure it is in sync.
Refer to Crawler Store Consistency on page 157 for more information.
In a multi node crawler environment the tool can also be used to rebuild a duplicate server from the contents
of per-master postprocess checksum databases, using the ppduprebuild mode. Since this mode builds the
duplicate server from scratch it can also be used to change the number of duplicate servers in use, by first
changing the configuration of the collection and then rebuilding. Refer to Redistributing the Duplicate Server
Database on page 160 for more information.
The following log files will be generated by the tool. Be aware that log files are only created once the first URI
is written to a file, hence not all log files will be present.
Table 53: Output log files
Filename
Description
<mode>_ok.txt
Lists every URI found during the check, that was not removed as a result of an
inconsistency. The output from the metacheck mode in particular will list every
URI with a unique checksum, and is therefore useful for comparing against the
index. Be aware that documents may have been dropped by the pipeline, and
thus this file may correctly list URIs not actually present in the index. However,
URIs in the index that are not in this file may be safely removed from the index
as it is not known by the crawler.
<mode>_deleted.txt
This file lists each URI deleted by the tool. Unless indexer deletes were disabled
with the -n option they would also have been removed from the index. As these
URIs were only deleted due to internal inconsistencies within the crawler it is
entirely possible that they still exist on the web servers, and should thus rightly
be indexed. Therefore, it is recommended that this list of URIs is subsequently
re-crawled. This can be accomplished through the crawleradmin using the
--addurifile option. To expedite crawling add the --force option.
<mode>_deleted_reasons.txt
The contents of this file will be the same as the previous file, with the addition
of an "error code" preceding each URI. The error codes identify the reason for
each URI being deleted. The following codes exist:
•
•
•
•
•
•
•
•
<mode>_wrongnode.txt
190
101 - Document not found in document store
102 - Document found, but unreadable in document store
103 - Document found, but length does not match meta information
201 - Meta data for document not found
202 - Meta data found, but unreadable
203 - Meta data found, but does not match checksum in duplicate database
204 - Meta data found, but has no checksum
206 - URI's hostname not found in routing database
Only ever present on a multi node crawler, this file will output all URIs removed
from a particular node due to incorrect routing. This means that the URIs should
Enterprise Crawler - reference information
Filename
Description
be, and most likely also are, crawled by a different master node. Therefore,
these URIs are only output to the log file, but not deleted from the index.
<mode>_refeed.txt
The URIs listed in this file have had their URI equivalence class updates as a
result of running the tool. To bring the index in sync use postprocess refeed
with the -i option to refeed the contents of this file. Alternatively perform a full
refeed.
It is recommended to always redirect the stdout and stderr output of this tool to a log file on disk. Additionally,
on UNIX use either screen or nohup in order to prevent the tool from terminating in case the session is
disconnected.
Tool: $FASTSEARCH/bin/crawlerconsistency: option [options]
Table 54: crawlerconsistency options
Mandatory options
-M <mode>[,<mode>,..,<mode>]
Description
Selects the mode to run the tool in. The following modes are available
•
•
doccheck - Verifies that all documents referenced in the meta databases
also exist on disk.
docrebuild - Same as above, but re-writes all referenced documents to a
fresh document store, effectively getting rid of any orphans in the document
store.
Note: This can take a long time.
•
•
•
metacheck - Verifies that all checksums referenced in the PP databases
also exist in the meta databases.
metarebuild - Attempts to recovery a damaged metastore. Currently supports
rebuilding a bad or lost site database based on segment databases.
duprebuild: Rebuilds the contents of the Duplicate Server(s) from the local
Post Process DB.
Note: Exclusive mode. This mode must be run separately.
Additionally, the following 'modifiers' can be specified:
•
updatestat - Updates the statistics document store counter.
Note: Can only be used together with the doccheck/docrebuild mode.
Only applies to the stored statistics counter.
•
routecheck - Verifies that sites/URIs are routed to the correct.
Note: Only applies to multi-node crawlers.
-O <path>
Directory where the tool will place all output logs.
The tool will create a sub directory here with a name matching the current date
on the format <year><month><date>. If the directory already exists a counter
will be appended, e.g. ".1" in order to ensure clean directories each time the tool
is run.
191
FAST Enterprise Crawler
Optional options
-d <path>
Description
Location of crawl data, runtime configuration and logs in
subdirectories in the specified directory. Default: data
-C
A comma separated list of collections to check. Default: All
<collection>[,<collection>,...,<collection>]<
collections
-c <cluster>[,<cluster>,...,<cluster>]
A comma separated list of clusters to check. Default: All
clusters
Note: Applies to: doccheck and docrebuild.
-S <site>[,<site>,...,<site>]
Only process the specified site(s). Default: All sites
Note: Applies to: doccheck
-z
Compress documents in the document store when executing
the docrebuild mode. This overrides the collection level
option to compress documents if specified. Default: off
Note: Applies to: docrebuild
-i
Skip free disk space checks. Normally the tool will check
the amount of free disk space periodically and if it drops
below 1GB it will abort the operation and exit. This option
should be used with caution.
-n
Do not submit delete operations to the pipeline/indexer,
only log them to files.
In order to ensure removed documents are not present in
the index afterwards it is recommended to manually delete
the documents reported as deleted, or refeed the entire
collection into an initially empty index.
-F
Load crawler global config from file. Conflicting options
specified on the command line override the values in the
configuration file if given.
-T
Test mode. Tool does not delete anything from disk or issue
any deletes to the pipeline/indexer.
crawlerwqdump
The crawler work-queue-dump-tool writes the crawler queues that reside on disk to plain text files or to stdout.
The following queues may be output:
•
•
•
•
192
the masters queue of resolved URIs
the masters queue of unresolved URIs
the masters queue of unresolved sites
the slave work queues
Enterprise Crawler - reference information
Tool: $FASTSEARCH/bin/crawlerwqdump -d <dir> -c <collection> -t <target> -q <queue>
All options must be specified. Each entry in the output contains the collection name and an URI, separated
by ','.
Table 55: crawlerdbtool Options
Option
Description
-d <dir>
-c <collection>
Path to queue dir (data/crawler/queues).
The name(s) of your collection(s).
Use 'all' to process all collections.
Separate collections with ',' if you specify more than one.
-t <target>
Output directory or 'stdout'.
If you specify an output directory, the queues will be written to file and placed
in <target> directory and named:<queue>.<time>.<collection>.txt ex:
slavequeue.2005.12.21.11.9.mycollection.txt.
-q <queue>
Which queues to process: resolved/unresolved/slave/all.
Example:
crawlerwqdump -d $FASTSEARCH/data/crawler/queues/ -c
mycollection,myothercollection
-q slave" -t $FASTSEARCH/data/crawler/queuedumps/"
crawlerdbexport
The crawlerdbexport tool is used to dump the EC 6.3 databases to an intermediary format for subsequent
import to an EC 6.7 installation, as part of the crawler store migration process.
Dump files will be placed alongside the original databases, named with the suffix .dumped_nn.
Tool: $FASTSEARCH/bin/crawlerdbexport [options]
Table 56: crawlerdbexport options
Option
-m
Description
Required: Mode.
Valid values: export, deldumps
Default: export
-d
Required: Directory, path to crawler store ($FASTSEARCH/data/crawler).
Default: none
-g
Name of your collection.
If no collection is specified, then all collections are processed.
Default: none
-l
Log level.
193
FAST Enterprise Crawler
Option
Description
Valid values: normal, debug
Default: normal
-b
Batch size.
Maximum bytes per dump file.
Default: 100MB
crawlerstoreimport
The crawlerstoreimport tool loads the crawlerdbexport dump files one by one, creates new databases and
migrates the document storage, and a new 6.7 crawler store will be created.
This also includes the documents stored. This section lists options for the import tool.
Tool: $FASTSEARCH/bin/crawlerstoreimport [options]
Table 57: crawlerstoreimport options
Option
-m
Description
Required: Mode.
Valid values: import, deldumps
Default: import
-d
Required: Directory, path to old crawler store ($FASTSEARCH/data/crawler.old).
Default: none
-n
Required: Directory, path to new crawler store ($FASTSEARCH/data/crawler).
Default: none
-t
Required: Node type.
Valid values: ubermaster, master, ppdup
Default: none
-g
Name of your collection.
If no collection is specified, then all collections are processed.
Default: none
-s
Storage format.
Valid values: bstore, flatfile
Default: current format
-r
Remove dump files.
Valid values: 0,1
Default: 0 (no)
-p
194
ppdup format.
Enterprise Crawler - reference information
Option
Description
Valid values: hashlog, gigabase
Default:gigabase
-l
Log level.
Valid values: normal, debug
Default: normal
Crawler Port Usage
This appendix lists per process port usage for single node and multiple node crawlers.
The crawler port is sometimes specified on the command line: -P <hostname>:<crawlerbaseport>
<hostname>
By default binds to all interfaces.
<crawlerbaseport>
If the FASTSEARCH environment variable is set, the port is read from the
$FASTSEARCH/etc/NodeConf.xml file.
If the FASTSEARCH variable is not set OR reading the port fails, port 14000 is used.
Port range
The maximum crawler port range is from <crawlerbaseport> to
<crawlerbaseport>+299
Table 58: Crawler Port Usage (Single Node)
Process name
Purpose
Port
crawler
XML-RPC
<crawlerbaseport>
Postprocess
communication
<crawlerbaseport> + 2
crawler
Slave communication
<crawlerbaseport> + 3
crawlerfs
HTTP
<crawlerbaseport> + 4
postprocess
Slave communication
<crawlerbaseport> + 5
postprocess
XML-RPC
<crawlerbaseport> + 6
uberslave
XML-RPC
<crawlerbaseport> + 7 and up to <crawlerbaseport> + 198
cglogdispatcher (GUI
log dispatcher)
XML-RPC
<crawlerbaseport> + 199
Table 59: Crawler Port Usage (Multiple Node)
Process name
Purpose
Port
Ubermaster (crawler
-U)
XML-RPC
<crawlerbaseport>
Ubermaster (crawler
-U)
Master communication <crawlerbaseport>+1
Master (crawler -S)
XML-RPC
<crawlerbaseport> + 100
195
FAST Enterprise Crawler
Process name
Purpose
Port
Master (crawler -S)
Postprocess
communication
<crawlerbaseport> + 102
crawler -S
Slave communication
<crawlerbaseport> + 103
crawlerfs
HTTP
<crawlerbaseport> + 104
postprocess
Slave communication
<crawlerbaseport> + 105
postprocess
XML-RPC
<crawlerbaseport> + 106
uberslave
XML-RPC
<crawlerbaseport> + 107 and up to <crawlerbaseport> +
198
cglogdispatcher (GUI
log dispatcher)
XML-RPC
<crawlerbaseport> + 199
ppdup (Duplicate
Server)
Postprocess
communication
<crawlerbaseport> + 200
ppdup (Duplicate
Server)
Duplicate replication
<crawlerbaseport> + 201 and up to <crawlerbaseport> +
298
Log Files
The Enterprise Crawler creates numerous files in which to log information detailing the processing of URIs
and collections. Some are created automatically, others must be enabled via configuration.
Directory structure
The following table describes the key directories and files in a crawler installation, relative to the FAST ESP
installation root, $FASTSEARCH.
Table 60: Crawler Directory Structure
Structure
Description
$FASTSEARCH/bin
/crawler
Crawler executables
/crawleradmin
/postprocess
$FASTSEARCH/lib
Shared libraries and Python images
$FASTSEARCH/etc
FAST ESP configuration files read by
crawler
$FASTSEARCH/var/log/crawler
Folders for detailed crawler logs
/crawler.log
/dns
/dsfeed
/header
/fetch
196
Diagnostic and progress information
Daily log files directories. Most of the
directories are organized by collection.
Enterprise Crawler - reference information
Structure
Description
/screened
/site
/stats
/PP
$FASTSEARCH/data/crawler
Folders for configuration, work queues
and data/metadata store
/config
/queues
/dsqueues
$FASTSEARCH/data/crawler/store
Temporary and permanent
configuration data, work queues and
batches; mostly binary data
Data and metadata for crawled pages,
organized in subdirectories by
collection
/db
Metadata for each document gathered
/data
Document content
/PP/csum
Duplicate document checksum
databases
Log files and usage
DNS log
A directory that contains log files from DNS resolutions:
$FASTSEARCH/var/log/crawler/dns
Header log
A directory that contains logs of HTTP request/response exchanges, separated into
directories by sitename. The header log is disabled by default:
$FASTSEARCH/var/log/crawler/header/<collection>/
Screened log
A directory that contains log files of all URIs processed by the crawler and details for any
given URI on whether or not it will be placed on the work queue:
$FASTSEARCH/var/log/crawler/screened/<collection>/
The screened log is turned off by default. URIs that will be queued are logged as ALLOW
others as DENY. Additionally all URIs logged as DENY will have a explanation code logged
with it.
Site log
A directory that contains log files listing events in the processing of web sites. The logs
contain entries listing a site being processed, a time stamp, and details of the transition
in the state of that web site, such as STARTCRAWL, IDLE, REFRESH, and STOPCRAWL.
$FASTSEARCH/var/log/crawler/site/<collection>/
197
FAST Enterprise Crawler
Fetch log
A directory that contains log files for every collection that is populated by the crawler. The
crawler logs attempted retrievals of documents to a per-collection log. Each log file
describes actions taken for every URL along with a time stamp:
$FASTSEARCH/var/log/crawler/fetch/<collection>/
Crawler log
This file logs general diagnostic and progress information from the crawler process stdout
and stderr output. The verbose level of this log is governed by the -l <level> option
given to the crawler and can be modified in the crawler entry in
$FASTSEARCH/etc/NodeConf.xml. Use the -l <level> option to specify the log level.
Possible values are one of the following predefined log levels: debug, verbose, info,
warning, error . If you adjust the level, reload the configuration file into the node controller
(nctrl reloadcfg in $FASTSEARCH/bin) before stopping and starting the crawler for the
change to take effect.
$FASTSEARCH/var/log/crawler/crawler.log
Postprocess
log
A directory that contains log files from postprocess. Postprocess performs duplicate
detection of downloaded documents, and processes content to FAST ESP.The Postprocess
log contains the URIs and referrer URI to every unique document together with their size,
MIME type and URIs to any duplicates found:
$FASTSEARCH/var/log/crawler/PP/<collection>/
DSfeed log
A directory that contains log files for every collection that is populated by the crawler. The
logs contain the status of each URI submitted to document processing. Deletes are also
logged:
$FASTSEARCH/var/log/crawler/dsfeed/<collection>/
Enabling all Log Files
Logging options can be enabled via selection in the administrator interface, or by adding them to the XML
configuration file and reloading that using the crawleradmin tool.
An example of fully enabled log section from configuration file:
<section name="log">
<attrib name="dsfeed" type="string"> text </attrib>
<attrib name="fetch" type="string"> text </attrib>
<attrib name="header" type="string"> text </attrib>
<attrib name="postprocess" type="string"> text </attrib>
<attrib name="screened" type="string"> text </attrib>
<attrib name="site" type="string"> text </attrib>
</section>
Verbose and Debug Modes
In cases where warnings or errors indicate that the crawler may have a problem, it may be helpful to obtain
more detailed information than what is available in the daily crawler.log file.
The options available for logging are the verbose mode (-v) and the debug mode (-l <value>, where <value>
is often <debug>. To add these modes to the crawlers command line within FAST ESP:
1. Edit the NodeConf.xml file. To do so, find the Enterprise Crawler command specification, and add either
“-v” or “-l debug” to the <parameters> string.
2. Save the change.
3. Force the node controller to reread the file. Run the command: nctrl reloadcfg
The change will take effect when the crawler is next restarted
198
Enterprise Crawler - reference information
Crawler Log Messages
Below is a list of log messages that may be found in the $FASTSEARCH/var/log/crawler/crawler.log file.
Severity
CRITICAL
Log Message(s)
Cause(s)
Another process,
A process, most likely the crawler, is
most likely another already running on the crawler port.
crawler, is already
running on the
specified interface
'localhost:14000'
Action(s)
Ensure that the crawler is not already
running on the port specified on the
crawler command line. They may be
killed if necessary.
or
Unable to bind
master socket to
interface
'localhost:14000'
or Unable to open
XML-RPC socket
(%s:%s)
or
Another process,
most likely another
crawler, is already
running and holding
a lock on the file
<filename>
or
Unable to create
listen port for
slave
communication:
socket.error:
[Errno 98] Address
already in use
CRITICAL
Unable to perform
crawler license
checkout: <text>
The crawler was unable to retrieve a
valid license. Your license may have
expired.
Refer to the licensing information listed
in Contact Us on page iii for more
information.
or
Unable to check out
FLEXlm license.
Shutting down.
Contact FAST for a
new license
CRITICAL
Lost connection to The uberslave process has detected
Master. Taking down that the master is no longer running and
is shutting down. This can occur if
Slave
either the master crashes or on normal
shutdowns.
Check the logs for additional
information. If this was not the result of
a normal shutdown please submit a bug
report to FAST Technical Support.
Include logs and core files if available.
199
FAST Enterprise Crawler
Severity
CRITICAL
Log Message(s)
Cause(s)
Action(s)
Unable to start
Subordinate processes either could not Investigate system resources, process
limits, check log files for error
Slave/FileServer/PostProcess be started, or are failing repeatedly.
messages.
process
or
Too frequent
process crashes.
Shutting down
CRITICAL
No data directory
specified
Misconfiguration or
ownership/permission problems.
or
Unable to create
the data directory
<directory>
Verify that correct user is attempting to
run crawler, and that ownership of
crawler directories is correct. Recheck
configuration files and command-line
options.
or
Unable to write
crawler pidfile to
<directory>
or
Survival mode may
only be used by a
subordinate in a
multi node setup
CRITICAL
Failed to load
collection config
<text>. Shutting
down
Unable to read configuration database Verify existence and
or XML file.
ownership/permission of configuration
database or file.
or
Failed to load
collection config
specified on
command line:
<text>
CRITICAL
ERROR
200
DNS resolver error Crawler unable to contact DNS server Check system DNS configuration (e.g.
to resolve names or addresses.
/etc/resolv.conf), verify proper
operation (e.g. using nslookup/dig or
similar tool).
Lost connection
<name> (PID:
<pid>), possibly
due to crash
Communication between two crawler
processes has failed, possibly due to
a process crash.
None, the crawler will restart the
process. Contact FAST Technical
Support if it occurs repeatedly.
Enterprise Crawler - reference information
Severity
ERROR
ERROR
ERROR
ERROR
WARNING
WARNING
WARNING
WARNING
WARNING
Log Message(s)
Cause(s)
Action(s)
Remote csum
ownership, same
URI: <URI>
In a multiple node crawler setup this
can occur if the same site has been
routed to more than one master, or if
stale data has not been properly
deleted.
Contact FAST Technical Support if it
occurs repeatedly.
Unable to
load/create config
DB '<path>':
DBError: Failed to
obtain database
lock for
<path>/config.hashdb
The crawler is already running when
an attempt was made to start another
crawler or use a tool that requires the
crawler to be stopped first.
Stop the crawler. If, after waiting for at
least 5 minutes, there are still crawler
processes running they may need to
be killed.
Unable to connect
to <name> process.
Killing process
(PID=<PID>)
A process started by the master failed Check the logs for additional
to connect properly to the master. The information. Contact FAST Technical
process may have had startup
Support if it occurs repeatedly.
problems.
Timeout waiting for
<name> process to
connect to Master,
killing (PID=<PID>)
A process started by the master failed Check the logs for additional
to connect back within 60 seconds. The information. Contact FAST Technical
process may have had startup
Support if it occurs repeatedly.
problems.
<name> process (PID A crawler sub process identified by
<pid>) terminated <name> has crashed and will be
by signal <signal> restarted.
(core dumped)
Submit bug report to FAST Technical
Support. Include logs and core file.
Failed to read data
from '<path>',
discarding
URI=<URI>
The crawler was unable to read a
None unless this occurs repeatedly.
previously stored document from disk. Verify that there are no disk issues or
This can occur if the document has
other problems that could cause this.
since been deleted from the web server
and the crawler has a backlog.
Unable to read
block file index
for block file
<number>
A document store file index was either Submit bug report to FAST Technical
corrupt or missing on disk.
Support. Include logs.
Start URI <URI> is A start URI specified in the
configuration did not pass the
not valid
include/exclude rule checks.
Verify that all start URIs match the
include/exclude rules as well as HTTP
scheme and extension rules.
Data Search Feeder
The disk queue containing documents Delete the
failed to process
on disk for processing is corrupt.
$FASTSEARCH/data/crawler/dsqueues
packet: IOError
directory and perform a PostProcess
refeed as described in Re-processing
Crawler Data Using postprocess on
page 154.
201
FAST Enterprise Crawler
Severity
WARNING
WARNING
WARNING
WARNING
Log Message(s)
Cause(s)
KeepAlive ACK from In a multiple node crawler setup this
If the log message repeats restart all
can occur if the ubermaster and master crawler processes.
unknown Master
processes go out of sync.
Unable to flush
The master process work load is very If this repeats try to reduce the
workload by reducing the number of
Master comm channel high and communication between
processes are suffering.
concurrent sites being crawled or install
on more powerful hardware or
additional servers.
<name> engine poll The specified process has a very high None, unless this occurs constantly. If
workload. API calls may respond more so either decrease the work load by
used <number>
slowly.
crawling fewer sites concurrently or
seconds
install on more powerful hardware or
additional servers.
Master ID '<ID>'
already exists
A master has been started with a
symbolic ID that has already been
specified for another in the same
multiple node crawl.
Stop the offending master and change
the symbolic ID specified by the -I
option
WARNING
The Browser Engine is shutdown or
The Browser engine
unavailable
at <host>:<port> is
down
VERBOSE
The Browser Engine is up and running
The Browser engine
after having been down.
at <host>:<port> is
up
VERBOSE
The Browser Engine is overloaded and Tune the EC to Browser Engine
The Browser engine
will not process new documents until communication, tune the Browser
at <host>:<port> is
the queue length is reduced.
Engine. You may need to disable
overloaded
JavaScript and/or Flash processing or
only enable JavaScript and/or Flash for
certain sites.
PROGRESS
INFO
Ignoring site:
<sitename> (No
URIs)
Investigate why the Browser Engine is
down and rectify it. See the FAST ESP
Browser Engine Guide for more
information.
When postprocess re-feeding you may None needed. However, if the site
get this message for sites containing should contain URIs you may wish to
no URIs.
try to re-crawl it or examine logs to
determine why it has no URIs.
Collection '<name>' The refresh cycle of the collection has You may want to increase the refresh
period in order to completely crawl all
is not idle by time completed and the crawler is not
finished crawling all the sites.
sites within the refresh period.
of refresh
PostProcess Log
Below is a list of postprocess log messages that may be found in the
$FASTSEARCH/var/log/crawler/PP/<collection>/ directory.
202
Action(s)
Enterprise Crawler - reference information
Severity
CRITICAL
CRITICAL
STATUS
STATUS
PROGRESS
Log Message
Cause(s)
Action(s)
Must specify Master The postprocess process was run
without the correct command line
port
arguments.
The postprocess process can only be
run manually in refeed mode (-R
command line option), make sure the
arguments are correct.
Failed to start
The PostProcess module failed to
register with the configserver at
PostProcess:
ConfigServerError: initialization time.
Failed to register
with ConfigServer:
Fault: (146,
'Connection
refused')
The configserver process is stopped or
suspended. Restart it, wait a moment,
and restart the PostProcess.
Could not send
batch to Data
Search Content
Distributor, will
try again later.
The error was:
add_documents call
with batch <batch
ID> timed out
The batch could not be forwarded to a None, the batch will be resent
document processor since none were automatically.
idle. This is a built-in throttling
mechanism in FAST ESP.
Waiting for Data
Search to process
remaining data...
Hit CTRL+C to abort
During refeed this message is logged Optionally signal postprocess to stop
once all databases have been
and resume crawler.
traversed. Documents are still being
sent to the Content Distributor, but it is
safe to signal postprocess to stop and
resume crawling as the crawler will then
feed the remaining documents.
Ignoring site:
<sitename> (No
URIs)
During postprocess refeed traversal of The message can be ignored. If this
the databases, a site was encountered site should have URIs associated with
with no associated URIs.
it, then sanity check the configuration
rules and log files to discover why it has
no URIs.
Crawler Fetch Logs
The crawler will log attempted retrievals of documents to a per-collection log located in
$FASTSEARCH/var/log/crawler/fetch/<collection name>/<date>.log.
The screened log is disabled by default. When enabled ("Screened" log enabled in the Logging section in
the Advanced crawler collection configuration GUI), all URIs seen by the crawler and whether they will be
attempted retrieved or not is located in $FASTSEARCH/var/log/crawler/screened/<collection name>/<date>.log
The messages in these logs are in a whitespace-delimited format as follows:
<time stamp> <status code> <outcome> <uri> [<auxiliary information>]
where:
1. <time stamp> is a date/clock denoting a time at which the request was completed or terminated.
203
FAST Enterprise Crawler
2. <status code> contains a three letter code which describes the status of the outcome of the retrieval.
When this code is a numerical value, it maps directly to the same status code in the proper protocol, as
defined in RFC 2616 for HTTP/HTTPS, and RFC 765 for FTP.
The authoritative description of these status codes are always the respective protocol specifications, but
for convenience we describe a subset of these status codes informally below.
3. <outcome> is a somewhat more human readable status word that describes the status of the document
after retrieval.
4. <uri> denotes the URI that was requested.
5. [<auxiliary information>] contains additional informative information such as descriptive error
messages.
An excerpt from a fetch log is shown below:
2007-08-02-16:51:41 200 MODIFIED http://www.example.com/video/ JavaScript processing
complete
2007-08-02-16:52:32 301 REDIRECT http://www.example.com/video/living Redirect
URI=http://www.example.com/video/living/
2007-08-02-16:53:33 404 IGNORED
http://www.example.com/video/living/
2007-08-02-16:54:33 200 PENDING
http://www.example.com/video/live/live.html?stream=stream1 Javascript processing
Crawler Fetch Log Messages
Below is a list of log messages that may be found in the fetch log in the
$FASTSEARCH/var/log/crawler/fetch/<collection>/ directory.
Table 61: Status Codes - Fetch Log
Code/Message
Description/Possible Solution
200 - HTTP 200 "OK"
The request was successful. A document was retrieved following the request.
301 - HTTP 301 "Moved The document requested is available under a different URI. Target URI is shown in the
auxiliary information field.
permanently"
302 - HTTP 302 "Moved The document requested is available under a different URI. Target URI is shown in the
auxiliary information field. The crawler treats HTTP 301/302 identically.
temporarily"
204
303 - HTTP 303 "See
Other"
This method exists primarily to allow the output of a POST-activated script to redirect the
crawler to a new URI.
304 - HTTP 304 "Not
Modified"
The document has been retrieved earlier, and was now conditionally requested if the
server detected that it had changed since the last time. This is achieved by supplying the
Last-Modified time stamp or Etag given by the server the last time in the request. "Not
Modified" responses can be received when the "Send If-Modified-Since" setting is enabled
in the crawler configuration GUI.
401 - HTTP 401
"Unauthorized"
The web server requires that the crawler presents a set of credentials when requesting
the URI. This would occur using Basic or NTLM authentication.
403 - HTTP 403
"Forbidden"
The web server denies the crawler access to the URI, either because the crawler presented
a bad set of credentials or because none were given at all.
404 - HTTP 404 "Not
Found"
The web server does not know about the requested URI. Commonly, this is because a
"dead link" was seen by the crawler.
Enterprise Crawler - reference information
Code/Message
Description/Possible Solution
406 - HTTP 406 "Not
Acceptable"
The web server discovers that the crawler is not configured to receive the type of page it
has requested.
500 - HTTP 500
"Internal Server
Error"
Some unspecified error happened at the server when the request was serviced.
503 - HTTP 503
The server is currently unable to serve the request. This can for instance imply that the
"Service unavailable" server is overloaded.
226 - FTP 226
"Closing data
connection"
An operation was performed to completion.
426 - FTP 426
"Connection closed;
transfer aborted"
The retrieval of the document was aborted.
ERR
A non-HTTP error occurred (crawler or network related). Details of the error is shown in
the auxiliary information field.
TTL
The retrieval of the document exceeded the timeout setting. The number of seconds to
wait before an uncompleted request is terminated is governed by the "Fetch timeout"
setting in the crawler configuration GUI.
DSW
The document has been "garbage-collected" as it has not been seen for a number of
crawler refresh cycles. This means that the crawler has crawled more data than it can
deterministically re-crawl during one crawler refresh cycle and that documents are
periodically purged if they have not been seen over recently. The number of refresh cycles
to wait before purging documents is governed by the "DB switch interval" setting in the
crawler configuration GUI. Alternatively, the documents are being deleted because they
have become unreachable, either due to modifications in the crawler configuration or on
the website itself.
STU
Start URI was deleted. The specified start URI had been removed and excluded from the
configuration and has now been removed from the crawler store.
USC
The URI added from the crawler API (e.g. using crawleradmin) was deleted. A URI
crawled earlier has now been excluded by the configuration, and when re-adding it the
URI is now removed from the crawler store.
USR
The URI was deleted through the external API (e.g. using crawleradmin). Unless also
excluded by the configuration it may be re-crawled again later.
RSS
The URI was deleted due to the RSS settings. The URI was deleted due to the RSS
settings. The document was deleted either because it was too old, or because of the
maximum allowed number of documents for a feed has been reached.
Table 62: Outcome Codes - Fetch Log
205
FAST Enterprise Crawler
Code/Message
Description/Possible Solution
NEW
The retrieved document was seen for the first time by the crawler and will be further
processed, pending final duplicate checks.
UNCHANGED
The retrieved document was seen before, and the retrieved version did not differ from the
one retrieved the last time.
MODIFIED
The retrieved document was seen before, and the retrieved version did differ from the
one retrieved the last time. The updated version will be further processed, pending final
duplicate checks.
REDIRECT
The retrieval of the document resulted in a redirect, that is the server indicated that the
document is available at a different location. The redirect target URI will be retrieved later,
if applicable.
EXCLUDED
The document was retrieved, but properties of the response header or body was excluded
by the crawler configuration. Details of the cause is shown in the auxiliary information
field. Commonly, the data was of a MIME type not allowed in the crawler configuration.
DUPLICATE
The document was retrieved, but detected as a duplicate in the first level crawler duplicate
check. The document will not be processed further.
IGNORED
The retrieval of the document failed, because of protocol or other error. If not evident from
the status code (like HTTP 404, 403...), details of the cause is shown in the auxiliary
information field. If the document had been retried a number of times and failed in all
attempts, the last attempt will be flagged as IGNORED.
DEPENDS
The document was retrieved, but has dependencies to external documents required for
further processing. Currently, this means that JavaScripts are enabled in the crawler
configuration and that the document contained references to external JavaScripts. The
document will be further processed when all dependencies have been retrieved.
DEP
The retrieved document was depended on by another document.
PENDING
206
A document was sent to an external component for processing. Examples include
JavaScript and Flash documents, which are processed by the Browser Engine. There
might be multiple pending messages for the same URI.
DELETED
The document had been retrieved earlier but is no longer available, or the document had
been retrieved earlier but has not been seen for a number of refresh cycles (refer to the
DSW status code). The document will be flagged as deleted.
RETRY
An error occurred and the retrieval of the document will be retried. The number of times
a document is retried is governed by the settings in the "HTTP Errors"/"FTP Errors" settings
in the crawler configuration GUI.
CANCELLED
The BrowserEngine canceled processing of a document. This is either caused by that the
BrowserEngine was shut down, or because processing of a document timed out. If the
cancel operation was caused by time out, a text message will be logged in the auxiliary
information field.
STOREFAIL
The crawler experienced an error saving the document contents to disk.
Enterprise Crawler - reference information
Code/Message
Description/Possible Solution
AUTHRETRY or AUTHPROXY The crawler was denied access to the URI, either directly or via the proxy. If Basic or
NTLM authentication has been configured, this may be a normal part of the protocol.
FAILED
LIST
RSSFEED
SITEMAP
The crawler was unable to complete internal processing of the document. Check the
crawler log file to see if additional details were noted.
A directory listing was retrieved via FTP to obtain URIs for FTP documents.
A new RSS feed has been detected by the crawler.These feeds are processed as specified
by the RSS settings of the collection.
A sitemap or sitemap index has been detected and parsed by the crawler.
Table 63: Crawler Fetch Log Auxiliary Field Messages
Message
Description
Referrer=<referrer
uri>
The URI was referred by the given referrer URI.
Redirect URI=<target
uri>
The retrieved URI redirects to the given target URI.
Empty document
The document was retrieved but contained no data.
META Robots
<directives>
The document contained the given HTML META Robots directives.
MIME type:
<MIME-type>
The document was of the specified MIME type (and was excluded because of this).
Connection reset by
peer
The connection to the server was reset by the server (BSD socket error message).
Connection refused
The connection to the server failed to be established (BSD socket error message).
Crawler Screened Log Messages
Below is a list of screen log messages that may be found in the
$FASTSEARCH/var/log/crawler/screened/<collection>/ directory.
Table 64: Status Codes - Screened Log
Code/Message
Description/Possible Solution
ALLOW
The URI is eligible for retrieval according to the crawler configuration.
DENY
The URI is not eligible for retrieval according to either crawler configuration, robots.txt file
or HTML robots META tags.
Table 65: Outcome Codes - Screened Log
207
FAST Enterprise Crawler
Code/Message
Description/Possible Solution
OK
The URI was allowed and is eligible for retrieval.
URI
The URI was disallowed due to URI inclusion/exclusion settings in the crawler configuration.
These are the URI include/exclude filters and Extension excludes in the crawler
configuration GUI
.
208
DOMAIN
The URI was disallowed due to hostname inclusion/exclusion settings in the crawler
configuration. This is governed by the Hostname include/exclude filters settings in the
crawler configuration GUI.
ROBOTS
The URI was disallowed due to restrictions imposed by the robots.txt file on the web
server for its site. Additional discussion of ROBOTS issues can be found in the External
limits on fetching pages on page 19 section.
LINKTYPE
The URI was disallowed due to the type of HTML tag it was extracted from. Allowed link
types are governed by the Link extraction settings in the crawler configuration GUI.
NOFOLLOW
The URI was disallowed due to the referring document containing a HTML META robots
tag disallowing URI extraction. Additional discussion of ROBOTS issues can be found in
the External limits on fetching pages on page 19 section.
SCHEME
The URI had a disallowed scheme. Allowed schemes are specified in the Allowed
schemes setting in the crawler configuration GUI.
FWDLINK
Forwarding of non-local links are disabled. The URI was disallowed because the crawler
configuration disallows following links from one website to another. This is governed by
the Follow cross-site URIs setting in the crawler configuration GUI.
PARSEERR
Failed to parse the URI into URI components, i.e. scheme, host, path, and other elements
if specified.
LENGTH
The URI is too long to process and store.
WQMAXDOC
The maximum number of documents for the site has been reached.
WQEXISTS
Already queued on the work queue, will not queue again.
NOTNEW
In Adaptive refresh mode (only), this URI has already been queued as a previously fetched
entry.
REFRESHONLY
In Refreshing mode (only), this URI is not a previously fetched entry, and so will be ignored.
RECURSION
Maximum level of URI recursions (i.e. repeated patterns in the path element) reached.
MAXREDIRS
Maximum number of redirects reached.
Enterprise Crawler - reference information
Crawler Site Log Messages
Below is a list of log messages that may be found in the site log in the
$FASTSEARCH/var/log/crawler/site/<collection>/ directory.
Table 66: Sttaus Codes - Site log
Message
Description
STARTCRAWL <site>
The crawler will start crawling the specified site.
STOPCRAWL <site>
Crawling of the specified site stopped voluntarily. Look for associated IDLE log message
to determine cause.
STOPCRAWL SHUTDOWN
<site>
Crawling of the specified site was stopped due to the crawler being shut down.
REFRESH <site>
The specified site is refreshing.
REFRESH FORCE <site>
The specified site will be refreshed as a result of a user initiated force re-fetch operation.
REFRESHSKIPPED
NOTIDLE <site>
The specified site skipped refresh due to not yet having finished the previous refresh
cycle. This event can occur only when refresh mode soft is used.
WQERASE MAXDOC <site> The specified site has reached the maximum documents per cycle setting specified in the
Max doc limit <count> configuration. The remaining work queues have been erased.
reached, erasing work
queue
IDLE <reason> <site>
<detailed reason>
The specified site has gone idle (stopped crawling). The reason is given by <reason> and
<detailed reason>.
REPROCESS <site>
Ready for
reprocessing
The crawler has been notified to reprocess (refeed) the specified site in the crawler store.
DELSITE DELSITECMD
<site> <count> URIs
ready for deletion
from crawler store
The crawler has been notified to initiate the deletion of the specified URIs from the crawler
store.
DELURIS DELURICMD
The crawler has been notified to initiate the deletion of the specified site from the crawler
store.
<site> Ready for
deletion from crawler
store
LOGIN GET/POST <site> The crawler has initiated the form login sequence for the specified site.
Performing
Authentication
LOGGEDIN <site>
Through <login site>
The crawler has successfully logged into the specified site through <login site>.
209
FAST Enterprise Crawler
Message
Description
DELAYCHANGED
ROBOTSDELAY <site>
Set to <delay>
seconds
The robots.txt file of the current site has changed the crawl delay to <delay> seconds by
specifying the "Crawl-Delay" directive.
BLACKLIST <site>
The specified site was blacklisted for <time span> number of seconds. During this time
Blacklisted for <time no downloads will be performed for the site, but URIs will be kept on work queues. Once
expired URIs will be eligible for crawling again.
span> seconds.
A blacklist operation may have been the result of either an explicit user action (e.g.
thorough the crawleradmin tool) or an internal backoff mechanism within the crawler
itself.
210
UNBLACKLIST EXPIRED
<site>
A site previously blacklisted is no longer blacklisted, and may resume crawling if there is
available capacity.
JSENGINE DOWN <site>
Crawling paused
The Browser Engine is down and the crawler has paused crawling the site.
JSENGINE OVERLOADED
<site> Crawling
paused
All the available Browser Engines are overloaded and the crawler has stopped sending
requests to the Browser Engine. .
JSENGINE UP <site>
Crawling resumed
The Browser Engine is ready to process documents after having been down or overloaded.