source: main/waeup.kofa/trunk/docs/INSTALL.txt @ 17265

Last change on this file since 17265 was 17264, checked in by uli, 2 years ago

dockerize kofa

File size: 6.1 KB
RevLine 
[11381]1Installation of Kofa
2####################
[10120]3
[17263]4These are generic installation instructions for the WAeUP.Kofa
[11381]5student information portal and customized versions thereof.
[10120]6
[11381]7For specific aspects of this package please refer to the local README
8file.
[10120]9
[11381]10Please note, that **only Linux-based installs** are described and actively
11supported. We recommend use of Debian_ / Ubuntu_.
[11323]12
[11381]13.. note:: This means we do not actively support Windows(tm)!
[11323]14
[12864]15.. contents:: Table of Contents
16   :local:
[11323]17
[11384]18
[11381]19Prerequisites
20*************
[11323]21
[17264]22Installing `kofa` from sources on a local system involves many steps to meet
23all requirements, dependencies, etc. For quick setup we provide `docker`_
24based installs which ease the whole setup procedure very much.
25
26There are, however, a few things, you should be aware of. Most important:
27`kofa` stores persistent data on disk, in an own `var/` directory. This
28directory keeps all files, database data and also log files. You must keep this
29directory if you want to keep your data.
30
31Starting with version 1.8, each release of `kofa` contains a `Dockerfile` in
32the sources root. You can use this file to build a dockerized version of
33`kofa`. But you can also use this file as a reference, how to build `kofa` from
34sources.
35
36Good to know and very important if you want to install the manual way:
[11381]37The Kofa packages are based on `Grok`_, which is a Python_
[13075]38framework for agile web application development. Grok_ itself is based
[11381]39on `Zope`_.
[11323]40
[17264]41Both, Grok_ and Zope_, are written in the `Python`_ programming language (with
42parts written in C). For a source install you therefore have to have `Python`_
43installed (including `Python`_ headers) in version 2.7 (Python 3.x is currently
44not supported).
[11323]45
[17264]46If you want to install using `docker` you of course need `docker` installed on
47your system. Please refer to your system documentation or to https://docker.com
48for details.
[11323]49
50
[17264]51Quick Install (dockerized)
52**************************
[11323]53
[17264]54The Dockerfiles contained in our releases fetch sources from the central Python
55package repository `https://pypi.org/`. Visit the Dockerfile to learn, how you
56can build kofa from a local source tree.
[11323]57
[17264]58Go to the directory with the `Dockerfile` (we assume here, it is called
59`waeup.kofa`)::
[11323]60
[17264]61  $ cd waeup.kofa
[11323]62
[17264]63You might want to create a `var/` directory to keep the persisted data later::
[11323]64
[17264]65  $ mkdir var/
[11323]66
[17264]67Build `kofa` and tag the build, so you can tell different versions apart later
68on::
[11527]69
[17264]70  $ docker build -t kofa:latest .
[13690]71
[17264]72Please note the separated dot at the end of the command.
[11323]73
[17264]74Replace `kofa:latest` with any tag you find useful. Usual alternative tags
75would be: `kofa:1.8.1.dev0` or similar. But also `mybuild:foo` or just
76`mybuild` are valid tags.
[11323]77
[17264]78This command will take a lot of time and will perform all the steps, you would
79need to do to install `kofa` natively.
[11323]80
[17264]81If all works well, you can start a new `kofa` instance in foreground like this::
[11323]82
[17264]83  $ docker run --rm -it -p 8080:8080 -v kofadata1:/home/kofa/waeup.kofa/var kofa:latest
[11323]84
[17264]85Use the tag you picked before (here: `kofa:latest`) and connect to the running instance
86
87https://localhost:8080/
88
89Your username and password will be `grok` and `grok`.
90
91Enter the credentials (username 'grok', password 'grok' by default)
92and name and add a `University`.
93
94Congratulations, you got Kofa running.
95
96
97What else can I do with `kofa` and Docker?
98******************************************
99
100Some remarks about the last `docker` command:
101`-v kofadata1:/home/kofa/waeup.kofa` keeps a persistent volume named `kofadata1` on
102your host. You do not have to know where this volume resides on your machine
103(while you can, if you insist). The containers using this volume can be
104discarded after use and you can of course keep multiple volumes in parallel on
105your system.
106
107You can stop the instance running in foreground pressing `CTRL-C`.
108
109Passing `--rm` to `docker` means to dispose a container after it stopped.
110
111
112Run `kofa` daemonized:
113**********************
114
115If you want to run `kofa` daemonized, use this::
116
117  $ docker run --rm -d -p 8080:8080 -v kofadata1:/home/kofa/waeup.kofa/var kofa:latest
118
119Instead of interactive (`-it`) we now use daemonized mode (`-d`). We also
120tunnel the containers port 8080 to our hosts port 8080 because otherwise we
121could not reach `kofa`. For security reasons it binds to containers localhost
122address by default.
123
124You can stop this instance with::
125
126   $ docker stop kofa:latest
127
128which will stop and destroy the running container. If you create a new
129container with the same volume data, all objects from the last run should be
130visible and usable.
131
132
133Enter the `kofa` filesystem inside container
134********************************************
135
136If an instance is running, you can enter the filesystem with for instance:
137
138   $ docker run --rm -it -v kofadata1:/home/kofa/waeup.kofa/var kofa:latest /bin/bash
139
140which will drop you into a shell inside the container. Your system credentials
141are by default `kofa` and `kofa`.
142
143
144Copy data in and out of the container
145*************************************
146
147For backups etc. it is essential that you can copy data from or to the
148container. To do this, we mount a second local directory into the container and
149use that for transmitting data:
150
151  $ mkdir mybackup
152  $ docker run --rm -it -v kofadata1:/home/kofa/waeup.kofa/var -v `pwd`/mybackup:/data kofa:latest cp -ar /home/kofa/waeup.kofa/var /mybackup
153
154which will copy the whole container-internal `var/`-directory into our local
155`mybackup` dir.
156
157
158How to start/stop `kofa` when running the native setup
159******************************************************
160
[17263]161  ## startup Kofa in foreground
[11323]162
[17263]163  $ bin/kofactl fg
164  # press CTRL-D to stop the kofa server
[11323]165
[17263]166  ## startup Kofa in background
[13830]167
[17263]168  $ bin/kofactl start
169  $ bin/kofactl status  # check status, running or not
170  $ bin/kofactl stop    # stop running instance (also 'restart' possible)
[13830]171
[17264]172That should start you.
[13830]173
[17264]174Have fun with Kofa!
[13830]175
176
177
[17264]178.. _Debian: https://www.debian.org/
179.. _docker: https://
[11381]180.. _Grok: http://grok.zope.org/
[17264]181.. _Python: https://www.python.org/
182.. _Subversion: https://subversion.apache.org/
183.. _Ubuntu: https://www.ubuntu.com/
184.. _virtualenv: https://www.virtualenv.org/en/latest/
[11381]185.. _WAeUP: https://www.waeup.org/
[17264]186.. _Zope: https://www.zope.org/
187.. _zc.buildout: https://pypi.org/project/zc.buildout
[17263]188
Note: See TracBrowser for help on using the repository browser.