いますぐ実践! Linuxシステム管理

[バックナンバーのトップへ] [Linux システム管理のトップへ]


いますぐ実践! Linux システム管理 / Vol.063 / 読者数:843名

こんばんは、うすだです。

先月でおわったはずのお仕事が、まだ続いていて、 もんもんとした日々を過ごしております。

要求仕様を満たさなかった自分が悪いのですが、ひたすらデバッグや調査を繰り返し、 もっともらしいドキュメントを仕上げるという作業は、 自分にはものすごく向いていないということを、実感しております。

ずっと、そのことに気づいていないふりをしていたのですが、体は正直でした。 今、体重の増加、右肩の痛みというシグナルを体が発しています。

というわけで、以下をじっくり読んで、落ち着かせたいと思います。

プログラマの心の健康
http://www.hyuki.com/kokoro/

ちょっと気持ちがすっきりしてきました。
しかし、右肩などの肉体的な問題は、すぐには解決されないようです…。

では、無理矢理テンションを上げて、今週もはりきってまいりましょう!

今週のお題 - 設定ファイルをまとめてリビジョン管理する

先々週、先週と、RCS を使った、設定ファイルのリビジョン管理方法を、 ご紹介しました。

Vol.061 - 設定ファイルをリビジョン管理する
http://www.usupi.org/sysad/061.html
Vol.062 - 設定ファイルをもっとリビジョン管理する
http://www.usupi.org/sysad/062.html

ただ、RCS は、基本的には、個々のファイルを対象とします。
しかし、Apache や postfix などのように、 あるディレクトリ以下に設定ファイルが束になっている場合、 RCS でそれぞれ管理するのは、けっこう大変ではないかと思います。

というわけで今週は、設定ファイルの束を、 まとめてリビジョン管理してみようと思います。


はい、お察しの通り、今週は CVS を使います。
あ、CVS なら開発で使ってるよ、なんていう貴兄は、読み飛ばしちゃってくださいまし。

で、例によって例のごとく、cvs パッケージが入っていなければ、 apt や yum などで入れておいてください。

さて、その CVS ですが、RCS と大きく違うところは、以下の3点です。

  • 複数のファイル(あるディレクトリ以下すべて)を対象とする。
  • 複数の人々で管理できる。
  • ネットワークに対応している。

複数のファイルをまとめて管理しますので、 リポジトリと呼ばれるところにデータを置き、別の作業場所に取り出して、 編集などするようになっています。 (今回は、2,3番目には触れません。ごめんなさい。)


さて、ちゃんとした理解などは、書籍や検索で勉強していただくとして、 ここでは早速、実際に使ってみることにしましょう。

まずは、リポジトリを作成します。
環境変数 CVSROOT でその場所を指定して、cvs コマンドの init を実行します。

  # export CVSROOT=/usr/local/cvs
  # cvs init

csh 系のかたは、以下のようにしてください。

  # setenv CVSROOT /usr/local/cvs
  # cvs init

上記の例では、/usr/local/cvs に、リポジトリを作成しています。


リポジトリができましたので、次は、プロジェクトを登録します。
ここでは、/etc/httpd 以下を管理対象としてみたいと思います。
登録するには、管理対象とするディレクトリに移動して、 cvs コマンドの import を実行します。

  # cd /etc/httpd
  # cvs import httpd usu apache_config

httpd は、プロジェクト名です。作業ディレクトリに取り出すときなど、 プロジェクトを指定する際に使用します。
あとの usu と apache_config は、それぞれベンダータグ、 リリースタグと呼ばれるものです。どういうときに使うのか、 わたしにはわかりませんので、いつも適当につけています。(す、すみません…)

以下のように、リポジトリに登録されたことがわかります。

  # ls /usr/local/cvs
  CVSROOT/  httpd/

今度は、リポジトリから作業ディレクトリへ、取り出してみましょう。
取り出すには、cvs コマンドの checkout を、プロジェクト名を指定して実行します。

  # cd /tmp
  # cvs checkout httpd
  # ls httpd
  CVS/  conf/  conf.d/

