2017-07-05 20:27:17 +00:00
|
|
|
For some background, see:
|
|
|
|
|
|
|
|
- https://fedoraproject.org/wiki/Workstation/AtomicWorkstation
|
|
|
|
- https://fedoraproject.org/wiki/Changes/WorkstationOstree
|
|
|
|
|
|
|
|
(Note also this repo obsoletes https://pagure.io/atomic-ws)
|
|
|
|
|
|
|
|
High level design
|
|
|
|
-----------------
|
|
|
|
|
|
|
|
The goal of the system is to be a workstation, using
|
|
|
|
rpm-ostree for the base OS, and a combination of
|
|
|
|
Docker and Flatpak containers, as well as virtualization
|
|
|
|
tools such as Vagrant.
|
|
|
|
|
|
|
|
Status
|
|
|
|
------
|
|
|
|
|
|
|
|
This project is actively maintained and is ready for use
|
|
|
|
by sophisticated and interested users, but not ready
|
|
|
|
for widespread promotion.
|
|
|
|
|
2017-11-20 15:21:51 +00:00
|
|
|
Installing
|
|
|
|
------------
|
2017-08-07 16:41:21 +00:00
|
|
|
|
2017-11-20 15:21:51 +00:00
|
|
|
There are ISOs available for [Fedora 27](https://dl.fedoraproject.org/pub/fedora/linux/releases/27/WorkstationOstree/x86_64/iso/).
|
2017-08-07 16:41:21 +00:00
|
|
|
|
2017-11-20 15:21:51 +00:00
|
|
|
Alternatively, see a guide for [installing inside an existing system](README-install-inside.md).
|
2017-07-05 20:27:17 +00:00
|
|
|
|
|
|
|
Important issues:
|
|
|
|
-----------------------
|
|
|
|
|
|
|
|
- [flatpak system repo](https://github.com/flatpak/flatpak/issues/113#issuecomment-247022006)
|
2017-08-30 17:43:54 +00:00
|
|
|
|
2017-11-20 15:21:51 +00:00
|
|
|
Using the system
|
|
|
|
--------------------
|
2017-08-30 17:43:54 +00:00
|
|
|
|
2017-11-20 15:21:51 +00:00
|
|
|
One of the first things you should do use is use a container runtime of your
|
|
|
|
choice to manage one or more "pet" containers. This is where you will use
|
|
|
|
`yum/dnf` to install utilities.
|
2017-08-30 17:43:54 +00:00
|
|
|
|
2017-11-20 15:21:51 +00:00
|
|
|
With `docker` for example, you can use the `-v /srv:/srv` command line option so
|
|
|
|
these containers can share content with your host (such as git repositories).
|
|
|
|
Note that if you want to share content between multiple Docker containers and
|
|
|
|
the host (e.g. your desktop session), you should execute (once):
|
2017-07-05 20:27:17 +00:00
|
|
|
|
|
|
|
```
|
2017-11-20 15:21:51 +00:00
|
|
|
sudo chcon -R -h -t container_file_t /var/srv
|
2017-07-05 20:27:17 +00:00
|
|
|
```
|
|
|
|
|
|
|
|
Next, let's try flatpak. Before you do: There's a known flatpak issue on
|
|
|
|
AtomicWS - run [this workaround](https://github.com/flatpak/flatpak/issues/113#issuecomment-247022006),
|
|
|
|
which you only need to do once. After that, [try flatpak](http://flatpak.org/apps.html).
|
|
|
|
|
|
|
|
If you are a developer for server applications,
|
|
|
|
try [oc cluster up](https://github.com/openshift/origin/blob/master/docs/cluster_up_down.md) to
|
|
|
|
create a local OpenShift v3 cluster.
|
|
|
|
|
2017-11-20 15:21:51 +00:00
|
|
|
Finally, try out `rpm-ostree install` to layer additional packages directly on
|
|
|
|
the host. This is needed for "host extensions" - privileged software that
|
|
|
|
doesn't make sense to live in a container. For example, `rpm-ostree install
|
|
|
|
powerline` to use that software for the shell prompts of the host. Another
|
|
|
|
good example is `rpm-ostree install vagrant-libvirt` to use [Vagrant](https://www.vagrantup.com/)
|
|
|
|
to manage VMs.
|
2017-07-05 20:27:17 +00:00
|
|
|
|
|
|
|
Future work
|
|
|
|
-----------
|
|
|
|
|
|
|
|
- GNOME Software support for both rpm-ostree/flatpak and possibly docker
|
|
|
|
- automated tests that run on this content
|