2
0
mirror of https://github.com/linka-cloud/d2vm.git synced 2024-11-22 15:56:24 +00:00
d2vm/examples/full
Adphi a41be6d27c
fix: dockerfile relative path when running in docker
docs: update README.md to current command line api
fix: command line output white for default level

Signed-off-by: Adphi <philippe.adrien.nousse@gmail.com>
2022-09-10 19:41:36 +02:00
..
.dockerignore cli: improve flags and commands 2022-04-21 18:28:50 +02:00
build.sh cli: improve flags and commands 2022-04-21 18:28:50 +02:00
Dockerfile add verbose flag, deprecate debug false 2022-09-10 19:41:31 +02:00
README.md fix: dockerfile relative path when running in docker 2022-09-10 19:41:36 +02:00
resize cli: improve flags and commands 2022-04-21 18:28:50 +02:00

ZSH Workstation example

This example demonstrate the setup of a ZSH workstation with cloud-init support.

Dockerfile

FROM ubuntu

# Install some system packages
RUN apt update && DEBIAN_FRONTEND=noninteractive apt install -y --no-install-recommends \
      qemu-guest-agent \
      ca-certificates \
      dnsutils \
      sudo \
      openssh-server

# Add a utility script to resize serial terminal
COPY resize /usr/local/bin/

# User setup variables
ARG USER=d2vm
ARG PASSWORD=d2vm
ARG SSH_KEY=https://github.com/${USER}.keys

# Setup user environment
RUN DEBIAN_FRONTEND=noninteractive apt install -y --no-install-recommends \
      bash-completion \
      curl \
      zsh \
      git \
      vim \
      tmux \
      htop \
      lsb-core \
      cloud-init \
      cloud-guest-utils

# Create user with sudo privileged and passwordless sudo
RUN useradd ${USER} -m -s /bin/zsh -G sudo && \
      echo "${USER}:${PASSWORD}" | chpasswd && \
      sed -i 's|ALL=(ALL:ALL) ALL|ALL=(ALL:ALL) NOPASSWD: ALL|g' /etc/sudoers

# Add ssh public keys
ADD ${SSH_KEY} /home/${USER}/.ssh/authorized_keys
# Setup permission on .ssh directory
RUN chown -R ${USER}:${USER} /home/${USER}/.ssh

# Run everything else as the created user
USER ${USER}

# Setup zsh environment
RUN bash -c "$(curl -fsSL https://gist.githubusercontent.com/Adphi/f3ce3cc4b2551c437eb667f3a5873a16/raw/be05553da87f6e9d8b0d290af5aa036d07de2e25/env.setup)"
# Setup tmux environment
RUN bash -c "$(curl -fsSL https://gist.githubusercontent.com/Adphi/765e9382dd5e547633be567e2eb72476/raw/a3fe4b3f35e598dca90e2dd45d30dc1753447a48/tmux-setup)"
# Setup auto login serial console
RUN sudo sed -i "s|ExecStart=.*|ExecStart=-/sbin/agetty --autologin ${USER} --keep-baud 115200,38400,9600 \%I \$TERM|" /usr/lib/systemd/system/serial-getty@.service

There is no need to configure the network as d2vm will generate a netplan configuration that use DHCP.

Build

USER=mygithubuser
PASSWORD=mysecurepasswordthatIwillneverusebecauseIuseMostlySSHkeys
OUTPUT=workstation.qcow2

d2vm build -o $OUTPUT --build-arg USER=$USER --build-arg PASSWORD=$PASSWORD --build-arg SSH_KEY=https://github.com/$USER.keys --force -v .

Run it:

d2vm run qemu --mem 4096 --cpus 4 $IMAGE

... you should be automatically logged in with a oh-my-zsh shell

You should be able to find the ip address inside the VM using:

hostname -I
# or
ip a show eth0 | grep inet | awk '{print $2}' | cut -d/ -f1

And connect using ssh...

In order to quit the terminal you need to shut down the VM with the poweroff command:

sudo poweroff

I hope you will find it useful and that you will have fun...