作業ディレクトリ /tmp に、httpd 以下が取り出されました。
ただし、実際は、/etc/httpd で作業しますので、 各ディレクトリに作成された CVS ディレクトリを、/etc/httpd 以下へコピーします。

  # find httpd -name CVS | \
  while read dir; do mv -i $dir /etc/`dirname $dir`; done

あ、csh 系の場合は、以下のようにしてください。

  # foreach dir (`find httpd -name CVS`)
  foreach? mv -i $dir /etc/`dirname $dir`
  foreach? end

では次に、設定ファイルを修正しましたので、更新してみましょう。
更新するには、cvs コマンドの commit を実行します。

  # cvs commit httpd.conf
  /usr/local/cvs/httpd/conf/httpd.conf,v  <--  httpd.conf
  new revision: 1.2; previous revision: 1.1

また、新たなファイルを管理対象に加えたいときは、 cvs コマンドの add を実行します。
たとえば、/etc/httpd/conf.d/test.conf を追加するには、以下のように実行します。

  # cd /etc/httpd/conf.d
  # cvs add test.conf
  cvs add: scheduling file `test.conf' for addition
  cvs add: use `cvs commit' to add this file permanently

commit の実行で、実際に登録されます。

  # cvs commit test.conf
  /usr/local/cvs/httpd/conf.d/test.conf,v  <--  test.conf
  initial revision: 1.1

さて、それぞれのファイルに、1.1 や 1.2 などというバージョンがついていますが、 きりのいいときに、全体で1つの名前をつけたいですよね。
CVS では、今の状態にタグをつけることができます。cvs コマンドの tag を、 タグ名を指定して実行します。

  # cd /etc/httpd
  # cvs tag apache_20060625

上記では、apache_20060625 というべたなタグ名をつけています。
将来、この状態に戻りたいときには、checkout の際に、 -r オプションでタグを指定します。

  # cd /tmp
  # cvs checkout -r apache_20060625
  # tar cf - httpd | (cd /etc; tar xvfp -)

今回は、tar コマンドで、/etc/httpd にまるっとコピーしています。


以上、CVS によるリビジョン管理について、簡単にご紹介しました。

他に、update, log などの命令や、 SSH を使って別のマシンから取り出したりといったところをご紹介したかったのですが、 これ以上長くなると読んでもらえないかもと思いましたので、泣く泣く割愛しました。
# わかりにくくてすみません。簡潔に記述する能力がほしいです…。

とりあえずは、あたり触りのないところや、 どうでもいいディレクトリをでっちあげて試してみると、 よろしいのではないかと思います。

宿題の答え

先週の宿題は、

  ロックしなくてもチェックインできるようにしてみましょう。

でした。

rcs コマンドの -U オプションを使えば、そのようにできます。

  # rcs -U /etc/hosts
  RCS file: /etc/hosts,v
  done

こうすれば、ロックせずにチェックアウトして、 変更後いきなりチェックインができます。

  # co /etc/hosts
  /etc/hosts,v  -->  /etc/hosts
  revision 1.3
  done
  (/etc/hosts の編集)
  # ci /etc/hosts
  /etc/hosts,v  <--  /etc/hosts
  new revision: 1.4; previous revision: 1.3
  enter log message, terminated with single '.' or end of file:
  >> add new hosts.
  >> .
  done

もとに戻したい場合は、rcs コマンドの -L オプションを使います。

  # rcs -L /etc/hosts
  RCS file: /etc/hosts,v
  done

今週の宿題

今週の宿題は、

  CVS ディレクトリにあるファイルを眺めてみましょう。

です。

CVS 以下のファイルは、どれもテキスト形式ですので、中を覗くと、 どのように管理しているのかが、おぼろげにわかるのではないかと思います。

あとがき

そんなこんなで設定ファイルの管理について、3週間やってきました。

正直に言いますと、わたしは、 バックアップファイルをその都度作成することのほうが、多いです。
具体的には、ファイル名に、".数字" を付加したバックアップファイルを作成します。 こんな感じで。

  # cp -p /etc/hosts /etc/hosts.0
  # cp -p /etc/hosts /etc/hosts.1
  ...

どう考えても、RCS を使った方がすっきりするはずなのですが、 一度脳に刻み込まれた習慣は、なかなか変えられないようです。

さて、設定ファイルをどう管理するかという問題は、 みなさん抱えていらっしゃるようでして、こんなのがありました。

