(ずいぶん長いこと書いていなかった。)
今まで利用していたISPは
BEKKOAME -> AT&T Jens(現JENS SpinNet?) -> Highway
だった。
BEKKOAMEは接続料金固定の草分けで、環境としてはよくなかったけど、料金的に当時は他に選択肢がなかった。
下井草から上井草に引越し、接続料金固定プロバイダも増えたので、バックボーンがしっかりしてそうなAT&Tに変更。
ところが、多摩川を越えたらアクセスポイントがなく、Highwayに変更。
アクセスポイントか。ダイアルアップがなつかしい。
この度、KDDIの光プラスというサービスを利用することになった。
プロバイダは自動的にDION。
そこで、多摩川を越えてからずっとお世話になったHighwayとの契約も今日で終了。
この光プラスというのは、今住んでいる集合住宅まではなんと1Gbpsの光ファイバ、構内はVDSLという方式で今までの銅線を利用して接続するのだそう。
で、契約したのはネット接続と電話。
やがて電話もNTTとの契約が解除される。
トータルの通信費がちょうどHighwayの月額料金分だけ安くなる感じ。
インターネットを利用するようになって約9年。
振り返ると環境の進化に改めて驚くなあ。
木曜日, 4月 20, 2006
甘露の法雨(2003/10/28 日記鯖より転載)
もともと「生長の家」という新興宗教を興した谷口雅春という人が感得して書いた自由詩ということだが、
今は生長の家の「聖教」という名のお経になっているようだ。
「般若心経」の空の教えをわかりやすくし、浄土教の教えも併せ持ったような内容だ。
なかなかよくこなれていると思う。
昔は新興宗教というだけで毛嫌いしていたものだが、先入観を持たなければ、そこに新たな発見があるかもしれない。
もっとも、興味があるのは書かれた内容であって、組織を維持するために存在する宗教団体に関心があるわけではないのだが。
今は生長の家の「聖教」という名のお経になっているようだ。
「般若心経」の空の教えをわかりやすくし、浄土教の教えも併せ持ったような内容だ。
なかなかよくこなれていると思う。
昔は新興宗教というだけで毛嫌いしていたものだが、先入観を持たなければ、そこに新たな発見があるかもしれない。
もっとも、興味があるのは書かれた内容であって、組織を維持するために存在する宗教団体に関心があるわけではないのだが。
ニューソート(2003/10/17 日記鯖より転載)
ジョセフ・マーフィーの翻訳本は結構好きです。
日本人では、「生長の家」をつくった谷口雅春の書いたものにもよい文が含まれていると思います。
「成功」とか「金持ち」とかいう言葉のイメージが強いニューソートですが、私には「心の平安」という表現や神秘主義的要素がより魅力的に映ります。
「心の平安」を実感できるようになれば、それがすなわち「成功」に他ならず、外見的な成功やお金も後から自然についてくる気がします。
私の中では、念仏も含め「祈り」が最近のキーワードです。
日本人では、「生長の家」をつくった谷口雅春の書いたものにもよい文が含まれていると思います。
「成功」とか「金持ち」とかいう言葉のイメージが強いニューソートですが、私には「心の平安」という表現や神秘主義的要素がより魅力的に映ります。
「心の平安」を実感できるようになれば、それがすなわち「成功」に他ならず、外見的な成功やお金も後から自然についてくる気がします。
私の中では、念仏も含め「祈り」が最近のキーワードです。
Perl DBIでバイナリデータ(2006/04/04 mixiの日記より転載)
Windows上のCygwinにDBIとDBD::ODBCを使ってSQL Serverにローカルファイルを入れたり、ファイルデータを取り出したりするサンプル。
DBIとDBD::ODBCは、CPANからソースを持ってきてインストール。
入れるときは
$sth->bind_param(4,$buff,DBI::SQL_LONGVARBINARY);
取り出すときは
$dbh->{LongReadLen} = 10 * 1024 * 1024;
$dbh->{LongTruncOk} = 1;
あたりがミソかも。
---(ここから)---
#!/usr/bin/perl -w
use strict;
use DBI;
my $site_id = $ARGV[0]; # サイトID
my $item_id = $ARGV[1]; # 項目ID
my $extension = $ARGV[2]; # ファイル拡張子
my $dir_path = $ARGV[3]; # ディレクトリパス
my %CONTENT_TYPE = (
"jpg" => "image/jpeg",
"jpeg" => "image/jpeg",
"gif" => "image/gif",
"bmp" => "image/bmp",
"png" => "image/png",
"js" => "text/plain",
"css" => "text/css",
"pdf" => "application/pdf",
"rdf" => "application/rtf",
"doc" => "application/msword",
"xls" => "application/vnd.ms-excel",
"swf" => "application/x-shockwave-flash",
"xml" => "text/xml",
"txt" => "text/plain",
"ico" => "image/x-icon",
"flv" => "application/octet-stream",
"php" => "text/plain",
"htm" => "text/html",
"html" => "text/html",
"csv" => "application/octet-stream"
); # ファイル拡張子とコンテンツタイプ
my %CONTENT_TYPE_2 = (
"image/jpeg" => "jpg",
"image/pjpeg" => "jpg",
"image/gif" => "gif",
"image/bmp" => "bmp",
"image/x-bmp" => "bmp",
"image/png" => "png",
"text/css" => "css",
"application/pdf" => "pdf",
"application/x-pdf" => "pdf",
"application/rtf" => "rtf",
"text/richtext" => "rtf",
"application/msword" => "doc",
"application/vnd.ms-excel" => "xls",
"application/x-shockwave-flash" => "swf",
"text/xml" => "xml",
"text/plain" => "txt",
"image/x-icon" => "ico",
"text/html" => "html"
); # ファイル拡張子とコンテンツタイプ2
my $dataSource = "dbi:ODBC:" .
"driver={SQL Server};" .
"Server=(local);database=db;" .
"Trusted_Connection=no;" .
"AutoTranslate=no;";
my $user = "user";
my $passwd = passwd"";
# DB接続
my $dbh = DBI->connect($dataSource,$user,$passwd) or die $DBI::errstr;
$dbh->{AutoCommit} = 0;
$dbh->{RaiseError} = 1;
$dbh->{LongReadLen} = 10 * 1024 * 1024; # 10MB
$dbh->{LongTruncOk} = 1;
# テーブルにデータを入れる
my $sth = $dbh->prepare("INSERT INTO personal_file (user_id,item_id,content_type,content) VALUES (?,?,?,?)") or die $dbh->errstr;
foreach my $file (@files) {
my $buff = "";
my $file_path = $dir_path . '/' . $file;
my $user_id = (split(/\./, $file))[0];
eval {
# ファイルデータを取得
open IN, "< $file_path";
binmode IN;
$buff = do { local $/; };
close IN;
};
if ($@) {
print "$@" . "($user_id)" . "\n";
next;
}
eval {
# データ格納
$sth->bind_param(1,$user_id);
$sth->bind_param(2,$item_id);
$sth->bind_param(3,$CONTENT_TYPE{$extension});
$sth->bind_param(4,$buff,DBI::SQL_LONGVARBINARY);
$sth->execute or die $dbh->errstr;
$dbh->commit or die $dbh->errstr;
};
if ($@) {
print "$@" . "($user_id)" . "\n";
$dbh->rollback or die $dbh->errstr;
}
}
# データの取り出し
$sth = $dbh->prepare("SELECT user_id,content_type,content FROM personal_file WHERE item_id=$item_id") or die $dbh->errstr;
$sth->execute or die $dbh->errstr;
while (my $row = $sth->fetchrow_arrayref) {
my($user_id,$content_type,$content) = @$row;
# 拡張子
my $ext = "";
foreach my $type (keys %CONTENT_TYPE_2) {
if ($content_type eq $type) {
$ext = '.' . $CONTENT_TYPE_2{$type};
}
}
# ファイル出力
my $file_path = $dir_path . '/' . $user_id . $ext;
open OUT, ">> $file_path";
binmode OUT;
print OUT $content;
close OUT;
print $file_path . "\n";
}
# DB切断
$sth->finish;
$dbh->disconnect;
exit;
__END__
---(ここまで)---
DBIとDBD::ODBCは、CPANからソースを持ってきてインストール。
入れるときは
$sth->bind_param(4,$buff,DBI::SQL_LONGVARBINARY);
取り出すときは
$dbh->{LongReadLen} = 10 * 1024 * 1024;
$dbh->{LongTruncOk} = 1;
あたりがミソかも。
---(ここから)---
#!/usr/bin/perl -w
use strict;
use DBI;
my $site_id = $ARGV[0]; # サイトID
my $item_id = $ARGV[1]; # 項目ID
my $extension = $ARGV[2]; # ファイル拡張子
my $dir_path = $ARGV[3]; # ディレクトリパス
my %CONTENT_TYPE = (
"jpg" => "image/jpeg",
"jpeg" => "image/jpeg",
"gif" => "image/gif",
"bmp" => "image/bmp",
"png" => "image/png",
"js" => "text/plain",
"css" => "text/css",
"pdf" => "application/pdf",
"rdf" => "application/rtf",
"doc" => "application/msword",
"xls" => "application/vnd.ms-excel",
"swf" => "application/x-shockwave-flash",
"xml" => "text/xml",
"txt" => "text/plain",
"ico" => "image/x-icon",
"flv" => "application/octet-stream",
"php" => "text/plain",
"htm" => "text/html",
"html" => "text/html",
"csv" => "application/octet-stream"
); # ファイル拡張子とコンテンツタイプ
my %CONTENT_TYPE_2 = (
"image/jpeg" => "jpg",
"image/pjpeg" => "jpg",
"image/gif" => "gif",
"image/bmp" => "bmp",
"image/x-bmp" => "bmp",
"image/png" => "png",
"text/css" => "css",
"application/pdf" => "pdf",
"application/x-pdf" => "pdf",
"application/rtf" => "rtf",
"text/richtext" => "rtf",
"application/msword" => "doc",
"application/vnd.ms-excel" => "xls",
"application/x-shockwave-flash" => "swf",
"text/xml" => "xml",
"text/plain" => "txt",
"image/x-icon" => "ico",
"text/html" => "html"
); # ファイル拡張子とコンテンツタイプ2
my $dataSource = "dbi:ODBC:" .
"driver={SQL Server};" .
"Server=(local);database=db;" .
"Trusted_Connection=no;" .
"AutoTranslate=no;";
my $user = "user";
my $passwd = passwd"";
# DB接続
my $dbh = DBI->connect($dataSource,$user,$passwd) or die $DBI::errstr;
$dbh->{AutoCommit} = 0;
$dbh->{RaiseError} = 1;
$dbh->{LongReadLen} = 10 * 1024 * 1024; # 10MB
$dbh->{LongTruncOk} = 1;
# テーブルにデータを入れる
my $sth = $dbh->prepare("INSERT INTO personal_file (user_id,item_id,content_type,content) VALUES (?,?,?,?)") or die $dbh->errstr;
foreach my $file (@files) {
my $buff = "";
my $file_path = $dir_path . '/' . $file;
my $user_id = (split(/\./, $file))[0];
eval {
# ファイルデータを取得
open IN, "< $file_path";
binmode IN;
$buff = do { local $/;
close IN;
};
if ($@) {
print "$@" . "($user_id)" . "\n";
next;
}
eval {
# データ格納
$sth->bind_param(1,$user_id);
$sth->bind_param(2,$item_id);
$sth->bind_param(3,$CONTENT_TYPE{$extension});
$sth->bind_param(4,$buff,DBI::SQL_LONGVARBINARY);
$sth->execute or die $dbh->errstr;
$dbh->commit or die $dbh->errstr;
};
if ($@) {
print "$@" . "($user_id)" . "\n";
$dbh->rollback or die $dbh->errstr;
}
}
# データの取り出し
$sth = $dbh->prepare("SELECT user_id,content_type,content FROM personal_file WHERE item_id=$item_id") or die $dbh->errstr;
$sth->execute or die $dbh->errstr;
while (my $row = $sth->fetchrow_arrayref) {
my($user_id,$content_type,$content) = @$row;
# 拡張子
my $ext = "";
foreach my $type (keys %CONTENT_TYPE_2) {
if ($content_type eq $type) {
$ext = '.' . $CONTENT_TYPE_2{$type};
}
}
# ファイル出力
my $file_path = $dir_path . '/' . $user_id . $ext;
open OUT, ">> $file_path";
binmode OUT;
print OUT $content;
close OUT;
print $file_path . "\n";
}
# DB切断
$sth->finish;
$dbh->disconnect;
exit;
__END__
---(ここまで)---
mixiって何だろう(2006/04/01 mixiの日記より転載)
昨日会社の人に招待してもらい、mixiの会員になった。
YAPC::Asiaでmixiの開発責任者の方の話を聴いて、どのようなことができるサービスなのか興味が湧いたのさ。
この日記も「mixiの使い方」を見て、いろいろ操作している一環。
ところで、今夜は夜勤and会社の近所のホテルにお泊り。
ま、何もないでしょう。
システムを担当していると仕方ないのかな。
YAPC::Asiaでmixiの開発責任者の方の話を聴いて、どのようなことができるサービスなのか興味が湧いたのさ。
この日記も「mixiの使い方」を見て、いろいろ操作している一環。
ところで、今夜は夜勤and会社の近所のホテルにお泊り。
ま、何もないでしょう。
システムを担当していると仕方ないのかな。
水曜日, 4月 19, 2006
ubuntu
Debian系のLinuxディストリビューションubuntu(ウブントゥ)の日本語版を会社のデスクトップPCにインストールしてみた。
イイ。かなりイイ。
これまでは、昨年仕事上必要があって、Red Hat Enterprise Linuxと互換性のある(正確にはそのソースをbuildしてつくられた)CentOSが入っていた。Windows2000とデュアルブート。
ただ、もうローカルで動作確認の必要もないので、そのパーティションを利用してubuntuを入れてみたのさ。
Fedoraのようにグラフィカルなインストーラではないが、Debianのよりはずっと簡単。
パッケージ管理はDebianと同様なので、とても楽チン。
さすがDistroWatchでtopなだけのことはあります。
必要最低限のものだけインストールされて、でもデスクトップとしては完成度が高くて、追加したいものは後からパッケージマネージャで自分で好きなだけ入れればいい。ってところがイイのかな。
今までは、パッケージマネージャがRPMだけどapt-getが使えるVine Linuxがお気に入りだったけど、これからはubuntuかな。
水曜日, 4月 12, 2006
今どきのWeb上のサービス
このところ、YAPC::Asiaの影響もあって、mixi、はてな、Bloglinesを使いはじめた。
とはいっても、会員登録をしましたというだけで、それぞれのサービス内容全体を把握しているわけではない。
多くの方からすると、何を今更なのだろうが、何事も「はじめるのに遅すぎることはない」のさ。
とはいっても、会員登録をしましたというだけで、それぞれのサービス内容全体を把握しているわけではない。
多くの方からすると、何を今更なのだろうが、何事も「はじめるのに遅すぎることはない」のさ。
登録:
投稿 (Atom)