技術メモ

biffpopのインストール

自宅ではMyDNSを使用してダイナミックDNSを使っているため、
定期的に自宅のグローバルIPアドレスを通知する必要がある。
MyDNSではメール受信処理を自分のアカウントに行えば、
それでグローバルIPアドレスを更新してくれるため、今回は
メール受信を行ってくれる「biffpop」をインストールした。

1.biffpopをダウンロード

[root@developServer ~]# wget http://www.nakata-jp.org/computer/freesoft/biffpop.tgz
2.ダウンロードしたbiffpopを解凍

[root@developServer ~]#tar xvzf biffpop.tgz

3.biffpopをインストール

[root@developServer ~]# cd biffpop/src/

[root@developServer src]# make
cc -O3 -DIPv6 -DKILLLIST -DUSE_SSL  -c -Wall biffpop.c -o biffpop.o
biffpop.c:35 から include されたファイル中:
biffpop.h:17:1: 警告: “TRUE” が再定義されました
/usr/include/krb5.h:7 から include されたファイル中,
/usr/include/openssl/kssl.h:72 から,
/usr/include/openssl/ssl.h:191 から,
biffpop.c:24 から:
/usr/include/krb5/krb5.h:184:1: 警告: ここが以前の宣言がある位置です
cc -O3 -DIPv6 -DKILLLIST -DUSE_SSL  -c -Wall Pop3Client.c -o Pop3Client.o
cc -O3 -DIPv6 -DKILLLIST -DUSE_SSL  -c -Wall ApopString.c -o ApopString.o
cc -O3 -DIPv6 -DKILLLIST -DUSE_SSL  -c -Wall md5c.c -o md5c.o
cc -O3 -DIPv6 -DKILLLIST -DUSE_SSL  -o biffpop biffpop.o Pop3Client.o ApopString.o md5c.o  -lssl

※もしmakeコマンドでエラーが出るならコンパイラが必要かもしれません。

以下のコマンドでコンパイラをインストールしてください。

yum -y install gcc

yum -y install gcc-c++

[root@developServer src]# cp biffpop /usr/bin/

[root@developServer ~]# rm -rf biffpop
[root@developServer ~]# rm -rf biffpop.tgz

4.biffpopの設定ファイルの作成

一度biffpopコマンドを実行すると、root直下に.biffpoprcという設定ファイルが出力されます。

[root@developServer ~]# biffpop
-Config file does not exist : /root/.biffpoprc
+Trying to create new config file.
+New config file created : /root/.biffpoprc

  • ~/.biffpoprc must be configured before running biffpop.
    [root@developServer ~]#

5.設定ファイルの更新

vi .biffpoprc

Replace all < > with appropriate data

#
start          HIROROOM
popserver       メールサーバー名
port            110     # connection port
portv6          110     # connection port for IPv6
username        アカウント名
password        パスワード
mailcheckdelay  600     # default mail check time in seconds
viewallmessages 0       # 0 Shows both unread & total messages
inhibitAPOP     0       # 0 can use APOP
#                        and 1 never use APOP
end

6.メール受信テスト

[root@developServer ~]# biffpop
HIROROOM      mesg : unread 0 / total 0

※こんな感じで表示されればOK

7.biffpopの実行&ログ取得用バッチの作成

[root@developServer biffpop]# mkdir biffpop

[root@developServer biffpop]# cd biffpop/

[root@developServer biffpop]# vi  biffpopExec.sh

#!/bin/sh
#

メールチェックし、DNS更新

#
dateTime=date '+%Y%m%d%H%M%S'
HOME=/root

#

End configuration section

#
export LANG=ja_JP.UTF-8

echo “” >> /root/biffpop/biffpop.log
echo ${dateTime} >> /root/biffpop/biffpop.log
/usr/bin/biffpop >> /root/biffpop/biffpop.log 2>&1

8.CRONで定期的にバッチを実行させる

[root@developServer ~]# vi /etc/crontab

下記の1文を最終行に追加し、30分ごとにチェックするようにする

*/30 * * * * root /root/biffpop/biffpopExec.sh

9.30分ごとにログが出力され、ちゃんとメール受信できているか確認

[root@developServer ~]# less biffpop/biffpop.log

20101103180625
HIROROOM        mesg : unread 0 / total 0

