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

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


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

こんばんは,うすだです.

今週後半は,遅い夏休みをとって,長野県あたりを旅行してきました.

家族がそれぞれ行きたいところ,やりたいことを詰め込んだため, かなりハードなスケジュールとなりました.
それでも,長年の夢だった美ヶ原高原美術館や,栗のメッカである小布施など, 行きたいところへ行くことができ,満足しています.

一応ノートパソコンを持っていき, 電話回線経由でネットにつなげられる準備はしていきましたが, する気がなかったり,つながらなかったりで, 結局一度もネットにつなぐことなく,旅を過ごしました.

1日1回はネットにアクセスしないと死んでしまうのではないか,と思っていましたが, まったくそんなことはありませんでした.
たまには,そんな日々があってもよいのではないか,と思います.

そんなわけで,完全に準備不足の状態で,お届けをいたしております.
そ,それでは,今日も,はりきってまいりましょう!

今週のお題 - ログイン情報をでっちあげる

はい,先週は,ログイン情報が記録されている wtmp について, ご紹介をしました.

Vol.025 - ログイン情報を知る
http://www.usupi.org/sysad/025.html

詳しくは,上記を見ていただくとして,乱暴にまとめますと, ログインと呼べる行為やそれに準ずることを行うと, wtmp に記録されるようになっている,というお話でした.

しかし,それは,既存のサービスが wtmp に記録するように, 実装されているからなわけですね.そうなっていないサービスや, 自作したものなどに対しても,wtmp に記録を残せると, last コマンドなどで確認することができ,便利になります.

というわけで,今週は,wtmp に記録するものを作ってみようと思います.

ただし,さすがに,いきなり /var/log/wtmp に書き込んで, なにか問題が発生すると,責任問題が発生したりなどしますと,お互い, 非常にまずい状況に陥ってしまいます.
ですので,どうなってもいいテスト環境上か,wtmp をコピーしたもので, まず試していただければと思います.(いや,是非そうしてください.)

さて,いつもの如く,結論から申し上げますと,
updwtmp() という関数を用いれば,ログイン情報を追加できます.

  #include <utmp.h>

  void updwtmp(const char *wtmp_file, const struct utmp *ut);

すみません,今回は,ご覧の通り,C 言語を使います.
(Perl で updwtmp を呼べるようにしようと思いましたが, 準備不足のため見合わせていただきます.申し訳ありません…)

まず,第1引数 wtmp_file は,wtmp のパスを指定します.
/var/log/wtmp であれば,_PATH_WTMP を指定すればいいです.
コピーした wtmp を使うなら,そのパス名を指定します.

第2引数 ut は,utmp 構造体のポインタを指定します.
utmp 構造体は,Linux(glibc)の場合,/usr/include/bits/utmp.h で定義されています.例を以下に示します.

  struct utmp
  {
    short int ut_type;           /* ログインの型(後述) */
    pid_t ut_pid;                /* プロセスID */
    char ut_line[UT_LINESIZE];   /* デバイス名(tty名など) */
    char ut_id[4];               /* inittab のID */
    char ut_user[UT_NAMESIZE];   /* ユーザ名 */
    char ut_host[UT_HOSTSIZE];   /* ホスト名 */
    struct exit_status ut_exit;  /* 終了の状態 */
    long int ut_session;         /* セッションID */
    struct timeval ut_tv;        /* このエントリの生成時間 */
    int32_t ut_addr_v6[4];       /* リモートホストのアドレス */
    char __unused[20];           /* 予約(未使用) */
  };

これが,wtmp の1つのエントリの情報です.
だいたい見ての通りですが,ut_type に対しては,ログイン時には USER_PROCESS を, ログアウト時には DEAD_PROCESS を指定するようです.

では,サンプルプログラムを以下に示します.
リストを全部載せると暴動が起こりそうですので,以下をご覧ください.

ソースコードを覗き見るだけ
http://www.usupi.org/sysad/026-1_c.txt
ソースコード一式を得る
http://www.usupi.org/sysad/026.tgz