設定ファイルをまとめて管理する
http://playrecord.org/archive/config-files-on-Unix/myconf.html

ユーザのホームに設定ファイルを置いておき、 sudo で make コマンドを実行すると /etc などにコピーされるよう、 Makefile を記述しておくという方法です。

方法は単純ですが、バックアップや複数マシンへの対応など、 メリットはたくさんありそうです。
わたしは、これを読んで、Makefile に細工して拡張したくなりました。

ちなみに、上記は、「オレンジニュース」というサイトで、 数日前に紹介されていました。(実は、冒頭のも、そうです。)

オレンジニュース
http://secure.ddo.jp/~kaku/tdiary/

ここは、いろんなサイトのネタを紹介してくれるところです。
技術ネタなんて、あちこち巡回せず、ここだけを見ればいいというくらいに、 充実しています。(雑多ネタもおもしろいです。)

WWW のページは星の数ほどありますが、 ここを定期的にチェックしておくといいよっていうところは、 とても貴重ではないかと思います。

わたしも、そんなサイトを目指して、じわじわがんばろうと思いました。
変に着地したところで、今宵はここまでにいたしとうございます。

今週も、ここまで読んでいただき、ありがとうございました。
それでは、また来週に、お会いしましょう!

「いますぐ実践! Linux システム管理」の解除は、以下からできます。
http://www.usupi.org/sysad/ (まぐまぐ ID:149633)

バックナンバーは、こちらにほぼ全部そろっています。
http://www.usupi.org/sysad/backno.html

「栗日記」−はやくギャラリーを観に行かねば…。
http://www.usupi.org/kuri/ (まぐまぐ ID:126454)
http://usupi.seesaa.net/ (栗日記ブログ)
http://www.fumido.co.jp/kuriniki/ (栗日記ぎゃらりー)


[バックナンバーのトップへ] [Linux システム管理のトップへ]

トップ

バックナンバー
    [日付順] [目的別]

プロフィール

▼ リンク

独学Linux
Linuxデスクトップ環境に関する情報が満載です。 メルマガもありますよ。
Server World
CentOS 5 をサーバとしたときの設定例が、これでもかというくらいたくさん載っています。 CentOS以外のディストリビューションや、Solaris10の例も充実しています。
LINUXで自宅サーバーを構築・導入(Fedora8)
Fedora8のインストールの仕方から管理方法まで、詳しく載っています。 SearchManには情報がもりだくさんです。
マロンくん.NET
〜サーバ管理者への道〜
Linuxをサーバとして使用するための、いろいろな設定方法が載っています。 マロンくんもかわいいです。 なんといっても、マロンくんという名前がいいですね!!
日本の Linux 情報
日本の、Linux 総本山的なところです。
Linux Square − @IT
@ITが提供する、Linux の情報が満載。 載っていない設定方法はないんじゃないでしょうか。
Open Tech Press
Linux に限らず、オープンソース関連の記事が網羅されています。
ITmediaエンタープライズ:Linux Tips 一覧
Tips というより FAQ 集でしょうか。わからないことがあれば覗きましょう。
IBM developerWorks : Linux
開発者向けですが、勉強になりますよ。
Yahoo!ニュース - Linux
Yahoo!のLinuxに関するニュース一覧です。
栗日記
システム管理とかと全然関係ありませんが、毎日栗の絵を描いています。
システム管理につかれちゃったとき、癒されたいときに、ご覧ください。:-)
WEB RANKING - PC関連
ランキングに参加してみました。押してやってください。

▼ 作ってみました

Add to Google

▼ せんでん





▼ 最近読んだ本

ハリー・ポッターと不死鳥の騎士団 ハリー・ポッターと不死鳥の騎士団
J.K.Rowling
  ハリポ月刊なので読み直してます
ハリー・ポッターと炎のゴブレット ハリー・ポッターと炎のゴブレット
J.K.Rowling
  ハリポ月刊なので読み直してます
ハリー・ポッターとアズカバンの囚人 ハリー・ポッターとアズカバンの囚人
J.K.Rowling
  ハリポ月刊なので読み直してます
ハリー・ポッターと秘密の部屋 ハリー・ポッターと秘密の部屋
J.K.Rowling
  ハリポ月刊なので読み直してます
