[11381] | 1 | Installation of Kofa |
---|
| 2 | #################### |
---|
[10120] | 3 | |
---|
[17263] | 4 | These are generic installation instructions for the WAeUP.Kofa |
---|
[11381] | 5 | student information portal and customized versions thereof. |
---|
[10120] | 6 | |
---|
[11381] | 7 | For specific aspects of this package please refer to the local README |
---|
| 8 | file. |
---|
[10120] | 9 | |
---|
[11381] | 10 | Please note, that **only Linux-based installs** are described and actively |
---|
| 11 | supported. 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] | 19 | Prerequisites |
---|
| 20 | ************* |
---|
[11323] | 21 | |
---|
[17264] | 22 | Installing `kofa` from sources on a local system involves many steps to meet |
---|
| 23 | all requirements, dependencies, etc. For quick setup we provide `docker`_ |
---|
| 24 | based installs which ease the whole setup procedure very much. |
---|
| 25 | |
---|
| 26 | There 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 |
---|
| 28 | directory keeps all files, database data and also log files. You must keep this |
---|
| 29 | directory if you want to keep your data. |
---|
| 30 | |
---|
| 31 | Starting with version 1.8, each release of `kofa` contains a `Dockerfile` in |
---|
| 32 | the 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 |
---|
| 34 | sources. |
---|
| 35 | |
---|
| 36 | Good to know and very important if you want to install the manual way: |
---|
[11381] | 37 | The Kofa packages are based on `Grok`_, which is a Python_ |
---|
[13075] | 38 | framework for agile web application development. Grok_ itself is based |
---|
[11381] | 39 | on `Zope`_. |
---|
[11323] | 40 | |
---|
[17264] | 41 | Both, Grok_ and Zope_, are written in the `Python`_ programming language (with |
---|
| 42 | parts written in C). For a source install you therefore have to have `Python`_ |
---|
| 43 | installed (including `Python`_ headers) in version 2.7 (Python 3.x is currently |
---|
| 44 | not supported). |
---|
[11323] | 45 | |
---|
[17264] | 46 | If you want to install using `docker` you of course need `docker` installed on |
---|
| 47 | your system. Please refer to your system documentation or to https://docker.com |
---|
| 48 | for details. |
---|
[11323] | 49 | |
---|
| 50 | |
---|
[17264] | 51 | Quick Install (dockerized) |
---|
| 52 | ************************** |
---|
[11323] | 53 | |
---|
[17264] | 54 | The Dockerfiles contained in our releases fetch sources from the central Python |
---|
| 55 | package repository `https://pypi.org/`. Visit the Dockerfile to learn, how you |
---|
| 56 | can build kofa from a local source tree. |
---|
[11323] | 57 | |
---|
[17264] | 58 | Go 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] | 63 | You might want to create a `var/` directory to keep the persisted data later:: |
---|
[11323] | 64 | |
---|
[17264] | 65 | $ mkdir var/ |
---|
[11323] | 66 | |
---|
[17264] | 67 | Build `kofa` and tag the build, so you can tell different versions apart later |
---|
| 68 | on:: |
---|
[11527] | 69 | |
---|
[17264] | 70 | $ docker build -t kofa:latest . |
---|
[13690] | 71 | |
---|
[17264] | 72 | Please note the separated dot at the end of the command. |
---|
[11323] | 73 | |
---|
[17264] | 74 | Replace `kofa:latest` with any tag you find useful. Usual alternative tags |
---|
| 75 | would be: `kofa:1.8.1.dev0` or similar. But also `mybuild:foo` or just |
---|
| 76 | `mybuild` are valid tags. |
---|
[11323] | 77 | |
---|
[17264] | 78 | This command will take a lot of time and will perform all the steps, you would |
---|
| 79 | need to do to install `kofa` natively. |
---|
[11323] | 80 | |
---|
[17264] | 81 | If 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] | 85 | Use the tag you picked before (here: `kofa:latest`) and connect to the running instance |
---|
| 86 | |
---|
| 87 | https://localhost:8080/ |
---|
| 88 | |
---|
| 89 | Your username and password will be `grok` and `grok`. |
---|
| 90 | |
---|
| 91 | Enter the credentials (username 'grok', password 'grok' by default) |
---|
| 92 | and name and add a `University`. |
---|
| 93 | |
---|
| 94 | Congratulations, you got Kofa running. |
---|
| 95 | |
---|
| 96 | |
---|
| 97 | What else can I do with `kofa` and Docker? |
---|
| 98 | ****************************************** |
---|
| 99 | |
---|
| 100 | Some remarks about the last `docker` command: |
---|
| 101 | `-v kofadata1:/home/kofa/waeup.kofa` keeps a persistent volume named `kofadata1` on |
---|
| 102 | your 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 |
---|
| 104 | discarded after use and you can of course keep multiple volumes in parallel on |
---|
| 105 | your system. |
---|
| 106 | |
---|
| 107 | You can stop the instance running in foreground pressing `CTRL-C`. |
---|
| 108 | |
---|
| 109 | Passing `--rm` to `docker` means to dispose a container after it stopped. |
---|
| 110 | |
---|
| 111 | |
---|
| 112 | Run `kofa` daemonized: |
---|
| 113 | ********************** |
---|
| 114 | |
---|
| 115 | If 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 | |
---|
| 119 | Instead of interactive (`-it`) we now use daemonized mode (`-d`). We also |
---|
| 120 | tunnel the containers port 8080 to our hosts port 8080 because otherwise we |
---|
| 121 | could not reach `kofa`. For security reasons it binds to containers localhost |
---|
| 122 | address by default. |
---|
| 123 | |
---|
| 124 | You can stop this instance with:: |
---|
| 125 | |
---|
| 126 | $ docker stop kofa:latest |
---|
| 127 | |
---|
| 128 | which will stop and destroy the running container. If you create a new |
---|
| 129 | container with the same volume data, all objects from the last run should be |
---|
| 130 | visible and usable. |
---|
| 131 | |
---|
| 132 | |
---|
| 133 | Enter the `kofa` filesystem inside container |
---|
| 134 | ******************************************** |
---|
| 135 | |
---|
| 136 | If 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 | |
---|
| 140 | which will drop you into a shell inside the container. Your system credentials |
---|
| 141 | are by default `kofa` and `kofa`. |
---|
| 142 | |
---|
| 143 | |
---|
| 144 | Copy data in and out of the container |
---|
| 145 | ************************************* |
---|
| 146 | |
---|
| 147 | For backups etc. it is essential that you can copy data from or to the |
---|
| 148 | container. To do this, we mount a second local directory into the container and |
---|
| 149 | use 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 | |
---|
| 154 | which will copy the whole container-internal `var/`-directory into our local |
---|
| 155 | `mybackup` dir. |
---|
| 156 | |
---|
| 157 | |
---|
| 158 | How 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] | 172 | That should start you. |
---|
[13830] | 173 | |
---|
[17264] | 174 | Have 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 | |
---|