Settings

Theme

Back to FreeBSD – Part 2 – Jails

hypha.pub

117 points by vermaden a month ago · 32 comments

Reader

ggm a month ago

I think they understate the importance of accepting OCI and Dockerfile semantics as a path to an external "run one of these" and having it actually emerge as a jail based outcome.

I get saying "we don't need these additional layers/abstractions" but what it ignores is me saying "I want to run this code, and what I have is a suite of Docker based behaviour and I want a low friction path to use that Docker compose method, to get where I want"

They also haven't yet addressed how things re-scale sideways. Pods, and scaling is why people wind up behind traefik or caddy, fronting a service. It's not because the service lies in RFC1918 (how I wish they had written kubernetes to V6 native) it's because the service is being delivered by multiple discrete runtime states "inside" and scales horizontally.

  • lstodd a month ago

    It's a different operating system. You can't point at a dockerfile, say "port this please from linux-such-and-such to FreeBSD" and expect it to work every time. There are nuances even with linux-compat.

    Contrary to popular belief load-balance/scaleout is orthogonal to containers (and k8s is only one of the ways to go about it), so obviously it's not discussed in an article about containers.

    • nine_k a month ago

      Very often you can, or could, because the software is portable (e.g. Node or Python or Postgres), and / or platform-independent (e.g. written in JS, Python, bash, etc).

      In my practice it was completely normal to build things inside a container to be deployed on Linux using the same sources and basically the same package names and versions as used on a developer macOS machine (which is BSD-like enough down below).

      • trashb a month ago

        > macOS machine (which is BSD-like enough down below)

        That's like saying an Ubuntu .deb will work on Gentoo because it's all Linux anyway. It's not that simple. There is dependencies and there are differences in the packages, package managers and surrounding system for a reason. It's not 1:1. Perhaps the naming scheme happened to line up for the packages you where using, but this should be considered not assumed.

        It would be nice if there was some sort of translator that could handle "most common cases". I think it would improve the usability of Jails. Perhaps that would require someone to keep a list of packages mapping certain packages between operating systems.

        Something like "apt install python3-serial" -> "pkg install py311-pyserial" may suffice.

        For anyone that would use something like that, you should implement a prototype, publish it and perhaps someone else will build upon what you started!

        • Joker_vD a month ago

          > It's not that simple.

          It would tremendously benefit almost everyone if it were.

          > There is dependencies and there are differences in the packages, package managers and surrounding system for a reason.

          Yeah, the NIH syndrome. And sometimes, of course, there are decent technical reasons as well.

        • LoganDark a month ago

          This is called https://brew.sh

  • sharts a month ago

    Isn’t podman already supported? I wouldn’t be surprised that there already exist tools that will jail-ify that as well.

sunshine-o a month ago

The article is written by the people who created jail.run [0]

Ten years in with Docker and Linux containers I felt something was very wrong so I looked at how Solaris and FreeBSD were doing it and I saw the light (too).

I would agree with them: bringing the Dockerfile format to jails doesn't make any sense, unless you just want to attract curious Linux users.

Dockerfiles are useful and familiar but are also an abomination.

What we need is solid way to do configuration management. I guess this is what they are trying to do with their own configuration system [1] but I am not sold on it yet.

Anyway those people are doing some good work !

- [0] https://jail.run/

- [1] https://jail.run/reference/jail-config/

rtpg a month ago

I'll bite: how do we take advantage of ZFS layering if not via the docker-style layering?

I find dockerfile layering to be unsatisfying because step 5 might depend on step 2 but not 3 or 4... the linearisation of a DAG makes them harder to maintain and harder to cache cleanly (with us also having monster single-line CMDs all in the main of image results).

So is there a better way that people are using?

  • lstodd a month ago

    FS layers are a poor replacement for a package manager, so maybe just don't use wrong tools for a job?

bivlked a month ago

