Many developers rely on multiple terminal windows for managing various development tasks. Think npm run start
, Docker containers, Rails servers, and Webpack – all running concurrently. This isn't inherently bad, but it can be cumbersome. Remembering commands and arranging the terminal environment efficiently can be a challenge. Personally, I prefer split panes over tabs, though tabs work fine for separate projects.
Seeking solutions on Twitter yielded several options:
-
tmux: This was the most popular suggestion. It creates virtual panes within a single terminal session, allowing simultaneous execution of different commands. Its versatility is impressive, and its use in a new dev environment by my CodePen co-founder further validated its capabilities.
tmuxinator
offers improved configuration management for tmux. -
kitty: Described by one user as a more advanced tmux alternative, kitty supports custom layouts and startup commands.
-
Native Terminal Apps: Each operating system offers native solutions:
- macOS: iTerm2 excels at split panels and session management, though lacks built-in command triggering for pre-defined layouts. The default macOS Terminal also supports tabs and splitting, but feels less robust.
- Linux: Terminator is a popular choice.
- Windows: The default Windows Terminal provides pane support.
-
npm Task Runners: Tools like
concurrently
andnpm-run-all
streamline running multiple npm scripts. However, they're limited to npm scripts and don't inherently support separate pane output, making them better suited for short-running tasks. While you could create npm scripts for other commands, the output management remains a limitation.
As a macOS user, I focused on iTerm2 solutions. While lacking built-in command-triggered layouts, iTerm2's scriptability proved useful. While AppleScript support is being phased out in favor of Python, AppleScript currently works well.
Here's an AppleScript example:
iTerm2 AppleScript
tell application "iTerm" tell current window create window with default profile tell current session of current tab set name to "run.sh" write text "cd '/Users/chriscoyier/GitHub/CPOR'" write text "./run.sh" end tell create tab with default profile tell current session of current tab set name to "Rails" write text "cd '/Users/chriscoyier/GitHub/CPOR'" write text "nvm use" write text "yarn" write text "bundle install" write text "yarn run rails" end tell create tab with default profile tell current session of current tab set name to "webpack" write text "cd '/Users/chriscoyier/GitHub/CPOR'" write text "nvm use" write text "yarn" write text "yarn run dev" end tell (* split vertically - requires further investigation *) (* tell application "System Events" to keystroke "d" using command down *) (* delay 1 *) (* split horizontally - requires further investigation *) (* tell application "System Events" to keystroke "d" using {shift down, command down} *) (* delay 1 *) (* moving panes - requires permission *) (* tell application "System Events" to keystroke "]" using command down *) end tell end tell
This script successfully launches the desired processes in separate tabs. The commented-out sections represent attempts at programmatic pane splitting, which require further exploration. The reliance on keystrokes feels less elegant, and investigating Python-based scripting for more direct control is a future goal. The lack of easy compilation into a standalone app is also noteworthy.
Another macOS option is Alfred, a powerful workflow automation tool capable of managing complex terminal setups.
The above is the detailed content of One Action, Multiple Terminal Windows Running Stuff. For more information, please follow other related articles on the PHP Chinese website!

Yes,youshouldlearnbothFlexboxandGrid.1)Flexboxisidealforone-dimensional,flexiblelayoutslikenavigationmenus.2)Gridexcelsintwo-dimensional,complexdesignssuchasmagazinelayouts.3)Combiningbothenhanceslayoutflexibilityandresponsiveness,allowingforstructur

What does it look like to refactor your own code? John Rhea picks apart an old CSS animation he wrote and walks through the thought process of optimizing it.

CSSanimationsarenotinherentlyhardbutrequirepracticeandunderstandingofCSSpropertiesandtimingfunctions.1)Startwithsimpleanimationslikescalingabuttononhoverusingkeyframes.2)Useeasingfunctionslikecubic-bezierfornaturaleffects,suchasabounceanimation.3)For

@keyframesispopularduetoitsversatilityandpowerincreatingsmoothCSSanimations.Keytricksinclude:1)Definingsmoothtransitionsbetweenstates,2)Animatingmultiplepropertiessimultaneously,3)Usingvendorprefixesforbrowsercompatibility,4)CombiningwithJavaScriptfo

CSSCountersareusedtomanageautomaticnumberinginwebdesigns.1)Theycanbeusedfortablesofcontents,listitems,andcustomnumbering.2)Advancedusesincludenestednumberingsystems.3)Challengesincludebrowsercompatibilityandperformanceissues.4)Creativeusesinvolvecust

Using scroll shadows, especially for mobile devices, is a subtle bit of UX that Chris has covered before. Geoff covered a newer approach that uses the animation-timeline property. Here’s yet another way.

Let’s run through a quick refresher. Image maps date all the way back to HTML 3.2, where, first, server-side maps and then client-side maps defined clickable regions over an image using map and area elements.

The State of Devs survey is now open to participation, and unlike previous surveys it covers everything except code: career, workplace, but also health, hobbies, and more.


Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

SublimeText3 Chinese version
Chinese version, very easy to use

Dreamweaver CS6
Visual web development tools

MantisBT
Mantis is an easy-to-deploy web-based defect tracking tool designed to aid in product defect tracking. It requires PHP, MySQL and a web server. Check out our demo and hosting services.

DVWA
Damn Vulnerable Web App (DVWA) is a PHP/MySQL web application that is very vulnerable. Its main goals are to be an aid for security professionals to test their skills and tools in a legal environment, to help web developers better understand the process of securing web applications, and to help teachers/students teach/learn in a classroom environment Web application security. The goal of DVWA is to practice some of the most common web vulnerabilities through a simple and straightforward interface, with varying degrees of difficulty. Please note that this software

Atom editor mac version download
The most popular open source editor