ハリー・ポッターと賢者の石 ハリー・ポッターと賢者の石
J.K.Rowling
  ハリポ月刊なので読み直してます
アルケミスト アルケミスト
パウロ・コエーリョ
  また読んだ
賢者の書 賢者の書
喜多川 泰
  違った視点から見られてよかった
セキュリティウォリア セキュリティウォリア
Cyrus Peikari, Anton Chuvakin
  やや冗長…ためにはなりました
CORE MEMORY CORE MEMORY
John Alderman, Mark Richards
  この筐体でPC作ってほしい!
新訳 星の王子さま 新訳 星の王子さま
サン=テグジュベリ
倉橋 由美子
  つまらない大人になったのか…
.....

[X]
「センネン画報」 今日 マチ子
「粟津潔 デザインする言葉」 粟津潔
「Binary Hacks」 高林 哲,鵜飼 文敏,佐藤 祐介,浜地 慎一郎,首藤 一幸
「Make: Volume01」 オライリー・ジャパン
「セーラが町にやってきた」 清野 由実
「手紙屋」 喜多川 泰
「Linuxカーネル2.6解読室」 高橋 浩和,小田 逸郎,山幡 為佐久
「人蕩し術」 無能 唱元
「子育てハッピーアドバイス2」 明橋 大二, 太田 知子
「ラッセル幸福論」 B. Russell
「それでも人生にイエスと言う」 Viktor Emil Frankl
「子育てハッピーアドバイス」 明橋 大二, 太田 知子
「考具」 加藤 昌治
「北欧デザイン<3>」 渡部 千春
「北斎の謎を解く」 諏訪 春雄
「体感美術館」 平野 暁臣
「チベット永遠の書」 Theodore Illion
「リナックスの革命」 Pekka Himanen
「人月の神話」 Frederick Phillips,Jr. Brooks
「ヤバい経済学」 Steven D. Levitt, Stephen J. Dubner
「小布施ッション<2001-2002>」 セーラ・マリ カミングス
「アンパンマン伝説」 やなせ たかし
「夢をかなえるゾウ」 水野 敬也
「ゲーム開発者のためのAI入門」 David M. Bourg, Glenn Seemann
「北欧デザイン<2>」 渡部 千春
「北欧デザイン<1>」 渡部 千春
「ヒューマン2.0」 渡辺 千賀
「中国・ロシア同盟がアメリカを滅ぼす日」 北野 幸伯
「超ロング・セラー 絶滅寸前商品」 湯浅 豊彦
「The BUG(ザ・バグ)」 すずき ひろのぶ,かとう みつあき
「デザインのデザイン」 原 研哉
「マキアヴェッリ語録」 塩野 七生
「ハンバーガーを待つ3分間の値段」 斎藤 由多加
「星の旅人-スペイン「奥の細道」-」 黛 まどか
「食品の裏側」 安部 司
「On Lisp」 Paul Graham
「ぼくが医者をやめた理由 つづき」 永井 明
「あなたならどうする?」 Jack Nikolaschka
「セキュアプログラミング−失敗から学ぶ設計・実装・運用・管理」
      Mark G. Graff, Kenneth R. van Wyk
「「左利き」は天才?−利き手をめぐる脳と進化の謎
      David Wolman
「自分の中に毒を持て」 岡本 太郎
「アトピーの薬を減らす本」 田中 貴子
「岡本太郎「明日の神話」修復960日間の記録」 吉村 絵美留
「X51.ORG THE ODYSSEY」 佐藤 健寿
「アレルギーっ子の暮らし応援BOOK」 佐藤 のり子
「沖縄文化論」 岡本 太郎
「「伝説の社員」になれ!」 土井 英司
「コンピュータの構成と設計(上)」 Patterson & Hennessy
「カラスのジョンソン」 明川 哲也
「ドリルを売るには穴を売れ」 佐藤 義典
「頭がよくなる照明術」 結城 未来
「クロフォードのインタラクティブデザイン論」 Chris Crawford
「いじめの根を絶ち子どもを守るガイド」 Barbara Coloroso
「非常識のすすめ―逆発想の仏教論」 ひろさちや
「Linuxアドバンストネットワーク構築ガイド - HAサーバ構築編」
      デージーネット
