Multithreading in
PowerShell with runspaces
1/18/2017
Drew Furgiuele
Senior DBA, IGS Energy
1/18/2017 2
About me
dfurgiuele@igsenergy.com
@pittfurg
http://www.port1433.com
http://www.genesface.com
Contact Info
I’m a Senior SQL Server DBA at
IGS Energy in Dublin, Ohio. I’ve
been using SQL Server since SQL
Server 2000 and I love it. I also
enjoy DevOps, release
management, and PowerShell.
AGENDA
1/18/2017 3
1. Multithreading in PowerShell: Why?
2. How it works
3. Differences between runspaces and Invoke-Job
4. Examples!
Multithreading with PowerShell
• Most PowerShell scripts execute serially
• Which is usually fine!
• … Except when it isn’t
• Some things don’t always run fast, despite all the
optimization in the world
• And if something runs “fast” when applied to n+1
targets, it might become slow
1/18/2017 4
Runspaces – The good
• Runspaces spin up new threads on an existing
process for parallel execution.
• Threads can be invoked asynchronously
• Can automatically manage the number of
threads executing (so you don’t overwhelm
your CPU)
• Can return pretty much anything you want
1/18/2017 5
Runspaces – The not so good
1/18/2017 6
• Can be complex to set up and configure
• Need monitored
• Need cleaned up
• Are hard to troubleshoot
• Modules don’t persist
“… so preoccupied with whether or not you could…”
• “…that you didn't stop to think if you should.”
• Multithreading is a great tool to keep in your
toolbox, but it’s not a hammer looking for a nail
• Ever heard of failing at scale?
• How about failing at scalex?
1/18/2017 7
Creating Runspaces
• CODE!
1/18/2017 8
What about Start-Job / Receive-Job?
• Start-Job incurs a lot of overhead
• No throttling
• Same goes for –AsJob and Invoke-Command
• Does have a –ThrottleLimit, but that just limits
concurrent commands, NOT sessions
• How much of a difference? Let’s see it in action.
1/18/2017 9
Practical Example #1
• Reading Error Logs
• Text parsing in PowerShell is an expensive, slow
process
• Breaking up the workload into threads can vastly
improve performance
1/18/2017 10
Practical Example
• Master Data Management
1/18/2017 11
Learning More
• Runspaces – Hey Scripting Guy!
https://blogs.technet.microsoft.com/heyscriptingguy/
2015/11/26/beginning-use-of-powershell-runspaces-
part-1/
• Runspaces simplified as much as possible:
https://blog.netnerds.net/2016/12/runspaces-
simplified/
• Joe Prox’s PoshRSJob:
https://github.com/proxb/PoshRSJob
1/18/2017 12
1/18/2017 13
About me
dfurgiuele@igsenergy.com
@pittfurg
http://www.port1433.com
http://www.genesface.com
Contact Info
I’m a Senior SQL Server DBA at
IGS Energy in Dublin, Ohio. I’ve
been using SQL Server since SQL
Server 2000 and I love it. I also
enjoy DevOps, release
management, and PowerShell.

More Related Content

PPTX
Full stack development using javascript what and why - ajay chandravadiya
PDF
Creating Hyper Performant Web Apps with React
PPTX
Saving Time By Testing With Jest
PDF
Seven Jobs You Should Be Running #sqlsat126
PDF
Composer manager module for Drupal
PPTX
SQL Server Days 2014 - How to (not) torment your fellow SSIS developer
PPTX
The Five Stages of Chef Grief: My First 6 months with Chef, and Getting Aroun...
PPTX
Tech writing in a continuous deployment environment
Full stack development using javascript what and why - ajay chandravadiya
Creating Hyper Performant Web Apps with React
Saving Time By Testing With Jest
Seven Jobs You Should Be Running #sqlsat126
Composer manager module for Drupal
SQL Server Days 2014 - How to (not) torment your fellow SSIS developer
The Five Stages of Chef Grief: My First 6 months with Chef, and Getting Aroun...
Tech writing in a continuous deployment environment

What's hot (20)

