<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="en">
	<id>https://wiki.grooper.com/index.php?action=history&amp;feed=atom&amp;title=Talk%3AThread_Processing_Guidance</id>
	<title>Talk:Thread Processing Guidance - Revision history</title>
	<link rel="self" type="application/atom+xml" href="https://wiki.grooper.com/index.php?action=history&amp;feed=atom&amp;title=Talk%3AThread_Processing_Guidance"/>
	<link rel="alternate" type="text/html" href="https://wiki.grooper.com/index.php?title=Talk:Thread_Processing_Guidance&amp;action=history"/>
	<updated>2026-04-30T10:20:53Z</updated>
	<subtitle>Revision history for this page on the wiki</subtitle>
	<generator>MediaWiki 1.42.3</generator>
	<entry>
		<id>https://wiki.grooper.com/index.php?title=Talk:Thread_Processing_Guidance&amp;diff=32385&amp;oldid=prev</id>
		<title>Dgreenwood: /* 2026-02-06 DGreenwood */</title>
		<link rel="alternate" type="text/html" href="https://wiki.grooper.com/index.php?title=Talk:Thread_Processing_Guidance&amp;diff=32385&amp;oldid=prev"/>
		<updated>2026-02-06T15:40:43Z</updated>

		<summary type="html">&lt;p&gt;&lt;span dir=&quot;auto&quot;&gt;&lt;span class=&quot;autocomment&quot;&gt;2026-02-06 DGreenwood&lt;/span&gt;&lt;/span&gt;&lt;/p&gt;
&lt;table style=&quot;background-color: #fff; color: #202122;&quot; data-mw=&quot;interface&quot;&gt;
				&lt;col class=&quot;diff-marker&quot; /&gt;
				&lt;col class=&quot;diff-content&quot; /&gt;
				&lt;col class=&quot;diff-marker&quot; /&gt;
				&lt;col class=&quot;diff-content&quot; /&gt;
				&lt;tr class=&quot;diff-title&quot; lang=&quot;en&quot;&gt;
				&lt;td colspan=&quot;2&quot; style=&quot;background-color: #fff; color: #202122; text-align: center;&quot;&gt;← Older revision&lt;/td&gt;
				&lt;td colspan=&quot;2&quot; style=&quot;background-color: #fff; color: #202122; text-align: center;&quot;&gt;Revision as of 10:40, 6 February 2026&lt;/td&gt;
				&lt;/tr&gt;&lt;tr&gt;&lt;td colspan=&quot;2&quot; class=&quot;diff-lineno&quot; id=&quot;mw-diff-left-l1&quot;&gt;Line 1:&lt;/td&gt;