車掃除用ハンドクリーナー(dyson DC31motorhead サテンブルー)

車の中の掃除は大変です。

我が家はドッグランに行くときに犬を車に乗せたりするので毛がわんさか付きます(+_+)

そんな時のためにハンドクリーナーがあれば便利と思い、

奮発してダイソンのハンドクリーナーを購入しました。

ちょっと重いけど使いやすいです(^-^)

吸引力はそこまで強くないけど、犬の毛ぐらいなら取れました。

dyson DC31motorhead サテンブルー

Amazonで27,504円でした。

レーダー探知機の取り付け

CELLSTARのミラー取り付け型のレーダー探知機を購入!!!

型番はASSURA AR-910MTです。AUTOBACKSで27,800円でした。
Amazonで見てみたら安い!!!
軽くショックを受けますね・・・

その時の取り付け方法を説明します。

電源はヒューズボックスから取るようにしました。

1.レーダーをミラーに取り付け。配線はフロントガラスの上の部分にある天井の中に入れ、

運転席の足元まで配線

2.アースの取り場所がいいとこが見つからなかったので、運転席のドアに配線。微妙だな~(+_+)

3.ヒューズボックスから電源を取る。

差し口を調査したところ、34番はエンジンOFFで電源が切れるようになっていたため、

34番に配線

完了~!余計な警告が多いけど、満足です(^◇^)

Oracleのパフォーマンス障害についてのメモ

Oracle9iの頃はあんまり無かったが、10gになってから
パフォーマンスに関する障害がよく起こる。
その際の原因と対応策についてメモしとく。

##あくまで経験上の話であり、絶対正しい分けではないので注意!

○現象
特定のSQL実行時にCPUが100%に張り付き、
処理が完了しない。
##SQL自体は正常時には数秒で返ってくる程度

○原因
実行計画の不備と思われる。
主にCPUに負荷のかかる実行計画で実行され、
速度遅延を起こしている。
根本原因は統計情報の不足。

○対応策
案としては下記の2つが上げられる。

①使用するテーブルをアナライズ
Oracle10gではWeb板のEnterpriseManager(以後EMとする)で統計情報の取得が
実行できるのでそれを使用すると楽かも。
あと10gからDBMS_STATS.GATHER_SCHEMA_STATS等のオプションの
デフォルト値が変わり、デフォルトではno_invalidate(実行計画の再生成の有無)が
oracle任せになっているので注意。
アナライズを行っても実行計画が変わらない可能性があるのでFalseにすること。
##no_invalidateオプションはEMではカーソルの無効化という名前になっています。

なおOracle10gではデフォルトでアナライズを行うジョブが登録されているが、
統計情報が失効したオブジェクトのみ、カーソルの無効化もoracle任せになっている。
理論的には統計情報が失効したオブジェクトのアナライズのみでも問題なさそうだが
常に最適な実行計画をoracleが判断してくれることを考えると独自で
アナライズジョブを作成し、全てのオブジェクトに対し即カーソルの無効化をさせるように
設定したほうがよいと思われる。

②SQLチューニング・アドバイザ
oracle10gからSQLチューニング・アドバイザなるものがある。
簡単に説明すると障害の発生したSQLを分析し、こうしたら早くなるよ~っと
アドバイスしてくれる機能である。
今回はそのアドバイスの中に出てくる(出てこない場合もある)実行計画の変更を
利用する。出てきた実行計画を「実装」させることにより、そのSQLのみ実装した
実行計画で実行されるようになる。
上記①だと場合によっては長時間かかることがあり、もし運用での切羽詰った状況では
アナライズできない場合もある。
それに比べ②は時間もかかっても数分なので助かる。

実行の仕方はEMからアラート等に表示されている特定の遅いSQLをクリックし、
「SQLチューニング・アドバイザのスケジュール」等で実行する。
その後診断結果が出るのでその中にある統計情報?を実装させてやればよい。

NoEditor(テキストエディタ)

○ソフト名
NoEditor(テキストエディタ)

○画面イメージ

○ソフト説明
テキストエディタです。
テキストエディタは秀丸とかサクラエディタなどなどたくさん種類はありますが
個人的にはこれが一番気に入ってます(^-^)/
ファイル比較でVSSみたいビジュアル表示されるのが最高です!

○URL
http://www.yokkasoft.net/