Skip to content
/ git Public

A minimal Docker image containing the latest Git version, optimized for managing multiple GitHub accounts efficiently.

Notifications You must be signed in to change notification settings

softjapan/git

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

1 Commit
 
 
 
 
 
 

Repository files navigation

softjpn/git

A minimal Docker image based on Alpine Linux with the latest version of git installed.
This image is designed to keep the size as small as possible while providing the essential git functionality in a containerized environment.


Table of Contents

  1. Overview
  2. Features
  3. Dockerfile
  4. Usage
  5. Building from Source
  6. Per-Folder GitHub Account Configuration
  7. License
  8. Author

Overview

softjpn/git is a lightweight Docker image that packages the latest Git client. By mounting your project directory into the container, you can run all standard Git commands without installing Git locally. This is especially useful for maintaining a clean environment or for CI/CD pipelines where you need a reliable, up-to-date Git version.


Features

  • Small Image Size: Built on Alpine Linux, this image is significantly smaller than many alternatives.
  • Latest Git Version: Uses the Alpine package manager to install Git (frequently updated).
  • Simple Volume Mount: Easily mount your local directory into /app for Git operations.
  • SSH Client Pre-Installed: Includes openssh-client so you can work with private repositories that require SSH keys.

Dockerfile

Below is the core of the Dockerfile, located in this repository:

FROM alpine:3.18

RUN apk update && \
    apk add --no-cache git openssh-client && \
    rm -rf /var/cache/apk/*

WORKDIR /app

ENTRYPOINT ["git"]

Usage

Pull from Docker Hub

docker pull softjpn/git

Run Git Commands

Mount your local directory to the container’s /app folder and run Git commands as needed:

# Check status
docker run --rm -it -v "$PWD:/app" softjpn/git status

# Add files
docker run --rm -it -v "$PWD:/app" softjpn/git add -A .

# Commit changes
docker run --rm -it -v "$PWD:/app" softjpn/git commit -m "Your commit message"

# Push to remote repository
docker run --rm -it -v "$PWD:/app" softjpn/git push origin main

Common Git Operations

Here are some additional commands you may find useful. Simply prefix with docker run --rm -it -v "$PWD:/app" softjpn/git:

  • Clone a repository
    docker run --rm -it -v "$PWD:/app" softjpn/git clone https://github.com/user/repo.git
  • List branches
    docker run --rm -it -v "$PWD:/app" softjpn/git branch
  • Check logs
    docker run --rm -it -v "$PWD:/app" softjpn/git log --oneline --graph
  • Create/switch branch
    # Create and switch to a new branch
    docker run --rm -it -v "$PWD:/app" softjpn/git checkout -b feature-branch
    
    # Switch to an existing branch
    docker run --rm -it -v "$PWD:/app" softjpn/git checkout main
  • Pull updates
    docker run --rm -it -v "$PWD:/app" softjpn/git pull
  • Merge branches
    # Switch to the branch you want to merge into
    docker run --rm -it -v "$PWD:/app" softjpn/git checkout main
    
    # Merge the other branch
    docker run --rm -it -v "$PWD:/app" softjpn/git merge feature-branch
  • Rebase
    docker run --rm -it -v "$PWD:/app" softjpn/git checkout main
    docker run --rm -it -v "$PWD:/app" softjpn/git rebase feature-branch
  • Stash changes
    docker run --rm -it -v "$PWD:/app" softjpn/git stash
    docker run --rm -it -v "$PWD:/app" softjpn/git stash pop
  • Tag and push tags
    docker run --rm -it -v "$PWD:/app" softjpn/git tag v1.0.0
    docker run --rm -it -v "$PWD:/app" softjpn/git push --tags

Building from Source

If you wish to build the Docker image locally from the Dockerfile in this repository:

git clone https://github.com/softjapan/git.git
cd git
docker build -t softjpn/git .

Per-Folder GitHub Account Configuration

To maintain different Git configurations per project (e.g., different username, email), you have multiple options:

  1. Local .git/config
    • Inside each project’s .git/config, specify:
      [user]
        name = "Your Name"
        email = "your.email@example.com"
  2. Mount a Custom .gitconfig
    • You can keep a custom .gitconfig file in your project folder and mount it into the container:
      docker run --rm -it \
        -v "$PWD:/app" \
        -v "$PWD/.my_gitconfig:/root/.gitconfig" \
        softjpn/git config --list

License

This project is licensed under the MIT License - feel free to use, modify, and distribute it.


Author

For any inquiries or suggestions, please open an issue on GitHub or contact us directly. We appreciate all contributions and feedback!


About

A minimal Docker image containing the latest Git version, optimized for managing multiple GitHub accounts efficiently.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published