Skip to content

Commit

Permalink
Document new installation flow
Browse files Browse the repository at this point in the history
  • Loading branch information
ilesoft committed Dec 7, 2024
1 parent 1cbc337 commit 6f5079e
Showing 1 changed file with 42 additions and 90 deletions.
132 changes: 42 additions & 90 deletions docs/installation.md
Original file line number Diff line number Diff line change
Expand Up @@ -5,10 +5,10 @@
### Lähiverkko

Kaikkien tietokoneiden pitää olla samassa verkossa niin että niillä on
verkkoyhteys palvelimelle johon Kipa on asennettu. Yhteyden toimivuutta voi
kokeilla vaikka ping \<IP osoite\> komennolla. Palvelimelle tarvitaan
portti 80 auki http-liikennöintiä varten. Jos kisatoimistosta ei ole pääsy
Internettiin kannattaa harkita palomuurin sammuttamisesta palvelimelta.
verkkoyhteys palvelimelle johon Kipa on asennettu. Palvelimelle tarvitaan
käytetty TCP-portti auki http-liikennöintiä varten. Jos kisatoimistosta ei
ole pääsyä Internettiin kannattaa harkita palomuurin sammuttamista
palvelimelta.

### Internet

Expand All @@ -22,89 +22,41 @@ riittävän hyvää verkkoyhteyttä.

## Docker-asennus