「イノベーションの達人!」 Tom Kelly, Jonathan Littman
「クリエーター50人が語る創造の原点」 小原 啓渡
「欺術 - 史上最強のハッカーが明かす禁断の技法」 Kevin Mitnick
「楽しい気象観察図鑑」 武田 康男
「入門 Ajax」 高橋 登史朗
「リリカルな自画像」 岡本 太郎
「やぎの目ゴールデンベスト」 林 雄司
「初めてのPython 第2版」 Mark Lutz,David Ascher
「鼻兎」 小林 賢太郎
「なぜ、これがアートなの?」 Amelia Arenas
「芸術起業論」 村上 隆
「まほう色の瞳」 Enrique Barrios
「ラーメンズつくるひとデコ」 ラーメンズ
「R25 つきぬけた男たち」 R25編集部
「美の呪力」 岡本 太郎
「しろのあお」 上大岡 トメ
「ザ・ゴール」 Eliyahu M. Goldratt
「ハッカーと画家」 Paul Graham
「岡本太郎に乾杯」 岡本 敏子
「Fedore Core Expert」 Software Design
「誰も知らない男」 ブルース・バートン
「子どもが育つ魔法の言葉」 ドロシー・ロー・ノルト
「国家の罠」 佐藤 優
「夜回り先生」 水谷 修
「やぎの目絵日記」 林 雄司
「7つの習慣」 スティーブン・R. コヴィー
「まろ、ん?−大掴源氏物語」 小泉 吉宏
「ザ・サーチ グーグルが世界を変えた」 ジョン・バッテル
「ポストモダン・マーケティング」 スティーブン ブラウン
「機動戦士ガンダムさん」 大和田 秀樹
「小エロのひみつ - Webやぎの目研究発表」 林 雄司
「これ、誰がデザインしたの?」 渡部千春
「60分間・企業ダントツ化プロジェクト」 神田 昌典
「ガルシアへの手紙」 エルバート ハバード
「人生は素晴らしいものだ」 オグ・マンディーノ
「ザ・マインドマップ」 トニー・ブザン,バリー・ブザン
「ワインバーグのシステム思考法」 G.M.ワインバーグ
「渋谷ではたらく社長の告白」 藤田 晋
「渋井真帆の日経新聞読みこなし隊」 渋井 真帆
「コラム息切れ」 小野 法師丸
「早朝起業」 松山 真之介
「変な人が書いた驚くほどツイてる話」 斎藤 一人
「35歳から仕事で大切にしたいこと」 村井 勉
「金融広告を読め」 吉本 佳生
「発想する会社!」 トム・ケリー,ジョナサン・リットマン
「エハイク」 吉田 戦車
「人生の旋律」 神田 昌典
「仕事の思想」 田坂 広志
「CPUの創りかた」 渡波 郁
「非常識な成功法則」 神田 昌典
…これ以前は記録してません…

▼ 気に入ってる本

夢をかなえるゾウ 夢をかなえるゾウ
水野 敬也
  いままでで最高の「笑える」成功本
Linuxデバイスドライバ Linuxデバイスドライバ
Alessandro Rubini,
Jonathan Corbet
  ドライバ作らなくてもためになる
Firefoxの改造テクニック! Firefoxの改造テクニック!
大浦 淳
  いま栗日記拡張を考えてます
Apacheモジュール プログラミングガイド Apacheモジュール プログラミングガイド
小山 浩之
  Apacheの中身もわかるよ
図解 実戦マーケティング戦略 図解 実戦マーケティング戦略
佐藤 義典
  栗日記も戦略的に行こう!
やぎの目ゴールデンベスト やぎの目ゴールデンベスト
林 雄司
  よめも爆笑してました
アルケミスト アルケミスト
パウロ・コエーリョ
  ヘコみそうなとき読みます
X51.ORG THE ODYSSEY X51.ORG THE ODYSSEY
佐藤 健寿
  X51.ORGの集大成
チベット永遠の書 チベット永遠の書
Theodore Illion
  いろんな意味ですごい!!
影響力の武器 影響力の武器
ロバート・B・チャルディーニ
  思わず納得します