PDF
ClojureScript: I can't believe this is JavaScript
PDF
Why puppet? Why now?
PDF
New Server in an Hour
PDF
An introduction in to the world of front end automation - frontend ne (02 07-15)
PPTX
Introduction to Coffeescript
PDF
Kanban @ nine.ch
PDF
Performance - When, What and How
PDF
GETTING STARTED WITH JavaScript and ReactJS
PDF
DevOps for Drupal: Why We Cook With Chef
PPT
Coffee script final
PPTX
Raven db byexample
PPTX
Zeev Suraski "The PHP 7 Story, and beyond"
PDF
No More Cowboy Coding: Modern WordPress Development Workflow That Scales
PPTX
Coding for the cloud - development of modern web applications
PDF
It Sounded Good on Paper - Lessons Learned with Puppet
PPT
Developer Week
PDF
Supporting large scale React applications
PPTX
Building large scalable mission critical business applications on the web
PDF
Getting started with dev tools (atl)
PDF
Devops at Startup Weekend BXL
ClojureScript: I can't believe this is JavaScript
Why puppet? Why now?
New Server in an Hour
An introduction in to the world of front end automation - frontend ne (02 07-15)
Introduction to Coffeescript
Kanban @ nine.ch
Performance - When, What and How
GETTING STARTED WITH JavaScript and ReactJS
DevOps for Drupal: Why We Cook With Chef
Coffee script final
Raven db byexample
Zeev Suraski "The PHP 7 Story, and beyond"
No More Cowboy Coding: Modern WordPress Development Workflow That Scales
Coding for the cloud - development of modern web applications
It Sounded Good on Paper - Lessons Learned with Puppet
Developer Week
Supporting large scale React applications
Building large scalable mission critical business applications on the web
Getting started with dev tools (atl)
Devops at Startup Weekend BXL
Ad

Similar to PowerShell Runspaces (6)

PPTX
09 automation in scale - remoting
PPTX
Wsv406 Advanced Automation Using Windows Power Shell2.0
PPT
PowerShell Remoting
PPTX
Managing enterprise with PowerShell remoting
PPTX
PowerShell 3.0 workflows
PPTX
Intro to PowerShell Workflow
09 automation in scale - remoting
Wsv406 Advanced Automation Using Windows Power Shell2.0
PowerShell Remoting
Managing enterprise with PowerShell remoting
PowerShell 3.0 workflows
Intro to PowerShell Workflow
Ad

Recently uploaded (20)

PDF
sustainability-14-14877-v2.pddhzftheheeeee
PDF
1 - Historical Antecedents, Social Consideration.pdf
PPTX
MicrosoftCybserSecurityReferenceArchitecture-April-2025.pptx
PDF
Architecture types and enterprise applications.pdf
PDF
Convolutional neural network based encoder-decoder for efficient real-time ob...
PDF
“A New Era of 3D Sensing: Transforming Industries and Creating Opportunities,...
PDF
Taming the Chaos: How to Turn Unstructured Data into Decisions
PPTX
Build Your First AI Agent with UiPath.pptx
PDF
Developing a website for English-speaking practice to English as a foreign la...
PPTX
Microsoft Excel 365/2024 Beginner's training
PDF
UiPath Agentic Automation session 1: RPA to Agents
PDF
The influence of sentiment analysis in enhancing early warning system model f...
PDF
ENT215_Completing-a-large-scale-migration-and-modernization-with-AWS.pdf
PPTX
GROUP4NURSINGINFORMATICSREPORT-2 PRESENTATION
PPT
Geologic Time for studying geology for geologist
PPTX
Modernising the Digital Integration Hub
PPTX
TEXTILE technology diploma scope and career opportunities
PPTX
The various Industrial Revolutions .pptx
PDF
A proposed approach for plagiarism detection in Myanmar Unicode text
PPT
Galois Field Theory of Risk: A Perspective, Protocol, and Mathematical Backgr...
sustainability-14-14877-v2.pddhzftheheeeee
1 - Historical Antecedents, Social Consideration.pdf
MicrosoftCybserSecurityReferenceArchitecture-April-2025.pptx
Architecture types and enterprise applications.pdf
Convolutional neural network based encoder-decoder for efficient real-time ob...
“A New Era of 3D Sensing: Transforming Industries and Creating Opportunities,...
Taming the Chaos: How to Turn Unstructured Data into Decisions
Build Your First AI Agent with UiPath.pptx
Developing a website for English-speaking practice to English as a foreign la...
Microsoft Excel 365/2024 Beginner's training
UiPath Agentic Automation session 1: RPA to Agents
The influence of sentiment analysis in enhancing early warning system model f...
ENT215_Completing-a-large-scale-migration-and-modernization-with-AWS.pdf
GROUP4NURSINGINFORMATICSREPORT-2 PRESENTATION
Geologic Time for studying geology for geologist
Modernising the Digital Integration Hub
TEXTILE technology diploma scope and career opportunities
The various Industrial Revolutions .pptx
A proposed approach for plagiarism detection in Myanmar Unicode text
Galois Field Theory of Risk: A Perspective, Protocol, and Mathematical Backgr...

PowerShell Runspaces