Add basic README
This commit is contained in:
parent
909e7b58ef
commit
9846867740
1 changed files with 81 additions and 0 deletions
81
alpine-matrix/README.md
Normal file
81
alpine-matrix/README.md
Normal file
|
@ -0,0 +1,81 @@
|
||||||
|
Matrix synapse service with IRC and Telegram gateways
|
||||||
|
=====================================================
|
||||||
|
|
||||||
|
A collection of systemd services that run synapse, matrix-appservice-irc
|
||||||
|
and mautrix-telegram in a read-only alpine squashfs image.
|
||||||
|
|
||||||
|
Building the squashfs image
|
||||||
|
---------------------------
|
||||||
|
|
||||||
|
Run:
|
||||||
|
|
||||||
|
``` {.sourceCode .shell}
|
||||||
|
$ sh build.sh
|
||||||
|
```
|
||||||
|
|
||||||
|
It will create a rootfs/ folder with an alpine filesystem, install
|
||||||
|
synapse, matrix-appservice-irc and mautrix-telegram and compress it into
|
||||||
|
a squashfs image that will be used as a root filesystem for the
|
||||||
|
container.
|
||||||
|
|
||||||
|
If the script finished successfully, you should get an \~50M matrix.raw
|
||||||
|
image.
|
||||||
|
|
||||||
|
Running the portable services
|
||||||
|
-----------------------------
|
||||||
|
|
||||||
|
Attach the container with `sudo portablectl attach ./matrix.raw`.
|
||||||
|
|
||||||
|
The output should look something like this:
|
||||||
|
|
||||||
|
``` {.sourceCode .shell}
|
||||||
|
$ sudo portablectl attach ./matrix.raw
|
||||||
|
|
||||||
|
Created directory /etc/systemd/system.attached.
|
||||||
|
Created directory /etc/systemd/system.attached/matrix.service.d.
|
||||||
|
Written /etc/systemd/system.attached/matrix.service.d/20-portable.conf.
|
||||||
|
Created symlink /etc/systemd/system.attached/matrix.service.d/10-profile.conf → /usr/lib/systemd/portable/profile/default/service.conf.
|
||||||
|
Copied /etc/systemd/system.attached/matrix.service.
|
||||||
|
Created directory /etc/systemd/system.attached/matrix-telegram.service.d.
|
||||||
|
Written /etc/systemd/system.attached/matrix-telegram.service.d/20-portable.conf.
|
||||||
|
Created symlink /etc/systemd/system.attached/matrix-telegram.service.d/10-profile.conf → /usr/lib/systemd/portable/profile/default/service.conf.
|
||||||
|
Copied /etc/systemd/system.attached/matrix-telegram.service.
|
||||||
|
Created directory /etc/systemd/system.attached/matrix-appservice-irc.service.d.
|
||||||
|
Written /etc/systemd/system.attached/matrix-appservice-irc.service.d/20-portable.conf.
|
||||||
|
Created symlink /etc/systemd/system.attached/matrix-appservice-irc.service.d/10-profile.conf → /usr/lib/systemd/portable/profile/default/service.conf.
|
||||||
|
Copied /etc/systemd/system.attached/matrix-appservice-irc.service.
|
||||||
|
Created symlink /etc/portables/matrix.raw → /home/vladan/dev/portabled/alpine-matrix/matrix.raw.
|
||||||
|
```
|
||||||
|
|
||||||
|
Start/Stop as any other systemd service, e.g:
|
||||||
|
|
||||||
|
``` {.sourceCode .shell}
|
||||||
|
sudo systemctl start matrix-appservice-irc.service matrix-telegram.service
|
||||||
|
sudo systemctl stop matrix.service
|
||||||
|
```
|
||||||
|
|
||||||
|
Existing matrix installations
|
||||||
|
-----------------------------
|
||||||
|
|
||||||
|
1. Stop your current services.
|
||||||
|
2. Copy all configuration files to `/etc/matrix`.
|
||||||
|
3. Run all portable services, so that they create all directories in
|
||||||
|
`/var/lib`.
|
||||||
|
4. Copy all data files, e.g. homeserver.db if you\'re using sqlite,
|
||||||
|
media and upload folders for synapse, rooms.db for the irc gateway,
|
||||||
|
etc. to `/var/lib/matrix-{synapse,telegram,appservice-irc}`.
|
||||||
|
|
||||||
|
Warning
|
||||||
|
-------
|
||||||
|
|
||||||
|
You\'ll need to modify the configuration if the services are configured
|
||||||
|
to log to disk, i.e. modify any filesystem except
|
||||||
|
`/var/lib/matrix-{synapse,telegram,appservice-irc}`.
|
||||||
|
|
||||||
|
TODO
|
||||||
|
----
|
||||||
|
|
||||||
|
- Use a Makefile to build the image. Add attach, detach and clean
|
||||||
|
targets.
|
||||||
|
- Rename matrix.service to matrix-synapse.service and add
|
||||||
|
matrix.target that starts matrix.service
|
Loading…
Reference in a new issue