[[戻る>DoldoWorkz#subversion]] *SubversionのリポジトリをWeb上のレンタルサーバに置く [#s3545e22] Subversionを使った際のメモを書いていきます。 #hr #contents #hr *レンタルサーバーを探す [#kf776c78] 会社の同僚にCORESERVERというサーバを教えてもらいました。~ CGIもある程度揃っていて、容量も15ギガで良さげです。~ これの前身?のXREAというサーバーもやってるらしいので、実績もまずますです。~ -[[CORESERVER.JP コアサーバー:http://www.coreserver.jp/]]~ ~ とりあえず、サーバはここに決定!!~ しかし最初からSubversionが入っているのは良いが、バージョンが古いためBLOCKGROUPから移植してきたリポジトリが使えない!~ ということで、安定バージョンの中で新しいバージョン(1.6.4)をインストールして使うことにしました。~ *「CORESERVER.jp」にSubversion安定版の新バージョン(1.6.4)をインストールする [#CORESERVERInstallSVN] 以下の説明の元ソースです。~ Linux初心者には、こういう解説はものすご~くありがたいです。~ 以下のWebページの作者に感謝⌣~ -[[CORESERVERにSubversionをインストールする:http://stickstack.org/coreserver/subversion]]~ -[[coreserverにSubversion入れようとしたのだが…:http://hemiolia.com/blog/200801/000138]]~ ~ +&color(blue){''入れるのが初めてであればこの項目は飛ばしてください。''};~ 旧バージョンを全く同じ手順で入れている場合、ホームのルートに「packages」フォルダが出来ていると思います。~ この中に前回インストールしたファイル群が含まれていますので、このフォルダを削除して下さい。~ これで古いバージョンのアンインストールは完了です。~ +&color(blue){''過去で既に行っている場合はこの項目は飛ばしてください。''};~ 作業用に「tmp」フォルダを作成~ mkdir ~/tmp +「Oracle Berkeley DB」のファイルをダウンロード~ 「Oracle Berkeley DB」のページから最新バージョンのBerkeley DB 4.7.25.tar.gz(db-4.7.25.tar.gz)をダウンロードして「tmp」フォルダに突っ込む~ --[[Oracle Berkeley DB>http://www.oracle.com/technology/software/products/berkeley-db/db/index.html]] +「Oracle Berkeley DB」をインストールする~ 以下のコマンドを順番に打ち込めばインストール出来ます。~ cd ~/tmp tar xvzf db-4.7.25.tar.gz cd db-4.7.25/build_unix/ ../dist/configure --prefix=$HOME/packages --enable-compat185 make make install ※&color(red){''killされたりエラーが出たりして止まってしまった場合はもう一度''};行う。~ +「Subversion」のファイル2つをダウンロード~ のページからバージョン1.6.4ファイルを2つダウンロードする~ トップページから辿るとファイルのありかが分からなかったため、直指定でURLを叩く~ [[http://subversion.tigris.org/downloads/subversion-1.6.4.tar.gz>http://subversion.tigris.org/downloads/subversion-1.6.4.tar.gz]]~ [[http://subversion.tigris.org/downloads/subversion-deps-1.6.4.tar.gz>http://subversion.tigris.org/downloads/subversion-deps-1.6.4.tar.gz]]~ この2つのファイル(subversion-1.6.4.tar.gz と subversion-deps-1.6.4.tar.gz)を「tmp」フォルダに突っ込む~ +「Subversion」をインストールする~ 以下のコマンドを順番に打ち込めばインストール出来ます。~ cd ~/tmp tar xvzf subversion-1.6.4.tar.gz tar xvzf subversion-deps-1.6.4.tar.gz cd subversion-1.6.4 ./configure --prefix=$HOME/packages --with-ssl make make install ※&color(red){''killされたりエラーが出たりして止まってしまった場合はもう一度''};行う。~ ※特に「make」に関してはけっこう待たされるのでKillされることが多いです&color(red){''自分の場合は「make」を3回繰り返してようやく成功しました。''};~ +&color(blue){''過去で既に行っている場合はこの項目は飛ばしてください。''};~ カレントフォルダに「.bashrc」ファイルを作成する~ 「.bashrc」という名前(&color(blue){''ファイル名はとても重要''};なので間違えないようにしてください)のテキストファイルを作り、ファイルの内容を以下のようにする~ export PATH=/virtual/ユーザー名/packages/bin:$PATH ※当然、ユーザー名の所は自分のユーザー名を入れてね~ +&color(blue){''過去で既に行っている場合はこの項目は飛ばしてください。''};~ 「.bashrc」ファイルを認識させるためにコマンドを打つ~ cd ~ source .bashrc +ログインし直して、以下の3つのコマンドとも、バージョンが1.6.4と出れば成功です。~ ++「svn」コマンドのバージョン svn --version ~ svn, version 1.6.4 (r38063) compiled ??? ?? ????, ??:??:?? Copyright (C) 2000-2009 CollabNet. Subversion is open source software, see http://subversion.tigris.org/ This product includes software developed by CollabNet (http://www.Collab.Net/). The following repository access (RA) modules are available: * ra_neon : Module for accessing a repository via WebDAV protocol using Neon. - handles 'http' scheme - handles 'https' scheme * ra_svn : Module for accessing a repository using the svn network protocol. - handles 'svn' scheme * ra_local : Module for accessing a repository on local disk. - handles 'file' scheme * ra_serf : Module for accessing a repository via WebDAV protocol using serf. - handles 'http' scheme - handles 'https' scheme ++「svnadmin」コマンドのバージョン svnadmin --version ~ svnadmin, version 1.6.4 (r38063) compiled ??? ?? ????, ??:??:?? Copyright (C) 2000-2009 CollabNet. Subversion is open source software, see http://subversion.tigris.org/ This product includes software developed by CollabNet (http://www.Collab.Net/). The following repository back-end (FS) modules are available: * fs_fs : Module for working with a plain file (FSFS) repository. ++「svnserve」コマンドのバージョン svnserve --version ~ svnserve, version 1.6.4 (r38063) compiled ??? ?? ????, ??:??:?? Copyright (C) 2000-2009 CollabNet. Subversion is open source software, see http://subversion.tigris.org/ This product includes software developed by CollabNet (http://www.Collab.Net/). The following repository back-end (FS) modules are available: * fs_fs : Module for working with a plain file (FSFS) repository. **TortoiseSVNの設定 [#n311d55b] 例えば、カレントにリポジトリのフォルダ「repository」を置いた場合、アクセスするURLは以下の通りです。 -puttyを使わない(こちらは毎回パスワードを聞かれます)~ IDとパスワードがそのままネット上に流れてしまうため、セキュリティが低くおすすめできません。~ svn+ssh://ユーザー名@http指定のサーバー名/virtual/ユーザー名/repository --例 svn+ssh://username@s99.coreserver.jp/virtual/username/repository -puttyの証明書形式を使って接続する(秘密鍵・公開鍵のKey passphraseのパスワードを聞かれます)~ IDとパスワードが暗号化された状態でネットに流れるため安全です。~ [[PuTTY で鍵交換方式による SSH 接続:http://www.kuins.kyoto-u.ac.jp/news/47/putty-gen.html]]~ svn+ssh://ユーザー名@puttyセッション名/virtual/ユーザー名/repository --例 svn+ssh://username@coreserverhost/virtual/username/repository いちいち秘密鍵・公開鍵のKey passphraseを入れるのがめんどくさい!という方は、作成時にKey passphraseを空にすると聞いてこなくなります。~ ただこの場合、秘密鍵のファイルを盗まれてしまった場合、盗んだ人にサーバの進入を許してしまうという危険性があります。~ そのあたりは自己責任で。~ *Subversionのリポジトリのバックアップを取る [#s0cc4bdf] FTPで接続して「repository」のフォルダを丸ごとダウンロードしてください。~ *コミット時に「post-commit hook failed (exit code 255) with no output.」という警告が出る [#me0481b0] 「post-commit」自体は、コミット後に実行するスクリプトの設定です。~ ほとんどの人はこのフックの利用には、リポジトリのコミットやバックアップに関する連絡メールを送るのに使う様です。~ この設定を何もしていないのに、警告が出る場合はpost-commitを無効化してしまいましょう。~ -[[Subversion によるバージョン管理 フックスクリプト:http://subversion.bluegate.org/doc/book.html#svn.reposadmin.create.hooks]]~ リポジトリ内のfooksフォルダの中のファイル post-commit.tmpl post-commit を以下の様にリネームすると実行されなくなります。 post-commit.tmpl_ post-commit_