Latest Publications

capistranoで同一サーバーにcopyで配置する時は注意

相当手間取った。

新しくしたサーバーにcapistranoでデプロイしようとしたら
途中で反応がなくなり、エラーも出ずに固まってしまう。

サイズが大きいこともありテストを重ねるのに時間がかかり
解決に非常に手間取ってしまった。

下記copyでのデプロイを設定している上で

set :deploy_via, :copy

capistranoを起動するサーバーとデプロイ先のサーバーが同じだった場合に
下記のように圧縮ファイルを同じ場所に転送しようとしてファイルが壊れることが原因だった。

sftp upload /tmp/20140828071729.tar.gz -> /tmp/20140828071729.tar.gz

解決策は、コピー先を適当な別の場所に指定する。

set :copy_remote_dir, "/var/tmp"

順を追えばすぐに解決できそうなものだったけど
サーバーが遅い&データが大きいことにより
sshが止まってしまったのが苦労の原因だった。

AWSのSESでのバウンスメールをSNSのhttp(s)で通知してシステム受信

AWSのコンソールでSNSを開く
create New Topic
sesBounceEshima / SES Bounce Eshima などと適当に名前を付ける。
Create Subscriptionで受信するシステムのhttpsのURLを入れる
指定したURLにJsonでデータが来る

$dataJson = file_get_contents('php://input');

最初の認証前の状態だとSubscribeURLが入っているのでアクセスすると認証。
(再送信として同じURLで何度でもCreate Subscriptionできる)

AWSのコンソールでSESを開く
対象のEmail Addressの虫眼鏡アイコンから詳細表示
NotificationsのEdit Configration
SNS Topic ConfigurationのBounceでSNSで作ったTopicが選択できるので設定。

これで、SESでBounceが発生したらSNS経由でhttps通知が来る。

元々はSESのSuppression List解除を
システムからできるようにするために実装したけど
調べたら手動解除か、14日間待つしかない??

もしできるようなら教えてください。

puppy linuxで設定ファイルを変更したせいで起動しなくなった時の対処

旧WindowsXPの古いパソコンを動かすために
USBメモリに入れてbootしているpuppy linuxと格闘中。

起動に関係のある設定ファイル
/etc/inittab
を変更したら起動しなくなって焦った。

puppyのデータの仕組みがまだわかっていなかったのだけど
bootするUSBメモリに入っているprecisesave.4fsというファイルが
起動の度にPCに書き込まれて設定ファイル群として動いている様子。

設定ファイルinittabはその中に入っているようで
Macなどから修正しようとしてもできなかった。

結局、CDブートでpuppyを立ちあげた上で
precisesave.4fsをダブルクリックするとマウントされて
中身を見ることができ、編集できて元に戻せた。

charset=gb2312のメールをPHPで処理

中国在住の日本人の方から
charset=gb2312(中国語)で日本語のメールが来て
PHPの処理で文字化けが発生したので対応。

GB2312というコードで変換をしてみたけど一部の文字が化けてしまった。
GBKと指定すればOK。

//mb_convert_encoding($str, "UTF-8", "GB2312");
mb_convert_encoding($str, "UTF-8", "GBK");

手間取ったのが、メールの件名の文字化け。

mb_decode_mimeheader($headerList['Subject']);

の処理で既に文字化けが発生しているので
その後でmb_convert_encodingをしても直らない。

よく見ると、最初にGB2312でコンバートしていたのと同等の文字化けだった。
mb_decode_mimeheaderをかける前を見てみると、この時点でエンコード形式が指定されているよう。
=?GB2312?B?UmU6IM・・・

無理やりだけど、

$headerList['Subject'] = str_replace('GB2312', 'GBK', $headerList['Subject']);

としてエンコード形式の指定をGBKに置き換えたら直った。

tumblrのモバイルテーマ

tumblrで購入したテーマの相談を受けた。

PC向けはトップページがカスタマイズされているが
iPhoneなどで見ると最新記事がいくつか並んでいるだけの表示になるとのこと。

調べると、スマホからのアクエセスは
初期設定ではtumblrデフォルトの
モバイルテーマが適応されるようになっているとのこと。

テーマの詳細設定から「デフォルトのモバイルテーマを使用」がオンになっているのを
オフにすると、通常のテーマがスマホでも表示される。

ただ、そのテーマがスマホ対応していなければ
見にくい/崩れることになってしまう。

その場合、テーマのカスタマイズで「ページの追加」を選択し
「カスタムデザイン」びurlを「iphone-theme」に設定すると
iPhoneなどモバイルからのアクセスで適応されるテーマを設定できる。

