rust-landlock VS crun

Compare rust-landlock vs crun and see what are their differences.

rust-landlock

A Rust library for the Linux Landlock sandboxing feature (by landlock-lsm)

crun

A fast and lightweight fully featured OCI runtime and C library for running containers (by containers)
Our great sponsors
  • WorkOS - The modern identity platform for B2B SaaS
  • InfluxDB - Power Real-Time Data Analytics at Scale
  • SaaSHub - Software Alternatives and Reviews
rust-landlock crun
1 30
78 2,761
- 2.6%
6.1 9.3
15 days ago 6 days ago
Rust C
GNU General Public License v3.0 or later GNU General Public License v3.0 only
The number of mentions indicates the total number of mentions that we've tracked plus the number of user suggested alternatives.
Stars - the number of stars that a project has on GitHub. Growth - month over month growth in stars.
Activity is a relative number indicating how actively a project is being developed. Recent commits have higher weight than older ones.
For example, an activity of 9.0 indicates that a project is amongst the top 10% of the most actively developed projects that we are tracking.

rust-landlock

Posts with mentions or reviews of rust-landlock. We have used some of these posts to build our list of alternatives and similar projects. The last one was on 2021-12-26.

crun

Posts with mentions or reviews of crun. We have used some of these posts to build our list of alternatives and similar projects. The last one was on 2024-03-06.
  • Show HN: dockerc – Docker image to static executable "compiler"
    12 projects | news.ycombinator.com | 6 Mar 2024
    Yep pretty much.

    The executables bundle crun (a container runtime)[0], and a fuse implementation of squashfs and overlayfs. Appended to that is a squashfs of the image.

    At runtime the squashfs and overlayfs are mounted and the container is started.

    [0]: https://github.com/containers/crun

  • Howto: WASM runtimes in Docker / Colima
    5 projects | dev.to | 12 Jan 2024
    cpu: 4 disk: 60 memory: 12 arch: host hostname: colima autoActivate: true forwardAgent: false # I only tested this with 'docker', not 'containerd': runtime: docker kubernetes: enabled: false version: v1.24.3+k3s1 k3sArgs: [] network: address: true dns: [] dnsHosts: host.docker.internal: host.lima.internal # Added: # - containerd-snapshotter: true (meaning containerd will be used for pulling images) # - default-runtime / runtimes: crun (instead of the default 'runc') docker: default-runtime: crun features: buildkit: true containerd-snapshotter: true runtimes: crun: path: /usr/local/bin/crun vmType: vz rosetta: true mountType: virtiofs mountInotify: false cpuType: host # This provisioning script installs WasmEdge and builds crun with wasmedge support: provision: - mode: system script: | [ -f /etc/docker/daemon.json ] && echo "Already provisioned!" && exit 0 echo "Install system updates:" apt-get update -y apt-get upgrade -y echo "Install WasmEdge and crun dependencies:" # NOTE: packages curl git python3 already installed: apt-get install -y make gcc build-essential pkgconf libtool libsystemd-dev libprotobuf-c-dev libcap-dev libseccomp-dev libyajl-dev libgcrypt20-dev go-md2man autoconf automake criu apt-get clean -y - mode: user script: | [ -f /etc/docker/daemon.json ] && echo "Already provisioned!" && exit 0 echo "Installing WasmEdge:" curl -sSf https://raw.githubusercontent.com/WasmEdge/WasmEdge/master/utils/install.sh | sudo bash -s -- -p /usr/local echo echo "`wasmedge -v` installed!" # NOTE: I failed to Configure Wasmtime properly - turned off for now: #echo "Installing Wasmtime:" #curl -sSf https://wasmtime.dev/install.sh | bash #sudo cp .wasmtime/bin/* /usr/local/bin/ #rm -rf .wasmtime #echo "`wasmtime -V` installed!" echo "Install crun:" git clone https://github.com/containers/crun cd crun ./autogen.sh #./configure --with-wasmedge --with-wasmtime ./configure --with-wasmedge make sudo make install crun -v echo "crun installed! Replacing runc with crun:" # NOTE: replacing runc with runc is to simplify containerd config TRC=`which runc` sudo rm -rf $TRC sudo cp `which crun` $TRC echo "Configuring containerd:" sudo mkdir -p /etc/containerd/ containerd config default | sudo tee /etc/containerd/config.toml >/dev/null echo "Restarting/reloading docker/containerd services:" sudo systemctl daemon-reload sudo systemctl restart containerd # As soon as Colima writes its /etc/docker/daemon.json file (right after this provisioning script), # it will also start the Docker daemon. If we stop Docker here, the changes will actually take effect: sudo systemctl stop docker sshConfig: true mounts: [] env: {}
  • Google assigns a CVE for libwebp and gives it a 10.0 score
    5 projects | news.ycombinator.com | 26 Sep 2023
    On this note, I was really surprised to find Red Hat's OCI runtime is written in C: https://github.com/containers/crun

    Is anyone working on a Rust version?

  • US Cybersecurity: The Urgent Need for Memory Safety in Software Products
    3 projects | news.ycombinator.com | 21 Sep 2023
    It's interesting that, in light of things like this, you still see large software companies adding support for new components written in non-memory safe languages (e.g. C)

    As an example Red Hat OpenShift added support for crun(https://github.com/containers/crun) this year(https://cloud.redhat.com/blog/whats-new-in-red-hat-openshift...), which is written in C as an alternative to runc, which is written in Go(https://github.com/opencontainers/runc)...

  • Barco: Linux Containers from Scratch in C
    4 projects | news.ycombinator.com | 6 Aug 2023
  • Crun: Fast and lightweight OCI runtime and C library for running containers
    1 project | /r/hypeurls | 4 Jun 2023
    7 projects | news.ycombinator.com | 4 Jun 2023
    Kubernetes needs an OCI runtime to run containers with. Crun is one implementation it can use.

    Docker also appears to be able to use crun for it's engine as well. https://github.com/containers/crun/issues/37

  • Best virtualization solution with Ubuntu 22.04
    8 projects | /r/linuxquestions | 28 May 2023
    crun
  • Why did the Krustlet project die?
    6 projects | /r/kubernetes | 14 Jan 2023
  • Is this an incompatibility with docker or an I doing something else wrong?
    1 project | /r/podman | 22 Nov 2022
    Looks like https://github.com/containers/crun/issues/255 - start there.

What are some alternatives?

When comparing rust-landlock and crun you can also consider the following projects:

youki - A container runtime written in Rust

runc - CLI tool for spawning and running containers according to the OCI specification

bubblewrap - Low-level unprivileged sandboxing tool used by Flatpak and similar projects

containrs - General purpose container library

cri-o - Open Container Initiative-based implementation of Kubernetes Container Runtime Interface

podman - Podman: A tool for managing OCI containers and pods.

wasm-micro-runtime - WebAssembly Micro Runtime (WAMR)

runtime-tools - OCI Runtime Tools

awesome-alternatives-in-rust - A curated list of replacements for existing software written in Rust

rules_docker - Rules for building and handling Docker images with Bazel