diff --git a/.github/workflows/library-ruby3.4.yaml b/.github/workflows/library-ruby3.4.yaml new file mode 100644 index 00000000..2abfb83b --- /dev/null +++ b/.github/workflows/library-ruby3.4.yaml @@ -0,0 +1,83 @@ +name: library/ruby:3.4 + +on: + repository_dispatch: + types: [core_merge, elfloader_merge, libelf_merge, lwip_merge] + + workflow_dispatch: + + schedule: + - cron: '45 1 * * *' + + push: + branches: [main] + paths: + - 'library/ruby/3.4/**' + - '.github/workflows/library-ruby3.4.yaml' + + pull_request: + types: [opened, synchronize, reopened] + branches: [main] + paths: + - 'library/ruby/3.4/**' + - '.github/workflows/library-ruby3.4.yaml' + +# Automatically cancel in-progress actions on the same branch +concurrency: + group: ${{ github.workflow }}-${{ github.event_name == 'pull_request_target' && github.head_ref || github.ref }} + cancel-in-progress: true + +jobs: + build: + strategy: + fail-fast: false + matrix: + include: + - plat: qemu + arch: x86_64 + - plat: fc + arch: x86_64 + + runs-on: ubuntu-latest + + steps: + - uses: actions/checkout@v4 + + - name: Build ruby3.4 + uses: unikraft/kraftkit@staging + with: + loglevel: debug + workdir: library/ruby/3.4 + runtimedir: /github/workspace/.kraftkit + plat: ${{ matrix.plat }} + arch: ${{ matrix.arch }} + push: false + output: oci://index.unikraft.io/unikraft.org/ruby:3.4 + + - name: Archive OCI digests + uses: actions/upload-artifact@v4 + with: + name: oci-digests-${{ matrix.arch }}-${{ matrix.plat }} + path: ${{ github.workspace }}/.kraftkit/oci/digests + if-no-files-found: error + + push: + if: ${{ github.event_name == 'push' || github.event_name == 'schedule' }} + needs: [ build ] + runs-on: ubuntu-latest + + steps: + - uses: actions/checkout@v4 + + - name: Login to OCI registry + uses: docker/login-action@v3 + with: + registry: index.unikraft.io + username: ${{ secrets.REG_USERNAME }} + password: ${{ secrets.REG_TOKEN }} + + - name: Retrieve, merge and push OCI digests + uses: ./.github/actions/merge-oci-digests + with: + name: index.unikraft.io/unikraft.org/ruby:3.4 + push: true diff --git a/examples/httpserver-ruby3.4-base/.dockerignore b/examples/httpserver-ruby3.4-base/.dockerignore new file mode 100644 index 00000000..1b8123b9 --- /dev/null +++ b/examples/httpserver-ruby3.4-base/.dockerignore @@ -0,0 +1 @@ +/.unikraft/ diff --git a/examples/httpserver-ruby3.4-base/.gitignore b/examples/httpserver-ruby3.4-base/.gitignore new file mode 100644 index 00000000..1b8123b9 --- /dev/null +++ b/examples/httpserver-ruby3.4-base/.gitignore @@ -0,0 +1 @@ +/.unikraft/ diff --git a/examples/httpserver-ruby3.4-base/Dockerfile b/examples/httpserver-ruby3.4-base/Dockerfile new file mode 100644 index 00000000..26f2e7e7 --- /dev/null +++ b/examples/httpserver-ruby3.4-base/Dockerfile @@ -0,0 +1,41 @@ +FROM --platform=linux/x86_64 ruby:3.4-bookworm AS build + +FROM alpine:3 AS sys + +RUN set -xe; \ + mkdir -p /target/etc; \ + mkdir -p /blank; \ + apk --no-cache add \ + ca-certificates \ + tzdata \ + ; \ + update-ca-certificates; \ + ln -sf ../usr/share/zoneinfo/Etc/UTC /target/etc/localtime; \ + echo "Etc/UTC" > /target/etc/timezone; + +FROM scratch + +COPY --from=sys /target/etc /etc +COPY --from=sys /usr/share/zoneinfo/Etc/UTC /usr/share/zoneinfo/Etc/UTC +COPY --from=sys /etc/ssl/certs/ca-certificates.crt /etc/ssl/certs/ca-certificates.crt +COPY --from=sys /blank /tmp + +# Ruby binary +COPY --from=build /usr/local/bin/ruby /usr/bin/ruby + +# Ruby libraries +COPY --from=build /usr/local/lib/ruby /usr/local/lib/ruby + +# System libraries +COPY --from=build /usr/local/lib/libruby.so.3.4 /usr/local/lib/libruby.so.3.4 +COPY --from=build /lib/x86_64-linux-gnu/libz.so.1 /lib/x86_64-linux-gnu/libz.so.1 +COPY --from=build /lib/x86_64-linux-gnu/libgmp.so.10 /lib/x86_64-linux-gnu/libgmp.so.10 +COPY --from=build /lib/x86_64-linux-gnu/libcrypt.so.1 /lib/x86_64-linux-gnu/libcrypt.so.1 +COPY --from=build /lib/x86_64-linux-gnu/libm.so.6 /lib/x86_64-linux-gnu/libm.so.6 +COPY --from=build /lib/x86_64-linux-gnu/libc.so.6 /lib/x86_64-linux-gnu/libc.so.6 +COPY --from=build /lib/x86_64-linux-gnu/libgcc_s.so.1 /lib/x86_64-linux-gnu/libgcc_s.so.1 +COPY --from=build /lib64/ld-linux-x86-64.so.2 /lib64/ld-linux-x86-64.so.2 +COPY --from=build /etc/ld.so.cache /etc/ld.so.cache + +# Simple Ruby HTTP server +COPY ./server.rb /src/server.rb diff --git a/examples/httpserver-ruby3.4-base/Kraftfile b/examples/httpserver-ruby3.4-base/Kraftfile new file mode 100644 index 00000000..a957143c --- /dev/null +++ b/examples/httpserver-ruby3.4-base/Kraftfile @@ -0,0 +1,9 @@ +spec: v0.6 + +name: httpserver-ruby3.4-base + +runtime: base:latest + +rootfs: ./Dockerfile + +cmd: ["/usr/bin/ruby", "/src/server.rb"] diff --git a/examples/httpserver-ruby3.4-base/README.md b/examples/httpserver-ruby3.4-base/README.md new file mode 100644 index 00000000..6c236ea8 --- /dev/null +++ b/examples/httpserver-ruby3.4-base/README.md @@ -0,0 +1,64 @@ +# Ruby Web Server + +This directory contains a [Ruby](https://www.ruby-lang.org/en/) web server running on Unikraft. + +## Set Up + +To run this example, [install Unikraft's companion command-line toolchain `kraft`](https://unikraft.org/docs/cli), clone this repository and `cd` into this directory. + +## Run and Use + +Use `kraft` to run the image and start a Unikraft instance: + +```bash +kraft run --rm -p 8080:8080 --plat qemu --arch x86_64 -M 512M . +``` + +If the `--plat` argument is left out, it defaults to `qemu`. +If the `--arch` argument is left out, it defaults to your system's CPU architecture. + +Once executed, it will open port `8080` and wait for connections. +To test it, you can use `curl`: + +```bash +curl localhost:8080 +``` + +You should see a "Bye, World!" message. + +## Inspect and Close + +To list information about the Unikraft instance, use: + +```bash +kraft ps +``` + +```text +NAME KERNEL ARGS CREATED STATUS MEM PORTS PLAT +zealous_ramu oci://unikraft.org/ruby:3.4 /usr/bin/ruby /src/server.rb 14 minutes ago running 488M 0.0.0.0:8080->8080/tcp qemu/x86_64 +``` + +The instance name is `zealous_ramu`. +To close the Unikraft instance, close the `kraft` process (e.g., via `Ctrl+c`) or run: + +```bash +kraft rm zealous_ramu +``` + +Note that depending on how you modify this example your instance **may** need more memory to run. +To do so, use the `kraft run`'s `-M` flag, for example: + +```bash +kraft run --rm -p 8080:8080 --plat qemu --arch x86_64 -M 1024M . +``` + +## `kraft` and `sudo` + +Mixing invocations of `kraft` and `sudo` can lead to unexpected behavior. +Read more about how to start `kraft` without `sudo` at [https://unikraft.org/sudoless](https://unikraft.org/sudoless). + +## Learn More + +- [How to run unikernels locally](https://unikraft.org/docs/cli/running) +- [Building `Dockerfile` Images with `BuildKit`](https://unikraft.org/guides/building-dockerfile-images-with-buildkit) diff --git a/examples/httpserver-ruby3.4-base/server.rb b/examples/httpserver-ruby3.4-base/server.rb new file mode 100644 index 00000000..45d8c6e7 --- /dev/null +++ b/examples/httpserver-ruby3.4-base/server.rb @@ -0,0 +1,20 @@ +# https://dev.to/leandronsp/web-basics-a-simple-http-server-in-ruby-2jj4 + +require 'socket' + +socket = TCPServer.new(8080) + +loop do + client = socket.accept + + request = client.gets + + response = "HTTP/1.1 200 OK\r\n" \ + "Content-type: text/html\r\n" \ + "Connection: close\r\n" \ + "\r\n" \ + "Bye, World!" + client.puts(response) + + client.close +end diff --git a/examples/httpserver-ruby3.4/.dockerignore b/examples/httpserver-ruby3.4/.dockerignore new file mode 100644 index 00000000..1b8123b9 --- /dev/null +++ b/examples/httpserver-ruby3.4/.dockerignore @@ -0,0 +1 @@ +/.unikraft/ diff --git a/examples/httpserver-ruby3.4/.gitignore b/examples/httpserver-ruby3.4/.gitignore new file mode 100644 index 00000000..1b8123b9 --- /dev/null +++ b/examples/httpserver-ruby3.4/.gitignore @@ -0,0 +1 @@ +/.unikraft/ diff --git a/examples/httpserver-ruby3.4/Dockerfile b/examples/httpserver-ruby3.4/Dockerfile new file mode 100644 index 00000000..d605b1c5 --- /dev/null +++ b/examples/httpserver-ruby3.4/Dockerfile @@ -0,0 +1,4 @@ +FROM unikraft.org/ruby:3.4 + +# Simple Ruby HTTP server +COPY ./server.rb /src/server.rb diff --git a/examples/httpserver-ruby3.4/Kraftfile b/examples/httpserver-ruby3.4/Kraftfile new file mode 100644 index 00000000..f28db10e --- /dev/null +++ b/examples/httpserver-ruby3.4/Kraftfile @@ -0,0 +1,9 @@ +spec: v0.6 + +name: httpserver-ruby3.4 + +runtime: ruby:3.4 + +rootfs: ./Dockerfile + +cmd: ["/usr/bin/ruby", "/src/server.rb"] diff --git a/examples/httpserver-ruby3.4/README.md b/examples/httpserver-ruby3.4/README.md new file mode 100644 index 00000000..6c236ea8 --- /dev/null +++ b/examples/httpserver-ruby3.4/README.md @@ -0,0 +1,64 @@ +# Ruby Web Server + +This directory contains a [Ruby](https://www.ruby-lang.org/en/) web server running on Unikraft. + +## Set Up + +To run this example, [install Unikraft's companion command-line toolchain `kraft`](https://unikraft.org/docs/cli), clone this repository and `cd` into this directory. + +## Run and Use + +Use `kraft` to run the image and start a Unikraft instance: + +```bash +kraft run --rm -p 8080:8080 --plat qemu --arch x86_64 -M 512M . +``` + +If the `--plat` argument is left out, it defaults to `qemu`. +If the `--arch` argument is left out, it defaults to your system's CPU architecture. + +Once executed, it will open port `8080` and wait for connections. +To test it, you can use `curl`: + +```bash +curl localhost:8080 +``` + +You should see a "Bye, World!" message. + +## Inspect and Close + +To list information about the Unikraft instance, use: + +```bash +kraft ps +``` + +```text +NAME KERNEL ARGS CREATED STATUS MEM PORTS PLAT +zealous_ramu oci://unikraft.org/ruby:3.4 /usr/bin/ruby /src/server.rb 14 minutes ago running 488M 0.0.0.0:8080->8080/tcp qemu/x86_64 +``` + +The instance name is `zealous_ramu`. +To close the Unikraft instance, close the `kraft` process (e.g., via `Ctrl+c`) or run: + +```bash +kraft rm zealous_ramu +``` + +Note that depending on how you modify this example your instance **may** need more memory to run. +To do so, use the `kraft run`'s `-M` flag, for example: + +```bash +kraft run --rm -p 8080:8080 --plat qemu --arch x86_64 -M 1024M . +``` + +## `kraft` and `sudo` + +Mixing invocations of `kraft` and `sudo` can lead to unexpected behavior. +Read more about how to start `kraft` without `sudo` at [https://unikraft.org/sudoless](https://unikraft.org/sudoless). + +## Learn More + +- [How to run unikernels locally](https://unikraft.org/docs/cli/running) +- [Building `Dockerfile` Images with `BuildKit`](https://unikraft.org/guides/building-dockerfile-images-with-buildkit) diff --git a/examples/httpserver-ruby3.4/server.rb b/examples/httpserver-ruby3.4/server.rb new file mode 100644 index 00000000..45d8c6e7 --- /dev/null +++ b/examples/httpserver-ruby3.4/server.rb @@ -0,0 +1,20 @@ +# https://dev.to/leandronsp/web-basics-a-simple-http-server-in-ruby-2jj4 + +require 'socket' + +socket = TCPServer.new(8080) + +loop do + client = socket.accept + + request = client.gets + + response = "HTTP/1.1 200 OK\r\n" \ + "Content-type: text/html\r\n" \ + "Connection: close\r\n" \ + "\r\n" \ + "Bye, World!" + client.puts(response) + + client.close +end diff --git a/library/ruby/3.2/README.md b/library/ruby/3.2/README.md index 416f90c7..7b12240f 100644 --- a/library/ruby/3.2/README.md +++ b/library/ruby/3.2/README.md @@ -54,7 +54,7 @@ kraft run --rm -M 256M -p 8080:8080 --plat qemu --arch x86_64 unikraft.org/ruby: The commands so far used the pre-build Ruby image available in the Unikraft registry. -In oder to to build a local image, clone this repository and `cd` into this directory. +In order to build a local image, clone this repository and `cd` into this directory. Then use `kraft` to build an image locally: ```bash diff --git a/library/ruby/3.4/Dockerfile b/library/ruby/3.4/Dockerfile new file mode 100644 index 00000000..c01fcd88 --- /dev/null +++ b/library/ruby/3.4/Dockerfile @@ -0,0 +1,41 @@ +FROM --platform=linux/x86_64 ruby:3.4-bookworm AS build + +FROM alpine:3 AS sys + +RUN set -xe; \ + mkdir -p /target/etc; \ + mkdir -p /blank; \ + apk --no-cache add \ + ca-certificates \ + tzdata \ + ; \ + update-ca-certificates; \ + ln -sf ../usr/share/zoneinfo/Etc/UTC /target/etc/localtime; \ + echo "Etc/UTC" > /target/etc/timezone; + +FROM scratch + +COPY --from=sys /target/etc /etc +COPY --from=sys /usr/share/zoneinfo/Etc/UTC /usr/share/zoneinfo/Etc/UTC +COPY --from=sys /etc/ssl/certs/ca-certificates.crt /etc/ssl/certs/ca-certificates.crt +COPY --from=sys /blank /tmp + +# Ruby binary +COPY --from=build /usr/local/bin/ruby /usr/bin/ruby + +# Ruby libraries +COPY --from=build /usr/local/lib/ruby /usr/local/lib/ruby + +# System libraries +COPY --from=build /usr/local/lib/libruby.so.3.4 /usr/local/lib/libruby.so.3.4 +COPY --from=build /lib/x86_64-linux-gnu/libz.so.1 /lib/x86_64-linux-gnu/libz.so.1 +COPY --from=build /lib/x86_64-linux-gnu/libgmp.so.10 /lib/x86_64-linux-gnu/libgmp.so.10 +COPY --from=build /lib/x86_64-linux-gnu/libcrypt.so.1 /lib/x86_64-linux-gnu/libcrypt.so.1 +COPY --from=build /lib/x86_64-linux-gnu/libm.so.6 /lib/x86_64-linux-gnu/libm.so.6 +COPY --from=build /lib/x86_64-linux-gnu/libc.so.6 /lib/x86_64-linux-gnu/libc.so.6 +COPY --from=build /lib/x86_64-linux-gnu/libgcc_s.so.1 /lib/x86_64-linux-gnu/libgcc_s.so.1 +COPY --from=build /lib64/ld-linux-x86-64.so.2 /lib64/ld-linux-x86-64.so.2 +COPY --from=build /etc/ld.so.cache /etc/ld.so.cache + +# Simple Ruby HTTP server +COPY ./server.rb /src/server.rb diff --git a/library/ruby/3.4/Kraftfile b/library/ruby/3.4/Kraftfile new file mode 100644 index 00000000..1ff4a0aa --- /dev/null +++ b/library/ruby/3.4/Kraftfile @@ -0,0 +1,146 @@ +spec: v0.6 + +name: ruby + +rootfs: ./Dockerfile + +cmd: ["/usr/bin/ruby", "/src/server.rb"] + +template: + source: https://github.com/unikraft/app-elfloader.git + version: staging + +unikraft: + source: https://github.com/unikraft/unikraft.git + version: staging + kconfig: + # Configurations options for app-elfloader + # (they can't be part of the template atm) + CONFIG_LIBPOSIX_PROCESS_ARCH_PRCTL: 'y' + CONFIG_APPELFLOADER_BRK: 'y' + CONFIG_APPELFLOADER_CUSTOMAPPNAME: 'y' + CONFIG_APPELFLOADER_STACK_NBPAGES: 128 + CONFIG_APPELFLOADER_VFSEXEC_EXECBIT: 'n' + CONFIG_APPELFLOADER_VFSEXEC: 'y' + CONFIG_APPELFLOADER_HFS: 'y' + CONFIG_APPELFLOADER_HFS_ETCRESOLVCONF: 'y' + CONFIG_APPELFLOADER_HFS_ETCHOSTS: 'y' + CONFIG_APPELFLOADER_HFS_ETCHOSTNAME: 'y' + CONFIG_APPELFLOADER_HFS_REPLACEEXIST: 'y' + # Unikraft options + CONFIG_HAVE_PAGING_DIRECTMAP: 'y' + CONFIG_HAVE_PAGING: 'y' + CONFIG_I8042: 'y' + CONFIG_LIBDEVFS_AUTOMOUNT: 'y' + CONFIG_LIBDEVFS_DEV_NULL: 'y' + CONFIG_LIBDEVFS_DEV_STDOUT: 'y' + CONFIG_LIBDEVFS_DEV_ZERO: 'y' + CONFIG_LIBDEVFS: 'y' + CONFIG_LIBPOSIX_ENVIRON_ENVP0: "PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin" + CONFIG_LIBPOSIX_ENVIRON_ENVP1: "LD_LIBRARY_PATH=/usr/local/lib:/usr/lib:/lib" + CONFIG_LIBPOSIX_ENVIRON_ENVP2: "HOME=/" + CONFIG_LIBPOSIX_ENVIRON: 'y' + CONFIG_LIBPOSIX_ENVIRON_LIBPARAM: 'y' + CONFIG_LIBPOSIX_ENVIRON_LIBPARAM_MAXCOUNT: '64' + CONFIG_LIBPOSIX_EVENTFD: 'y' + CONFIG_LIBPOSIX_FDIO: 'y' + CONFIG_LIBPOSIX_FDTAB: 'y' + CONFIG_LIBPOSIX_FUTEX: 'y' + CONFIG_LIBPOSIX_MMAP: 'y' + CONFIG_LIBPOSIX_NETLINK: 'y' + CONFIG_LIBPOSIX_PIPE: 'y' + CONFIG_LIBPOSIX_POLL: 'y' + CONFIG_LIBPOSIX_PROCESS: 'y' + CONFIG_LIBPOSIX_PROCESS_MULTITHREADING: 'y' + CONFIG_LIBPOSIX_SOCKET: 'y' + CONFIG_LIBPOSIX_SYSINFO: 'y' + CONFIG_LIBPOSIX_TIME: 'y' + CONFIG_LIBPOSIX_TIMERFD: 'y' + CONFIG_LIBPOSIX_UNIXSOCKET: 'y' + CONFIG_LIBPOSIX_USER_GID: 0 + CONFIG_LIBPOSIX_USER_GROUPNAME: "root" + CONFIG_LIBPOSIX_USER_UID: 0 + CONFIG_LIBPOSIX_USER_USERNAME: "root" + CONFIG_LIBPOSIX_USER: 'y' + CONFIG_LIBRAMFS: 'y' + CONFIG_LIBSYSCALL_SHIM_HANDLER_ULTLS: 'y' + CONFIG_LIBSYSCALL_SHIM_HANDLER: 'y' + CONFIG_LIBSYSCALL_SHIM_LEGACY_VERBOSE: 'y' + CONFIG_LIBSYSCALL_SHIM: 'y' + CONFIG_LIBUKALLOCPOOL: 'y' + CONFIG_LIBUKBLKDEV_MAXNBQUEUES: '1' + CONFIG_LIBUKBLKDEV_DISPATCHERTHREADS: 'y' + CONFIG_LIBUKBLKDEV_SYNC_IO_BLOCKED_WAITING: 'y' + CONFIG_LIBUKBLKDEV: 'y' + CONFIG_LIBUKBOOT_BANNER_MINIMAL: 'y' + CONFIG_LIBUKBOOT_HEAP_BASE: '0x400000000' + CONFIG_LIBUKBOOT_MAINTHREAD: 'y' + CONFIG_LIBUKBOOT_SHUTDOWNREQ_HANDLER: 'y' + CONFIG_LIBUKCPIO: 'y' + CONFIG_LIBUKDEBUG_CRASH_SCREEN: 'y' + CONFIG_LIBUKDEBUG_ENABLE_ASSERT: 'y' + CONFIG_LIBUKDEBUG_PRINT_SRCNAME: 'n' + CONFIG_LIBUKDEBUG_PRINT_TIME: 'y' + CONFIG_LIBUKDEBUG_PRINTK_ERR: 'y' + CONFIG_LIBUKDEBUG_PRINTK: 'y' + CONFIG_LIBUKDEBUG: 'y' + CONFIG_LIBUKFALLOC: 'y' + CONFIG_LIBUKMPI: 'n' + CONFIG_LIBUKSIGNAL: 'y' + CONFIG_LIBUKRANDOM_DEVFS: 'y' + CONFIG_LIBUKRANDOM: 'y' + CONFIG_LIBUKRANDOM_GETRANDOM: 'y' + CONFIG_LIBUKVMEM_DEFAULT_BASE: '0x0000001000000000' + CONFIG_LIBUKVMEM_DEMAND_PAGE_IN_SIZE: 12 + CONFIG_LIBUKVMEM_PAGEFAULT_HANDLER_PRIO: 4 + CONFIG_LIBUKVMEM: 'y' + CONFIG_LIBVFSCORE_AUTOMOUNT_CI: 'y' + CONFIG_LIBVFSCORE_AUTOMOUNT_CI_EINITRD: 'y' + CONFIG_LIBVFSCORE_AUTOMOUNT_UP: 'y' + CONFIG_LIBVFSCORE_AUTOMOUNT: 'y' + CONFIG_LIBVFSCORE_NONLARGEFILE: 'y' + CONFIG_LIBVFSCORE: 'y' + CONFIG_LIBUK9P: 'y' + CONFIG_OPTIMIZE_DEADELIM: 'y' + CONFIG_OPTIMIZE_LTO: 'y' + CONFIG_PAGING: 'y' + CONFIG_STACK_SIZE_PAGE_ORDER: 4 # 128 * 4K = 512K + CONFIG_UKPLAT_MEMREGION_MAX_COUNT: 64 + CONFIG_LIBUKNETDEV_EINFO_LIBPARAM: 'y' + + # Debug options + # CONFIG_LIBUKDEBUG_PRINTD: 'y' + # CONFIG_LIBUKDEBUG_PRINTK_INFO: 'y' + # CONFIG_LIBSYSCALL_SHIM_STRACE: 'y' + # CONFIG_LIBSYSCALL_SHIM_DEBUG: 'y' + +libraries: + lwip: + source: https://github.com/unikraft/lib-lwip.git + version: staging + kconfig: + CONFIG_LWIP_LOOPIF: 'y' + CONFIG_LWIP_UKNETDEV: 'y' + CONFIG_LWIP_LOOPBACK: 'y' + CONFIG_LWIP_TCP: 'y' + CONFIG_LWIP_UDP: 'y' + CONFIG_LWIP_RAW: 'y' + CONFIG_LWIP_WND_SCALE: 'y' + CONFIG_LWIP_TCP_KEEPALIVE: 'y' + CONFIG_LWIP_THREADS: 'y' + CONFIG_LWIP_HEAP: 'y' + CONFIG_LWIP_SOCKET: 'y' + CONFIG_LWIP_AUTOIFACE: 'y' + CONFIG_LWIP_IPV4: 'y' + CONFIG_LWIP_DHCP: 'y' + CONFIG_LWIP_DNS: 'y' + CONFIG_LWIP_NUM_TCPCON: 64 + CONFIG_LWIP_NUM_TCPLISTENERS: 64 + CONFIG_LWIP_ICMP: 'y' + libelf: + source: https://github.com/unikraft/lib-libelf.git + version: staging + +targets: +- fc/x86_64 +- qemu/x86_64 diff --git a/library/ruby/3.4/README.md b/library/ruby/3.4/README.md new file mode 100644 index 00000000..7a04debe --- /dev/null +++ b/library/ruby/3.4/README.md @@ -0,0 +1,83 @@ +# Ruby + +This directory contains the [Ruby](https://www.ruby-lang.org) runtime on Unikraft, in binary compatibility mode. +It implements a simple HTTP server running on Unikraft that provides a simple response to each request. + +## Run and Use + +Use `kraft` to run the image and start a Unikraft instance: + +```bash +kraft run -M 512M -p 8080:8080 --plat qemu --arch x86_64 unikraft.org/ruby:3.4 +``` + +If the `--plat` argument is left out, it defaults to `qemu`. +If the `--arch` argument is left out, it defaults to your system's CPU architecture. + +Once executed, it will open port `8080` and wait for connections. +To test it, you can use `curl`: + +```bash +curl localhost:8080 +``` + +You should see a "Hello, World!" message. + +## Inspect and Close + +To list information about the Unikraft instance, use: + +```bash +kraft ps -a +``` + +```text +NAME KERNEL ARGS CREATED STATUS MEM PORTS PLAT +zealous_titus project://ruby:qemu/x86_64 /usr/bin/ruby /src/server.rb 9 seconds ago running 488M 0.0.0.0:8080->8080/tcp qemu/x86_64 +``` + +The instance name is `zealous_titus`. +To close the Unikraft instance, use: + +```bash +kraft rm zealous_titus +``` + +Note that closing the `kraft run` command (e.g., via `Ctrl+c`) does not kill the Unikraft instance. +If you want the Unikraft instance closed when closing the `kraft run` command, use the `--rm` option: + +```bash +kraft run --rm -M 512M -p 8080:8080 --plat qemu --arch x86_64 unikraft.org/ruby:3.4 +``` + +## Build and Run Locally + +The commands so far used the pre-build Ruby image available in the Unikraft registry. + +In order to build a local image, clone this repository and `cd` into this directory. +Then use `kraft` to build an image locally: + +```bash +kraft build --no-cache --no-update --plat qemu --arch x86_64 +``` + +Similar to the `kraft run` command, if the `--plat` argument is left out, it defaults to `qemu`. +If the `--arch` argument is left out, it defaults to your system's CPU architecture. + +In order to run the locally built image, use `.` (_dot_, the current directory) as the final argument to the `kraft run` command: + +```bash +kraft run -M 512M -p 8080:8080 --plat qemu --arch x86_64 . +``` + +Same as above, it will open port `8080` and wait for connections. + +## `kraft` and `sudo` + +Mixing invocations of `kraft` and `sudo` can lead to unexpected behavior. +Read more about how to start `kraft` without `sudo` at [https://unikraft.org/sudoless](https://unikraft.org/sudoless). + +## Learn More + +- [How to run unikernels locally](https://unikraft.org/docs/cli/running) +- [How to build `Dockerfile` root filesystems with BuildKit](https://unikraft.org/docs/getting-started/integrations/buildkit) diff --git a/library/ruby/3.4/server.rb b/library/ruby/3.4/server.rb new file mode 100644 index 00000000..76553fa6 --- /dev/null +++ b/library/ruby/3.4/server.rb @@ -0,0 +1,20 @@ +# https://dev.to/leandronsp/web-basics-a-simple-http-server-in-ruby-2jj4 + +require 'socket' + +socket = TCPServer.new(8080) + +loop do + client = socket.accept + + request = client.gets + + response = "HTTP/1.1 200 OK\r\n" \ + "Content-type: text/html\r\n" \ + "Connection: close\r\n" \ + "\r\n" \ + "Hello, World!" + client.puts(response) + + client.close +end