Skip to content

Latest commit

 

History

History
134 lines (98 loc) · 4.61 KB

README.md

File metadata and controls

134 lines (98 loc) · 4.61 KB

Puavo Image Repository

This document describes how to setup your own Puavo Image Repository.

Why?

But why would you wand to run your own repostiory? You might want

  • that your user only acces a repository which runs (e.g. for privacy reasons) under your local jurisdiction.
  • that the load of the main repository decreases
  • to use modified or extend version of Puavo-OS

Requirements

A Puavo Image Repository is just a plain https service, which is only serving static files. So any server with enough disc space (~500 Gbyte) will do the job. Be aware, that the generation of the rdiff-files is very cpu/io intensive so it might be reasonable to prepare your date offline, only uploading the final data to the server.

Mirror Preparation

Let's assume we want to expose the following images (living in e.g. the puavo-os-images dir) for the clients:

puavo-os-images
├── puavo-os-amxa-buster-2021-04-13-192449-amd64.img
├── puavo-os-amxa-buster-2021-04-13-193910-amd64.img
├── puavo-os-amxa-buster-2022-01-17-120001-amd64.img
├── puavo-os-amxa-buster-2022-01-20-173248-amd64.img
└── puavo-os-free-buster-2022-02-04-140532-amd64.img

For ensure the integrity of the data and to spped up the update process of clients some additional file have to be generated:

  • A cheksum file.
  • Some meta files.
  • And, of course, the rdiff files.

This might look like this:

mirror
├── CKSUMS
├── meta
│   ├── puavo-os-amxa-buster-amd64.json
│   └── puavo-os-free-buster-amd64.json
├── puavo-os-amxa-buster-2021-04-13-192449-amd64.img
├── puavo-os-amxa-buster-2021-04-13-193910-amd64.img
├── puavo-os-amxa-buster-2022-01-17-120001-amd64.img
├── puavo-os-amxa-buster-2022-01-20-173248-amd64.img
├── puavo-os-free-buster-2022-02-04-140532-amd64.img
└── rdiffs
    ├── puavo-os-amxa-buster-2021-04-13-192449--2021-04-13-193910-amd64.rdiff
    ├── puavo-os-amxa-buster-2022-01-17-120001--2022-01-20-173248-amd64.rdiff
    └── puavo-os-amxa-buster-2022-01-20-173248--2022-01-17-120001-amd64.rdiff

The creation of these additional files is an integral part of PuavoOS and can be done on every Puavo installation (of course it can also be done on non PuavoOS oss's)

On PuavoOS

When your images are in puavo-os-images and your mirror will reside in mirror. You just call (the binary in this repo!):

# puavo-update-repository puavo-os-images mirror

Now, just wait (some hours) and enjoy your updated repository.

On other Platforms

Other platforms lack the PuavoOS installation. So just do

$ git clone https://github.com/puavo-org/puavo-os.git

and call puavo-update-repository with

# puavo-update-repository --puavo-os path/to/puavo-os puavo-os-images mirror

puavo-update-repository

The main task of this progie is the generation of the needed config files before the function the PuavoOS funtion make-rdiffs is called.

Usage: puavo-img-repo  IMAGE_DIR [MIRROR_DIR]

       Maintains an image repository of all images from IMAGE_DIR
       in MIRROR_DIR (def: IMAGE_DIR/mirror)

Options:
    -r, --repository  HOSTNAME   set repository's hostname (def: images.amxa.ch)
    -p, --puavo-os DIR           set dir to DIR of puavo-os (def: /puavo-os/)
    -n, --no-config              does not generate confiruation files
    -h, --help                   show this message

Manual Configuration

puavo-update-repository exposes all images found to the mirror. Sometimes this is not desired (or for some other reasons) the whole process can be made manually.

Config Files

The config files reside in /puavo-os/config/images/. There is one file per distribution (stretch, buster, bullseye, bookworm, ...), whis is named e.g. buster.json for the buster distribution.

This might e a typical file for /puavo-os/config/images/buster.json:

{
  "puavo-os-amxa-buster-amd64": [
    "puavo-os-amxa-buster-2022-01-17-120001-amd64.img",
    "puavo-os-amxa-buster-2022-01-20-173248-amd64.img"
 ],
  "puavo-os-free-buster-amd64": [
    "puavo-os-free-buster-2022-02-04-140532-amd64.img"
 ]
}

Use the option --no-config to prevent puavo-update-repository overwriting your manually maintained config files.

Making Rdiffs

Edit the file /puavo-os/defaults.mk to reflect your seetings (you may remove all other lines!):

   image_dir               := <path/to/your/image_dir>
   images_urlbase          := <https://host.domain.tld>
   mirror_dir              := <path/to/mirror_dir>

then

$ cd /puavo-os/
$ sudo make rdiffs

Btw: That's exactly what puavo-update-repository does!