Ero sivun ”Subversion” versioiden välillä

Siirry navigaatioon Siirry hakuun
3 877 merkkiä lisätty ,  28. kesäkuuta 2016
(→‎Muita hyödyllisiä komentoja: ovat kopioita, eivät versioita)
(13 välissä olevaa versiota 5 käyttäjän tekeminä ei näytetä)
Rivi 1: Rivi 1:
Subversion on kehittynyt [[versionhallintajärjestelmä]]. Monet projektit ovat viime aikoina siirtyneet [[CVS]]:stä Subversioniin. Lyhennetään yleensä SVN.
{{Ohjelma
| nimi=Subversion
| kuva=
| kuvateksti=
| lisenssi=[[ASL]] 2.0
| käyttöliittymä=teksti
| kotisivu=[https://subversion.apache.org/ subversion.apache.org]
}}
 
'''Subversion''' on kehittynyt [[versionhallintajärjestelmä]]. Monet projektit ovat viime aikoina siirtyneet [[CVS]]:stä Subversioniin. Lyhennetään yleensä SVN.
 
==Asennus==
{{Asenna|Svn|subversion}}


== Asiakasohjelma ==
== Asiakasohjelma ==
Rivi 9: Rivi 21:
*Työhakemistossa voi projektiin lisätä tiedostoja komennolla <tt>svn add</tt>, esimerkiksi
*Työhakemistossa voi projektiin lisätä tiedostoja komennolla <tt>svn add</tt>, esimerkiksi
  svn add uusfilu.cpp
  svn add uusfilu.cpp
Vastaavasti <tt>svn rm tiedosto</tt>
Vastaavasti <tt>svn rm tiedosto</tt> ja <tt>svn mkdir hakemisto</tt>
*Tiedostoja voidaan muokata tämän jälkeen työhakemistosta millä tahansa tekstieditorilla.
*Tiedostoja voidaan muokata tämän jälkeen työhakemistosta millä tahansa tekstieditorilla.
*Muokkausten jälkeen muutokset päivitetään komennolla <tt>svn ci</tt>, esimerkiksi
*Muokkausten jälkeen muutokset päivitetään komennolla <tt>svn ci</tt>, esimerkiksi
Rivi 19: Rivi 31:
*<tt>svn update</tt> &ndash; Päivittää projektin työkopion uusimpaan versioon.
*<tt>svn update</tt> &ndash; Päivittää projektin työkopion uusimpaan versioon.
*<tt>svn revert</tt> &ndash; Peruuttaa työkopioon tehdyt muutokset.
*<tt>svn revert</tt> &ndash; Peruuttaa työkopioon tehdyt muutokset.
*<tt>svn status</tt> &ndash; Näyttää työkopiossa muuttuneet tiedostonnimet.
*<tt>svn diff</tt> &ndash; Näyttää työkopion tiedostojen sisällön muutokset suhteessa edelliseen päivitykseen.
*<tt>svn help</tt> &ndash; Näyttää listan kaikista komennoista.
*<tt>svn help</tt> &ndash; Näyttää listan kaikista komennoista.
*<tt>svn help komento</tt> &ndash; Näyttää tietyn komennon käyttöohjeen.
*<tt>svn help komento</tt> &ndash; Näyttää tietyn komennon käyttöohjeen.
==Skripti esimerkki Subversionin käytöstä==
<source lang="sh">
#!/bin/sh
cd /polku/lähdekoodiin # esim. ~/trunk
NUM=0
echo "Please wait..."
`svn update > /tmp/svnupdtscrpt` && NUM=`wc -l /tmp/svnupdtscrpt | tr -d /[:alpha:]`
if [ "$NUM" -gt "1" ]; then
  echo "Writing change log to Desktop..."
  ( svn log ) > ~/Desktop/changed.log 2>&1
  echo "Done!"
else
  if [ "$NUM" -eq "1" ]; then
    echo "Sources are already up to date!"
  else
    echo "Error while updating sources!"
  fi
fi
</source>
Skripti toimii sillä oletuksella että "svn update" tuottaa vain yhden rivin tekstiä kun päivityksiä ei ole.
`svn update > /tmp/svnupdtscrpt` && NUM=`wc -l /tmp/svnupdtscrpt | tr -d /[:alpha:]`
[[wc]] käsky laskee rivien määrän vain jos "svn update" komento onnistuu (johtuu merkeistä &&). Muutoin muuttujalle NUM jää arvoksi 0.
[[tr]] käsky poistaa ylimääräiset merkit (merkin "/" ja kirjaimet) wc käskyn tulosteesta (koska joissain wc ohjelman versioissa myös tiedoston nimi tulostetaan).


== Palvelin ==
== Palvelin ==
Rivi 28: Rivi 69:
  mkdir /var/svn
  mkdir /var/svn
  cd /var/svn
  cd /var/svn
  svnadmin create --fs-type bdb varasto
  svnadmin create varasto
Joka luo Berkeley DB -tyyppisen varaston nimelle varasto, ja /var/svn-hakemistoon ilmestyy hakemisto varasto. Voit käyttää myös uudempaa FSFS-formaattia (<tt>--fs-type fsfs</tt>) joka on alustariippumaton ja vie vähemmän tilaa. Toinen FSFS-formaatin etu on se, ettei se ei vaadi huoltotoimenpiteitä, kuten Berkley DB.
Työkalu luo oletuksena FSFS-tyyppisen varaston. Se saa nimekseen ''varasto'' ja /var/svn-hakemistoon ilmestyy hakemisto ''varasto''. Voit käyttää myös vanhempaa Berkeley DB -tyyppistä varastoa käyttämällä valitsinta <tt>--fs-type bdb</tt>. FSFS-formaatin etuna on, että se on alustariippumaton ja vie vähemmän tilaa. Toinen FSFS-formaatin etu on se, ettei se ei vaadi huoltotoimenpiteitä, kuten Berkley DB.


*Luotuun varastoon voidaan myös hakea valmiiksi vähän pohjaa seuraavalla tavalla
*Luotuun varastoon voidaan myös hakea valmiiksi vähän pohjaa seuraavalla tavalla
Rivi 61: Rivi 102:


WebSVN:llä tulee olla lukuoikeudet svn-varastoon, ja lisäksi kirjoitusoikeudet varaston db-hakemistoon.
WebSVN:llä tulee olla lukuoikeudet svn-varastoon, ja lisäksi kirjoitusoikeudet varaston db-hakemistoon.
== Henkilökohtaisen varaston luominen==
Subversionia on myös mahdollista käyttää yhden käyttäjän ympäristössä tiedostojen muutosten seurantaan. Versiohallinta on vaivaton tapa pitää varmuuskopioita vanhoista työtiedostoista ja huolehtia tiedostojen vaivattomasta siirrosta esimerkiksi koulun ja kodin välillä. Henkilökohtainen varasto on tiedostotasolla ja asiakasohjelmien tasolla täysin yhteensopiva monen käyttäjän varaston kanssa.
Henkilökohtaisen varaston perustamiseen ei tarvitse pääkäyttäjän oikeuksia. Tähän tehtävään riittää jokin tietokone, johon saa yhteyden ssh:lla. Esimerkiksi yliopistojen tarjoamat päätekoneet, kuten Jyväskylän yliopiston <tt>jalava.cc.jyu.fi</tt>, soveltuvat tähän tehtävään erinomaisesti. Myös pelkästään paikallisen versiohallinnan perustaminen esimerkiksi muistitikulle on mahdollista käyttäen <tt>file:</tt>-URIa.
Olkoon meillä avoinna ssh-pääteyhteys koneeseen <tt>tieto.kone.fi</tt> ja käyttätunnuksena <tt>tunnus</tt>. Varaston voi luoda minne tahansa. Tässä tilanteessa käytetään kotihakemistoa, koska siihen on aina kirjoitusoikeudet.
Varaston luominen palvelimelle:
svnadmin create ~/omasvn
Selvitä käytetty hakemistopolku komentamalla:
cd ~/omasvn
pwd
Kopioi tulostunut hakemistonnimi talteen. Siihen viitataan jatkossa nimellä <tt>svnpolku</tt>. Nyt varasto on luotu, eikä mitään muut asetusten tekemistä tarvita. Luodun varaston osoite muodostuu seuraavasti: <tt>svn+ssh://'''tunnus'''@'''tieto.kone.fi'''/'''svnpolku'''</tt> .
Voit kokeilla sen toimivuutta toiselta tietokoneelta käsin komentamalla:
svn info svn+ssh://tunnus@tieto.kone.fi/svnpolku
Mikäli saat listan ominaisuuksista etkä virheilmoitusta, onnittele itseäsi; sinulla on toimiva henkilökohtainen tietovarasto!
Nyt voit komentaa niillä koneilla, joilta haluat ottaa varastosta työkopion, seuraavaa:
svn checkout svn+ssh://tunnus@tieto.kone.fi/svnpolku omat
Tällöin svn noutaa sinulle aluksi tyhjän työkopion, johon voit luoda hakemistoja eri projekteille, kuten kursseille. Tutustu [[Subversion#Asiakasohjelma|asiakasohjelman komentoihin]].
Huomaa, että mikäli käytössäsi ei ole SSH-avainvarmennusta, saatat joutua syöttämään salasanan useita kertoja muodostaessasi yhteyttä palvelimelle. Tältä voi välttyä käyttämällä [[Ssh#Tunnistaminen_avainparilla|SSH-avaimia]].


==Aiheesta muualla==
==Aiheesta muualla==
* [http://subversion.tigris.org Subversionin kotisivu]
*[http://subclipse.tigris.org/files/documents/906/8847/file_8847.dat?filename=subclipse%20%2d%20install%2c%20use%20and%20compile%2epdf Subversionin dokumentaatio (PDF)]
*[http://subclipse.tigris.org/files/documents/906/8847/file_8847.dat?filename=subclipse%20%2d%20install%2c%20use%20and%20compile%2epdf Subversionin dokumentaatio (PDF)]
* [http://svnbook.red-bean.com/ Version Control with Subversion (kirja)]
* [http://svnbook.red-bean.com/ Version Control with Subversion (kirja)]

Navigointivalikko