Skip to content

Commit

Permalink
feat: Automaticly set controlport
Browse files Browse the repository at this point in the history
feat: Automaticly set controlport
  • Loading branch information
kroese authored Nov 20, 2023
2 parents d497d70 + 546532c commit 5161d0f
Show file tree
Hide file tree
Showing 6 changed files with 24 additions and 25 deletions.
7 changes: 1 addition & 6 deletions Dockerfile
Original file line number Diff line number Diff line change
Expand Up @@ -18,12 +18,7 @@ RUN apt-get update && apt-get -y upgrade && \
&& apt-get clean \
&& rm -rf /var/lib/apt/lists/* /tmp/* /var/tmp/*

# Using a wildcard causes caching problems on some systems
COPY src/disk.sh /run/
COPY src/display.sh /run/
COPY src/entry.sh /run/
COPY src/install.sh /run/
COPY src/network.sh /run/
COPY ./src /run/
RUN chmod +x /run/*.sh

VOLUME /storage
Expand Down
5 changes: 2 additions & 3 deletions docker-compose.yml
Original file line number Diff line number Diff line change
Expand Up @@ -4,12 +4,11 @@ services:
container_name: qemu
image: qemux/qemu-docker:latest
environment:
DISPLAY: "vnc"
CPU_CORES: "1"
RAM_SIZE: "512M"
DISK_SIZE: "16G"
BOOT: "https://dl-cdn.alpinelinux.org/alpine/v3.18/releases/x86_64/alpine-standard-3.18.2-x86_64.iso"
DISPLAY: "vnc"
CONTROL_PORTS: "5900"
devices:
- /dev/kvm
- /dev/vhost-net
Expand All @@ -18,7 +17,7 @@ services:
cap_add:
- NET_ADMIN
ports:
- 22:22
- 2222:22
- 5900:5900
restart: on-failure
stop_grace_period: 1m
28 changes: 15 additions & 13 deletions readme.md
Original file line number Diff line number Diff line change
Expand Up @@ -28,14 +28,16 @@ services:
container_name: qemu
image: qemux/qemu-docker:latest
environment:
DISPLAY: "vnc"
DISK_SIZE: "16G"
BOOT: "https://dl-cdn.alpinelinux.org/alpine/v3.18/releases/x86_64/alpine-standard-3.18.2-x86_64.iso"
devices:
- /dev/kvm
cap_add:
- NET_ADMIN
ports:
- 22:22
- 2222:22
- 5900:5900
restart: on-failure
```
Expand Down Expand Up @@ -124,8 +126,19 @@ docker run -it --rm -e "BOOT=http://www.example.com/image.iso" --device=/dev/kvm
```

If you receive an error from `kvm-ok` indicating that KVM acceleration can't be used, check your BIOS settings.

* ### How can I connect with VNC?

To enable VNC, add the following lines to your compose file:

```yaml
environment:
DISPLAY: "vnc"
ports:
- 5900:5900
```

* ### How do I provide extra arguments to QEMU?
* ### How do I provide custom arguments to QEMU?

You can create the `ARGUMENTS` environment variable to provide additional arguments to QEMU at runtime:

Expand Down Expand Up @@ -187,17 +200,6 @@ docker run -it --rm -e "BOOT=http://www.example.com/image.iso" --device=/dev/kvm

Please note that even if you don't need DHCP, it's still recommended to enable this feature as it prevents NAT issues and increases performance by using a `macvtap` interface.

* ### How can I connect with VNC?

To enable VNC, add the following lines to your compose file:

```yaml
ports:
"5900:5900"
environment:
DISPLAY: "vnc"
```

[build_url]: https://github.com/qemu-tools/qemu-docker/
[hub_url]: https://hub.docker.com/r/qemux/qemu-docker/
[tag_url]: https://hub.docker.com/r/qemux/qemu-docker/tags
Expand Down
2 changes: 1 addition & 1 deletion src/display.sh
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,7 @@ set -Eeuo pipefail

: ${DISPLAY:='none'} # Display type

case "$DISPLAY" in
case "${DISPLAY,,}" in
vnc)
DISPLAY_OPTS="-nographic -vga std -vnc :0"
;;
Expand Down
3 changes: 1 addition & 2 deletions src/entry.sh
Original file line number Diff line number Diff line change
Expand Up @@ -33,8 +33,8 @@ cd /run

. install.sh # Get bootdisk
. disk.sh # Initialize disks
. network.sh # Initialize network
. display.sh # Initialize display
. network.sh # Initialize network

KVM_ERR=""
KVM_OPTS=""
Expand Down Expand Up @@ -69,7 +69,6 @@ ARGS=$(echo "$ARGS" | sed 's/\t/ /g' | tr -s ' ')
trap - ERR
info "Booting image using ${VERS}..."


[[ "${DEBUG}" == [Yy1]* ]] && set -x
exec qemu-system-x86_64 ${ARGS:+ $ARGS}
{ set +x; } 2>/dev/null
4 changes: 4 additions & 0 deletions src/network.sh
Original file line number Diff line number Diff line change
Expand Up @@ -148,6 +148,10 @@ configureNAT () {

ip link set dev "${VM_NET_TAP}" master dockerbridge

if [[ -z "${CONTROL_PORTS}" ]] && [[ "${DISPLAY,,}" == "vnc" ]]; then
CONTROL_PORTS='5900'
fi

CONTROL_PORT_ARGS=''
for PORT in $CONTROL_PORTS ; do
CONTROL_PORT_ARGS="$CONTROL_PORT_ARGS ! --dport $PORT"
Expand Down

0 comments on commit 5161d0f

Please sign in to comment.