Class: Concurrent::RubySingleThreadExecutor
Relationships & Source Files | |
Super Chains via Extension / Inclusion / Inheritance | |
Class Chain:
|
|
Instance Chain:
|
|
Inherits: |
Concurrent::RubyThreadPoolExecutor
|
Defined in: | lib/concurrent-ruby/concurrent/executor/ruby_single_thread_executor.rb |
Overview
A thread pool with a single thread an unlimited queue. Should the thread die for any reason it will be removed and replaced, thus ensuring that the executor will always remain viable and available to process jobs.
A common pattern for background processing is to create a single thread on which an infinite loop is run. The thread’s loop blocks on an input source (perhaps blocking I/O or a queue) and processes each input as it is received. This pattern has several issues. The thread itself is highly susceptible to errors during processing. Also, the thread itself must be constantly monitored and restarted should it die. SingleThreadExecutor
encapsulates all these behaviors. The task processor is highly resilient to errors from within tasks. Also, should the thread die it will automatically be restarted.
The API and behavior of this class are based on Java’s SingleThreadExecutor
.
Constant Summary
Concern::Logging
- Included
AbstractExecutorService
- Inherited
RubyThreadPoolExecutor
- Inherited
DEFAULT_MAX_POOL_SIZE, DEFAULT_MAX_QUEUE_SIZE, DEFAULT_MIN_POOL_SIZE, DEFAULT_SYNCHRONOUS, DEFAULT_THREAD_IDLETIMEOUT
Class Method Summary
-
.new(opts = {}) ⇒ RubySingleThreadExecutor
constructor
Create a new thread pool.
RubyThreadPoolExecutor
- Inherited
.new | Create a new thread pool. |
RubyExecutorService
- Inherited
AbstractExecutorService
- Inherited
.new | Create a new thread pool. |
Instance Attribute Summary
- #fallback_policy ⇒ Symbol readonly
RubyThreadPoolExecutor
- Inherited
#can_overflow? | Does the task queue have a maximum size? |
#idletime | The number of seconds that a thread may be idle before being reclaimed. |
#max_length | The maximum number of threads that may be created in the pool. |
#max_queue | The maximum number of tasks that may be waiting in the work queue at any one time. |
#min_length | The minimum number of threads that may be retained in the pool. |
#synchronous | Whether or not a value of 0 for |
#ns_limited_queue? |
RubyExecutorService
- Inherited
AbstractExecutorService
- Inherited
#auto_terminate= |
|
#auto_terminate? | Is the executor auto-terminate when the application exits? |
#fallback_policy, #name, | |
#running? | Is the executor running? |
#shutdown | Begin an orderly shutdown. |
#shutdown? | Is the executor shutdown? |
#shuttingdown? | Is the executor shuttingdown? |
#ns_auto_terminate? |
ExecutorService
- Included
#can_overflow? | Does the task queue have a maximum size? |
#serialized? | Does this executor guarantee serialization of its operations? |
Instance Method Summary
-
#<<(task) ⇒ self
Submit a task to the executor for asynchronous processing.
-
#auto_terminate=(value) ⇒ Boolean
deprecated
Deprecated.
Has no effect
-
#auto_terminate? ⇒ Boolean
Is the executor auto-terminate when the application exits?
-
#can_overflow? ⇒ Boolean
Does the task queue have a maximum size?
-
#kill
Begin an immediate shutdown.
-
#post(*args) { ... } ⇒ Boolean
Submit a task to the executor for asynchronous processing.
-
#running? ⇒ Boolean
Is the executor running?
-
#serialized? ⇒ Boolean
Does this executor guarantee serialization of its operations?
-
#shutdown
Begin an orderly shutdown.
-
#shutdown? ⇒ Boolean
Is the executor shutdown?
-
#shuttingdown? ⇒ Boolean
Is the executor shuttingdown?
-
#wait_for_termination(timeout = nil) ⇒ Boolean
Block until executor shutdown is complete or until
timeout
seconds have passed.
RubyThreadPoolExecutor
- Inherited
#active_count | The number of threads that are actively executing tasks. |
#completed_task_count | The number of tasks that have been completed by the pool since construction. |
#largest_length | The largest number of threads that have been created in the pool since construction. |
#length | The number of threads currently in the pool. |
#prune_pool | Prune the thread pool of unneeded threads. |
#queue_length | The number of tasks in the queue awaiting execution. |
#remaining_capacity | Number of tasks that may be enqueued before reaching |
#scheduled_task_count | The number of tasks that have been scheduled for execution on the pool since construction. |
#ns_add_busy_worker | creates new worker which has to receive work to do after it’s added. |
#ns_assign_worker | tries to assign task to a worker, tries to get one from @ready or to create new one. |
#ns_enqueue | tries to enqueue task. |
#ns_execute, #ns_initialize, #ns_kill_execution, | |
#ns_prune_pool | try oldest worker if it is idle for enough time, it’s returned back at the start. |
#ns_ready_worker | handle ready worker, giving it new job or assigning back to @ready. |
#ns_remove_busy_worker | removes a worker which is not in not tracked in @ready. |
#ns_reset_if_forked, #ns_shutdown_execution, #ns_worker_died, #ready_worker, #remove_busy_worker, #worker_died, #worker_task_completed |
RubyExecutorService
- Inherited
#<< | Submit a task to the executor for asynchronous processing. |
#auto_terminate= |
|
#auto_terminate? | Is the executor auto-terminate when the application exits? |
#can_overflow? | Does the task queue have a maximum size? |
#kill | Begin an immediate shutdown. |
#post | Submit a task to the executor for asynchronous processing. |
#running? | Is the executor running? |
#serialized? | Does this executor guarantee serialization of its operations? |
#shutdown | Begin an orderly shutdown. |
#shutdown? | Is the executor shutdown? |
#shuttingdown? | Is the executor shuttingdown? |
#wait_for_termination | Block until executor shutdown is complete or until |
#ns_shutdown_execution, #stop_event, #stopped_event |
AbstractExecutorService
- Inherited
#<< | Submit a task to the executor for asynchronous processing. |
#can_overflow? | Does the task queue have a maximum size? |
#kill | Begin an immediate shutdown. |
#post | Submit a task to the executor for asynchronous processing. |
#serialized? | Does this executor guarantee serialization of its operations? |
#to_s, | |
#wait_for_termination | Block until executor shutdown is complete or until |
#fallback_action | Returns an action which executes the #fallback_policy once the queue size reaches |
#ns_execute, | |
#ns_kill_execution | Callback method called when the executor has been killed. |
#ns_shutdown_execution | Callback method called when an orderly shutdown has completed. |
Concern::Deprecation
- Included
ExecutorService
- Included
#<< | Submit a task to the executor for asynchronous processing. |
#post | Submit a task to the executor for asynchronous processing. |
Concern::Logging
- Included
#log | Logs through global_logger, it can be overridden by setting @logger. |
Synchronization::LockableObject
- Inherited
Constructor Details
.new(opts = {}) ⇒ RubySingleThreadExecutor
Create a new thread pool.
# File 'lib/concurrent-ruby/concurrent/executor/ruby_single_thread_executor.rb', line 11
def initialize(opts = {}) super( min_threads: 1, max_threads: 1, max_queue: 0, idletime: DEFAULT_THREAD_IDLETIMEOUT, fallback_policy: opts.fetch(:fallback_policy, :discard), ) end
Instance Attribute Details
#fallback_policy ⇒ Symbol
(readonly)
# File 'lib/concurrent-ruby/concurrent/executor/ruby_single_thread_executor.rb', line 8
class RubySingleThreadExecutor < RubyThreadPoolExecutor # @!macro single_thread_executor_method_initialize def initialize(opts = {}) super( min_threads: 1, max_threads: 1, max_queue: 0, idletime: DEFAULT_THREAD_IDLETIMEOUT, fallback_policy: opts.fetch(:fallback_policy, :discard), ) end end
Instance Method Details
#<<(task) ⇒ self
Submit a task to the executor for asynchronous processing.
# File 'lib/concurrent-ruby/concurrent/executor/ruby_single_thread_executor.rb', line 8
class RubySingleThreadExecutor < RubyThreadPoolExecutor # @!macro single_thread_executor_method_initialize def initialize(opts = {}) super( min_threads: 1, max_threads: 1, max_queue: 0, idletime: DEFAULT_THREAD_IDLETIMEOUT, fallback_policy: opts.fetch(:fallback_policy, :discard), ) end end
#auto_terminate=(value) ⇒ Boolean
Has no effect
Set
the auto-terminate behavior for this executor.
# File 'lib/concurrent-ruby/concurrent/executor/ruby_single_thread_executor.rb', line 8
class RubySingleThreadExecutor < RubyThreadPoolExecutor # @!macro single_thread_executor_method_initialize def initialize(opts = {}) super( min_threads: 1, max_threads: 1, max_queue: 0, idletime: DEFAULT_THREAD_IDLETIMEOUT, fallback_policy: opts.fetch(:fallback_policy, :discard), ) end end
#auto_terminate? ⇒ Boolean
Is the executor auto-terminate when the application exits?
# File 'lib/concurrent-ruby/concurrent/executor/ruby_single_thread_executor.rb', line 8
class RubySingleThreadExecutor < RubyThreadPoolExecutor # @!macro single_thread_executor_method_initialize def initialize(opts = {}) super( min_threads: 1, max_threads: 1, max_queue: 0, idletime: DEFAULT_THREAD_IDLETIMEOUT, fallback_policy: opts.fetch(:fallback_policy, :discard), ) end end
#can_overflow? ⇒ Boolean
Does the task queue have a maximum size?
# File 'lib/concurrent-ruby/concurrent/executor/ruby_single_thread_executor.rb', line 8
class RubySingleThreadExecutor < RubyThreadPoolExecutor # @!macro single_thread_executor_method_initialize def initialize(opts = {}) super( min_threads: 1, max_threads: 1, max_queue: 0, idletime: DEFAULT_THREAD_IDLETIMEOUT, fallback_policy: opts.fetch(:fallback_policy, :discard), ) end end
#kill
Begin an immediate shutdown. In-progress tasks will be allowed to complete but enqueued tasks will be dismissed and no new tasks will be accepted. Has no additional effect if the thread pool is not running.
# File 'lib/concurrent-ruby/concurrent/executor/ruby_single_thread_executor.rb', line 8
class RubySingleThreadExecutor < RubyThreadPoolExecutor # @!macro single_thread_executor_method_initialize def initialize(opts = {}) super( min_threads: 1, max_threads: 1, max_queue: 0, idletime: DEFAULT_THREAD_IDLETIMEOUT, fallback_policy: opts.fetch(:fallback_policy, :discard), ) end end
#post(*args) { ... } ⇒ Boolean
Submit a task to the executor for asynchronous processing.
# File 'lib/concurrent-ruby/concurrent/executor/ruby_single_thread_executor.rb', line 8
class RubySingleThreadExecutor < RubyThreadPoolExecutor # @!macro single_thread_executor_method_initialize def initialize(opts = {}) super( min_threads: 1, max_threads: 1, max_queue: 0, idletime: DEFAULT_THREAD_IDLETIMEOUT, fallback_policy: opts.fetch(:fallback_policy, :discard), ) end end
#running? ⇒ Boolean
Is the executor running?
# File 'lib/concurrent-ruby/concurrent/executor/ruby_single_thread_executor.rb', line 8
class RubySingleThreadExecutor < RubyThreadPoolExecutor # @!macro single_thread_executor_method_initialize def initialize(opts = {}) super( min_threads: 1, max_threads: 1, max_queue: 0, idletime: DEFAULT_THREAD_IDLETIMEOUT, fallback_policy: opts.fetch(:fallback_policy, :discard), ) end end
#serialized? ⇒ Boolean
Does this executor guarantee serialization of its operations?
# File 'lib/concurrent-ruby/concurrent/executor/ruby_single_thread_executor.rb', line 8
class RubySingleThreadExecutor < RubyThreadPoolExecutor # @!macro single_thread_executor_method_initialize def initialize(opts = {}) super( min_threads: 1, max_threads: 1, max_queue: 0, idletime: DEFAULT_THREAD_IDLETIMEOUT, fallback_policy: opts.fetch(:fallback_policy, :discard), ) end end
#shutdown
Begin an orderly shutdown. Tasks already in the queue will be executed, but no new tasks will be accepted. Has no additional effect if the thread pool is not running.
# File 'lib/concurrent-ruby/concurrent/executor/ruby_single_thread_executor.rb', line 8
class RubySingleThreadExecutor < RubyThreadPoolExecutor # @!macro single_thread_executor_method_initialize def initialize(opts = {}) super( min_threads: 1, max_threads: 1, max_queue: 0, idletime: DEFAULT_THREAD_IDLETIMEOUT, fallback_policy: opts.fetch(:fallback_policy, :discard), ) end end
#shutdown? ⇒ Boolean
Is the executor shutdown?
# File 'lib/concurrent-ruby/concurrent/executor/ruby_single_thread_executor.rb', line 8
class RubySingleThreadExecutor < RubyThreadPoolExecutor # @!macro single_thread_executor_method_initialize def initialize(opts = {}) super( min_threads: 1, max_threads: 1, max_queue: 0, idletime: DEFAULT_THREAD_IDLETIMEOUT, fallback_policy: opts.fetch(:fallback_policy, :discard), ) end end
#shuttingdown? ⇒ Boolean
Is the executor shuttingdown?
# File 'lib/concurrent-ruby/concurrent/executor/ruby_single_thread_executor.rb', line 8
class RubySingleThreadExecutor < RubyThreadPoolExecutor # @!macro single_thread_executor_method_initialize def initialize(opts = {}) super( min_threads: 1, max_threads: 1, max_queue: 0, idletime: DEFAULT_THREAD_IDLETIMEOUT, fallback_policy: opts.fetch(:fallback_policy, :discard), ) end end
#wait_for_termination(timeout = nil) ⇒ Boolean
# File 'lib/concurrent-ruby/concurrent/executor/ruby_single_thread_executor.rb', line 8
class RubySingleThreadExecutor < RubyThreadPoolExecutor # @!macro single_thread_executor_method_initialize def initialize(opts = {}) super( min_threads: 1, max_threads: 1, max_queue: 0, idletime: DEFAULT_THREAD_IDLETIMEOUT, fallback_policy: opts.fetch(:fallback_policy, :discard), ) end end