1. Luo itsellesi GitHubin personal access
token [täältä](https://github.com/settings/tokens) jakirjaudu
Docker-clientillä sisään GitHubin pakettivarantoon esimerkiksi
komennolla `docker login ghcr.io`
2. Aja komento `docker run -d -p 3000:80 -v kipa_db:/app/db --name kipa -d ghcr.io/partio-scout/kipa:latest`
* Halutessasi voit myös käyttää kehitysversiota vaihtamalla `latest`-tagin sijaan `develop`in.
3. Mene selaimella osoitteeseen http://localhost:3000/kipa/ – voilá!

Yllä opastettu ajotapa käyttää kipa_db-nimisessä Docker-volumessa olevaa
SQLite-kantaa. Sen sijaan voit käyttää esimerkiksi MySQL-kantaa
mounttaamalla erillisen local.py-tiedoston tähän tapaan:
`-v /home/user/kipa/local.py:/app/web/settings/local.py`. Voit myös yliajaa
muita settings/__init__.py:ssä olevia määrityksiä em. tavalla, esimerkiksi
ottaa käyttöön välimuistituksen.

## macOS-asennus

Toimivaksi todettu macOS Montereylla (12.0), luultavasti toimii myös
uudemmilla käyttöjärjestelmillä. Huom! Tämä ohje asentaa Kipan
kehityspalvelimen (development server).

macOS sisältää valmiiksi kaiken muun, paitsi itse Djangon. Sen asennus on
hyvin yksinkertainen ja onnistuu keneltä tahansa pääkäyttäjän oikeuksilla.

1. Avaa Terminal klikkaamalla oikeasta yläkulmasta suurennuslasia ja
kirjoittamalla hakukenttään Terminal
2. Asenna Django kirjoittamalla terminaaliin
`sudo easy_install django==1.3.1`
Anna salasanasi, jos terminaali sitä kysyy. Tämä asentaa Djangon
uusimman saatavilla olevan version.
3. Hae Kipa GitHubista kirjoittamalla
`git clone https://github.com/partio-scout/kipa.git`
Jos et ole aiemmin käyttänyt Gittiä, tulee näytölle varmistus Command
Line Developer Toolsin asentamisesta. Hyväksy asennus ja aja käsky
uudelleen.
4. Hyväksy terminaalin mahdollinen kysymys palvelimen sertifikaatista.
5. Siirry Kipan web-hakemistoon kirjoittamalla `cd kipa/web`
6. Käynnistä Django ja Kipa `sudo python manage.py runserver`
7. Jos saat ilmoitukseksi “Development server is running at...”, voit avata
selaimen (esim. Safari) ja kirjoittaa osoitteeksi 127.0.0.1:8000/kipa/

Kun lopetat Kipan käytön, siirry terminaaliin ja paina Ctrl+C, joka
pysäyttää Djangon.

## Linux-asennus

Pohjalle tarvitaan moderni Linux-käyttöjärjestelmä, testattu Ubuntu
20.04:lla

Huom! Ohjeessa {{kipa_asennus}} viittaa kansioon, johon Kipa on asennettu
(eli 2. Kohdassa .zip tiedosto purettu).

1. Lataa Kipa
lähdekoodi [GitHubista](https://github.com/partio-scout/kipa/archive/refs/heads/master.zip)
2. Pura .zip tiedosto kansioon, johon haluat asentaa Kipa
3. Asenna tarvittavat paketit komennolla
`sudo apt install apache2 python libapache2-mod-python mysql-server libmysqlclient-dev python-dev build-essential`

* Pythonin asennuksen jälkeen asenna pip, katso esim.
ohjeet: https://stackoverflow.com/a/66719099
* Pip:n asennuksen jälkeen asenna vaadittava versio Djangosta ajamalla
kipa-kansiossa komento pip install -r requirements.txt

4. Lisää /etc/apache2/apache2.conf tiedoston loppuun seuraavat rivit

<Location "/kipa/">
SetHandler python-program
PythonHandler django.core.handlers.modpython
SetEnv DJANGO_SETTINGS_MODULE web.settings
PythonDebug On
PythonPath "['{{kipa_asennus}}/kipa', '{{kipa_asennus}}/kipa/web'] + sys.path"
</Location>

5. Aja seuraavat komennot

chown www-data {{kipa_asennus}}/kipa/web
chown www-data {{kipa_asennus}}/kipa/web/tupa.db
ln -s {{kipa_asennus}}/kipa/web/media /var/www/html/kipamedia

6. Käynnistä apache2 uudestaan komennolla `sudo systemctl restart apache2`
7. Kipa pitäisi toimia nyt osoitteessa localhost://kipa/

## Windows-asennus

Lataa [asennustiedosto](https://github.com/partio-scout/kipa/releases/tag/1.6.2)
ja aja se. Testattu toimivaksi Windows 10 ja Windows XP.
Kipan saa käymään yksinkertaisimmillaan komennolla
`docker run -p 8000:80 --name kipa -d ghcr.io/partio-scout/kipa:latest`

Mikäli haluaa käynnistää Kipasta kehitysversion se tapahtuu vaihtamalla
tagin `latest` tilalle `develop`.

Nyt Kipan pitäisi löytyä selaimella osoitteesta http://localhost:8000/kipa.

## Asennus Nginx-proxyn taakse

Paremmin konfikuroitava ja joustavampi tapa ajaa Kipaa on ajaa sitä
WSGI-palvelin Gunicornin avulla käyttäen http-palvelin Nginx:ää proxynä.
Paikallisesti ajettuna Kipan SQLite-tietokannan sijainnin voi asettaa
johonkin sopivaksi katsottuun paikkaan: luo asetushakemistoon
`web/settings/` local.py, jossa asetetaan tietokannan polku. Tietokantana
voi myös käyttää jotakin muuta Djangon tukemaa tietokantaa.

Asennuksen vaiheet:

1. Asenna Nginx.
2. Asenna Kipan tukema Python.
3. Luo jonnekkin virtuaaliympäristö: `python -m venv /polku/venv`
4. Aktivoi virtuaaliympäristö: `source /polku/venv/bin/activate`
5. Asenna riippuvuudet: `pip install -r requirements.txt`
6. Siirry Kipan `web`-hakemistoon.
7. Aja Kipa gunicornin avulla:
`gunicorn --daemon --bind unix:/tmp/kipa.sock wsgi`
* Muilla kuin *unix pohjaisilla järjestelmillä voi bindata soketin
sijasta oletusarvoiseen http-porttiin 8000: `gunicorn --daemon wsgi`
8. Konfiguroi Nginx ohjaamaan liikenne valitusta portista Gunicornin
luomaan sokettiin tai sen kuuntelemaan TCP-porttiin.
9. Luo Nginx:än konfiguraatioon esim. alias, joka palvelee staattisten
tiedostojen kyselyjä (`/kipamedia/*`) hakemistosta `web/media/`,
varmista että Nginx-prosessin käyttäjällä on lukuoikeus kyseiseen
hakemistoon.

Esimerkki Nginx:än konfikuraatiosta löytyy repositorion juuresta tai
sitten [Gunicornin dokumentaatiosta](https://docs.gunicorn.org/en/latest/deploy.html).

0 comments on commit 6f5079e

Please sign in to comment.