Version 11 (modified by jpo, 7 years ago)

--

Uruchamianie SVN na kopii plików katalogu repository

Niniejszą procedurę stosuje się, gdy posiadamy kopię plików w katalogu repository z przenoszonego serwera lecz z jakichś powodów nie posiadamy kopii samego SVNa i nie zależy nam na poprzednich wersjach plików a jedynie na ich ostatnich aktualnych wersjach.

Czyszczenie repozytorium oraz lokalnej bazy

cd /home/<user>
rm -rf repos
rm -rf repository/.svn

Tworzenie bazy repozytorium

svnadmin create repos
cd repository
svn checkout file:///home/<user>/repos .

Następnym krokiem jest wyszukwanie oraz usunięcie wszystkich katalogów .svn z repository.

# Wyszukiwanie
find . -name .svn
# Usuwanie
find . -name .svn -type d -print0 | xargs -0 rm -r --

Wykonujemy commit wszystkich plików znajdujących się w katalogu repository_2 oraz nadajemy uprawnienia dla użytkownika www-data

svn add repository_2
cd repository_2
svn ci -m "Komentarz"
cd ..
chown -R www-data:edokumenty repository repos
chmod -R u+rwX,g+rwX,o-rwx repository repos

Naprawa SVN po aktualizacji systemu Linux

W przypadku gdy po aktualizacji dystrybucji Linuxa podczas edycji plików w eDokumentach a następnie po ich zatwierdzaniu 'commit' otrzymujemy poniższy komunikat

$ svn status
svn: E155036: Please see the 'svn upgrade' command
svn: E155036: Working copy '/home/edokumenty/repository' is too old (format 10, created by Subversion 1.6)

Wszystkie czynności wykonujemy na użytkowniku www-data, w przypadku wykonywania komend z innego użytkownika po zakończeniu prac należy zweryfikować uprawnienia do katalogów.

W tym celu należy zaktualizować aktywną kopię plików. W tym celu używamy polecenia

svn upgrade

które wykonujemy na katalogu z aktywną kopia repozytorium czyli - /home/edokumenty/repository. Ponownie sprawdzamy stan repozytorium

svn status
lub 
svn st

Ostatnim poleceniem jest

svn cleanup

Naprawa SVN w przypadku otrzymania komunikatu o nie prawidłowej wersji pliku

svn ci file_1652969.xlsx -m ""
Wysyłanie file_1652969.xlsx
svn: Zatwierdzenie nie powiodło się (szczegóły poniżej):
svn: Plik '/repository_2/2016/10/05/file_1652969.xlsx' jest nieaktualny

Wykonujemy kopię pliku

cp file_1652969.xlsx file_1652969.xlsx_backup

Podnosimy wersję

svn up file_1652969.xlsx
Odkryto konflikt w 'file_1652969.xlsx'.
Wybierz: (p) odłóż,
(mf) moje w całości, (tf) ich w całości,
(s) pokaż wszystkie opcje: mf
G file_1652969.xlsx
Uaktualniono do wersji 12228.

Przywracamy wersję pliku

p file_1652969.xlsx_backup file_1652969.xlsx

Wykonujemy commit, zatwierdzenie wersji

vn ci file_1652969.xlsx -m ""
Wysyłanie file_1652969.xlsx
Przesyłanie treści pliku.
Zatwierdzona wersja 12229.

Wersja pliku działa już poprawnie. Ale aby wszystko zgadzało się z otwarciem wersji z właściwości pliku musimy zmodyfikować wpis w tabeli versions

SELECT * FROM versions WHERE fileid='1652969';

Następnie aktualizujemy numer wersji w bazie

begin;
UPDATE versions SET revnum = '12229' where ver_id='1010771';

gdzie revnum to numer wersji z commita z wykonanego z konsoli Gdy wszystko jest poprawnie to zatwierdzamy zmiany {{ commit; }}}