&lt;td colspan=&quot;2&quot; class=&quot;diff-lineno&quot;&gt;Line 1:&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;== 2026-02-06 DGreenwood ==&lt;/div&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;== 2026-02-06 DGreenwood ==&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;br&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;br&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&quot;diff-marker&quot; data-marker=&quot;−&quot;&gt;&lt;/td&gt;&lt;td style=&quot;color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #ffe49c; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;Consider an alternative tone&lt;/div&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot; data-marker=&quot;+&quot;&gt;&lt;/td&gt;&lt;td style=&quot;color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;Consider an alternative tone&lt;ins style=&quot;font-weight: bold; text-decoration: none;&quot;&gt;. Alternative is commented out here. Edit to view.&lt;/ins&gt;&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;br&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;br&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td colspan=&quot;2&quot; class=&quot;diff-side-deleted&quot;&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot; data-marker=&quot;+&quot;&gt;&lt;/td&gt;&lt;td style=&quot;color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #a3d3ff; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;&lt;ins style=&quot;font-weight: bold; text-decoration: none;&quot;&gt;&amp;lt;!---&lt;/ins&gt;&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;Grooper [[Activity Processing]] services are responsible for distributing processing resources to automated tasks within a Batch Process. This article describes how threads are used by Grooper and provides recommended best practices for thread allocation and service configuration.&lt;/div&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;div&gt;Grooper [[Activity Processing]] services are responsible for distributing processing resources to automated tasks within a Batch Process. This article describes how threads are used by Grooper and provides recommended best practices for thread allocation and service configuration.&lt;/div&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;tr&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;br&gt;&lt;/td&gt;&lt;td class=&quot;diff-marker&quot;&gt;&lt;/td&gt;&lt;td style=&quot;background-color: #f8f9fa; color: #202122; font-size: 88%; border-style: solid; border-width: 1px 1px 1px 4px; border-radius: 0.33em; border-color: #eaecf0; vertical-align: top; white-space: pre-wrap;&quot;&gt;&lt;br&gt;&lt;/td&gt;&lt;/tr&gt;
&lt;/table&gt;</summary>
		<author><name>Dgreenwood</name></author>
	</entry>
	<entry>
		<id>https://wiki.grooper.com/index.php?title=Talk:Thread_Processing_Guidance&amp;diff=32384&amp;oldid=prev</id>
		<title>Dgreenwood: Created page with &quot;== 2026-02-06 DGreenwood ==  Consider an alternative tone  Grooper Activity Processing services are responsible for distributing processing resources to automated tasks within a Batch Process. This article describes how threads are used by Grooper and provides recommended best practices for thread allocation and service configuration.  === What is a thread? ===  A &#039;&#039;&#039;thread&#039;&#039;&#039; is the smallest unit of execution managed by an operating system. Threads represent individ...&quot;</title>
		<link rel="alternate" type="text/html" href="https://wiki.grooper.com/index.php?title=Talk:Thread_Processing_Guidance&amp;diff=32384&amp;oldid=prev"/>
		<updated>2026-02-06T15:40:04Z</updated>

		<summary type="html">&lt;p&gt;Created page with &amp;quot;== 2026-02-06 DGreenwood ==  Consider an alternative tone  Grooper &lt;a href=&quot;/index.php?title=Activity_Processing&quot; class=&quot;mw-redirect&quot; title=&quot;Activity Processing&quot;&gt;Activity Processing&lt;/a&gt; services are responsible for distributing processing resources to automated tasks within a Batch Process. This article describes how threads are used by Grooper and provides recommended best practices for thread allocation and service configuration.  === What is a thread? ===  A &amp;#039;&amp;#039;&amp;#039;thread&amp;#039;&amp;#039;&amp;#039; is the smallest unit of execution managed by an operating system. Threads represent individ...&amp;quot;&lt;/p&gt;