テーマを新たに作ることになるが
下記でデフォルトテーマのソース(?)が提供されている。
ただし、どうも古いようなので最新バージョンではなさそう。

orangkucing/Default-iPhone-theme-for-Tumblr · GitHub

イチから作るのも難しいので、このテーマをベースに
カスタマイズして必要な表示にさせた。

tumblrのLoad Moreをjavascriptで動かす

Tumblrで作ったサイトの相談を受けた。

表示記事に対してjavascriptで絞込がされるテーマにおいて
特定のタグに対しては記事が表示されないとのこと。

確認すると、全記事からではなく表示記事中からの絞り込みのようで
「Load More」ボタンを押して
一旦記事を初期表示以上にロードしてからでないと表示されない。

ただ、初期表示の件数に上限があり
それ以上は設定できない。

ということで、
無理やり「Load More」を押したかのような動きを
javascriptでさせることに。

</body>タグの前に

<script type="text/javascript">
$('#more-projects').trigger("click");
</script>

で動いた。

各サーバーのバックアップをAmazon Glacier(S3)に保存する環境を作った

AWSのS3も初使用。

GlacierはS3の約10分の1の価格で使えるデータストレージ。1G・1円/月くらい。
安価な代わりにデータの取り出しには数時間かかる。
バックアップ向け。

AWS コマンドライン インターフェイス

まずはコマンドラインでAWSを操作できるように環境を作る。

AWS コマンドラインインターフェイス | アマゾン ウェブ サービス(AWS 日本語)

Python 2.6.3 or later

python --version

Pythonのパッケージ管理ツール、pipを準備。
まずはダウンロード
get-pip.py

python get-pip.py

pipが使えるようになったらaws cliをインストール

pip install awscli

確認。

aws --version

awsコマンドを試す

まずはAWSの管理画面でS3を使いバケットという大きい単位の入れ物を作る。
また、IDとシークレットキーも取得し、下記コマンドで設定。

aws configure

これでawsコマンドが使えるようになる。

lsやcpやmvなど使い慣れたコマンドが使える。
こんな感じ。

aws ls s3://
aws ls s3://yourbucketname/
aws cp /home/username/test.txt s3://yourbucketname/test.txt
aws mv /home/username/test.txt s3://yourbucketname/test.txt

Glacierの設定

これはAWSの管理画面から。

バケット単位でもフォルダ単位でもできるけど
特定のバケットをGlacier専用に設定。
そのバケットに入ったらすぐにS3からGlacierに移すようにできる。
保存に関してはS3に保存するのと同じ。

cronでの処理

超手間取った。
コマンドで入力したら動くのにcronだとどうしても動かなかった。
原因はconfigファイルが参照できていなかったこと。

シェルスクリプト内に下記を書いたら動いた。
cronの実行ユーザーと合わせる。

export AWS_CONFIG_FILE=/home/username/.aws/config

例えばこんな感じ

export AWS_CONFIG_FILE=/home/username/.aws/config
scp username@servername":~/backup/hoge.gz /home/username/backup/hoge.gz
/usr/local/bin/aws s3 cp /home/username/backup/hoge.gz s3://yourbacketname/hoge.gz

crontabが動かなかった

cronのテストをしていた時に何故か変更したものが反映されない。

タイミングが良くわからなかったので

sudo /etc/init.d/crond restart 

をするようにしたら動いた。

WordPressの新規投稿時のデフォルト設定

管理者権限のユーザーでも新規投稿時にステータスpost_statusをレビュー待ちpendingにしたかったので。

function.phpに追加。

//新規投稿のステータス初期値を「レビュー待ち」にする
function post_function($data){
	//処理
	$data['post_status'] = 'pending';
	return $data;
}
add_filter('wp_insert_post_data', 'post_function');

MacPortsのアップデートでphpエラー

MacPortsのアップデートしたらphpでエラーがでるようになった。

PHP Startup: Unable to load dynamic library '/opt/local/lib/php54/extensions/no-debug-non-zts-20100525/gd.so'

ということで調査開始。

php -ini

でiniファイルを探すと

/opt/local/var/db/php54/gd.ini

ができてた(元から??)ので開いてみると

extension=gd.so

とエラー部分の呼出しがあったので

;extension=gd.so

とコメントしたらエラーが消えた。

ただ、MacPortsが自動で更新するファイルだから
さわっちゃダメよ、と書いてあったファイルなので
また上書きされてしまうんだと思う。

とりあえず、の処置ということで。