Compare commits

...

15 Commits
v1.00 ... v1.02

Author SHA1 Message Date
Kroese
1bef943281 feat: Local drivers (#18) 2024-01-15 05:33:59 +01:00
Kroese
32e6b2a77e docs: Title (#17) 2024-01-15 05:02:12 +01:00
Kroese
cabf74a0ba fix: Web GUI before install (#16) 2024-01-15 04:27:57 +01:00
Kroese
1a08bcea4a docs: Features (#15) 2024-01-15 04:11:08 +01:00
Kroese
5d32e036dc docs: Installation (#14) 2024-01-15 04:04:39 +01:00
Kroese
a958bb1dcf docs: Installation (#13) 2024-01-15 04:01:54 +01:00
Kroese
ed4f6f7f7f docs: Webbased viewer (#12) 2024-01-15 03:58:58 +01:00
Kroese
f1bcd5a9ee docs: Minimum requirements (#11) 2024-01-15 03:38:24 +01:00
Kroese
3943181075 docs: Installation steps (#10) 2024-01-15 03:31:58 +01:00
Kroese
9fd26e4145 docs: Readme (#9) 2024-01-14 20:52:15 +01:00
Kroese
21ea7584a4 fix: Remove progress (#8) 2024-01-14 20:44:08 +01:00
Kroese
0652998966 fix: Quotes (#7) 2024-01-14 20:33:50 +01:00
Kroese
131fa1379b feat: Windows 11 support (#6) 2024-01-14 20:32:24 +01:00
Kroese
748bf5f4e7 docs: CPU cores 2024-01-14 20:12:08 +01:00
Kroese
7cc56998cb docs: Windows 11 support 2024-01-14 19:13:24 +01:00
4 changed files with 62 additions and 38 deletions

View File

@@ -8,17 +8,23 @@ RUN apt-get update \
&& apt-get --no-install-recommends -y install \ && apt-get --no-install-recommends -y install \
curl \ curl \
novnc \ novnc \
swtpm \
p7zip-full \
genisoimage \
&& apt-get clean \ && apt-get clean \
&& rm -rf /var/lib/apt/lists/* /tmp/* /var/tmp/* && rm -rf /var/lib/apt/lists/* /tmp/* /var/tmp/*
COPY ./src /run/ COPY ./src /run/
ADD https://raw.githubusercontent.com/ElliotKillick/Mido/main/Mido.sh /run/mido.sh ADD https://raw.githubusercontent.com/ElliotKillick/Mido/main/Mido.sh /run/mido.sh
ADD https://fedorapeople.org/groups/virt/virtio-win/direct-downloads/stable-virtio/virtio-win.iso /run/drivers.iso
RUN chmod +x /run/*.sh RUN chmod +x /run/*.sh
EXPOSE 8006 EXPOSE 8006
VOLUME /storage VOLUME /storage
ENV CPU_CORES "1" ENV CPU_CORES "2"
ENV RAM_SIZE "4G" ENV RAM_SIZE "4G"
ENV DISK_SIZE "64G" ENV DISK_SIZE "64G"

View File

@@ -1,4 +1,4 @@
<h1 align="center">Windows for Docker<br /> <h1 align="center">Windows in Docker<br />
<div align="center"> <div align="center">
<img src="https://github.com/dockur/windows/raw/master/.github/logo.png" title="Logo" style="max-width:100%;" width="128" /> <img src="https://github.com/dockur/windows/raw/master/.github/logo.png" title="Logo" style="max-width:100%;" width="128" />
</div> </div>
@@ -16,7 +16,9 @@ Windows in a docker container.
## Features ## Features
- Multi-platform - Multi-platform
- ISO downloader
- KVM acceleration - KVM acceleration
- Web-based viewer
## Usage ## Usage
@@ -29,7 +31,7 @@ services:
container_name: windows container_name: windows
image: dockurr/windows:latest image: dockurr/windows:latest
environment: environment:
VERSION: "win10x64" VERSION: "win11x64"
devices: devices:
- /dev/kvm - /dev/kvm
cap_add: cap_add:
@@ -43,39 +45,58 @@ services:
Via `docker run` Via `docker run`
```bash ```bash
docker run -it --rm -e "VERSION=win10x64" -p 8006:8006 --device=/dev/kvm --cap-add NET_ADMIN dockurr/windows:latest docker run -it --rm -e "VERSION=win11x64" -p 8006:8006 --device=/dev/kvm --cap-add NET_ADMIN dockurr/windows:latest
``` ```
## FAQ ## FAQ
* ### How do I perform the installation?
- Start the container and wait until the ISO download is completed. If needed, you can view this progress in the Docker log, wait until you see the message ```BdsDxe: starting Boot```.
- Connect to port 8006 of the container in your webbrowser.
- Start the installation by clicking ```Install now```. On the next screen, press 'OK' when prompted for ```Load driver``` and select the ```VirtIO SCSI``` driver from the list that matches your Windows version. So for Windows 11, select ```D:\amd64\w11\vioscsi.inf``` and click 'Next'.
- Accept the license agreement and select your preferred Windows edition, like Home or Pro.
- Choose ```Custom: Install Windows only (advanced)```, and click ```Load driver``` in the next screen. Select 'Browse' and navigate to the ```D:\NetKVM\w11\amd64``` folder and click 'OK'. Select the ```VirtIO Ethernet Adapter``` from the list, and click 'Next'.
- Select 'Drive 0' and click 'Next'.
- Wait until Windows finishes copying files and completes the installation.
- Once you see your desktop, open File Explorer and navigate to the CD-ROM drive (D:). Double-click on ```virtio-win-gt-x64``` and proceed to install the VirtIO drivers.
- Now your Windows installation is ready for use. Enjoy it and don't forget to star this repo!
* ### How do I specify the Windows version? * ### How do I specify the Windows version?
You can modify the `VERSION` environment variable to specify the version you want: You can modify the `VERSION` environment variable to specify the version of Windows you want to download:
```yaml ```yaml
environment: environment:
VERSION: "win10x64" VERSION: "win11x64"
``` ```
Select from the values below: Select from the values below:
- ~~```win11x64``` (Windows 11)~~ - ```win11x64``` (Windows 11)
- ```win10x64``` (Windows 10) - ```win10x64``` (Windows 10)
- ```win81x64``` (Windows 8.1) - ```win81x64``` (Windows 8.1)
- ```win7x64-ultimate``` (Windows 7 )
- ```win2016-eval``` (Windows Server 2016)
- ```win2019-eval``` (Windows Server 2019)
- ```win2022-eval``` (Windows Server 2022) - ```win2022-eval``` (Windows Server 2022)
- ```win2019-eval``` (Windows Server 2019)
* ### How do I see the screen? - ```win2016-eval``` (Windows Server 2016)
* ### How can I view the screen?
The container includes a web-based viewer, so you can visit [http://localhost:8006/](http://localhost:8006/) using any webbrowser to view the screen and interact with Windows via the keyboard/mouse. The container includes a web-based viewer, so you can visit [http://localhost:8006/](http://localhost:8006/) using any webbrowser to view the screen and interact with Windows via the keyboard/mouse.
Alternatively it is also possible to connect to port 5900 using a VNC client like RealVNC or many others. This is mainly for use during installation, as afterwards you can use Remote Desktop, TeamViewer or any other software you prefer.
* ### How do I increase the amount of CPU or RAM? * ### How do I increase the amount of CPU or RAM?
By default, a single core and 4 GB of RAM are allocated to the container. By default, 2 CPU cores and 4 GB of RAM are allocated to the container, as that are the minimum requirements of Windows 11.
To increase this, add the following environment variables: To increase this, add the following environment variables:

View File

@@ -7,6 +7,9 @@ echo " For support visit https://github.com/dockur/windows"
export DISPLAY=web export DISPLAY=web
export BOOT_MODE=windows export BOOT_MODE=windows
ln -sfn /usr/share/novnc/vnc_lite.html /usr/share/novnc/index.html
websockify -D --web /usr/share/novnc/ 8006 localhost:5900 2>/dev/null
cd /run cd /run
. reset.sh # Initialize system . reset.sh # Initialize system
@@ -20,9 +23,8 @@ cd /run
trap - ERR trap - ERR
if [[ "${DISPLAY,,}" == "web" ]]; then mkdir -p /tmp/emulated_tpm
websockify -D --web /usr/share/novnc/ 8006 localhost:5900 2>/dev/null swtpm socket -t -d --tpmstate dir=/tmp/emulated_tpm --ctrl type=unixio,path=/tmp/emulated_tpm/swtpm-sock --log level=1 --tpm2
fi
info "Booting Windows using $VERS..." info "Booting Windows using $VERS..."

View File

@@ -1,40 +1,35 @@
#!/usr/bin/env bash #!/usr/bin/env bash
set -Eeuo pipefail set -Eeuo pipefail
: "${VERSION:="win10x64"}" : "${VERSION:="win11x64"}"
ARGUMENTS="-chardev socket,id=chrtpm,path=/tmp/emulated_tpm/swtpm-sock $ARGUMENTS"
ARGUMENTS="-tpmdev emulator,id=tpm0,chardev=chrtpm -device tpm-tis,tpmdev=tpm0 $ARGUMENTS"
BASE="$VERSION.iso" BASE="$VERSION.iso"
[ -f "$STORAGE/$BASE" ] && return 0 [ -f "$STORAGE/$BASE" ] && return 0
# Check if running with interactive TTY or redirected to docker log rm -rf "$STORAGE/tmp"
if [ -t 1 ]; then mkdir -p "$STORAGE/tmp"
PROGRESS="--progress=bar:noscroll" SCRIPT="$STORAGE/tmp/mido.sh"
else
PROGRESS="--progress=dot:giga"
fi
SCRIPT="$STORAGE/mido.sh"
rm -f "$SCRIPT"
cp /run/mido.sh "$SCRIPT" cp /run/mido.sh "$SCRIPT"
chmod +x "$SCRIPT" chmod +x "$SCRIPT"
cd "$STORAGE/tmp"
bash "$SCRIPT" "$VERSION" bash "$SCRIPT" "$VERSION"
rm -f "$SCRIPT" rm -f "$SCRIPT"
[ ! -f "$STORAGE/$BASE" ] && error "Failed to download $VERSION.iso!" && exit 66 [ ! -f "$STORAGE/tmp/$BASE" ] && error "Failed to download $VERSION.iso from the Microsoft servers!" && exit 66
DEST="$STORAGE/drivers.img" info "Customizing ISO to remove keypress requirement during boot..."
if [ ! -f "$DEST" ]; then 7z x "$BASE" -ounpack
genisoimage -b boot/etfsboot.com -no-emul-boot -c BOOT.CAT -iso-level 4 -J -l -D -N -joliet-long -relaxed-filenames -v -V "Custom" -udf -boot-info-table -eltorito-alt-boot -eltorito-boot efi/microsoft/boot/efisys_noprompt.bin -no-emul-boot -o "$STORAGE/tmp/$BASE.tmp" -allow-limited-size unpack
info "Downloading VirtIO drivers for Windows..." mv "$STORAGE/tmp/$BASE.tmp" "$STORAGE/$BASE"
DRIVERS="https://fedorapeople.org/groups/virt/virtio-win/direct-downloads/stable-virtio/virtio-win.iso" rm -rf "$STORAGE/tmp"
{ wget "$DRIVERS" -O "$DEST" -q --no-check-certificate --show-progress "$PROGRESS"; rc=$?; } || : cd /run
(( rc != 0 )) && info "Failed to download $DRIVERS, reason: $rc" && rm -f "$DEST"
fi
return 0 return 0