&lt;p&gt;&lt;b&gt;New page&lt;/b&gt;&lt;/p&gt;&lt;div&gt;== 2026-02-06 DGreenwood ==&lt;br /&gt;
&lt;br /&gt;
Consider an alternative tone&lt;br /&gt;
&lt;br /&gt;
Grooper [[Activity Processing]] services are responsible for distributing processing resources to automated tasks within a Batch Process. This article describes how threads are used by Grooper and provides recommended best practices for thread allocation and service configuration.&lt;br /&gt;
&lt;br /&gt;
=== What is a thread? ===&lt;br /&gt;
&lt;br /&gt;
A &amp;#039;&amp;#039;&amp;#039;thread&amp;#039;&amp;#039;&amp;#039; is the smallest unit of execution managed by an operating system. Threads represent individual execution paths that allow work to be performed concurrently within an application.&lt;br /&gt;
&lt;br /&gt;
* Threads are the execution units used by software to perform work.&lt;br /&gt;
* Performance cores typically support &amp;#039;&amp;#039;&amp;#039;two threads per core&amp;#039;&amp;#039;&amp;#039;.&lt;br /&gt;
* Efficiency cores typically support &amp;#039;&amp;#039;&amp;#039;one thread per core&amp;#039;&amp;#039;&amp;#039;.&lt;br /&gt;
&lt;br /&gt;
=== Determining the number of available threads ===&lt;br /&gt;
&lt;br /&gt;
The number of threads available on a system depends on the CPU architecture and whether the system is physical or virtual.&lt;br /&gt;
&lt;br /&gt;
&amp;#039;&amp;#039;&amp;#039;Physical machines&amp;#039;&amp;#039;&amp;#039;&lt;br /&gt;
* Open Windows &amp;#039;&amp;#039;&amp;#039;Task Manager&amp;#039;&amp;#039;&amp;#039;.&lt;br /&gt;
* Navigate to &amp;#039;&amp;#039;&amp;#039;Performance&amp;#039;&amp;#039;&amp;#039; → &amp;#039;&amp;#039;&amp;#039;CPU&amp;#039;&amp;#039;&amp;#039;.&lt;br /&gt;
* Threads are displayed as &amp;#039;&amp;#039;&amp;#039;Logical processors&amp;#039;&amp;#039;&amp;#039;.&lt;br /&gt;
&lt;br /&gt;
&amp;#039;&amp;#039;&amp;#039;Virtual machines&amp;#039;&amp;#039;&amp;#039;&lt;br /&gt;
* Open Windows &amp;#039;&amp;#039;&amp;#039;Task Manager&amp;#039;&amp;#039;&amp;#039;.&lt;br /&gt;
* Navigate to &amp;#039;&amp;#039;&amp;#039;Performance&amp;#039;&amp;#039;&amp;#039; → &amp;#039;&amp;#039;&amp;#039;CPU&amp;#039;&amp;#039;&amp;#039;.&lt;br /&gt;
* Threads are displayed as &amp;#039;&amp;#039;&amp;#039;Virtual processors&amp;#039;&amp;#039;&amp;#039;.&lt;br /&gt;
&lt;br /&gt;
=== How Grooper utilizes threads ===&lt;br /&gt;
&lt;br /&gt;
&amp;#039;&amp;#039;&amp;#039;Activity Processing&amp;#039;&amp;#039;&amp;#039;&lt;br /&gt;
&lt;br /&gt;
Threads are primarily consumed by [[Activity Processing]] services to execute Activity tasks in a Batch Process.&lt;br /&gt;
&lt;br /&gt;
* Each Activity Processing service has a configurable &amp;#039;&amp;#039;&amp;#039;Number of Threads&amp;#039;&amp;#039;&amp;#039; setting that defines its maximum concurrent execution capacity.&lt;br /&gt;
* Multiple Activity Processing services may be installed on a single machine.&lt;br /&gt;
* Activity Processing services may also be installed on multiple machines connected to the same Grooper Repository to distribute processing workloads across servers.&lt;br /&gt;
&lt;br /&gt;
&amp;#039;&amp;#039;&amp;#039;Web application&amp;#039;&amp;#039;&amp;#039;&lt;br /&gt;
&lt;br /&gt;
Threads are also used by the Grooper Application Pool on the Grooper Web Server to service user interactions with the Grooper Web Application.&lt;br /&gt;
&lt;br /&gt;
=== Activity Processing service sizing considerations ===&lt;br /&gt;
&lt;br /&gt;
For most workloads, distributing available threads across multiple Activity Processing services provides better throughput and stability than allocating a large number of threads to a single service.&lt;br /&gt;
&lt;br /&gt;
* A common and effective configuration is &amp;#039;&amp;#039;&amp;#039;3–4 threads per Activity Processing service&amp;#039;&amp;#039;&amp;#039;.&lt;br /&gt;
* Example: On a processing server with 50 available threads, overall throughput is typically higher when running &amp;#039;&amp;#039;&amp;#039;16 Activity Processing services configured with 3 threads each&amp;#039;&amp;#039;&amp;#039; than when running &amp;#039;&amp;#039;&amp;#039;a single service configured with all 50 threads&amp;#039;&amp;#039;&amp;#039;.&lt;br /&gt;
&lt;br /&gt;
=== Use of Processing Queues ===&lt;br /&gt;
&lt;br /&gt;
Processing Queues control how threads are assigned to specific steps within a Batch Process and help prevent resource contention.&lt;br /&gt;
&lt;br /&gt;
* Processing Queues are associated with both Batch Process Steps and Activity Processing services.&lt;br /&gt;
** Batch Process Steps reference a Processing Queue using the &amp;#039;&amp;#039;&amp;#039;Queue Name&amp;#039;&amp;#039;&amp;#039; property.&lt;br /&gt;
** Activity Processing services bind to Processing Queues using the &amp;#039;&amp;#039;&amp;#039;Queue Name&amp;#039;&amp;#039;&amp;#039; property.&lt;br /&gt;
* Processing Queues should be used to isolate resource-intensive or long-running Activity tasks.&lt;br /&gt;
* Without Processing Queues, long-running tasks may occupy all available threads, causing other Batch Process Steps to remain idle.&lt;br /&gt;
&lt;br /&gt;
*Example:*  &lt;br /&gt;
The &amp;#039;&amp;#039;&amp;#039;Recognize&amp;#039;&amp;#039;&amp;#039; step commonly requires more processing time due to OCR operations. If all threads are consumed by Recognize tasks, subsequent steps will not begin processing until those threads become available.&lt;/div&gt;</summary>
		<author><name>Dgreenwood</name></author>
	</entry>
</feed>