-
Notifications
You must be signed in to change notification settings - Fork 57
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Thoughts on the underlying OS #37
Comments
Thank you @kraileth for your thoughtful remarks. I've only been using FreeBSD since last quarter, and only because FuryBSD mainly "just worked" for me and was logical and understandable. So most likely I haven't encountered many of the less pleasant sides of FreeBSD yet, but those exist on other OSes as well. Been using Mac OS X (yes, it was still called that when it was at its peak imho) and Linux for a long time. Have tried to build a Darwin-based system with the PureDarwin project around the time when Apple switched to Intel. Still, very new to FreeBSD proper. So your knowledge and experience of a longtime FreeBSD user and GhostBSD contributor is definitely highly welcome here! The "Linux" (and with that, I mostly mean userland - which I put the term in parantheses) world has this mentality that everything needs to be in a distribution, and not just a distribution but many of them. The "Core OS" is not really well defined by anyone so there are many very similar stacks that still are not really compatible. FreeBSD is one system, has one ports/packages collection, and so on - this makes the test (and support) matrix much smaller. In the "Linux" world you write something that works on your system and you can be sure the other day you get 1,001 bug reports because things are subtly broken somewhere. Distributions can't agree on the most basic aspects and fight everything that was "not invented here". At least this has been my experience with developing stuff for "Linux". There are already way too many Linux distributions for my taste. I don't think the world needs yet another one.
Yes, Clear Linux OS makes me jealous: Cold boot to a Gnome desktop in under 5 seconds on a very modest machine. But then, it's a Gnome desktop. Which I clearly don't want. Getting hello "into" Clear Linux OS probably won't happen, and cloning the whole Clear Linux OS thing is probably way more work than I am willing to invest. @jordanhubbard made great points imho with NeXTBSD, but apparently the wider FreeBSD audience didn't really embrace them (as did I back in the time when he advised me that rather wasting my time with Darwin I should better hack on FreeBSD).
FreeBSD's init system (rc.d) seems pretty OK in this regard to me. (Will it stay this way when parallel boot capabilities are added?)
It's dead, right? (Unfortunately almost everything that iXsystems was involved in is either dead or changed name and direction more often than I can keep up with.)
True. But are those real biggies?
Probably not, but if we deactivate them, do they really bother us much? (We probably might even be able to just delete them if we are really that concerned regarding space.)
Probably yes. But a preinstalled package isn't that much worse, is it?
This. Couldn't agree more. I'd like to see this happen. Could be in an extra archive (with all its drivers) as long as it was always released alongside the base system imho. But then, as long as "no one" uses FreeBSD on the desktop, maybe it's not seen as a priority. Chicken and egg.
Never heard of it. Need to check it out. Especially since I am sceptic about Wayland since it breaks POLA in grave ways. Does Xenocara answer the "Xorg is soo insecure" concerns of the Wayland folks?
Very true. That being said, we can think of different models on how the hello system gets updated. I could well imagine an image-based rather than a package based approach for the hello system. Think updating iOS or updating Android. Those images could be QC'd beforehand to ensure all components inside work well together.
Yes. Apple solves this nicely with plist files. I wonder why no one else seems to embrace them. Or, say, JSON. Or, say, YAML. Well, probably because no one can enforce anything on open source developers... It's an equal mess on Linux, though. At least ;-)
Thanks for pointing me there. Wasn't aware of Elektra. But then, do "mere mortals" really need all that configurability? I'd make the point that excessive configurability is a) because developers are too lazy to make things "just work" without the need for configuration, and b) results in undue complexity. (I know that this is a controversial theory, but I just like thinks that work right out of the box and make a habit of judging software by its default settings.) Again, thanks for chiming in. This project clearly can benefit a lot from users and developers like you who have a lot more experience in all things FreeBSD than myself. |
I just want to chime in with my thoughts. From what I've seen so far, the project has made two very good and very important design decisions.
That said, @probonopd please don't let anyone convince you into moving off FreeBSD. If there are problems/limitations with FreeBSD lets fix them instead of giving up. Obviously you've already taken a huge step towards doing that already with the architecture of this system. If I had one criticism, I would say it's don't try to be too much of a MacOS UI clone. I imagine that you are building an OS that's using FreeBSD as a core, but it's not 'technically' FreeBSD. I look forward to seeing what happens. Perhaps we may actually end up with a true open source and free Unix for everyone. If you need any computing resources (for project infrastructure, updates, websites, packaging, building) or assistance with FreeBSD specifics I'm happy to offer them. |
Oh yes, there are pain points with each and every system. FreeBSD is doing very well in comparison, but that doesn't mean that it doesn't have issues of its own. If you haven't been using it for too long, you've missed some of the good sides as well: E.g. updating is generally so much less of a problem due to the "whole system" concept. At work I have responsibility for some servers that begun as FreeBSD 5.x servers and they are still doing their work happily as 12.x today. Not that long ago actually I got a customer who had a root server (because he'd rather not pay for management) and after years he needed urgent help. That beast was still running FreeBSD 7.3 (!), so I had a system technically from 2008 (which is from before I started getting into the IT professionally) and he needed a "fix" ASAP because browsers started displaying warnings due to ancient OpenSSL and all that good stuff (and of course I had to operate with minimal downtime and without breaking anything). So I updated to 8, then to 9 and converted the system over to ZFS. Then I updated to 10, started jailing the running services and transferred those jails to a fresh system with 11 (because I didn't trust an OS not updated for so long). Was a bit of effort, yes, but worked like a charm. Good luck doing the same with a, say Debian 4 machine in 2018/19! With boot environments we have an especially great tool at hand that's only slowly coming to Linux land (due to the Trident "renegades" going to Void). It can make things so much easier for the end user.
I've been loosely following PureDarwin since I'm interested in cross-platform packaging and never had a Mac myself. Thanks for that project! But as an outsider it's hard to judge its state. There's probably too few people involved for it to really take off.
Wouldn't say that I'm a longtime FreeBSD user - about 5 years of using it seriously, a little longer if playing with it also counts. I've used Linux exclusively for about a decade before that, though.
Couldn't agree more. Before I left for FreeBSD I had been living in niches of the not so much mainstream distros for a while. What you describe is both a blessing and a curse IMO. A blessing because it's so easy to try out something completely new with Linux - and a curse because even if you got something really nice, there's basically no chance it'll be able to make as much impact as it should... E.g. I admire the work others have been doing with Musl, but as soon as you venture off from glibc, things start to break because just about no one cares for anything but the "standard" GNU C library. So I've kind of been fighting "Linuxisms" even before I got into BSD! 😆 I mean, it's perfectly legitimate that developers cannot care for hundreds of distros they are not using themselves. But sometimes I have this feeling that we're falling back to the dark ages before POSIX was a thing in some regards. And that's pretty bad.
Exactly! I've also been there; in 2012 I set off to start my own distro - for educational purposes, wanting to understand how that works. It was a good thing to have done some of the work, but I'd much rather help an existing project today if I wasn't completely convinced that I had a unique idea and use case (which I think applies to Hello).
What Intel did there really is impressive and we're a miles away from that. FreeBSD has this little problem that while it's officially a general purpose OS it really is a server OS for many of its protagonists. And since you don't boot servers quite that often... The desktop FreeBSD guys do exist and from my point of view do outstanding work. But desktop FreeBSD is a niche within a niche and it kind of shows (Again: just being honest here, no attempt to scare anybody off whatsoever!). A project like Hello might be beneficial for both sides, though. It might be worth the time to analyze the reasons for PC-BSD / TrueOS / Trident's demise and try to learn from that. Regarding parallel rc.d: I'd take that with a grain of salt. Or rather: I'll believe it when I see it. While I haven't dug as deep into it as I'd like, from what I can say the whole concept of rc.d does not fit so well with parallelism at all. Maybe somebody comes up with very clever ideas and compromises, but I kind of doubt it. People love the current implementation for one thing: simplicity. And that's going to die with parallelism added in. Worse: If doing parallel startup we should probably rather follow a more modern approach (there are enough toys on the table!) than try to retro-fit something into old technology and risk a half-baked outcome with potentially a lot of headaches. Maybe a middle ground is viable, though; the main problem with rc.d is probably that it's shell-based. It looks like people trying to come up with replacement technology agree that for something as important as system startup shell scripts should be avoided (projects like nosh even display it right in their name!). S6 uses execline which is a shell-like non-interactive scripting language that is more performant, has a lower memory footprint and is more secure by design. Maybe an "rc.d-elin" would be an interesting intermediary step? Just some brainstorming here, though.
As one of the initial project founders he's a legend and I have no idea what FreeBSD (or any BSD really) would look like if he hadn't done the old pkg-* tools and the ports framework. But I think a lot of people disagree with what he did later on. I have no real opinion on NeXTBSD, didn't look into it too much. Having something like launchd might have had quite some benefits, though!
It isn't. Basically it suffers from the same issues that SysV init does. You start a service and then want to know if it's running, so you ask the system about the status. System replies: "Yupp, it's up and running" - but it isn't, because it has crashed. The pid file is there, though, and thus the system believes that the service is running... This is terrible, worth of one of the inner circles of Dante's Inferno! While I like projects like OpenRC for adding parallelism and such, they do not really attack this problem. You do an "rc-status" and see that some service has crashed. Then you do "service foo start" and it says that it's already started! So it's "service foo zap" and then starting again... Solaris does much better with it's fault management. A service that should be running died? Just restart it. Died too often in X amount of time? Well, then back off and scream for the admin, there might be a configuration problem or another blocker that cannot be automatically resolved! Service supervision really is a thing if you want to have a reliable system. FreeBSD isn't doing exceptionally bad, but as a person who gets a notification and has to get up in the night (here I am at 3:00 am local... 😆) just because Apache had a bad day and tripped over its own legs for some strange reason (doing something special when log rotation happened or something...) I do see lots of room for improvement. 😉
As a graphical distro: Yes. But as far as I can tell, Eric forked it for continued use in GhostBSD.
In terms of space required and such? Not really, they could probably be neglected. But from the perspective of having a "clean" system I think it makes sense to start throwing some stuff out.
I wouldn't say that it's a high priority right now (or in the near future). But eventually I'd like to have a system that's well documented and as simple as possible. And superfluous components are... well, superfluous.
Well, a package can break with base system changes. Zsh specifically is linked against four libs in base. Let's say ncurses receives a soname bump and we restart after the system upgrade but without having updated the packages, yet. Then it's broken (can probably be "fixed" with a symlink, but still). I love zsh and use it all the time, but I'd never make it the default shell for administrative users - because it's not in base. The license is fine, though, and it's not that much of a burden. We can even configure it to behave like FreeBSD's default tcsh (e.g. what zsh calles "up-line-or-beginning-search" and what I miss so much when I have to use bash or the likes). It would be great to have it in base.
An additional distribution set, yes. That was exactly what I had in mind. OpenBSD does this btw. (split into multiple dist sets, though).
Haven't looked at it from a security perspective, but since OpenBSD ships it by default and those guys are dead serious, I'd expect that it's not worse than Xorg. 😉 Seriously though, one advantage would be that Xenocara resembles Xorg from the time before the "modular" builds. It can be built as a whole and not as dozens or hundreds of packages. How much of their hardening applies outside of OpenBSD is something that I don't know and cannot judge.
Makes perfect sense. TrueOS had an interesting approach, too: When you started an update it created a boot environment and installed the updates to it. That way you could continue working with the old system without any problems ("Firefox needs to restart because libraries have been updated") and you'd simply boot into the new system as time permits. This also had the advantage that you could get back easily if something broke. I think that the actual OS should be read-only anyway, so an image-based approach makes sense.
Not familiar with these. Will have to do a little research.
Chapter 0 of the book sums it up pretty well. In short: Context-aware configuration offers additional possibilities to the system as a whole and can make it possible to derive defaults from these context - i.e. making some configuration dispensable while still having a system that (automatically!) offers to different users what they are likely to need. E.g. based on geo-IP the system would guess that both of us would like a "de" keymap without us having to choose anything during the installer or later configuration! I don't know about you, but while it'd actually be wrong for me (I'm a de-neo² typist), it would be a good guess and actually closer than just assuming "us". And that's only the tip of the iceberg. A unified configuration resource would mean that applications have access to other application's configuration and can derive context information from that (e.g. if your desktop uses a high-contrast theme for the visually impaired other programs offering similar accessibility options might want to automatically enable them whereas on other systems it makes more sense to not enable them). Which means that there is no longer a single "default" but rather default being a context-dependent setting that is meant to be right out of the box even for the most diverse group of users. It's like admitting there is no "one size fits all" but still not giving up the idea of defaults. I think that something like this would be an aim that fits very well with the Hello project. And the best thing is that this is not all dreaming, but the basic framework to do this is here (but little known). If you take a somewhat closer look and like what you read, it might be for mutual benefit of both projects if Hello was to do something with it, because Elektra has kind of a hard time gaining a foothold even with several programs on Linux. Now imagine what a whole system designed to take advantage of this could look like! Being FreeBSD-based, Hello also has the advantage of being able to just do something like that system-wide - which would be very, very hard if not impossible on Linux due to fragmentation and it's nature of "kernel plus a bunch of packages (by different parties!)" vs. the BSD's "whole OS" approach. |
Hello, I decided to add feedback to this issue instead of creating a new one. Thanks @kraileth fot this initiative, idea is great and I'll keep my eyes on it. The SoftwareNowadays operating systems are tools for running Apps and I think that the more supported apps the more users it will have. Each user have his own set of Apps that help get her/his work done. Very often these Apps are proprietary and sooner or later you'll have to support them to break through. For me the set of tools is: docker, vscode, terminal and chrome. For other guy it'll be photoshop, Intellij IDEA and firefox. The HardwareI think that the biggest Macs' strength is PERFECT support for hardware. Every piece of engineering put into the machine is supported by macOS and just works. It's similar with Windows machines but hardware support is distributed between many hardware suppliers. When you choose to install Linux or BSD you agree to accept some inconvenience and that depends on hardware. On laptop A one can't suspend-resume, on laptop B a bluetooth device is not supported and on laptop C you can't even install your OS because of some undocumented EFI bug. SupportWhen the project will gain traction you'll receive ton of Github issues, often related to mediocre hardware. Apple have the comfort of supporting only narrow set of hardware and it is a multibillion dollar company. How could a volunteer project be able to support hundreds of computer models at similar level? I think that in order to succeed you'll need a budget and chosen set of hardware that you support. Speaking of myself, I would pay some amount of money to get well supported operating system that will help me get my job done. The Elementary project is experienced in that area and it could be valuable to talk with them and learn. ConclusionI have listed only a few hurdles to overcome to deliver a perfect desktop operating system. I may sound pessimistic, but I am writing all this to propose some ideas for your consideration:
I support this project with all my heart. I'll follow it and I'll try to use the system at the nearest opportunity. Good luck! |
Quite the long thread on this issue, I see! I'm not quite sure how to contextualize everything being discussed, particularly since FuryBSD seems to have EOL'd itself and retired and the link to daily ISO images on this project is also now dead, so I'm not really sure what the "work product" is or how to even evaluate it - the build scripts were not written to bootstrap from different platforms (like macOS, which lacks commands like realpath(1)) and the documentation on how to bootstrap all of this is not intuitively obvious, so... I guess I will simply try to make a few general points without having actually seen the tech first-hand:
Add to that picture a fully buildable source + ports tree which lets you tinker and customize it from there, learning about the internals along the way, and you'd really have a pretty amazing OS, something Linux lacks for the most part because everything is so encapsulated and "distro-ified "that it's not even clear how to build your own images, much less random pieces of the kernel and userland from one convenient, browsable location like FreeBSD still has. Just a bit of advice from an old guy who has been there, done that, and constantly sought to disrupt conventional thinking in whatever area he looks at, which is also why a lot of my suggestions for "NeXTBSD" were unpopular - that was very much the entire point of doing that (in point of fact the name "NeXTBSD" was a pure tongue-in-cheek joke that few seemed to actually get). If you want to really move the needle in tech, it shouldn't be about winning popularity contests so much as defying conventional wisdom and trying out new things, new approaches, and adapting to new technologies (like powerful little ARM machines that, in the case of the NVIDIA nano, can even do workstation level 3D graphics for under $100). Good luck! |
I absolutely love the spirit of what @jordanhubbard describes as seeking to disrupt conventional thinking: A good part of what Unix is comes from the will to challenge the given situation (simplicity instead of complexity), the will to defy the concept of "this is how it's done" and the will to explore new ways while at the same time trying to be reasonable and have a goal of creating something useful. Was going to write about what I see as a possible way forward for Hello, anyway. I'm still more interested in a sound underpinning for the actual desktop than the desktop UX itself. We really should think about the release process as well as the update process some more as that will lead to a bunch of interesting questions. Building FreeBSD is easy enough and installing it somewhere is also just a Here are a couple of thoughts on that:
I like the idea of e.g. SmartOS to basically have all the drive only for the data and persistent configuration while viewing the OS as something that needs to be replaceable all the time (updating SmartOS means putting a new image on the PXE server and rebooting the running machines - a very elegant approach!). Of course in desktop space relying on PXE booting makes little sense, but perhaps this idea of strictly restricting the OS to a well-defined role ("needs to be there obviously but the non-technical user should never have to care about it at all") could still be applied. What I have in mind here is that updating the OS basically means receiving some data, generating a new BE, reboot into the new system at a point in time where a reboot is ok for the user and be done.
All the things that I mentioned previously (init, what base should look like, Elektra, ...) can be tinkered with at a later time as this (system structure and distribution form) is something really basic to decide early on and I'd like to push for that first. Again, this is just a bunch of thoughts (some were on my mind for a while, though) to get a discussion going. Also with @probonopd obviously liking what NeXTBSD tried to do, too, I propose the somewhat similar "NexusBSD" as the name for the OS component of Hello. |
ZFS and the boot environment abstraction in FreeBSD are absolutely worth leveraging - we used that heavily in FreeNAS to support atomic updates (clone current environment, install to clone, roll-forward to clone only on complete success) and we also had our own delta-update mechanism. It wasn't accomplished through zfs send/receive since that would be too expensive (and currently not even possible) to support from a CDN, but the user doesn't ultimately care how the updates get streamed to them, just so they happen atomically and on whatever release train they're subscribed to (development, stable, experimental, etc) with the ability to hop between trains. See https://github.com/freenas/build for all the machinery to accomplish that, under BSD license. It should serve as inspiration if nothing else! |
Welcome @jordanhubbard and thanks for chiming in!
Here's a blog post that describes the basic ideas with screenshots. Right now this stage is in what I would call the brainstorming phase plus a pre-alpha continuous build of an installable Live ISO. The build system for the Live ISO is based on FuryBSD but really I see it more as "the missing FreeBSD Live ISO generation tool" than anything else: https://github.com/helloSystem/ISO/. Continuous (untested!) builds are at https://github.com/helloSystem/ISO/releases/tag/continuous-hello (but they are, to put it mildly, "still rough around the edges".
Totally agree that it needs to be dead simple to build (and change!) the ISO. In fact, I even go one step further in that I am trying to set up things in a way that can allow everyone to just clone the project and build their own ISOs using public services (like GitHub and Cirrus CI) so that one doesn't have to think about setting up infrastructure before being able to hack on the system (even though it's perfectly possible to build on private machines of course).
Yes, you described it better than I ever could.
Very true. For now I'd be happy if we could make something that runs e.g., graphics applications well enough so that graphic artists can use it without getting too distracted by "the system".
I really admire Apple's efforts to blend the best aspects of the Mac and of Unix in the early 2000s. Unfortunately I don't get the same vibes from their current products anymore, where the focus seems to be more on Memoji and locking down everything.
Looking for one of those that actually run FreeBSD well including GPU acceleration yet are still affordable. @darkain has already started work on aarch64 images. But an affordable tangible device with good FreeBSD support currently seems to be the missing piece... most affordable ARM systems seem to focus exclusively on Android/Linux support. Or do you have good news for us in this regard?
Been there: Got constant sh*t from the Linux community for pushing the idea of application bundles, err, AppImages (think .app inside a .dmg). Not even when Linus Torvalds said he liked the concept did it get much better... Thanks for your advice. Your points resonate very well with me. |
This project looks great and has a lot of overlap with what we wanted to achieve with Etoile (though without the overreach that largely killed that project). A few thoughts: ConfigurationPlease take a look at UCL. This is written by a FreeBSD developer and I believe it's in the base system. There was an effort in FreeBSD to port everything to being able to use UCL as a config file format. There are a few really nice things in UCL but the most useful feature from an OS packaging perspective is that it has generic merging rules that make it easy to put defaults in a read-only location and even have immutable defaults, system-wide configuration and per-user configuration, centrally managed. I think FreeBSD would accept patches to make everything in the base system use UCL so that's not a diff that you'd need to carry. FreeBSD has an annoying requirement that Nexenta had a mode in AppsAs a long-time GNUstep developer, I really like the .app bundle model, but it doesn't work well for libraries. macOS and Windows avoid most of this pain by shipping a few GBs of system libraries that anything can depend on. That's at odds with providing a small base image. The PBI model from PC-BSD was a similar idea. Effectively each app was built with a custom It's impossible to separate the app install problem from the library-dependency install problem. GUI toolkitsCocoa is not built on top of Carbon. Both were built on top of the CoreGraphics libraries that are roughly equivalent to Cairo / Skia. They may have shared some code internally but don't assume that you will be able to layer something nicer on top if you don't like Qt in the end. Aspects of the GUI programming APIs leak into the UI. For example, the way that OpenStep defines copy-and-paste and drag-and-drop make it easy to add things like Services, which are a huge win on macOS / GNUstep (anything you can select can be sent through filters, for example something that takes an equation in LaTeX markup and returns a PDF that then replaces the text and embeds the source in PDF metadata so the transformation is reversable). All the cool kids are using Electron now (they probably own shares in Micron), and there is a FreeBSD port. There are also some much lighter-weight embedded browser frameworks that might be interesting and are BSD / MIT licensed. There's also Godot. The important thing is to support things like DBUS (even if you hate it) so that things written with other toolkits. SandboxingI'm not a fan of Wayland but the authors' criticisms of X11 security are valid. Any app that can connect to your X server has basically full control over any other app you're running. For this reason, if no other, I'd be inclined to consider going the Wayland route, even if you use the X11 compat mode and run every app in a separate X11 instance in Wayland. FreeBSD has two good mechanisms that you can use for sandboxing apps. The conceptually simplest is Jails. These compose very well with ZFS: you can clone as ZFS filesystem, start a jail in that clone, let the app do whatever it wants in there, and mediate access to user files (for example by providing a FUSE filesystem that exposes the user's home directory with some access control preventing it from accessing files created by other apps unless the user explicitly authorises it). Jails have separate IP addresses, so you'd want to route them all to a dynamically configured firewall. You'll quickly see that dynamic firewall configuration is one of the big weak areas of FreeBSD. The jail model is very nice if you can get the tooling right because it means your users can run things 'as root' if they need to, yet still in a sandbox. The other is Capscicum, which prevents any access to the global namespace. You'd need to provide something like libpreload or Casper to explicitly grant them access to things. XDGYou can't get away from things like this. Their rules for where files are stored are not too bad. If you want config / cache files to go away when things are uninstalled (macOS with NSUserDomain has the same problem), then you can either make things like |
Hello @davidchisnall and thanks for sharing your thoughts.
Indeed there is another implementation based on GNUstep and could be made to use more components from Étoilé: https://github.com/probonopd/LIVEstep. As much as I admire the projects, sadly it seems there is not much user-facing development going on in GNUstep and Étoilé lately, possibly because there are not many develoeprs familiar with them. LIVEstep did get a few stars but no significant contributions so far. So my hope is that basing the hello system on Qt the barriers to entry will be lower for potential contributors, and more "native" applications will be available. UCL looks interesting. Since hello will be implemented as a very thin layer of GUI and defaults on top of FreeBSD, it would have to be FreeBSD who is adopting UCL, not hello. Unlike projects like GhostBSD we would like to stay as close to the underlaying FreeBSD as possible, especially in the beginning when the project is still very small.
The whole upgrade story for hello is not determined yet. I could imagine a read-only Core OS filesystem image (think Android, iOS) with an overlay/union filesystem for user modifications. One advantage would be that you could have many versions of such read-only bootable images in parallel on the same partition. In case we stay with a more traditional package-based system, we'll definitely want to do automatic Boot Environments before an attempted update.
From my experience with the AppImage project, what people want is a slowly-changing, well-tested, rock-solid Core OS with the possibility to run the latest and greatest user-facing applications. Ideally multiple versions in parallel, so that you can test things in the latest and greatest version and can always return to a "known good" one in case things don't work out properly. Traditionally, you had to update the Core OS in order to run the latest applications, for the reasons you are well aware of. I'd like to find a way to solve this. It is a tradeoff between efficiency and robustness, and with ever-increasing hardware capabilities I tend to lean more and more toward the robustness side. For Linux, there are now AppImages that bundle all dependencies (except for the kernel and Xorg), and while not the most efficient, they are not that terribly worse in terms of size than what we see on Windows and on the Mac... The file manager in hello can handle (simplified)
Let's reconsider it once it has proper NVidia support and screen recording works out of the box without the need for GNOME or KDE. Which may well be never.
Right now it seems to me that Qt/PyQt is not the worst choice, mainly for pragmatic reasons including application availability and developer availability. But I could imagine that over time the system could adopt something newer like the Fyne toolkit, depending on how its adoption for applications goes. Or some (which?) development will lead to a newborn interest in GNUstep?
Could it be used to implement per-process filesystem namespaces? Then it'd be super interesting for implementing the
Yes, we probably need to support it on some level but I consider it as a legacy liability. Conceptually it looks to me that we need something like a LaunchServices database. [More on this topic] Interesting that you mention XDG and FUSE in the same sentence. This idea had already crossed my mind while working on https://github.com/probonopd/go-appimage for Linux, but I've never come around to implement something. |
Well, this is probably the first time I've seen a github issue used as a mailing list. 😆
Rather than suggest a mailing list, creating a discord channel or even a free slack instance might be a more effective way of hammering out these sorts of details, but this is just a suggestion.
I'm not a big fan of docker containers, but I'm old enough to realize that they won this battle. The docker image is the new app bundle. |
This is FreeBSD based. Docker is based on containers, which is a re-imagined version of Jails from FreeBSD, but an overall worse implantation. The docker system has added some nice streamlining around it, however, containers have had some major issues too (you mention security, which they've actually been historically REALLY bad at). RedHat has moved away from Docker, and onto Podman now for example, as it doesn't require root access. But enough Docker talk. We're FreeBSD. We have jails. The containerization of applications is already solved in the base OS. "Side by side" applications are trivial with jails, as well as isolation. Jails also offer virtualized networking, so if the UI allowed it, applications could even be behind their own NAT or bridged connection away from the host. This also means that it will be easy to add resource limitations to applications, by adding those limitations to the jail itself. Jails are also very nicely integrated into FreeBSD's ZFS file system, so snapshots, backups, replication, rollback, etc will all also be very easy to implement. I do agree that these are solved issues, but solved in a different way. |
@darkain Well, I guess the point was that everybody and their dog is "talking Docker today" - and in that sense Docker has in fact won. The technical details are of less interest to the general public (or even many project managers who get to decide how money is being spent). If I didn't get it wrong, we even have TrueNAS scale today which is Debian-based simply because iX's customers kept demanding docker support. Let's face it: Even the most hard-core BSD enthusiasts are experimenting with Docker in Bhyve and stuff like that - usually because they need it at work (e.g. even Oleg Ginzburg, the guy behind cbsd and ClonOS who dares to challenge Proxmox with a FreeBSD-based system!). There sure are ways to do with FreeBSD what most people do with Linux and I would love to see more people with enough guts and technical knowledge to attack k8s for example (Hashi Nomad jails-driver anyone?). But previous efforts to e.g. get parts of the OpenStack infrastructure working on FreeBSD failed because it was pretty much a one man show and it was given up because of a serious lack of interest from the community. Not saying that improving that sad state would benefit FreeBSD as a whole and thus Hello as well (at least indirectly), the focus of this project is way different. I hope that after some more brainstorming the actual planning can begin and come up with a sound roadmap of things to do (and not to do). |
Well, an Here is a proof-of-concept: What looks like an application is actually an That Quick and dirty proof-of-concept code (not nice in any way):
The idea is that if you have multiple such AppDirs, then OpenZFS can do its deduplication magic. (Or we might even use hardlinks). (This works but is dog slow, because mounting many The downside of this approach is that packages are not very granular (do we really need a full Gnome icon set just to run Gnumeric? etc.). macOS and Windows have a clearly defined set of desktop-oriented libraries/frameworks that you can assume to "always be there". This does not exist on Linux or BSD. And even if we had it, developers tend to always depend on newer versions than what ships with OSes. Which is why an approach like the one I am thinking about here might be useful because it allows you to run the latest bleeding edge apps alongside long-term stable ones on a long-term stable OS. Does this make sense? Edit Nov 2022:
Works but is dog slow due to |
FreeBSD PkgBaseFrom #56 (comment) about shells:
From #1 (comment) about the system as a single file:
With an assumption that helloSystem will continue to support Additional context: #27 |
From my point of view, in the context of helloSystem being simple … and usable:
Wi-Fi works but where I get more than 70 meg with Windows 10, I get less than 10 meg with FreeBSD. The sleep/wake story now is far better than it was a couple of years ago, largely thanks (I believe) to understated work in the https://github.com/FreeBSDDesktop area. Still, the UX is far from simple:
– and so on.
+1 In 2018 the Foundation positioned FreeBSD as a system for a range of everyday activities, – whilst the rear of the flyer used phrases such as personal workstations, the words laptop and notebook are notably absent. Similarly, now at https://www.freebsd.org/ the word desktops is prominent but no mention of portable computers. |
Honestly I always prefer to work at a "personal workstation" (great name for what I usually call a "desktop computer") with wired networking whenever possible. But yes, the points you mention should be improved; and one way to get them improved is make more FreeBSD developers use it on their desktops. Maybe we can help with that? ;-) |
No difficulties so far. |
Are you saying you have a system that already has the new-fangled parallel boot capabilities? (I don't know yet whether and when this will land in anything that we can use for helloSystem, such as the 12.x and/or 13.x series.) |
Yes. |
Interesting @grahamperrin. Do you know, how many seconds does a boot need without and with parllel enabled? |
I haven't properly compared, I added it in isolation, it'll make more sense to compare after I have updated the system to a version with which it properly belongs. If I find anything interesting I'll post to freebsd-current |
The biggest shocker to me is that FreeBSD waits a minute and a half on every boot in case you plug in a USB or CD with a UFS filesystem on it -- why can't we specify the root filesystem in |
Sounds like a bug to me. Have not observed this. |
@linuxkettle, please file a FreeBSD bug about this with as much detail as you can. The slowest FreeBSD system that I have is an AMD E-350 (dual-core, 1.6GHz, slow microarchitecture). It takes a long time in the BIOS but under 10 seconds from loader finishing to the login prompt. The majority of the post-BIOS boot process is the bit where loader presents the boot menu and waits for a timeout before loading the kernel (you can reduce or eliminate this with a tunable, but I don't because I reboot sufficiently infrequently that a small cost every reboot is worth it for ease of recovery if something goes catastrophically wrong). |
It doesn't happen if I put a CD in the drive, so it might be hardware related. |
Please file a bug report. I suspect this is a bug in the USB cd driver. Some USB CD drives don't report ready unless there's a disk in the drive. Eventually the driver gives up and reports the drive as not-ready. I suspect there's a longer timeout than necessary here. It may be that the timeout is in something prodding the driver during boot. Some of these timeouts were introduced for old RAID systems that spun up drives one at a time to avoid overloading the power supply: if you've got a 32-disk spinning-rust array, spinning up all of the disks at once is a huge power draw (a lot more than steady state where they're all spinning with just a little power from the motor to compensate for drag), so a bunch of these arrays would spin up each drive in turn. If it takes 5 seconds to spin up each disk, then a 32-disk array will take 2.5 minutes (in practice you'd probably spin up 2-4 disks at a time, so it wouldn't be that bad). If you had fewer disks, you'd never hit this timeout because the disks would report ready much sooner, so you didn't care. If you had a lot, you didn't care because at least you got to boot in the end. If you apply the same heuristic to a CD drive that never reports ready in the media-not-present state, then you have very slow boot. |
It's the laptop's built-in CD/DVD drive. With 13.0-RELEASE, the timeout is reduced to 30 seconds, but that's still long enough to do the rest of the boot - in other words, that timeout takes up half of the boot process. It also changes to usbus1. |
Please file a bug report at https://bugs.freebsd.org/bugzilla/ @linuxkettle, thanks. |
Okay, I've done that now. |
It would not hurt to put the link to a Hardware Probe report into the ticket :-) |
Looking over old comments.
Yes, systemd in my opinion is one of the best things happening to linux, it makes everything simpler and more efficient. Also, I think your calculator package @probonopd would be a very good model for how a flatpak-like containerisation system could work, basically having those packages containing a tar archive with the app files to overlay, then a |
Then there's also haiku, with nearly everything in the base OS, including desktop environment, mounted read only or just referenced in code by the kernel, and then packages that get overlaid. I think if the UI/UX was less outdated and, well, yellow, then it could get up there with linux, because it has security like no other OS despite logging you into the root account, though maybe a password dialog might be good... |
Yes. I really like Haiku but I didn't base helloSystem on it because
|
On your first point: yeah, Haiku doesn't support much hardware yet, but that should improve with time. |
So to conclude the second point is what's holding us back. |
Yes, there are things you can expect to always be there but they are far and few. Windows and macOS guarantee a widget framework, high level libraries for doing lots of stuff etc. |
Here's a thought - when we were playing around with NeXTBSD (the name was a joke but some people apparently took it seriously?) we did port Mach IPC along with Grand Central Dispatch and some other nice bits of "glue code" that make Mac applications easier to port. If you're looking for a systemd equivalent that is already in wide use, launchd is a reasonable alternative and, as I noted, we already made it much easier to port by bringing the trusted IPC mechanism in that it relies on to ensure that session privileges are genuine. |
Sounds great! |
Indeed. (Describing launchd as a "systemd equivalent" is quite the understatement, systemd was clearly modeled after launchd.) For helloSystem, trying to implement this presents a dilemma: We want to stay as close as possible a "true FreeBSD" (e.g., no self-compiled kernel, no self-compiled ports but the stock FreeBSD ones - for very pragmatic reasons) but FreeBSD hasn't implemented the "NeXTBSD" ideas yet. |
One approach that might be worth trying is to reach out to Robert Watson and ask him how he sees the future of trusted IPC evolving in FreeBSD. Trusted IPC means far more than needing elevated privileges to talk to another application or system service - in fact if you need elevated privs to use it, you've already failed. The fundamental goal is to allow any application or service to talk to any other and be able to prove that it is who it says it is via a cryptographic signature that is attached to every message (AKA Mach IPC security trailers). This is why we brought back Mach IPC - we just couldn't find anything else as low-level that did what we wanted with full kernel support. Robert has been involved in the security space for years, so if he has something better in mind, that should be sussed out. If not, well, Mach technology has been at the core of FreeBSD since the beginning and is STILL in macOS / iOS since every time we wanted to "throw out Mach ports" because they're not exactly easy to understand, we failed because they Just Work and could be wrapped if one wanted easier semantics, so that is of course what happened (XPC wraps Mach IPC, for example). |
Yes, the hard thing is that we don't want to deviate too much from FreeBSD but the reality is we probably have to, or at least should, because of the many shortcomings of FreeBSD. This is not to say that we can't use BSD as a base but we might need to change stuff like the init system to make it more suited to desktop / gui users. |
I am curious about why FreeBSD was chosen as a base instead of OpenBSD. Either one is a good choice, but OpenBSD has a nice emphasis on security, code correctness, and documentation :) |
I'm obviously biased here, but I think there are a couple of FreeBSD features that are really important here that don't have OpenBSD analogues:
|
I chose it partly because Darwin references it (references other BSDs, too) and partly because there was a GitHub repository that produced a Live ISO with a working Xorg setup. This way I could try out FreeBSD without having to install anything. Later I could just fork it and go from there. Never looked back since. |
If I understand correctly … please, don't underestimate the potential burden of maintaining ports to be compatible with a change. |
User facing apps shouldn't need to deal with init scripts, and even so let's say we make something ourselves we can add support for rc.d scripts, like systemd has System V support. |
One might hope by now that a startup mechanism abstraction layer (API + CLI interface) which supported a variety of backend formats would keep ports / pkgs from needing this kind of intrinsic knowledge. MacPorts implemented this over a decade ago since macOS went through a similar evolutionary process and the implementers wanted portability to other OSes as well.
… On Oct 8, 2021, at 17:10, the seventh kettle (I think) ***@***.***> wrote:
User facing apps shouldn't need to deal with init scripts, and even so let's say we make something ourselves we can add support for rc.d scripts, like systemd has System V support.
—
You are receiving this because you were mentioned.
Reply to this email directly, view it on GitHub, or unsubscribe.
Triage notifications on the go with GitHub Mobile for iOS or Android.
|
Note that there is also interest upstream in an improved init system. I would like something that:
Note, this isn't actually describing an init system, it's describing a process supervision system. I don't need it to be pid 1. If someone wants to work on this, I'd be very happy to help with upstreaming, but it can also live in a port and gradually take responsibility for more of the core system until it's ready. |
Not exactly user-facing, but the first port that came to mind was webcamd:
– and so on, and I can't guess how many other ports use rc.d.
|
… http://www.daemonspawn.org/2016/01/a-comparison-of-alternatives-to-init8.html helped me to remember the name, now I see it was mentioned above by @kraileth: Bookmarked in 2015, referred from https://forums.pcbsd.org/thread-20225.html (no longer available). Also featured in a FreeBSD quarterly status report, https://www.freebsd.org/status/report-2015-10-2015-12.html#The-nosh-Project. Obscure historic mentions of nosh: https://web.archive.org/web/20201231033053/https://jdebp.eu./about-the-site.html#ThirdParty I have no idea whether it's suitable, it's simply something that caught my attention a few years ago. |
Hi all, relatively new to all this and more of a "mere mortal" as reference earlier lol 😅 Was it because of licensing not being able to work? Or something else? I mean sure it's not the biggest group of community projects to draw on but can't be called non-existent neither and this could be bringing it back to life or a passing of the torch as the code finds new uses 🚀❤️ Also if not going to be done, how difficult would it be for someone else even one who knows nothing about anything to rebase the stuff here from FreeBSD to the PureDarwin base? I know it's not completely compatible and needs ports but surely not the same as trying to make an equivalent of ReactOS but with XNU instead of NT or trying to port from Linux or something, right? 😕 EDIT: 20/10/2021 May have been barebones in the past but has a good base to take over from now and could be worth considering again to see if maybe it's not still a waste of time? 🤔 |
Does earlier commentary help to put this in context? In particular, #37 (comment) respectfully
|
In particular, sound on Darwin is implemented in CoreAudio, which is not open source. If you want to build a desktop OS on top of Darwin and you are not Apple then you need to write a new audio stack from scratch (or try to port the FreeBSD one) just to be able to go 'beep'. |
I am genuinely really sorry if this counts as 'necroing a dead thread' but is it okay if we request this topic to be put in "Discussions" aswell? |
@joelewing openbsd and dragonflybsd are about research and the needs of their own developers, so they don't have stable kernel ABI, so sooner or later (in case of openbsd - each release, so every 6 months) existing app bundles will break only because kernel ABI has incompatible change, so the only options for regular desktop users are freebsd and netbsd, but netbsd doesn't have proprietary nvidia drivers, instead they use nouveau, plus netbsd's GPU support is lagging behind freebsd (latest netbsd release uses drivers from linux 4.x (4.9? 4.14? can't remember) while latest netbsd snapshot uses linux 5.6 drivers which are gonna be shipped with netbsd 10.0), so freebsd suits more desktop users than netbsd because they have a huge difference in amount of resources |
speaking of parallel init and service supervision, how about runit? seems to be a simple solution |
The main point of this whole project seems to be offering a nice way for just about everybody to use a computer. I do not have any need for a polished desktop personally but I applaud visionary thinking and courage to try reaching for the stars! For that reason Hello is pretty appealing to me nevertheless.
What I'd like to point to are a few of FreeBSD's shortcomings. Don't get me wrong, this is not another "you should just use Linux instead!" topic. On the contrary; I'm using FreeBSD as the sole OS on my computers, I truly love it and I think that you made a good choice. But there are things that require work. Things that do not have any direct impact visible on shiny screenshots but can mean a lot to how the system feels as a whole. And no, I'm not talking about the splash screen feature being in a less than ideal state. It's things that go quite a bit deeper, more like - to the core.
FreeBSD has some weaknesses that show when it comes to the desktop. One thing is that multi-seat functionality is not available. While on Linux I can login with a different user without logging the other out, I can't do the same here. I'm a former team member of GhostBSD, had fun and learned quite a bit. But honesty demands also mentioning that the system is appealing more or less only to more technical people who know (!) what the advantages of FreeBSD are and are willing to accept the disadvantages for having them. If you are aiming for a general-purpose system for "mere mortals" there are some fields that would really require work - and ideally we should try to add more advantages over Linux to the list as well.
There has been initiatives to introduce OpenRC as an optional alternative, but it hasn't happened, yet. TrueOS (upon which GhostBSD is built these days) made the switch and as a result the desktop is ready quite a bit faster. It requires giving up things people have come to love (configuring services via rc.conf variables) but offers a couple of advantages over the old way. What it does not do however is provide reliable service management! To get that today still requires using venerable programs like daemontools. Solaris has SMF, Linux has Systemd (which merits a lot of critique but regarding service supervision it's definitely some form of progress!) - we're lacking behind here.
Recently there has been some interest in the s6 supervisor suite and the author of 66 (utils around s6 to make using it as init easier) has offered help if anybody was to seriously try getting it working properly on FreeBSD. Considering something like that would solve the problems of slow boot time and missing service reliability both for good and elegantly.
Not all base system components are ideal for a desktop system. Do we need things like Sendmail? BSNMP? Svnlite, portsnap and the like (if FreeBSD's packages are not to be used in the long run)? And on the other hand: Wouldn't it make sense to include zsh in base? What about making the attempt to import Xorg (or OpenBSD's Xenocara as done by the Hyperbola guys) into base? A system like Hello would never ever under no circumstances want to break the GUI! But by keeping X and the actual OS separate this is much more likely (and it has happened to me before) than if X was part of the OS.
Configuration is a mess on Unix-likes - and when it comes to the benefits of context-aware configuration, we're still living in the age of barbarism. I can only point to the book published by the Elektra initiative, chapter 0 alone has been a real eye-opener for me. We're wasting so much potential here by not designing our systems according to the results of that research. Hello is about things like auto-configuration? The Elektra principles could help a lot here.
These are just three points to start with. Other people do user-visible things way better than me, but if any of these (or other "under the hood" topics) would be of interest to the project I could probably contribute at least some research.
The text was updated successfully, but these errors were encountered: