I was looking at some old notes the other day and remembering that I had made a plan for going the other direction, of slaving other devices to my IDE for faster round tripping of UI development.
That’s a very heterogenous example, but at some point we will be discussing personal clouds, where people have a little cluster of commodity/older ARM hardware that they balance a bunch of services across.
For example, you can download the server part of Don’t Starve Together as a separate app that you can then leave running even if you log off. That should be the standard for coop games, and probably for multiplayer games in general.
We are also overdue for a rethink of CI/CD pipelines, and I don’t mean As A Service.
But it's not convergence. It's making the look and feel, and some APIs similar enough someone could target multiple machines.
I want convergence. Real bloody convergence. I want to hook my laptop's /dev and /sys , port applications over to my phone, continue using them, until I get to work, and then expand them back out there. And all the while, they would never quit, halt, freeze, or die.
Or I want to be able to collaborate on a program, send it to a buddy, have them work on it, and then get it back.
Why stop here? Why not make the application switching fully ubiquitous between multiple devices via app "off-loading" to the cloud?
There's many different ways they can approach this: a hobbyist hosting an ubuntu server running whatever's necessary to facilitate this; a hosted solution -- possibly by Canonical (ala Ubuntu One or competitors); and a corporate solution (your IT staff managing Ubuntu servers and environment).
I feel like this might be the next step, especially with app/desktop virtualization becoming more popular.
I’m hoping for a built-in resource sharing mechanism. I have a dual 4090 server accessible but right now all I can do is run blender on it. I’d love a way to just transparently use its resources while working on my machine.
Ooo I am very interested and hope this works out; I've only really used XOrg but a new contender/approach will be fun to see (of course I know it already exists, but operating on the assumption that this would cause its ecosystem to mature even further/faster)
Someone has to have built some kind of automated binhost thing like this _somewhere_. I would love it if you could also do crossdev for Arm with it as well.
If they were focusing in that part, I think the revenue sharing + cloud combo could open totally new opportunities that would also justify the investment in a custom OS.
I'm thinking of something like a return to the Unix philosophy. Piping together stuff from grep to cat to whatever is pretty great, but mostly only useful if you're dealing with text-ish files. We don't have much in the way of small tools that would be similarly designed for being chained together, but which would work well for say video files. In part because you'd want better OS-level support for that kind of information sharing (though maybe on 'nix you could just pipe stuff from one application to another?), but also to a large part because you'd need to have people making tools that didn't do much by their own and then convince users to download them and build stuff out of them. And telling people to "download this program which doesn't do much by itself, but which is useful if you download some other programs and then combine them" is hard. People want to minimize the amount of hassle, so mostly people bundle lots of different features into a single application that you can just download once.
On the other hand, if you had a platform where everything ran in the cloud, and there was no need to separately buy, install, or download things... if any application could call any other application made for the platform, then you could just start making your little specialized programs and making them available for anyone else to use. Any user might chain several of them together, or a programmer making their own application could use them as part of their application, maybe as easily as calling a library. That could open up huge possibilities. With the revenue sharing, there would even be a financial incentive for people to make small tools that were maximally useful for everyone, even if they mostly remained invisible for normal end-users.
That said, I'm seeing nothing in Solu's public presentation suggesting that they'd have thought of this angle, or would be invested in it. Which is a pity.
From a purely programming point of view, this looks like a very difficult task - different peripherals, different host systems. Kudos to their dev team if they can pull it off.
I'd like to see an OS where "your profile" is entirely in the cloud and every device you register becomes just another node. Your laptop, phone, desktop, smart watch, and homeserver are all just nodes with different capabilities. Some have touchscreens, some have GPUs, some have lots of memory, some are always-on, others are ephemeral.
I'd like to play a game on my phone but have my desktop's GPU render frames for me like Stadia.
I want my server to pick the next song in the playlist on my phone to match the tempo of the heart rate it hears from my watch.
I'd like to type "make -j" and have it transparently use every core ...on every device I own.
These things can be done today with ad-hoc hacks, but an OS designed around these ideas would mean you could write lots of programs very differently.
But in reality, I'm betting on hypervisor-based micro OSes as they way to go. We don't need another "app" format, like what Docker/libcontainer and this proposal are gravitating toward.
That approach works well for web apps, but not for desktop applications, of which there are (luckily) still thousands.
I agree that this seems over-engineered and a move to tie everything in the systemd ecosystem.
Frankly, I don't see why an approach like OS X's application bundles would not work. Sure, since libraries are generally less ABI stable, you'd end up packaging more libraries in the bundle, but disk space is cheap. Slap on some MAC and you'll also have sandboxing.
PC-BSD's PBI seems to go more in the right direction:
Indeed, in the future, any app could be built as a native shell that provides the integration to the OS, then the actual app is streamed from the Cloud.
So, we get a native app that also runs on a server, like a website.
As Microsoft Cloud Gaming (xCloud) and other platforms are proving, there are new markets for this type of apps.
That’s a very heterogenous example, but at some point we will be discussing personal clouds, where people have a little cluster of commodity/older ARM hardware that they balance a bunch of services across.
For example, you can download the server part of Don’t Starve Together as a separate app that you can then leave running even if you log off. That should be the standard for coop games, and probably for multiplayer games in general.
We are also overdue for a rethink of CI/CD pipelines, and I don’t mean As A Service.
reply