一式を得た方は,以下のようにコンパイルしてください.
tar コマンドで伸長すると,026 というディレクトリの下に一式ができています. make コマンドを実行すれば,wtmpset という実行形式ファイルが作成されます.

  % tar xfz 026.tgz
  % cd 026
  % make

これをとりあえず動かしてみるには,以下のように実行してください.
/var/log/wtmp をカレントディレクトリにコピーし,それに対して記録を行います.

  % cp /var/log/wtmp .
  % ./wtmpset
  Usage: ./wtmpset wtmpfile {i|o} pid line user
  % ./wtmpset ./wtmp i 1234 test1 usu
  (数分待ちます)
  % ./wtmpset ./wtmp o 1234 test1 usu

wtmpset の引数は,以下の通りです.
第1引数は,記録する wtmp ファイルを指定します. /var/log/wtmp を指定するときは,緊張しながら行ってください.
第2引数は,i だとログイン,o だとログアウトです.安直ですね.
第3引数は,プロセスID です.
第4引数は,デバイス名です.
第5引数は,ユーザ名です.

last コマンドで確認してみましょう.

  % last -f ./wtmp | head
  usu    test1                   Mon Sep  5 00:54 - 00:57  (00:03)
  ...後略

このように記録されていれば,成功です.
ちなみに,ログイン情報だけを記録すると,現在ログイン中だという出力になります.

  % ./wtmpset ./wtmp i 1235 test2 usu
  % last -f ./wtmp | head
  usu    test2                   Mon Sep  5 01:49 - still logged in

ただし,現在動作していないプロセスID を指定すると, ログアウトしていないよという出力になります.

  % ./wtmpset ./wtmp i 9999 test3 usu
  % last -f ./wtmp | head
  usu    test3                   Mon Sep  5 01:57 - gone - no logout

以上,wtmp ファイルへの書き込み方法について,ご紹介しました.
実際に使うことはほとんどないかもしれませんが, こんなふうに記録しているということを知っているだけでも, なにかの時に役に立つのではないかと思います.お暇でしたら,試してみてください.

宿題の答え

先週の宿題は,

  root でログインせずに,一般ユーザでログインして,root の権限で何
  か行う時は,su や sudo を使った方がいい理由は,なんでしょうか?

でした.

root でログインして作業すると, だれが root になって作業したのかがわかりませんので, 何か問題が起こった時に困ります.
ですが,su や sudo を使うと,誰が root になったかということが記録されるため, 問題が起こった時に,状況を聞くことができます.

ですので,普段は一般ユーザで使用し,root の権限が必要になった時にだけ, su や sudo を使って作業を行いましょう.

今週の宿題

今週の宿題は,こちらです.

  wtmp ファイルを読み出すプログラムを作ってみましょう

です.
last コマンドはわかりやすく出力してくれますが,せっかくですので, 各エントリを,そのままに近い状態で出力するものを作ってみましょう.
(C 言語じゃないと,実装しづらいかもしれません….)

あとがき

冒頭でも述べましたが,平日に休みを取得して,旅行に行きました.
平日に…ということは,その間,仕事を放り出して行ってきたわけです.

こんなとき,お客様に,なんと言っていいのか,悩みます.
特にせっぱつまっていなければ,正直に夏休みと言えるのですが, 納期が迫っているような状況ですと,さすがにまずいなと思うわけです.
(そんな状況で夏休みを取得する私は,すでに社会人失格ですが….)

とはいえ,旅館をすでに予約していましたので, 「家族+お金」と「仕事」を天秤にかけた結果,前者へ傾くことに決めました.

ま,結局,何も言わずに行きました.出荷作業は,他の人にお願いして. いちおう,ばれなかったようですが,周囲に迷惑をかけた, という事実は拭えないわけで,未だに,胸のあたりがしっくりきません.

答えなんてない気もしますが,ときには悩むことも大事だろうと思いますので, もう少し,もんもんと苦しんでみたいと思います.

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

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

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

「栗日記」−最初はそんなに栗好きではありませんでしたが,今は!
http://www.usupi.org/kuri/ (まぐまぐ ID:126454)


[バックナンバーのトップへ] [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・チャルディーニ
  思わず納得します