<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0"
	xmlns:content="http://purl.org/rss/1.0/modules/content/"
	xmlns:wfw="http://wellformedweb.org/CommentAPI/"
	xmlns:dc="http://purl.org/dc/elements/1.1/"
	xmlns:atom="http://www.w3.org/2005/Atom"
	xmlns:sy="http://purl.org/rss/1.0/modules/syndication/"
	xmlns:slash="http://purl.org/rss/1.0/modules/slash/"
	>

<channel>
	<title>bluegold &#187; redmine</title>
	<atom:link href="http://blog.bluegold.me/tag/redmine/feed/" rel="self" type="application/rss+xml" />
	<link>http://blog.bluegold.me</link>
	<description>OpenSolaris と MacBook で自宅ネットワークを構築するメモ</description>
	<lastBuildDate>Sat, 06 Aug 2011 16:10:12 +0000</lastBuildDate>
	<language>ja</language>
	<sy:updatePeriod>hourly</sy:updatePeriod>
	<sy:updateFrequency>1</sy:updateFrequency>
	<generator>http://wordpress.org/?v=3.2.1</generator>
		<item>
		<title>Redmine を監視して再起動する</title>
		<link>http://blog.bluegold.me/2010/04/monitor-and-restart-redmine-when-error-500/</link>
		<comments>http://blog.bluegold.me/2010/04/monitor-and-restart-redmine-when-error-500/#comments</comments>
		<pubDate>Tue, 20 Apr 2010 16:35:50 +0000</pubDate>
		<dc:creator>bg</dc:creator>
				<category><![CDATA[OpenSolaris]]></category>
		<category><![CDATA[opensolaris]]></category>
		<category><![CDATA[rails]]></category>
		<category><![CDATA[redmine]]></category>
		<category><![CDATA[shell]]></category>

		<guid isPermaLink="false">http://blog.bluegold.me/?p=444</guid>
		<description><![CDATA[Redmine の頻繁に 500 Internal Error を返すようになったので、監視して再起動させるスクリプトを作りました。]]></description>
			<content:encoded><![CDATA[<div>
<p>正確には Redmine が原因なのかどうかは判明していませんが、OpenSolaris 上に構築した Redmine が起動後何時間かすると<b>500 Internal Error</b>を返すようになってしまいました。</p>
<p>Redmine は以下のような環境で動かしています。</p>
<ul>
<li>Redmine 0.9.3</li>
<li>OpenSolaris 2009.06</li>
<li>Ruby 1.8.7-p249</li>
<li>Rails 2.3.5</li>
<li>Unicorn 0.97.0</li>
<li>nginx 0.7.65</li>
</ul>
<p>Ruby は /opt/sunstudio12.1/bin/cc(Sun Studio Express 12)でビルドしています。</p>
</div>
<div>
<p>OpenSolaris に付属の /usr/bin/ruby を使っていた時には問題なく動作していたんですが、Redmine 0.9.3 にバージョナップした所、致命的な問題が発生したため、Ruby を自分でビルドするように変更していました。</p>
<p>落ちているの気がついたら手動で再起動をしていたのですが、さすがにメンドウになってきたのでスクリプトを書きました。</p>
<p><span id="more-444"></span></p>
<pre class="brush: bash;">
#!/bin/sh

while `/bin/true`
do
    http_code=`curl --insecure -w &quot;%{http_code}&quot; -s -o /dev/null https://redmine/login`
    ts=`date +&quot;%Y/%m/%d %H:%M:%S&quot;`

    if [ $http_code -eq 200 ]; then
        echo $ts OK
        sleep 300
        continue
    fi

    cd /var/www/redmine
    pid=`cat tmp/pids/unicorn.pid`

    kill -USR2 $pid
    sleep 5
    kill $pid

    echo $ts unicorn $pid reloaded.
done

exit 0
</pre>
<p>手順としては、5分おきに curl で HTTP のステータスコードのみを受け取り、<b>200 OK</b>が帰ってこない場合は再起動、という流れです。</p>
<p>Unicorn は SIGUSR2 を送ると自分自身を fork() してから終了するはずなのですが、終了せずに残るので子プロセスの起動を待ってから SIGTERM を送っています。</p>
</div>
<div>
<p>とりあえずは、これで気にはならなくなりましたが。。。</p>
<p>そのうち、God あたりに切り替えよう。</p>
</div>
]]></content:encoded>
			<wfw:commentRss>http://blog.bluegold.me/2010/04/monitor-and-restart-redmine-when-error-500/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
	</channel>
</rss>

