
|
[バックナンバーのトップへ] [Linux システム管理のトップへ] いますぐ実践! Linux システム管理 / Vol.134 / 読者数:1320名こんばんは、うすだです。 最近、朝起きて、会社に行って仕事して、帰ってきたら栗の絵を描いて、 もろもろの残作業をしたりしなかったりして寝る、という単調な生活を、 延々と繰り返していることに気づきました。
社会に対してなにか有意義なことを行うためには、その栄養の素となる、
新鮮な情報を必要とするように思います。ですが、
限られた範囲内で単調な生活を行っているだけでは、
大切な栄養が不足してしまいがちです。 というわけで、というわけでもないのですが、今週末、大阪の実家を経由して、 奈良へ遊びに行ってきました。
春休み最後のウィークエンドであることや、桜が満開に近いこと、
ドラマの影響などから、奈良公園は、たいへんな賑わいでした。 ひょっとすると、新たな情報が必要なのだということを無意識に感じて、 旅などに行きたいという欲求をひねり出しているのかもしれないですね。 はい、特にオチはありませんので、今回も、はりきってまいりましょう! 今回のお題 - ログを暗号化してメールで送る前回、ログインに失敗しました的ログを抽出し、その内容をメールで送る方法を、 ご紹介しました。
Vol.133 - 特定のログをメールで通知する
しかしながら、よく考えますと、ユーザアカウントなどを含むやもしれぬ情報を、
基本的に平文で扱うメールで送ってしまうということは、
場合によっては情報漏洩につながる恐れがあります。
ですがやはり、緊急度の高い情報は、いち早く手に入れたいもの。 暗号化…と言いますと、すでに以前、GnuPG をご紹介しておりました。
Vol.087 - ファイルを暗号化する
もちろん、これはこれで、安全な方法だと言えると思います。 ですので今回は、もう少しお気楽に、ZIP で圧縮し、 パスワードをつけるという方法で、暗号化を行ってみたいと思います。
ただし、ZIP の場合、共通鍵暗号方式を用いますので、
送り側と受け側の双方とも同じパスワードを知っている必要があります。 ですが、今回の場合、システム管理者内でパスワードを決めておけばよいですし、 万が一漏洩した場合のリスクは、それほど高くないと思いますので、 今回は ZIP ファイルを使ってやりとりしてみたいと思います。 言い訳が終わりましたので、まずは、 ZIP ファイルの作成から始めてみることにしましょう。
ZIP ファイルを作成するには、zip コマンドを用います。
% zip -r foo.zip bar.txt baz.txt
adding: bar.txt (deflated 62%)
adding: baz.txt (deflated 61%)
この場合、bar.txt と baz.txt を圧縮して、 foo.zip というファイルに押し込めたことになります。 作成した ZIP ファイルの内容を確認したい場合は、unzip コマンドを、 -l オプションつきで実行します。
% unzip -l foo.zip
Archive: foo.zip
Length Date Time Name
-------- ---- ---- ----
104357 06-13-07 11:58 bar.txt
78368 02-20-08 16:14 baz.txt
-------- -------
182725 2 files
実際に伸長する場合は、そのまま unzip コマンドを実行します。
% unzip foo.zip
Archive: foo.zip
inflating: bar.txt
inflating: baz.txt
では次に、パスワードつきの ZIP ファイルを作成してみましょう。 % zip -er foo.zip bar.txt baz.txt Enter password: (パスワードを入力します) Verify password: (同じパスワードを入力します) ... 実行しますと、上記のようにパスワードを聞かれますので、 パスワードを2回入力します。問題なければ、 パスワードで保護された ZIP ファイルが作成されます。 これを unzip コマンドで伸長するには、パスワードが必要になります。
% unzip foo.zip
Archive: foo.zip
[foo.zip] bar.txt password: (パスワードを入力します)
inflating: bar.txt
inflating: baz.txt
もちろん、パスワードを間違えると、伸長に失敗します。
% unzip foo.zip
Archive: foo.zip
[foo.zip] bar.txt password: (間違ったパスワードを入力します)
password incorrect-reenter: (同上)
password incorrect-reenter: (同上)
skipping: bar.txt incorrect password
...後略...
これで、大事なログを、ZIP ファイルに託すことができますね。 …と言いたいところですが、 ログの内容から ZIP ファイルを作成する度にパスワードの入力が必要ですと、 自動化することができません。
そこで、パスワードを入力しなくて済むようにしたいと思います。
% zip -P TeSt01 -r foo.zip bar.txt baz.txt
adding: bar.txt (deflated 62%)
adding: baz.txt (deflated 61%)
この方法を用いますと、スクリプト内などに生のパスワードを記述する、 というリスクを伴いますが、たとえば root しか読めないようにすることで、 リスクを緩和することができるように思います。
さて、それでは、前回の続きで、抽出したログを、
パスワードつきの ZIP ファイルにして、メールで送信してみたいと思います。
#!/bin/bash
# ↓ 作業場
WORKPATH=/tmp/sysad_134
# ↓ ZIPファイルのパスワード
PASSWORD="sYs134Ad"
# ↓ 作業場に移動して、無限にいろいろ行う
cd $WORKPATH
while [ 1 ]; do
allmessages=""
# ↓ 吐かれたログをパイプから収集
while read -t 60 message; do
allmessages="${allmessages}${message}@RET@"
done < /var/log/authpriv
# ↓ ログの内容を通知すべきなら、以下を実行
if [ "z`echo $allmessages | grep -i fail`" != z ]; then
# ↓ この時点で $TXTFILE は作成される
TXTFILE=`mktemp syslog_auth_messages-XXXXX`
ZIPFILE=${TXTFILE}.zip
# ↓ 抽出したログを $TXTFILE に書き出す
echo $allmessages | sed 's/@RET@/\n/g' >> $TXTFILE
# ↓ ZIPファイルを作成
zip -q -P "$PASSWORD" -r $ZIPFILE $TXTFILE
# ↓ uuencode を介して Mail で送信
uuencode $ZIPFILE < $ZIPFILE | \
/usr/bin/Mail -s 'syslog authpriv' root
# ↓ $TXTFILE と $ZIPFILE は消しておく
rm -f $TXTFILE $ZIPFILE
fi
done
一時的にファイルをいくつか作成しますので、上記では、 /tmp/sysad_134 というディレクトリの下で作業するようにしています。
while 文の中は、前回のスクリプトとほぼ同様です。 このファイルを auth2mail.sh というファイル名で保存したら、 root なひとだけ参照できる状態にしておきます。 # chmod 700 auth2mail.sh そして、前回と同様に、 /etc/syslog.conf の設定や /var/log/authpriv の作成を行いましたら、 ディレクトリを作成し、上記を実行します。 # mkdir -m 700 /tmp/sysad_134 # ./auth2mail.sh 特にエラーなど発生していないようでしたら、 実際にログインに失敗してみてください。 数分後に以下のようなメールが届けば、成功です。 From: root@hoge.usupi.org To: root@hoge.usupi.org Subject: syslog authpriv begin 644 syslog_auth_messages-18663.zip M4$L#!!0`"0`(`(JUACA.$$Z@'`$``'<$```:`!4`<WES;&]G7V%U=&A?;65S M<V%G97,M,3@V-C-55`D``[33^$>TT_A'57@$```````<[FWQG(\8;*.W(=&2 ...中略... M&@`-```````!````@($````` |
▼ トップ ▼ プロフィール ▼ リンク
▼ 作ってみました
▼ せんでん
▼ 最近読んだ本 [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の創りかた」 渡波 郁 「非常識な成功法則」 神田 昌典 …これ以前は記録してません…
▼ 気に入ってる本
| ||||||||||||||||||||||||||||||||||||||||