Streamline setting up your next project's workspace!
Are you tired of wasting so much time fighting with your local machine long before you can even start on your next passion project? Do you get frustrated with debugging issues rooted in your machine's filesystem, OS, or some other unknown X-factor that you have no idea what could be causing it?
So was I, which was why I decided to create my own DevContainer to help better streamline the process for my future programable endeavors.
Through the power of VSCode and Docker, you can setup your own workspace with ease of process as well as ease of mind.
While this system is still provides its own isolated & independent environment, there are still a couple of things you'll need on your system before you get started.
- Visual Studio Code
- Docker
- Remote - Containers
- This one requires for you to have Visual Studio Code (VSCode) installed first, as this is an extension for the popular code editor.
If you do not know how to install Visual Studio Code or Docker, then please refer to the respective site's documentation for more information.
As of the date of this commit -- May 15, 2021 -- I've developed this using Docker's integrated WSL (Ubuntu 20.04 | x86_64) on my machine that primarily runs Windows 10 Pro, so the information I give is based solely on that environment.
- Clone or download this repo into its own private directory.
- Copy the
.devcontainer
directory over to your project. - Configure the details how you want (more details on those customizable features later on) in the following file:
.devcontainer/scripts/build_config.sh
and.devcontainer/.env
. - Make sure your Docker daemon is running and then open your project in Visual Studio code.
- Press
Ctrl + Shift + P
to open up text field. - Search for
Remote-Containers: Rebuild and Reopen Containers
. - Once you have that option selected, either click on it or press
Enter
. - Docker-Compose will then build your container(s). Once that's completed, your instance of VSCode will reload and will open up inside your new DevContainer. Enjoy!
While this is in an isolated environment, this will automatically copy over your GitHub credentials, assuming you have them set up with the following commands:
git config --global user.name "Mona Lisa"
git config --global user.email "[email protected]"
If you use GitHub SSH key, the DevContainer is setup for that through the use of the $SSH_AUTH_SOCK
variable where it'll share your credentials safely and without compromising your security.
That method is a bit trickier, however, is you'll need an SSH-Agent to forward your keys through the container's SSH socket.
Note: These instructions are based on WSL Ubuntu.
Run the following commands to install keychain
as a dependency:
sudo apt-get update && sudo apt-get install keychain
Copy & Paste the following script into ~/.profile
or ~/.bash_profile
(~/.zprofile
for ZSH):
eval $(keychain --quiet --eval --agents ssh id_ed25519)
if [ -z "$SSH_AUTH_SOCK" ]; then
# Check for a currently running instance of the agent
RUNNING_AGENT="`ps -ax | grep 'ssh-agent -s' | grep -v grep | wc -l | tr -d '[:space:]'`"
if [ "$RUNNING_AGENT" = "0" ]; then
# Launch a new instance of the agent
ssh-agent -s &> $HOME/.ssh/ssh-agent
fi
eval `cat $HOME/.ssh/ssh-agent`
fi
This script will ensure your SSH key(s) are made available from within the container.
Yo, dawg! I heard you like Docker containers, so I put a Docker containers inside your Docker container!
That's right! You can actually start your own game of Inception by building nested Docker containers with either Docker CLI or Moby CLI and Docker-Compose.
Env Variable Name | Default Value | Purpose |
---|---|---|
$USE_MOBY | false | This will install Moby CLI instead of Docker CLI. |
ENABLE_NONROOT_DOCKER | true | Assign Docker permissions either to root or node. |
You can even access this container from other Docker containers or vice versa.
Important Note: This has not been fully tested yet, so I do not know the limitations of this within the current setup.
This installs the latest version of NPM & Yarn package managers.
NVM Note: NVM is removed by default from this container to help eliminate any unneeded complications, but you can allow it in the container's build by setting the $KEEP_NVM
variable in .env
to TRUE
.
- node-gyp
- node-sass
- http-server
- ndb
- npm-check
- npm-check-updates
- pm2
- rimraf
- snyk
- typescript
- @commitlint/cli
There are also other configurable options for what global command line tools are installed, depending on your Node Project's needs:
Dependency | ENV Variable Name | Default |
---|---|---|
@angular/cli | $USE_ANGULAR | false |
@nestjs/cli | $USE_NESTJS | false |
@nrwl/cli | $USE_NRWL | false |
@capacitor/cli | $USE_IONIC | false |
@ionic/cli | $USE_IONIC | false |
cordova | $USE_IONIC | false |
By default, this DevContainer comes setup with MongoDB straight out of the box. Although, if you wish to remove it, simply comment out the sections involving MongoDB from the docker-compose.yml
file and set USE_MONGO
to false.
ENV Variable Name | Default |
---|---|
USE_MONGO | true |
MONGO_VARIANT* | 4.4.6 |
MONGO_HOST | dev-container-database |
MONGO_PORT | 6379 |
MONGO_INITDB_ROOT_USERNAME | root |
MONGO_INITDB_ROOT_PASSWORD | example |
MONGO_INITDB_DATABASE | your-database-here |
*MONGO_VARIANT
is to depict the version of the MongoDB command line tools you wish to use.
By default, this DevContainer comes setup with Redis straight out of the box. Although, if you wish to remove it, simply comment out the sections involving Redis from the docker-compose.yml
file and set USE_REDIS
to false.
ENV Variable Name | Default |
---|---|
USE_REDIS | true |
REDIS_VARIANT* | 6.2.3 |
REDIS_HOST | dev-container-cache |
REDIS_PORT | 27017 |
*REDIS_VARIANT
is to depict the version of the Redis Server command line tools you wish to use.
Important Note: This instance of Redis is configured with AOF turned off, uses RDB, and is using standard LRU eviction policies. If you wish to change any of these settings, go to .devcontainer/redis/redis.conf
to adjust accordingly. But please be sure to reference Redis' documentation while you do.
alias cra="npx create-react-app"
alias create-react-app="npx create-react-app"
alias create-nx-workspace="npx create-nx-workspace"
alias l="ls -CF"
alias la="ls -A"
alias lerna="npx lerna"
alias ll="ls -la"
alias redis="redis-cli"
This is my first time attempting to create an open-source project, so I apologize if this isn't the most flexible or customizable OSS project hosted on GitHub right now. This is but the first version -- a prototype if you will -- and I plan to refine it over time. Although, I also welcome others to contribute, and for those more familiar with OSS practices to offer up any advice they can provide. I'm very open to feedback and constructive criticisms.
Kerick Howlett - LinkedIn - [email protected]
Distributed under the MIT license. See LICENSE
for more information.
https://github.com/KerickHowlett
- Fork it
- Create your feature branch off the development branch. (
git checkout -b feature/fooBar development
) - Commit your changes (
git commit -am 'Add some fooBar'
) - Push to the branch (
git push origin feature/fooBar
) - Create a new Pull Request