diff --git a/collection-one/modules/.DS_Store b/collection-one/modules/.DS_Store index 080f076..c047028 100644 Binary files a/collection-one/modules/.DS_Store and b/collection-one/modules/.DS_Store differ diff --git a/collection-one/modules/command-line/basic-commands/basic-commands.md b/collection-one/modules/command-line/basic-commands/basic-commands.md index 3095923..fb56caf 100644 --- a/collection-one/modules/command-line/basic-commands/basic-commands.md +++ b/collection-one/modules/command-line/basic-commands/basic-commands.md @@ -1,21 +1,23 @@ # Unit 2: Basic Commands Overview -Welcome to "Basic Commands," a pivotal unit in our Command Line module. Here, you'll delve into the fundamental commands that are the building blocks of any successful command-line operation. Whether you're a software engineer, writer, or instructor based in Atlanta, mastering these essential commands is key to enhancing your productivity in various tech-related roles. +Welcome to "Basic Commands," a cornerstone unit within our Command Line Fundamentals module. This unit is designed with an understanding that the command line is not just a tool but a powerful ally in the tech world. Whether you're transitioning from a military role into software engineering, embarking on a new journey as a writer, or stepping into the tech scene in Atlanta as an instructor, mastering these fundamental commands will significantly boost your efficiency and confidence in tech-related tasks. ## Table of Contents -1. **[Navigating Directories](navigating-directories.md)**: Begin by learning how to navigate directories efficiently, a fundamental skill for effective command-line usage. +1. **[Navigating Directories](navigating-directories.md)**: Start your command line journey by learning how to navigate the digital terrain of directories. Just as you navigated complex terrains in your previous roles, this skill will help you move through your projects with ease. -2. **[File Operations](file-operations.md)**: Explore essential file operations, including copying, moving, and deleting files, enabling you to manage your files seamlessly. +2. **[File Operations](file-operations.md)**: Dive into essential file operations such as copying, moving, and deleting. Think of this as organizing your digital toolkit, ensuring that everything you need is right where you need it, when you need it. -3. **[Listing and Filtering Files](listing-and-filtering-files.md)**: Discover how to list and filter files to find what you need quickly, streamlining your workflow. +3. **[Listing and Filtering Files](listing-and-filtering-files.md)**: Learn the art of listing and filtering files, akin to reconnaissance missions where quick, accurate information is key to decision-making. -4. **[File Permissions](working-with-permissions.md)**: Gain a deep understanding of file permissions, ensuring you have the necessary access to perform actions on files and directories. +4. **[File Permissions](working-with-permissions.md)**: Understanding file permissions is crucial for maintaining the security and integrity of your data. This lesson parallels securing and controlling access to sensitive information, a familiar concept for veterans. -5. **[Disk and Directory Usage](disk-and-directory-usage.md)**: Learn how to monitor disk and directory usage, allowing you to manage your system resources effectively. +5. **[Disk and Directory Usage](disk-and-directory-usage.md)**: Monitor your disk and directory usage to manage resources efficiently, much like logistical planning and resource allocation in military operations. -6. **[Wildcards](wildcards.md)**: Master the use of wildcards to perform advanced operations on multiple files simultaneously. +6. **[Wildcards](wildcards.md)**: Mastering wildcards allows you to efficiently perform actions on multiple files simultaneously, enhancing your ability to handle broad tasks with precision. -7. **[File Paths](file-paths.md)**: Understand file paths, a critical aspect of working with files and directories on the command line. +7. **[File Paths](file-paths.md)**: Grasp the concept of file paths, essential for locating and working with files. This is your map through the vast landscape of your file system, guiding you to your objectives swiftly and accurately. -This unit equips you with the essential tools needed to manage your files and directories effectively, making your time on the command line both productive and efficient. Whether you're setting up projects, automating tasks, or managing system resources, these foundational commands are essential in achieving your goals. Enjoy your journey through the Basic Commands unit! \ No newline at end of file +This unit is designed to arm you with the command line skills necessary for effective file and directory management, setting a foundation for further exploration and mastery of the tech domain. Whether setting up projects, automating tasks, or managing system resources, these skills are indispensable. + +Remember, the transition to tech is a journey akin to mastering a new language or navigating a new terrain. Each command you learn and each task you accomplish brings you one step closer to your goal. Embrace the challenge, and enjoy the journey through the Basic Commands unit! diff --git a/collection-one/modules/command-line/basic-commands/disk-and-directory-usage.md b/collection-one/modules/command-line/basic-commands/disk-and-directory-usage.md new file mode 100644 index 0000000..064f9ee --- /dev/null +++ b/collection-one/modules/command-line/basic-commands/disk-and-directory-usage.md @@ -0,0 +1,58 @@ +# Disk and Directory Usage in Linux + +Understanding how to manage disk and directory usage is crucial for maintaining a healthy and efficient system. This lesson covers four fundamental commands that are indispensable for this purpose: `df`, `du`, `fdisk`, and `stat`. + +## `df` - Disk Free +The `df` command displays the amount of disk space used and available on your filesystems. It's particularly useful for getting a quick overview of your system's disk usage. + +### Usage +```bash +df -h +``` +The `-h` option formats the output in a human-readable form, showing sizes in KB, MB, or GB as appropriate. + +### Example +Imagine you're preparing to deploy new software or updates and need to ensure you have enough disk space. Use `df -h` to quickly check available space across all mounted filesystems. + +## `du` - Disk Usage +The `du` command estimates the space used by directories and files. It's essential for identifying what's consuming your disk space, especially when cleaning up or auditing system storage. + +### Usage +```bash +du -sh /path/to/directory +``` +The `-s` option provides a summary for the specified directory, and `-h` makes the output human-readable. + +### Example +To keep your system organized, akin to planning a field operation with precision, you might use `du` to pinpoint high-usage areas that require cleanup. + +## `fdisk` - Disk Partition Manipulation +`fdisk` is a powerful tool for manipulating disk partitions. While its use is more advanced and typically reserved for system administrators, understanding its function is beneficial. + +### Usage +```bash +sudo fdisk -l +``` +The `-l` option lists all partitions on all disks, helping identify available storage devices and their partition schemes. + +### Example +Before creating a new partition for a project, you'd use `fdisk -l` to identify the appropriate disk and its current partition layout, similar to assessing a terrain before establishing a base. + +## `stat` - File or Filesystem Status +The `stat` command provides detailed information about files or filesystems, including size, permissions, and last access time. + +### Usage +```bash +stat filename +``` + +### Example +When verifying the integrity of files or when conducting a detailed audit of file access times and permissions, `stat` offers a comprehensive overview, akin to a detailed after-action report. + +## Summary and Best Practices +Efficient management of disk and directory usage is akin to ensuring operational readiness in a military context. Regularly monitoring disk space, organizing files and directories, and being proactive about system maintenance can prevent issues before they arise. + +### Exercises +1. **Disk Space Audit:** Use `df` to identify filesystems with less than 10% free space. +2. **Cleanup Operation:** Find the top 5 largest directories or files in your home directory using `du`. +3. **Partition Planning:** List all disk partitions and identify a disk with free space for a new partition. \ No newline at end of file diff --git a/collection-one/modules/command-line/basic-commands/disk-and-directoy-usage.md b/collection-one/modules/command-line/basic-commands/disk-and-directoy-usage.md deleted file mode 100644 index 447bfc3..0000000 --- a/collection-one/modules/command-line/basic-commands/disk-and-directoy-usage.md +++ /dev/null @@ -1,16 +0,0 @@ -# Disk and Directory Usage - -## `df` -The `df` or "Disk Free" command shows the amount of disk space used and available on your filesystems. - -## `du` -The `du` or "Disk Usage" command estimates the space used by directories and files. It's a useful way to identify what's taking up your disk space. - -## `fdisk` -The `fdisk` command is a disk partition manipulation tool. It's generally used by administrators to create, delete, or modify disk partitions. - -## `stat` -The `stat` command provides detailed information about file or filesystem status such as size, type, and last access time. - -## Summary -Managing disk and directory usage efficiently is essential for system performance and integrity. Tools like `df`, `du`, `fdisk`, and `stat` give you comprehensive insights and control over disk utilization. diff --git a/collection-one/modules/command-line/basic-commands/file-operations.md b/collection-one/modules/command-line/basic-commands/file-operations.md index 4d3df7a..5456f10 100644 --- a/collection-one/modules/command-line/basic-commands/file-operations.md +++ b/collection-one/modules/command-line/basic-commands/file-operations.md @@ -1,19 +1,74 @@ -# File Operations +# Advanced File Operations in Linux -## `cp` -The `cp` or "Copy" command is used for copying files and directories from one location to another. You can copy multiple files at once, or even entire directories with the `-R` option for recursive copy. +Managing files and directories efficiently is a fundamental skill for navigating and operating within a Linux environment. This lesson delves into essential commands that enable you to copy, move, remove, and manage files and directories. -## `mv` -The `mv` or "Move" command is used to move or rename files and directories. It can function within the same directory to rename a file or between directories to move files. +## `cp` - Copy Files and Directories +The `cp` command allows you to copy files and directories, offering flexibility in how data is duplicated across the system. -## `rm` -The `rm` or "Remove" command is used to delete files. Use cautiously, as this deletes files permanently. The `-r` option can remove directories and their contents recursively. +### Usage +```bash +cp source_file target_file +cp -R source_directory target_directory +``` +The `-R` option enables recursive copying, essential for directories. To preserve file attributes, consider the `-p` option. -## `touch` -The `touch` command is used to create empty files quickly. It can also update the access and modification times of existing files. +### Example +Copy a deployment checklist from one directory to another, ensuring you have backups of critical files. -## `mkdir` -The `mkdir` or "Make Directory" command is used to create new directories. +## `mv` - Move or Rename +The `mv` command serves dual purposes: moving files between directories and renaming them. -## Summary -Understanding file operations is crucial when working in a command-line environment. The `cp` command allows for copying files, while `mv` enables moving and renaming operations. The `rm` command is used for deletion, but must be used carefully to avoid unintentional data loss. The `touch` and `mkdir` commands make file and directory creation a simple task. Mastering these commands will make your daily tasks more efficient and automated. +### Usage +```bash +mv old_filename new_filename +mv file_to_move target_directory/ +``` + +### Example +Rename a file to reflect its updated status or move it to a designated archive directory, much like reorganizing gear for efficiency and readiness. + +## `rm` - Remove Files and Directories +The `rm` command deletes files and directories, a powerful but potentially dangerous tool. + +### Usage +```bash +rm filename +rm -r directory_name +``` +Use `-i` for interactive deletions, prompting for confirmation—a good practice to avoid accidental data loss. + +### Example +Securely removing temporary files or decommissioning outdated documents, akin to clearing a site after mission completion. + +## `touch` - Create or Update Files +The `touch` command is versatile, allowing you to create new, empty files or update the timestamps of existing ones. + +### Usage +```bash +touch new_file +``` + +### Example +Quickly creating a new file for jotting down operations notes or updating the timestamp to reflect a review or modification. + +## `mkdir` - Create Directories +The `mkdir` command is straightforward yet essential for organizing files and directories. + +### Usage +```bash +mkdir new_directory +``` +To create a directory structure in one command, use `mkdir -p parent_directory/new_directory`. + +### Example +Setting up a new directory for a project or operation, ensuring a structured and organized workspace. + +## Summary and Best Practices +File management commands are the backbone of system navigation and organization. By mastering these commands, you enhance your operational efficiency, drawing parallels to meticulous planning and execution in military operations. + +### Exercises +1. **Backup Operation:** Use `cp` to create backups of your personal files in a separate directory. +2. **Reorganization Drill:** Move files from multiple locations into a single, organized directory. +3. **Cleanup Mission:** Safely remove temporary or unneeded files from your system, using `rm -i` to review each file before deletion. + +Adopting a disciplined approach to file management, akin to strategic military planning, ensures your system remains efficient, organized, and operational. \ No newline at end of file diff --git a/collection-one/modules/command-line/basic-commands/file-paths.md b/collection-one/modules/command-line/basic-commands/file-paths.md index 10e88c7..7cf3eeb 100644 --- a/collection-one/modules/command-line/basic-commands/file-paths.md +++ b/collection-one/modules/command-line/basic-commands/file-paths.md @@ -1,16 +1,55 @@ -# File Paths +# Navigating File Paths in Linux -## Relative Paths -These are paths that are relative to the current directory. They do not start with the root directory `/`. +Navigating through the filesystem efficiently is crucial for command-line proficiency. This lesson explores the concepts of relative and absolute file paths and introduces commands that help manage and interpret these paths. -## Absolute Paths -These paths start with the root directory and provide the full path to a file or directory. +## Relative vs. Absolute Paths -## `realpath` -The `realpath` command resolves symbolic links and outputs the absolute path to a file or directory. +- **Relative Paths** refer to a location that is relative to the current directory. They do not begin with a slash (`/`) and are used to navigate within the filesystem based on the current location. + + - Example: If you're in `/home/user` and want to access `documents`, the relative path would be `documents/filename`. -## `dirname` -The `dirname` command outputs the directory part of a file path, stripping the last portion that is generally the filename. +- **Absolute Paths** specify the full path to a file or directory from the root of the filesystem. They always start with a slash (`/`), indicating the root directory. + + - Example: The absolute path to a file might be `/home/user/documents/filename`. -## Summary -Understanding the concept of file paths, both relative and absolute, is fundamental when navigating and operating in a command-line environment. The `realpath` and `dirname` commands can be particularly useful for script-based tasks that require manipulating or identifying paths. +## Understanding `realpath` + +The `realpath` command is used to resolve any symbolic links and return the absolute path of a given file or directory. + +### Usage +```bash +realpath relative/path/to/file +``` + +### Example +Find the absolute path of a file when writing scripts that require a full path regardless of the current working directory. + +## Using `dirname` and `basename` + +- **`dirname`** extracts the directory path from a given file path, effectively removing the filename from the path. + + ```bash + dirname /path/to/file/filename + ``` + + This command would output `/path/to/file`, useful for scripts needing to work with directory paths. + +- **`basename`** complements `dirname` by extracting the filename from a given path. + + ```bash + basename /path/to/file/filename + ``` + + This command would return `filename`, ideal for cases where you need just the file name without the preceding path. + +## Summary and Best Practices + +Understanding and effectively using file paths are foundational skills for navigating the Linux filesystem. By mastering relative and absolute paths, and utilizing commands like `realpath`, `dirname`, and `basename`, you can streamline your workflow and enhance script automation. + +### Exercises + +1. **Path Exploration:** Navigate to your home directory using both a relative path and an absolute path from different starting points. +2. **Path Manipulation:** For a given file, use `realpath` to find its absolute path, `dirname` to extract its directory path, and `basename` to get just the filename. +3. **Scripting Challenge:** Write a simple script that takes a file path as an input, checks if the file exists, and then prints the file’s directory and name separately. + +Emphasizing hands-on practice and real-world applications makes these concepts more accessible and relevant, especially for veterans transitioning their operational planning and navigation skills to a digital environment. \ No newline at end of file diff --git a/collection-one/modules/git-and-github/basics-of-git.md b/collection-one/modules/git-and-github/basics-of-git.md index 33e17be..1a79a39 100644 --- a/collection-one/modules/git-and-github/basics-of-git.md +++ b/collection-one/modules/git-and-github/basics-of-git.md @@ -1,143 +1,100 @@ -## Lesson 2: Setting up Git ---- +## Lesson 2: Setting up Git ### Introduction -Welcome to Lesson 2! You've got some basics down; now let's get Git properly set up on your machine. This lesson walks you through the initial Git setup, SSH key creation, user identity, and proxy setup. +Welcome to Lesson 2! Having covered some basics, it's now time to properly configure Git on your machine. This lesson guides you through Git's initial setup, creating SSH keys, setting your user identity, and configuring a proxy for Git if necessary. ### Learning Outcomes -- Configure Git via the terminal -- Generate and use SSH keys -- Configure user identity in Git -- Set up a Proxy for Git + +By the end of this lesson, you will be able to: +- Configure Git using the terminal. +- Generate and utilize SSH keys for secure connections. +- Set and manage your user identity within Git. +- Configure a proxy for Git operations, when required. + +### Visual Aids + +**Insert Diagram**: "The Git Configuration Process" - A flowchart detailing the steps from installing Git to configuring user settings and SSH keys. --- ### Section 1: Configuring Git (Terminal) #### Setting Up User Info -You want Git to recognize you. You need to set up a username and email address to do that. + +First, let's personalize your Git environment by setting up your username and email address: + ```bash git config --global user.name "Your Name" git config --global user.email "your.email@example.com" ``` -#### Checking Your Settings -To verify that you've set up everything correctly, run: -```bash -git config --list -``` +**Interactive Tutorial**: Link to an interactive shell simulator where learners can practice Git configuration commands in real-time. ---- +#### Verifying Your Configuration -### Section 2: SSH Keys (Terminal & UI) +Ensure your setup is correct by listing your Git configuration: -#### Generate SSH Key -An SSH key is a way to identify yourself to Git without typing your username and password every time. ```bash -ssh-keygen -t rsa -b 4096 +git config --list ``` -#### Adding SSH Key to GitHub/GitLab -After generating the key: -Navigate to the settings in your GitHub or GitLab account. -Look for the "SSH and GPG keys" section. -Add your key. +**Exercise**: Verify your Git configuration and modify your username and email if necessary. --- -### Section 3: User Identity Configuration - -You've already set your user name and email, but if you ever need to update this information, just rerun the same config commands. +### Section 2: SSH Keys (Terminal & UI) ---- +#### Generating an SSH Key -### Section 4: Setting Up a Proxy (Terminal) +SSH keys secure your identity to Git services, eliminating the need for password entry on each operation. -You may need to set up a proxy if you're behind a corporate firewall. To do this: ```bash -git config --global http.proxy http://proxy.example.com:8080 +ssh-keygen -t rsa -b 4096 ``` ---- - -## Lesson 3: Your First Git Commands - ---- +**Insert Screenshot**: "Generating an SSH Key" - A visual guide showing the terminal during the key generation process. -### Introduction +#### Adding Your SSH Key to GitHub/GitLab -Alright, you've set up Git and are ready to roll! In this lesson, we'll execute our first Git commands, covering `git init,` `git clone,` commit changes, and learn about the staging area. +- Navigate to your GitHub or GitLab settings. +- Find the "SSH and GPG keys" section and add your new key. -### Learning Outcomes -- Use `git init` and `git clone` commands -- Commit changes to a Git repository -- Understand the staging area -- Use `git log` and `git status` to check repository status +**Video Tutorial**: A short video demonstrating how to add your SSH key to GitHub or GitLab. --- -### Section 1: Git init, git clone (Terminal) - -#### Initializing a New Repo -To kickstart a new Git repository, navigate to your project directory and run: -```bash -git init -``` - -#### Cloning an Existing Repo -To clone an existing repository, use the command: -```bash -git clone -``` - ---- +### Section 3: Proxy Configuration (Terminal) -### Section 2: Committing Changes (UI & Terminal) +If you're behind a corporate firewall, you may need to configure a proxy: -#### How to Commit -After making changes in your project files, first stage them: ```bash -git add +git config --global http.proxy http://proxy.example.com:8080 ``` -Next, commit these changes: -```bash -git commit -m "describe your changes here" -``` +**Troubleshooting Box**: Common proxy configuration issues and how to resolve them. --- -### Section 3: Understanding Staging (Terminal) +### Practical Example -#### What's a Staging Area? -The staging area is like a prep table where Git collects all the changes that will go into your next commit. +**Exercise**: Configure your Git with the provided details, generate an SSH key, and add it to your GitHub account. Verify all configurations using `git config --list`. -#### Adding to Staging -```bash -git add -``` +--- -#### Removing from Staging -```bash -git restore --staged -``` +### Further Reading and Resources ---- +- Official Git Documentation +- Advanced SSH Key Management in Git +- Best Practices for Git Configuration -### Section 4: Git log, git status (Terminal) +**Community Forum**: Join our Git learners' community to share insights, ask questions, and receive feedback. -#### Viewing the Commit History -```bash -git log -``` +### Lesson Recap -#### Checking Your Repository Status -```bash -git status -``` +In this lesson, you've learned how to set up Git on your machine, generate SSH keys for secure authentication, configure your Git user identity, and set up a proxy for Git if needed. Practice these steps to become comfortable with Git configuration and prepare for more advanced Git operations in future lessons. ---- +### Preview of Next Lesson -And there you go! You've learned the basics of Git, how to set it up, and how to perform basic operations. Keep practicing to make these commands second nature. \ No newline at end of file +In Lesson 3, we'll dive into your first Git commands, exploring `git init`, `git clone`, and the process of staging and committing changes. diff --git a/collection-one/modules/git-and-github/git-and-github.md b/collection-one/modules/git-and-github/git-and-github.md index 6001064..dfeac3c 100644 --- a/collection-one/modules/git-and-github/git-and-github.md +++ b/collection-one/modules/git-and-github/git-and-github.md @@ -1,12 +1,18 @@ -The "Git and GitHub (Terminal & UI)" module provides a comprehensive guide to mastering Git and GitHub, essentials for modern software development. It kicks off with Unit 1, offering a gentle introduction to GitHub, account setup, and profile customization. Unit 2 takes a deep dive into Markdown and key GitHub features like Issues, Actions, and GitHub Pages. Unit 3 is all about the basics of Git, teaching you the terminal commands you need to get started, followed by Unit 4 which elevates your skills in GitHub repository operations, such as creating repositories and basic Git workflows. For those looking to go beyond the basics, Unit 5 covers advanced Git topics like Git Flow and versioning. Unit 6 introduces the GitHub Command Line Interface (CLI), covering everything from installation to navigating GitHub with CLI commands. Finally, Unit 7 rounds out the module with a focus on GitHub Projects for project management. Each unit is broken down into lessons that include both UI-based and terminal-based instructions, making it a versatile resource for learners at all levels. +# Git and GitHub (Terminal & UI) Module Overview -**Table of Contents:** +Welcome to the updated "Git and GitHub (Terminal & UI)" module! This comprehensive guide now includes a new unit on GitHub Copilot and the Copilot CLI, aimed at introducing developers to AI-powered code completion and optimizing coding workflows with the Copilot CLI. From setting up your GitHub profile to mastering advanced Git concepts and leveraging AI in your coding projects, this module covers it all. -- [advanced-git-topics.md](File) - Files complete for git and GitHub, 5 minutes ago -- [basics-of-git.md](File) - Basics of git, 28 minutes ago -- [github-cli.md](File) - Files complete for git and GitHub, 5 minutes ago -- [github-projects.md](File) - Files complete for git and GitHub, 5 minutes ago -- [github-repository-operations.md](File) - Files complete for git and GitHub, 5 minutes ago -- [introduction-to-git-and-github.md](File) - Intro to git and GitHub complete, last week -- [learning-git-and-markdown.md](File) - Learning git and markdown complete, last week -- [markdown-tips.md](File) - Markdown tips, file status not specified. \ No newline at end of file +## Table of Contents + +- [Introduction to GitHub](introduction-to-git-and-github.md) +- [Learning Git and Markdown](learning-git-and-markdown.md) +- [Markdown Tips](markdown-tips.md) +- [Basics of Git](basics-of-git.md) +- [GitHub Repository Operations](github-repository-operations.md) +- [Advanced Git Topics](advanced-git-topics.md) +- [GitHub CLI](github-cli.md) +- [GitHub Projects for Project Management](github-projects.md) +- [GitHub Actions](github-actions.md) +- [Git flow](git-flow.md) +- [Github Pages](github-pages.md) +- [GitHub Copilot and Copilot CLI](github-copilot-and-copilot-cli.md) \ No newline at end of file