by Joaquin Menchaca Last Update: 2020年10月31日
This is my guide to getting DevOps oriented tools on Ubuntu 20.04.1 (Focal Fossa).
In the scope of DevOps oriented tools: these are tools used to implement DevOps philosophy, which includes tools used to build, test and deploy software that has a operational context (deployed as XaaS or supporting function). Such tools can include change configuration, deployment, scheduling/orchestration, build/release (such as tools supporting disciplines of CI/CD). These tools also support both local and cloud deployment solutions for containers and virtual machines. This is by no means, comprehensive, just popular tools in the industry since 2012.
I try my best to make these generic as possible, to use the latest version, but at any momement, the package owner can change the URLs, paths, packagename, etc. For this reason, I am dropping comments to when it was last updated and verified, using YYYY年MM月DD日
format (CJK characters because I am a language dork)
Platform Tested:
Distributor ID: Ubuntu
Description: Ubuntu 20.04.1 LTS
Release: 20.04
Codename: focal
- Getting Started
- Essential Tools
- Shell Environment
- Virtual Machines
- Vagrant
- Docker
- Kubernetes
- Client Tools
- kubectl
- helm
- Helm Diff Plugin
- [Helm Secrets Plugin](#helmsudo apt-get install atom-secrets-plugin)
- helmfile
- Platforms
- Client Tools
- Text Editors
- Language Platforms
- Cloud Provider Tools
- Change Configuration Tools
- HashiCorp Tools: Howbow Dah
- Applications
This guide will do a lot of configuration changes to the local shell. To safeguard against any accidents, we should backup the $HOME/.bashrc
file as well as use a configuration that we can source.
cp ~/.bashrc ~/.bashrc.backup.sh
touch ~/.toolbox.sh
echo "source ~/.toolbox.sh" >> ~/.bashrc
AppArmor will block many services from working, such as the case with MiniKube. The best practice is to open up services needed with AppArmor and fix bugs with either libvirt or ubuntu (1825745) and minikube (9452, 8299). The alternative is to just disable AppArmor:
sudo systemctl disable apparmor
SSH is needed for many services including getting code or releases using SSH. You can setup an SSH private and public key with this:
ssh-keygen -t rsa -b 4096 -C "[email protected]"
eval "$(ssh-agent -s)" && ssh-add ~/.ssh/id_rsa
For access to source code from a git repository, like GitHub, GitLab, or BitBucket, using SSH, you need to copy your public key generated earlier and add it to the git server. You can copy public from the command line with this:
sudo apt install -y xclip git
xclip -sel clip < ~/.ssh/id_rsa.pub
git config --global user.email "[email protected]"
git config --global user.name "Your Name"
After configuring this public key using whatever method the git server or online service requires. For example, if you configured a public key in your GitHub account, checkout code using SSH, e.g. git clone [email protected]:darkn3rd/devops_box_guides.git
Linux is already bundled with desirable tools like GNU Sed and GNU Awk. Here are some other small tools you may want to use:
bat
- cat with color syntax highlightingcurl
- download content off webgdebi
- install.deb
packages and dependencieshtml2
- converthtml
to a format usable with shell programminginxi
- get hardware system informationjq
- json pretty print + filterngrep
- network grepsilversearch-ag
- super grep on steroidssqlite3
- small sql db from binary filetree
- print directory in tree viewxml2
- convertxml
to a format usable with shell programming
# Basic Essentials
sudo apt install -y tree \
xml2 \
jq \
sqlite3 \
ngrep \
silversearcher-ag \
curl \
gdebi
## BAT - cat with color syntax highlighting
LATEST_BAT=$(curl -s https://api.github.com/repos/sharkdp/bat/releases | jq '[.[].tag_name][0]' -r)
pushd
wget https://github.com/sharkdp/bat/releases/download/${LATEST_BAT}/bat_${LATEST_BAT##v}_amd64.deb
sudo apt install ./bat_${LATEST_BAT##v}_amd64.deb
popd
This is a modular approach to manage configuration as an alternative putting everything in ~/.bashrc
. If you don't want to use this, then put these configurations into .bashrc
sed -i '/^for .*toolbox.d.*$/d' ~/.bashrc
printf '\nfor TOOLBOX_SCRIPT in ~/.toolbox.d/*.sh;do . "${TOOLBOX_SCRIPT}";done\n' >> ~/.bashrc
Here are some functions that can be useful for managing shell environment
function add_to_path() {
for p in ${(s.:.)2}; do
if [[ ! "${(P)1}" =~ "${p%/}" ]]; then
new_path="$p:${(P)1#:}"
export "$1"="${new_path%:}"
fi
done
}
function add_to_path() {
for path in ${2//:/ }; do
if ! [[ "${!1}" =~ "${path%/}" ]]; then # ignore last /
new_path="$path:${!1#:}"
export "$1"="${new_path%:}" # remove trailing :
fi
done
}
This covers virtual machines. Only one virtual machine type can be used with Linux. Choose wisely.
Still eliciting the exact requirements needed for KVM. These are the tools thus far identified:
bridge-utils
- Utilities for configuring the Linux Ethernet bridgecpu-checker
- Evaluate certain CPU (or BIOS) featureslibguestfs-tools
- guest disk image management systemlibvirt-clients
libvirt-daemon-system
libvirt-dev
- development files for the libvirt libraryqemu-kvm
- QEMU Full virtualization on x86 hardwarevirt-manager
- desktop application for managing virtual machines
sudo apt-get install -y \
bridge-utils \
cpu-checker \
libguestfs-tools \
libvirt-clients \
libvirt-daemon-system
libvirt-dev \
qemu-kvm \
virt-manager
Source: Ubuntu Community Page:
After this, I noticed a new route and links setup:
# ip route show
192.168.122.0/24 dev virbr0 proto kernel scope link src 192.168.122.1 linkdown
# ip link | grep -A1 virbr
4: virbr0: <NO-CARRIER,BROADCAST,MULTICAST,UP> mtu 1500 qdisc noqueue state DOWN mode DEFAULT group default qlen 1000
link/ether 52:54:00:58:5f:3e brd ff:ff:ff:ff:ff:ff
5: virbr0-nic: <BROADCAST,MULTICAST> mtu 1500 qdisc fq_codel master virbr0 state DOWN mode DEFAULT group default qlen 1000
link/ether 52:54:00:58:5f:3e brd ff:ff:ff:ff:ff:ff
I also noticed new users and groups, libvirt-qemu
and libvirt-dnsmasq
, which look like these are used for services, and a group libvirt
that allows users to create VMs.
virt-host-validate
Links:
- https://tutorialforlinux.com/2019/03/30/step-by-step-kvm-ubuntu-19-04-installation-guide/2/
- https://www.hiroom2.com/2019/06/18/ubuntu-1904-kvm-en/
wget -qO - https://www.virtualbox.org/download/oracle_vbox_2016.asc | sudo apt-key add -
sudo add-apt-repository \
"deb [arch=amd64] https://download.virtualbox.org/virtualbox/debian \
$(lsb_release -s -c) \
contrib"
sudo apt-get update
sudo apt-get install virtualbox-6.1
LATEST_VAGRANT=$(curl -s https://github.com/hashicorp/vagrant/releases.atom | xml2 | \
grep -oP '(?<=feed/entry/title=).*' | sort -V | tail -1
)
pushd ~/Downloads
curl -sOL https://releases.hashicorp.com/vagrant/${LATEST_VAGRANT##v}/vagrant_${LATEST_VAGRANT##v}_x86_64.deb
sudo apt install ./vagrant_${LATEST_VAGRANT##v}_x86_64.deb
popd
This is the default provider, so nothing needs to be configured. You can explicitly set the default configuration (though redundant):
printf "export VAGRANT_DEFAULT_PROVIDER=virtualbox\n" > ~/.toolbox.d/vagrant.sh
You can use vagrant with libvirt using vagrant-libvirt plugin.
## Enable 'deb-src' URIs for build-dep
sudo cp /etc/apt/sources.list /etc/apt/sources.list~
sudo sed -Ei 's/^# deb-src /deb-src /' /etc/apt/sources.list
sudo apt-get update
## Instructions from vagrant-libvirt
sudo apt-get build-dep vagrant ruby-libvirt
sudo apt-get install qemu ebtables dnsmasq-base
sudo apt-get install libxslt-dev libxml2-dev libvirt-dev zlib1g-dev ruby-dev
## Instsall Plugin for current user
vagrant plugin install vagrant-libvirt
## Default to Libvirt
export VAGRANT_DEFAULT_PROVIDER=libvirt
## configure shell environment
printf "export VAGRANT_DEFAULT_PROVIDER=libvirt\n" > ~/.toolbox.d/vagrant.sh
After this, I actually had to restart before I would have restart before I can create virtual machines that use libvirt (KVM).
mkdir test && cd test
vagrant init fedora/32-cloud-base
vagrant up --provider=libvirt
## VM Commands
vagrant status
virsh list
## Networking Commands
## ref. https://wiki.libvirt.org/page/Networking
## ref. https://wiki.libvirt.org/page/VirtualNetworking
brctl show
virsh net-list --all
virsh net-info vagrant-libvirt
virsh net-dumpxml vagrant-libvirt
General docker related technologies.
Verified: 2020年10月10日
## Install Prerequisites
sudo apt-get install -y \
apt-transport-https \
ca-certificates \
gnupg-agent
## Add Repository
curl -fsSL https://download.docker.com/linux/ubuntu/gpg | sudo apt-key add -
sudo add-apt-repository \
"deb [arch=amd64] https://download.docker.com/linux/ubuntu \
$(lsb_release -cs) \
stable"
## Install Packages
sudo apt update && sudo apt-get install -y docker-ce docker-ce-cli containerd.io
## Allow current user to use docker
sudo usermod -aG docker $USER
Update: 2020年10月16日
Docker Machine allows you to run Docker in a virtual machine guest instead of on the host. This is useful for scenarios to test a clean docker environment in a clean environment.
LATEST_MACHINE=$(curl -s https://api.github.com/repos/docker/machine/releases | jq '[.[].tag_name][0]' -r)
## Install binary
BASE=https://github.com/docker/machine/releases/download/$LATEST_MACHINE
curl -sL $BASE/docker-machine-$(uname -s)-$(uname -m) > /tmp/docker-machine
sudo mv /tmp/docker-machine /usr/local/bin/docker-machine &&
chmod +x /usr/local/bin/docker-machine
## ref. https://docs.docker.com/machine/install-machine/
BASE=https://raw.githubusercontent.com/docker/machine/$LATEST_MACHINE
for IDX in docker-machine-prompt.bash docker-machine-wrapper.bash docker-machine.bash
do
sudo wget "$BASE/contrib/completion/bash/${IDX}" -P /etc/bash_completion.d
done
Currently, neither of the two open source machine drivers kvm
or MiniKube's kvm2
work now with docker-machine
:
- Boot2docker Issues:
1407 -
rtl8139cp
missing kernel configuration - KVM Issues:
- 77 (Oc 2020) - Solution https://github.com/afbjorklund/docker-machine-kvm (thank you @afbjorklund)
- 76 (May 2020)
- KVM2 Issues:
In overview of the problems, the kvm
project is no longer making releases, so users can build binary and patch locally. For kvm2
is only supported with the embedded docker-machine
and the configuration that is sent to it is not documented. Currently, the default options do not work as kvm2
creates an invalid configuration. You can access the docker environment managed by minikube using minikube docker-env
.
## ref. https://github.com/dhiltgen/docker-machine-kvm
## REF. https://blog.scottlowe.org/2017/11/24/using-docker-machine-kvm-libvirt/
LATEST=$(curl curl -s https://api.github.com/repos/dhiltgen/docker-machine-kvm/releases | jq '[.[].tag_name][0]' -r)
curl -sOL https://github.com/dhiltgen/docker-machine-kvm/releases/download/$LATEST/docker-machine-driver-kvm-ubuntu16.04
sudo mv docker-machine-driver-kvm-ubuntu16.04 /usr/local/bin/docker-machine-driver-kvm &&
chmod +x /usr/local/bin/docker-machine-driver-kvm
## configure shell environment for kvm
printf "export export MACHINE_DRIVER=kvm\n" > ~/.toolbox.d/docker-machine.sh
docker-machine create default
eval $(docker-machine env)
docker run hello-world
- Requirements: python3
Create virtualenv for docker-compose (optional):
PYTHON_VERSION="3.9.0"
pyenv virtualenv $PYTHON_VERSION docker-compose-$PYTHON_VERSION
pyenv shell docker-compose-$PYTHON_VERSIONcomponents
pip install docker-compose
## This installs these python modules for docker-compose 1.27.4:
## attrs==20.2.0
## bcrypt==3.2.0
## cached-property==1.5.2
## certifi==2020.6.20
## cffi==1.14.3
## chardet==3.0.4
## cryptography==3.2
## distro==1.5.0
## docker==4.3.1
## docker-compose==1.27.4
## dockerpty==0.4.1
## docopt==0.6.2
## idna==2.10
## jsonschema==3.2.0
## paramiko==2.7.2
## pycparser==2.20
## PyNaCl==1.4.0
## pyrsistent==0.17.3
## python-dotenv==0.14.0
## PyYAML==5.3.1
## requests==2.24.0
## six==1.15.0
## texttable==1.6.3
## urllib3==1.25.11
## websocket-client==0.57.0
LATEST_KUBE=$(curl -s https://storage.googleapis.com/kubernetes-release/release/stable.txt)
curl -sOL https://storage.googleapis.com/kubernetes-release/release/$LATEST_KUBE/bin/linux/amd64/kubectl
chmod +x ./kubectl
sudo mv ./kubectl /usr/local/bin/kubectl
Source: https://kubernetes.io/docs/tasks/tools/install-kubectl/
pushd ~/Downloads
curl -fsSL -o get_helm.sh https://raw.githubusercontent.com/helm/helm/master/scripts/get-helm-3
chmod 700 get_helm.sh
./get_helm.sh
popd
Source: https://helm.sh/docs/intro/install/
helm plugin install https://github.com/databus23/helm-diff
helm plugin install https://github.com/zendesk/helm-secrets
LATEST_HELMFILE=$(curl -s https://api.github.com/repos/roboll/helmfile/releases/latest | jq -r '.tag_name')
curl -sOL https://github.com/roboll/helmfile/releases/download/$LATEST_HELMFILE/helmfile_linux_amd64
chmod +x helmfile_linux_amd64
sudo mv helmfile_linux_amd64 /usr/local/bin/helmfile
Requirements: AWS CLI, kubectl
Amazon EKS clusters can be easily created with eksctl
.
TARBALL="eksctl_$(uname -s)_amd64.tar.gz"
URL_PREFIX="https://github.com/weaveworks/eksctl/releases/latest/download"
curl --silent --location "$URL_PREFIX/$TARBALL" | tar xz -C /tmp
sudo mv /tmp/eksctl /usr/local/bin
Afterward, you can create a cluster:
eksctl create cluster --name <YOUR_CLUSTER_NAME> --region "us-west-2"
Source: https://docs.aws.amazon.com/eks/latest/userguide/getting-started-eksctl.html
Requirements: Azure CLI, kubectl
export RESOURCE_GROUP=<YOUR_RESOURCE_GROUP>
export CLUSTER_NAME=<YOUR_CLUSTER_NAME>
az group create \
--name=${RESOURCE_GROUP} \
--location="centralus" \
az aks create --resource-group ${RESOURCE_GROUP} \
--name ${CLUSTER_NAME} \
--node-count 3 \
--enable-addons monitoring \
--generate-ssh-keys
az aks get-credentials --resource-group ${RESOURCE_GROUP} --name ${CLUSTER_NAME}
Sources
- https://docs.microsoft.com/en-us/azure/aks/kubernetes-walkthrough
- https://zero-to-jupyterhub.readthedocs.io/en/latest/microsoft/step-zero-azure.html
Requirements: Google Cloud SDK, kubectl
## Create Cluster
gcloud container clusters create <YOUR_CLUSTER_NAME> \
--num-nodes 1 \
--machine-type "n1-standard-2" \
--zone "us-central1-b"
## Add K8S administrative privileges to an account
kubectl create clusterrolebinding cluster-admin-binding \
--clusterrole=cluster-admin \
--user=<your-email-address>
Sources
- https://zero-to-jupyterhub.readthedocs.io/en/latest/google/step-zero-gcp.html
- https://cloud.google.com/kubernetes-engine/docs/quickstart
Requirements: kubectl
pushd ~/Downloads
curl -sOL https://storage.googleapis.com/minikube/releases/latest/minikube_latest_amd64.deb
sudo apt install ./minikube_latest_amd64.deb
popd
minikube config set driver virtualbox
minikube start --nodes 3 --profile <YOUR_CLUSTER_NAME>
## ref. https://minikube.sigs.k8s.io/docs/drivers/kvm2/
## ref. https://fedoraproject.org/wiki/How_to_debug_Virtualization_problems
minikube config set driver kvm2
minikube start --nodes 3 --profile <YOUR_CLUSTER_NAME>
wget -q https://packages.microsoft.com/keys/microsoft.asc -O- | sudo apt-key add -
sudo add-apt-repository \
"deb [arch=amd64] https://packages.microsoft.com/repos/vscode \
stable \
main"
sudo apt update && sudo apt -y install code
# delete duplicate entries (not sure why this happens)
sudo rm /etc/apt/sources.list.d/vscode.list*
wget -qO - https://packagecloud.io/AtomEditor/atom/gpgkey | sudo apt-key add -
sudo add-apt-repository \
"deb [arch=amd64] https://packagecloud.io/AtomEditor/atom/any/ \
any \
main"
sudo apt-get update
sudo apt-get install atom
These are common set to tools and libraries needed for both Python and Ruby.
sudo apt-get update
sudo apt-get -y upgrade
sudo apt-get -y dist-upgrade
sudo apt -y autoremove
sudo apt-get install -y \
build-essential \
libffi-dev \
libncurses5-dev \
libncursesw5-dev \
libreadline-dev \
libsqlite3-dev \
libssl-dev \
software-properties-common \
zlib1g-dev
# extra packages needed to build python
sudo apt-get install -y \
libbz2-dev \
liblzma-dev \
llvm \
make \
python-openssl \
tk-dev \
wget \
xz-utils
# install pyenv
PROJ=pyenv-installer
SCRIPT_URL=https://github.com/pyenv/$PROJ/raw/master/bin/$PROJ
curl -sL $SCRIPT_URL | bash
# setup current environment
export PATH="$HOME/.pyenv/bin:$PATH"
eval "$(pyenv init -)"
eval "$(pyenv virtualenv-init -)"
## configure shell environment
cat <<-'PYENV' > ~/.toolbox.d/pyenv.sh
export PATH="$HOME/.pyenv/bin:$PATH"
eval "$(pyenv init -)"
eval "$(pyenv virtualenv-init -)"
PYENV
Now you can install a desired version of Python.
## Fetch Latest pyenv for updated version list
## Only Needed if earlier version of pyenv is used
cd ~/.pyenv/plugins/python-build/../.. && git pull && cd -
LATEST_PYTHON3=$(
pyenv install --list | tr -d ' ' | grep -oP '^3\.*\d+\.\d+' | sort -V | tail -1
)
## install and set desired ruby version (~8 minutes)
pyenv install $LATEST_PYTHON3
pyenv global $LATEST_PYTHON3
# upgrade pip
pip install --upgrade pip
# extra packages needed to build ruby
sudo apt-get install -y \
autoconf \
bison \
libcurl4-openssl-dev \
libgdbm-dev \
libxml2-dev \
libxslt1-dev \
libyaml-dev
## install rbenv
git clone https://github.com/rbenv/rbenv.git ${HOME}/.rbenv
git clone https://github.com/rbenv/ruby-build.git ${HOME}/.rbenv/plugins/ruby-build
## setup current environment
export PATH="$HOME/.rbenv/bin:$PATH"
eval "$(rbenv init -)"
## configure shell environment
cat <<-'RBENV' > ~/.toolbox.d/rbenv.sh
export PATH="$HOME/.rbenv/bin:$PATH"
eval "$(rbenv init -)"
RBENV
Install desired ruby version:
## install recent ruby
LATEST_STABLE_RUBY=$(
rbenv install --list 2> /dev/null | grep -P '^\d\.\d+\.\d+' | sort -V | tail -1
)
## install and set desired ruby version (~12 minutes)
rbenv install $LATEST_STABLE_RUBY
rbenv global $LATEST_STABLE_RUBY
## upgrade gems and install bundler
gem update && gem install bundler
LATEST_NODE=$(curl -s https://nodejs.org/dist/ | html2 | grep -oP '(?<=/html/body/pre/a/@href=)v[0-9.]+' | sort -V | tail -1)
LATEST_NVM=$(curl -s https://api.github.com/repos/nvm-sh/nvm/releases/latest | jq -r '.name')
# From http://nvm.sh
NVM_INSTALL_SCRIPT="https://raw.githubusercontent.com/nvm-sh/nvm/${LATEST_NVM}/install.sh"
curl -so- ${NVM_INSTALL_SCRIPT} | bash
# Use NVM immediately
export NVM_DIR="${HOME}/.nvm"
[[ -s "$NVM_DIR/nvm.sh" ]] && source "$NVM_DIR/nvm.sh"
cat <<-'NVM' >> ~/.toolbox.d/nvm.sh
export NVM_DIR="${HOME}/.nvm"
[[ -s "$NVM_DIR/nvm.sh" ]] && source "$NVM_DIR/nvm.sh"
NVM
Install a version of Node:
LATEST_NODE=$(curl -s https://nodejs.org/dist/ | html2 | grep -oP '(?<=/html/body/pre/a/@href=)v[0-9.]+' | sort -V | tail -1)
command -v nvm &> /dev/null && nvm install $LATEST_NODE
Afterward, install Node modules:
npm -g install typescript coffee-script
LATEST_GO=$(curl -s https://golang.org/dl/ | grep -oP '(?<=go).*(?=.linux-amd64.tar.gz">)' | sort -V | uniq | tail -1)
pushd ~/Downloads
curl -sOL https://golang.org/dl/go${LATEST_GO}.linux-amd64.tar.gz
sudo tar -C /usr/local -xzf go${LATEST_GO}.linux-amd64.tar.gz
export PATH=$PATH:/usr/local/go/bin
popd
## configure shell environment
echo 'export PATH=$PATH:/usr/local/go/bin' >> ~/.toolbox.d/gobin.sh
exec -l bash
## configure shell environment
cat <<-'GOPATH' >> ~/.toolbox.d/gopath.sh
export PATH=$PATH:$(go env GOPATH)/bin
export GOPATH=$(go env GOPATH)
GOPATH
exec -l bash
curl -s https://packages.cloud.google.com/apt/doc/apt-key.gpg | \
sudo apt-key --keyring /usr/share/keyrings/cloud.google.gpg add -
echo "deb [signed-by=/usr/share/keyrings/cloud.google.gpg] https://packages.cloud.google.com/apt cloud-sdk main" | \
sudo tee -a /etc/apt/sources.list.d/google-cloud-sdk.list
sudo apt-get update && sudo apt-get install google-cloud-sdk
- Updated: 2020年10月13日
Currently GCloud SDK is not compatible with latest stable version of Python with Python 3.9.0:
- https://issuetracker.google.com/issues/170716950
- https://stackoverflow.com/questions/64010263/gcloud-not-working-with-fedora33-and-python3-9
In order you use gcloud
command, you need to use a version earlier than Python 3.9. With pyenv
installed, you can run:
PYTHON_VERSION=$(pyenv install --list | tr -d ' ' | grep -P '^3\.7\.\d+'| tail -1)
pyenv install $PYTHON_VERSION
Afterward, before using gcloud
, you can run:
pyenv shell $PYTHON_VERSION
gcloud auth login
# Gtk-Message: 21:08:27.282: Failed to load module "appmenu-gtk-module"
gcloud config set project $PROJECT
gcloud compute instances list
AWS Command Line Tools and
pip install awscli
## aws-cli/1.18.157 installs
## awscli==1.18.157
## botocore==1.18.16
## colorama==0.4.3
## docutils==0.15.2
## jmespath==0.10.0
## pyasn1==0.4.8
## python-dateutil==2.8.1
## PyYAML==5.3.1
## rsa==4.5
## s3transfer==0.3.3
## six==1.15.0
## urllib3==1.25.10
AWS Vault can secure AWS credentials in local environment.
## ref. https://github.com/99designs/aws-vault
## article: https://99designs.com.au/tech-blog/blog/2015/10/26/aws-vault/
LATEST_AWSVAULT=$(curl -s https://api.github.com/repos/99designs/aws-vault/releases/latest | jq -r '.tag_name')
curl -sOL https://github.com/99designs/aws-vault/releases/download/$LATEST_AWSVAULT/aws-vault-linux-amd64
chmod +x aws-vault-linux-amd64 && sudo mv aws-vault-linux-amd64 /usr/local/bin/aws-vault
You can run your aws configure
to setup the initial configuration, or set this up manually.
## credentials = aws access key and aws secret key
## config = default region and default output format
mkdir -p ~/.aws && touch ~/.aws/{credentials,config}
## replace REDACTED with your keys
cat <<-CREDEOF > ~/.aws/credentials
[default]
aws_access_key_id = REDACTED
aws_secret_access_key = REDACTED
CREDEOF
## replace region/output with desired values
cat <<-CONFEOF > ~/.aws/credentials
[default]
region = us-west-2
output = json
CONFEOF
You can have multiple profiles, AWS calls these named profiles, for different users and levels of access. Some use cases could include accounts for different customers, different environments (e.g. test
, stage
, prod
), or different levels of access, such as S3 bucket vs. full administrator vs. kubernetes operator.
Below are some examples, using a ACME company. Note that the config
prepends the profile with the word profile
, with exception to the default profile, while credentials
does not. And yes, this is inconsistent and confusing.
$HOME/.aws/config:
[default]
region = us-west-2
output = json
[profile myhomestuff]
region = us-west-2
output = json
[profile acme-dev]
region = us-west-2
output = json
[profile acme-prod]
region = us-west-2
output = json
$HOME/.aws/credentials:
[default]
aws_access_key_id = REDACTED
aws_secret_access_key = REDACTED
[myhomestuff]
aws_access_key_id = REDACTED
aws_secret_access_key = REDACTED
[acme-dev]
aws_access_key_id = REDACTED
aws_secret_access_key = REDACTED
[acme-prod]
aws_access_key_id = REDACTED
aws_secret_access_key = REDACTED
You can configure the current working profile with AWS_PROFILE
(previously it was AWS_DEFAULT_PROFILE
).
cat <<-'LISTAWS' > ~/.toolbox.d/list_aws.sh
setaws() { [[ $# -ne 0 ]] && export AWS_PROFILE=$1; }
getaws() { echo AWS_PROFILE=$AWS_PROFILE; }
listaws() {
local PROFILES=$(grep profile ${HOME}/.aws/config | sed 's/profile //' | tr -d '[]')
for PROFILE in ${PROFILES}; do
if [[ ${PROFILE} == ${AWS_PROFILE} ]]; then
SEL="=>"
else
SEL=" "
fi
printf " ${SEL} %s\n" ${PROFILE};
done
}
LISTAWS
sudo apt remove azure-cli -y && sudo apt autoremove -y
curl -sL https://aka.ms/InstallAzureCLIDeb | sudo bash
Once installed you can log in and do Azure stuffs:
az login
Alright, I am not endorsing any particular tool, install the ones you like.
Create virtualenv for ansible (optional):
PYTHON_VERSION="3.9.0"
pyenv virtualenv $PYTHON_VERSION ansible-$PYTHON_VERSION
pyenv shell ansible-$PYTHON_VERSION
Install ansible with the current python version:
pip install ansible
## This installs these components:
## ansible==2.10.1
## ansible-base==2.10.2
## cffi==1.14.3
## cryptography==3.1.1
## Jinja2==2.11.2
## MarkupSafe==1.1.1
## packaging==20.4
## pycparser==2.20
## pyparsing==2.4.7
## PyYAML==5.3.1
## six==1.15.0
Create virtualenv for ansible (optional):
PYTHON_VERSION="3.9.0"
pyenv virtualenv $PYTHON_VERSION saltstack-$PYTHON_VERSION
pyenv shell saltstack-$PYTHON_VERSION
Install ansible with the current python version:
pip install salt
## This installs these components:
## certifi==2020.6.20
## chardet==3.0.4
## distro==1.5.0
## idna==2.10
## Jinja2==2.11.2
## MarkupSafe==1.1.1
## msgpack==1.0.0
## pycryptodomex==3.9.8
## PyYAML==5.3.1
## pyzmq==19.0.2
## requests==2.24.0
## salt==3001.1
## urllib3==1.25.10
You can fetch and install CFEngine 3.16 with:
wget -O- http://cfengine.package-repos.s3.amazonaws.com/quickinstall/quick-install-cfengine-community.sh | sudo bash
For a more formal installation, you can run this instead:
curl -fsSL https://cfengine-repotest.s3.amazonaws.com/pub/gpg.key | sudo apt-key add -
sudo add-apt-repository \
"deb https://cfengine-package-repos.s3.amazonaws.com/pub/apt/packages \
stable \
main"
- Updated: 2020年10月15日
If you have puppet installed already, you should remove it: sudo apt-get purge puppet
The instructions from Puppet are a bit unorthodox in that there's a deb package used to install requirements needed to install a deb package. These instructions cover best practices for adding external repository (gpg key + /etc/apt/sources.list.d/
list) and then installing the package, as well as making the tools accessible to run from the command line, something the puppet debian packages do not do.
The following components will be installed:
puppet-agent
(version6.15.0-1focal
) - contains all the components to runpuppet
including embedded ruby,facter
,hiera
puppet-bolt
(version2.30.0-1focal
) - task runner tool that can remote execute taskspdk
(version:1.18.1.0-1focal
) - puppet development kit used to build puppet modules
sudo apt-key adv \
--keyserver "hkp://pgp.mit.edu" \
--recv-keys "EF8D349F"
This system is production ready but un
# Add entry for Puppet Repository
echo "deb http://apt.puppetlabs.com $(lsb_release -c -s) puppet" \
| sudo tee -a /etc/apt/sources.list.d/puppet.list
# Install Puppet from Puppet Repository
sudo apt-get update && sudo apt-get install -y puppet-agent puppet-bolt pdk
# Make tools accessible
for ITEM in /opt/puppetlabs/bin/*; do
[[ -f /usr/local/bin/${ITEM##*/} ]] || \
sudo ln -sf /opt/puppetlabs/puppet/bin/wrapper.sh /usr/local/bin/${ITEM##*/}
done
NOTE: The Marionette Collective, a parallel execution and orchestration solution, has been deprecated by Puppet. The author had made this available as well as new project to cover the same functionality.
More information on legacy MCollective:
- The Marionette Collective Deprecation
- Marionette Collective
- Orchestration with MCollective
- puppet-mcollective
- Choria Legacy
- Updated: 2020年10月14日
Chef is a popular change configuration management solution that uses ruby
to configure servers by converging to a desired state specified in the Chef scripts called recipes. The ChefDK bundles several tools used with Chef, so that they do not have to be installed individually. It comes with its own embedded Ruby.
## extract part of JavaScript to get version list and get latest version
VERS=$(
echo "{$(curl -s https://downloads.chef.io/products/chefdk/ | \
grep -oP '"versionList.*\](?=,)')}" | \
jq -r '.versionList[]' | sort -V | tail -1
)
pushd ~/Downloads
curl -sOL https://packages.chef.io/files/stable/chefdk/$VERS/ubuntu/20.04/chefdk_$VERS-1_amd64.deb
sudo apt install ./chefdk_$VERS-1_amd64.deb
popd
If you use Knife-Zero, you can install it into Chef's embedded ruby environment:
chef exec gem install knife-zero
- Verified: 2020年10月13日
get_latest() {
local TYPE=${1}
local LATEST=$(curl -s https://github.com/hashicorp/$TYPE/releases.atom | xml2 | \
grep -oP '(?<=feed/entry/title=)v\d+.\d+.\d+$' | sort -V | tail -1
)
echo ${LATEST##v}
}
install_latest() {
local TYPE=${1}
local VERSION=$(get_latest $TYPE)
curl -sOL https://releases.hashicorp.com/$TYPE/$VERSION/${TYPE}_${VERSION}_linux_amd64.zip
unzip ${TYPE}_${VERSION}_linux_amd64.zip
sudo mv $TYPE /usr/local/bin
rm ${TYPE}_${VERSION}_linux_amd64.zip
}
pushd ~/Downloads
## Adjust list of desired tools to the ones you need
TOOLS="consul consul-template nomad packer terraform vault boundary waypoint"
for TOOL in $TOOLS; do install_latest $TOOL; done
popd
Some open source applications that you may want, edit as desired.
- Updated: 2020年10月13日
# add credentials for remote repository
curl -sS https://download.spotify.com/debian/pubkey_0D811D58.gpg | sudo apt-key add -
echo "deb http://repository.spotify.com stable non-free" | \
sudo tee /etc/apt/sources.list.d/spotify.list
# update package list and install spotify
sudo apt-get update && sudo apt-get install spotify-client
- Updated: 2020年10月15日
## scrape URL from website
DOWNLOAD_URL=$(
curl -s https://slack.com/downloads/instructions/ubuntu | \
grep -o 'https://downloads.slack-edge.com/linux_releases/slack-desktop-.*-amd64.deb'
)
## download and isntall
pushd ~/Downloads
curl -sOL $DOWNLOAD_URL && sudo apt install ./${DOWNLOAD_URL##*/}
popd