one thing that bit me with LXC: anything that needs its own kernel module won't work. jails have the same limitation — shared host kernel. ran into this trying to run a VPN server (needs DKMS for a custom wireguard fork) in an LXC container — module can't load, period. ended up on a full KVM VM.

pjmlp a month ago

To note that HP-UX Vaults and Solaris Zones predate these efforts, where only BSD and Linux keep being discussed.

With IBM and Unisys big iron predating ever further in the historic evolution, outside UNIX based operating systems.

rkrbaccord94f a month ago

Remote kernel execution should not be the bitter problem of development i.e. the identification of "human" capitol.

Perhaps formalisation lends values, which deploy in the analysis of field research.

davidcollantes a month ago

The main drawback I saw on jails is that they are FreeBSD. The owner doesn’t mention, and I have not researched it, but can you run any Linux distribution in a FreeBSD jail?

  • dgl a month ago

    FreeBSD has supported Linux emulation for a long time (https://docs.freebsd.org/en/books/handbook/linuxemu/). The emulation is at the syscall level but enough to run most apps.

  • ggm a month ago

    There is a significant investment in a linux compatible system call layer, and a linux compatible runtime link library suite.

    It isn't a complete answer, but the position as I understand it (haven't had to care for a long time) is that a LOT of linux binaries can work.

  • assimpleaspossi a month ago

    I believe you are asking about bhyve for running Linux on FreeBSD. Jails are for software isolation.

  • bandrami a month ago

    > can you run any Linux distribution in a FreeBSD jail

    -ish. There's a compatibility layer that works at the libc level but not the syscall level. In practice anything open source that works in emulation almost certainly has a FreeBSD version and anything proprietary that actually needs Linux will work better in a VM.

  • volkadav a month ago

    If you mean an isolated linux instance _including a linux kernel_, that would be provided by a virtual machine running under the bhyve hypervisor on freebsd (https://docs.freebsd.org/en/books/handbook/virtualization/#v...). You probably could frankenkludge something like linux-userland-on-a-frebsd-kernel using jails but that certainly seems like the path less traveled, haha. :)

  • olavgg a month ago

    I would not worry about running a distro. Most things are similar, there are some minor differences between the GNU applications and the FreeBSD alternatives. But for most people there is nothing to worry about. Most applications runs fine on BSD. Bind, PowerDNS, Java Applications, PostgreSQL, Python, rsync and many more. Getting PyTorch to work with Nvidia and Cuda is most likely another story.

    My main culprit with FreeBSD is that upgrading the kernel is not a simple dnf update command. But its still easier than upgrading RHEL from 9 to 10.

  • sunshine-o a month ago

    Yes what is confusing is it might be simpler than one might think.

    To run a Linux distribution in jail you need 2 things:

    - Enable "Linux Binary Compatibility"

    - copy your Linux distribution base filesystem in the chroot or just pick on that is packaged in FreeBSD and do 'pkg install' (Rocky and Ubuntu if I remember correctly)

    But you might not even need to "Run a Linux distribution". Just enabling "Linux Binary Compatibility" and executing the binary often works fine if it doesn't depends on a bunch of libraries.

    It is really that simple.

  • ssl-3 a month ago

    If I understand the question correctly: You want to run a Linux distribution like (say) Debian in a FreeBSD jail? With the Linux kernel and all?

NooneAtAll3 a month ago

Failed to verify your browser

Code 11

evanjrowley a month ago

I would like to explore the interoperability/compatibility limits of LXC and OCI support in FreeBSD 15. Both with FreeBSD as an OCI container and Linux OCI containers within FreeBSD.

rkrbaccord94f a month ago

Our report concludes SQL as "mostly" inept, pivoting to the following:

Identification of C++ develeopers

Compilation of C++ code into Python

Recursive .py scripts that are sector-enframings of the general "neural" framework deployment.

[1]:https://malus.sh/blog.html

Keyboard Shortcuts

j
Next item
k
Previous item
o / Enter
Open selected item
?
Show this help
Esc
Close modal / clear selection