Source: https://gist.github.com/berndbausch/a6835150c7a26c88048763c0bd739be6
Interestingly, the LXD command line client is named…. lxc
!
List available containers
lxc image list ubuntu: # ubuntu: is officially supported image source lxc image list images: # images: is an unsupported source lxc image alias list images: # lists user-friendly names
Launch a container
This creates and starts a container.
lxc launch ubuntu:14.04 CONTAINERNAME # image and container names are optional lxc launch ubuntu:14.04/armhf armcont # specific architecture lxc launch images:alpine/3.3/amd64 # unsupported images: source
Create container
Without starting it.
lxc init images:alpine/3.3/amd64 alpinecont lxc copy CONTAINER1 CONTAINER2 # clone lxc delete alpinecont [--force] # --force if it is running
Start/stop after creating it
lxc start alpinecont lxc stop alpinecont [--force] # --force if it doesn't want to stop lxc restart alpinecont [--force] lxc pause alpinecont # SIGSTOP to all container processes
List local containers
lxc list lxc list --columns "nsapt" # name, status, arch, PID of init, type lxc list security.privileged=true # filter for properties lxc info CONTAINERNAME # detailed info about one container
Available columns for the list command
4 - IPv4 address 6 - IPv6 address a - Architecture c - Creation date n - Name p - PID of the container's init process P - Profiles s - State S - Number of snapshots t - Type (persistent or ephemeral)
Rename
lxc move CONTAINERNAME NEWNAME
Configuration
Config changes are effective immediately, even if container is running.
export VISUAL=/usr/bin/vim lxc config edit CONTAINERNAME # launches editor lxc config set CONTAINERNAME KEY VALUE # change a single config item lxc config device add CONTAINERNAME DEVICE TYPE KEY=VALUE lxc config show [--expanded] CONTAINERNAME Configuration settings can be saved as **profiles**.
Enter the container
lxc exec CONTAINERNAME -- PROGRAM OPTIONS lxc exec CONTAINERNAME sh lxc exec CONATINERNAME --env KEY=VALUE PROGRAM # environment variable
This command runs the program in all the namespaces and cgroups of the container. The program must exist inside the container.
Access container files
lxc file pull CONTAINERNAME/etc/passwd /tmp/mypasswd lxc file push /tmp/mypasswd CONTAINERNAME/etc/passwd lxc file edit CONTAINERNAME/etc/passwd
Snapshots
lxc snapshot CONTAINERNAME SNAPNAME # SNAPNAME is optional; default name snap*X* lxc restore CONTAINERNAME SNAPNAME # resets the container to snapshot lxc copy CONTAINERNAME/SNAPNAME NEWCONTAINER # new container from snapshot lxc delete CONTAINERNAME/SNAPNAME lxc info CONTAINERNAME # lists snapshots among other info lxc move CONTAINERNAME/SNAPNAME CONTAINERNAME/NEWSNAPNAME # rename snapshot
# Forward a local port to a container lxc config device add nx-mysql-1 myport3306 proxy listen=tcp:0.0.0.0:3306 connect=tcp:127.0.0.1:3306 # Update a (ubuntu/mint) container lxc exec $container -- bash -c "apt update && apt upgrade -y && apt autoremove -y"
194200cookie-checkLinux: LXD /LXC containers