The /atg/commerce/endeca/index/ProductCatalogSimpleIndexingAdmin component (of class atg.endeca.index.admin.SimpleIndexingAdmin) manages the process of generating records, submitting them to Guided Search, and invoking indexing. The page for this component in the Component Browser of the Dynamo Server Admin presents a simple user interface for controlling and monitoring the process.
The SimpleIndexingAdmin class defines indexing in terms of an indexing job, which is made of up indexing phases, which in turn contain indexing tasks. Each indexing task is responsible for executing an individual Indexable component. Tasks within a phase may run in sequence or in parallel, but in either case all tasks in a phase must complete before the next phase can begin.
By default, the ProductCatalogSimpleIndexingAdmin defines three phases:
- PreIndexing -- Runs - /atg/commerce/endeca/index/CategoryTreeService.
- RepositoryExport -- Runs these components in parallel: - /atg/commerce/endeca/index/SchemaExporter
- /atg/commerce/endeca/index/CategoryToDimensionOutputConfig
- /atg/commerce/endeca/index/RepositoryTypeDimensionExporter
- /atg/commerce/search/ProductCatalogOutputConfig
 
- EndecaIndexing -- Runs - /atg/commerce/endeca/index/EndecaScriptService, which invokes Guided Search indexing scripts.
ProductCatalogSimpleIndexingAdmin reports information about an indexing job, such as the start and finish time of the job, the duration of each phase, the status of each task, and the number of records submitted.
You can invoke indexing jobs manually through the ProductCatalogSimpleIndexingAdmin user interface. In addition, the SimpleIndexingAdmin class implements the atg.service.scheduler.Schedulable interface, so it is also possible to configure the ProductCatalogSimpleIndexingAdmin component to invoke indexing jobs automatically on a specified schedule. (See the Platform Programming Guide for information about the Schedulable interface and other Scheduler services.)
Key configuration properties of ProductCatalogSimpleIndexingAdmin include:
phaseToPrioritiesAndTasks
This property defines the phases and tasks of an indexing job, and the order in which the phases are executed. It is a comma-separated list of phases, where the format of each phase definition is:
phaseName=priority:Indexable1;Indexable2;...;IndexableN
Phases are executed in priority order, with lower number priorities executed first.
By default, this is set to:
phaseToPrioritiesAndTasks=\
PreIndexing=5:CategoryTreeService,\
RepositoryExport=10:\
SchemaExporter;\
CategoryToDimensionOutputConfig;\
RepositoryTypeDimensionExporter;\
/atg/commerce/search/ProductCatalogOutputConfig,\
EndecaIndexing=15:EndecaScriptService
runTasksWithinPhaseInParallel
A boolean that controls whether to run tasks within a phase in parallel. Set to true by default. If set to false, the tasks are executed in sequence, in the order specified in the phaseToPrioritiesAndTasks property. Setting runTasksWithinPhaseInParallel to false can simplify debugging, because when tasks are run in parallel, logging messages from multiple components may be interspersed, making them difficult to read.
enableScheduledIndexing
A boolean that controls whether to invoke indexing automatically on a specified schedule. Set to false by default.
baselineSchedule
A String that specifies the schedule for performing baseline updates. Set to null by default. If you set enableScheduledIndexing to true, set baselineSchedule to a String that conforms to one of the formats accepted by classes implementing the atg.service.scheduler.Schedule interface, such as atg.service.scheduler.CalendarSchedule or atg.service.scheduler.PeriodicSchedule. For example, to schedule a baseline update to run every Sunday at 11:30 pm:
baselineSchedule=calendar * * 7 * 23 30
partialSchedule
A String that specifies the schedule for performing partial updates. The format for the String is the same as the format used for baselineSchedule. Set to null by default.
retryInMs
The amount of time (in milliseconds) to wait before retrying a scheduled indexing job if the first attempt to execute it fails. Set by default to -1, which means no retry. If you change this value, you should set it to a relatively short amount of time to ensure that the indexing job completes before the next scheduled job begins. If ProductCatalogSimpleIndexingAdmin estimates that the retried job will not complete before the next scheduled job, it skips the retry.
jobQueue
Specifies the component that manages queueing of index jobs. Set by default to /atg/endeca/index/InMemoryJobQueue. See Queueing Indexing Jobs for more information.
indexingMessageSource
A component of class atg.endeca.index.events.IndexingMessageSource that sends a JMS message when an indexing job completes. By default, this property is null, but you can set it to the /atg/endeca/index/events/IndexingMessageSource component that is included with the Oracle Commerce Platform. This message source is preconfigured in Patch Bay.
Note, however, that there is no message sink preconfigured to listen for events sent by IndexingMessageSource. The Oracle Commerce Platform does provide an abstract class, atg.endeca.index.events.IndexingMessageSink, that you can extend to listen for indexing events. You will also need to create a component from the class you create and configure the message sink in Patch Bay.
For more information about JMS and Patch Bay, see the Oracle Commerce Platform Message System chapter in the Platform Programming Guide.

