| name | os-scripting |
| description | Operating system and shell scripting troubleshooting workflow for Linux, macOS, and Windows. Covers bash scripting, system administration, debugging, and automation. |
| category | workflow-bundle |
| risk | safe |
| source | personal |
| date_added | 2026-02-27 |
OS/Shell Scripting Troubleshooting Workflow Bundle
Overview
Comprehensive workflow for operating system troubleshooting, shell scripting, and system administration across Linux, macOS, and Windows. This bundle orchestrates skills for debugging system issues, creating robust scripts, and automating administrative tasks.
When to Use This Workflow
Use this workflow when:
- Debugging shell script errors
- Creating production-ready bash scripts
- Troubleshooting system issues
- Automating system administration tasks
- Managing processes and services
- Configuring system resources
Workflow Phases
Phase 1: Environment Assessment
Skills to Invoke
bash-linux - Linux bash patterns
bash-pro - Professional bash scripting
bash-defensive-patterns - Defensive scripting
Actions
- Identify operating system and version
- Check available tools and commands
- Verify permissions and access
- Assess system resources
- Review logs and error messages
Diagnostic Commands
uname -a
cat /etc/os-release
hostnamectl
top
htop
df -h
free -m
ps aux
pgrep -f pattern
lsof -i :port
netstat -tulpn
ss -tulpn
ip addr show
Copy-Paste Prompts
Use @bash-linux to diagnose system performance issues
Phase 2: Script Analysis
Skills to Invoke
bash-defensive-patterns - Defensive scripting
shellcheck-configuration - ShellCheck linting
bats-testing-patterns - Bats testing
Actions
- Run ShellCheck for linting
- Analyze script structure
- Identify potential issues
- Check error handling
- Verify variable usage
ShellCheck Usage
sudo apt install shellcheck
brew install shellcheck
shellcheck script.sh
shellcheck -f gcc script.sh
Copy-Paste Prompts
Use @shellcheck-configuration to lint and fix shell scripts
Phase 3: Debugging
Skills to Invoke
systematic-debugging - Systematic debugging
debugger - Debugging specialist
error-detective - Error pattern detection
Actions
- Enable debug mode
- Add logging statements
- Trace execution flow
- Isolate failing sections
- Test components individually
Debug Techniques
set -x
set -e
set -u
set -o pipefail
log() {
echo "[$(date '+%Y-%m-%d %H:%M:%S')] $*" >> /var/log/script.log
}
trap 'echo "Error on line $LINENO"' ERR
bash -n script.sh
bash -x script.sh
Copy-Paste Prompts
Use @systematic-debugging to trace and fix shell script errors
Phase 4: Script Development
Skills to Invoke
bash-pro - Professional scripting
bash-defensive-patterns - Defensive patterns
linux-shell-scripting - Shell scripting
Actions
- Design script structure
- Implement functions
- Add error handling
- Include input validation
- Add help documentation
Script Template
#!/usr/bin/env bash
set -euo pipefail
readonly SCRIPT_NAME=$(basename "$0")
readonly SCRIPT_DIR=$(cd "$(dirname "$0")" && pwd)
log() {
local level="$1"
shift
echo "[$(date '+%Y-%m-%d %H:%M:%S')] [$level] $*" >&2
}
info() { log "INFO" "$@"; }
warn() { log "WARN" "$@"; }
error() { log "ERROR" "$@"; exit 1; }
usage() {
cat <<EOF
Usage: $SCRIPT_NAME [OPTIONS]
Options:
-h, --help Show this help message
-v, --verbose Enable verbose output
-d, --debug Enable debug mode
Examples:
$SCRIPT_NAME --verbose
$SCRIPT_NAME -d
EOF
}
main() {
local verbose=false
local debug=false
while [[ $# -gt 0 ]]; do
case "$1" in
-h|--help)
usage
exit 0
;;
-v|--verbose)
verbose=true
shift
;;
-d|--debug)
debug=true
set -x
shift
;;
*)
error "Unknown option: $1"
;;
esac
done
info "Script started"
info "Script completed"
}
main "$@"
Copy-Paste Prompts
Use @bash-pro to create a production-ready backup script
Use @linux-shell-scripting to automate system maintenance tasks
Phase 5: Testing
Skills to Invoke
bats-testing-patterns - Bats testing framework
test-automator - Test automation
Actions
- Write Bats tests
- Test edge cases
- Test error conditions
- Verify expected outputs
- Run test suite
Bats Test Example
#!/usr/bin/env bats
@test "script returns success" {
run ./script.sh
[ "$status" -eq 0 ]
}
@test "script handles missing arguments" {
run ./script.sh
[ "$status" -ne 0 ]
[ "$output" == *"Usage:"* ]
}
@test "script creates expected output" {
run ./script.sh --output test.txt
[ -f "test.txt" ]
}
Copy-Paste Prompts
Use @bats-testing-patterns to write tests for shell scripts
Phase 6: System Troubleshooting
Skills to Invoke
devops-troubleshooter - DevOps troubleshooting
incident-responder - Incident response
server-management - Server management
Actions
- Identify symptoms
- Check system logs
- Analyze resource usage
- Test connectivity
- Verify configurations
- Implement fixes
Troubleshooting Commands
journalctl -xe
tail -f /var/log/syslog
dmesg | tail
ping host
traceroute host
curl -v http://host
dig domain
nslookup domain
strace -p PID
lsof -p PID
iotop
du -sh /*
find / -type f -size +100M
lsof | grep deleted
Copy-Paste Prompts
Use @devops-troubleshooter to diagnose server connectivity issues
Use @incident-responder to investigate system outage
Phase 7: Automation
Skills to Invoke
workflow-automation - Workflow automation
cicd-automation-workflow-automate - CI/CD automation
linux-shell-scripting - Shell scripting
Actions
- Identify automation opportunities
- Design automation workflows
- Implement scripts
- Schedule with cron/systemd
- Monitor automation health
Cron Examples
crontab -e
0 2 * * * /path/to/backup.sh
0 3 * * 0 /path/to/cleanup.sh
0 * * * * /path/to/monitor.sh
Systemd Timer Example
[Unit]
Description=Daily backup timer
[Timer]
OnCalendar=daily
Persistent=true
[Install]
WantedBy=timers.target
Copy-Paste Prompts
Use @workflow-automation to create automated system maintenance workflow
Common Troubleshooting Scenarios
High CPU Usage
top -bn1 | head -20
ps aux --sort=-%cpu | head -10
pidstat 1 5
Memory Issues
free -h
vmstat 1 10
cat /proc/meminfo
Disk Space
df -h
du -sh /* 2>/dev/null | sort -h
find / -type f -size +500M 2>/dev/null
Network Issues
ip addr show
ip route show
ss -tulpn
curl -v http://target
Service Failures
systemctl status service-name
journalctl -u service-name -f
systemctl restart service-name
Quality Gates
Before completing workflow, verify:
Related Workflow Bundles
development - Software development
cloud-devops - Cloud and DevOps
security-audit - Security testing
database - Database operations
Limitations
- Use this skill only when the task clearly matches the scope described above.
- Do not treat the output as a substitute for environment-specific validation, testing, or expert review.
- Stop and ask for clarification if required inputs, permissions, safety boundaries, or success criteria are missing.