Ubuntu 11.10が起動時に "Waiting for network configuration..." と吐く件の対処
やっと11.10に追いついたと思ったら、ブート時に以下のようなメッセージが出る件。
Waiting for network configuration... Waiting up to 60 more seconds for network configuration... Booting system without full network configuration...
結論から言うと /etc/network/interfaces の次の一行をコメントアウトしたら出なくなりました。
#post-up /usr/sbin/ethtool -K eth0 tso off続きを読む
Ubuntu Oneiric + nginx + uwsgi + sinatra (rack)
Ubuntu Oneiric (11.10) + nginx + uwsgi な環境で Sinatra アプリを uwsgi に載せるまで。
まず sinatra のインストールから。 apt で sinatra をインストールしたい場合、現在は ruby-rack がみつからず依存関係エラーが出る。
$ sudo -s # apt-get install ruby-sinatra [...] 以下のパッケージには満たせない依存関係があります: ruby-sinatra : 依存: ruby-rack しかし、インストールすることができません E: 問題を解決することができません。壊れた変更禁止パッケージがあります。 # apt-get install ruby-rack [...] パッケージ ruby-rack はデータベースには存在しますが、利用できません。 おそらく、そのパッケージが見つからないか、もう古くなっているか、 あるいは別のソースからのみしか利用できないという状況が考えられます E: パッケージ 'ruby-rack' にはインストール候補がありません
ubuntu-proposed リポジトリに対策済みパッケージがあるので、有効にしてから ruby-sinatra をインストール。
参考:Bug #843734 in ruby-sinatra (Ubuntu): “ruby-sinatra : Depends: ruby-rack but it is not installable”
# vi /etc/apt/sources.list
... deb http://jp.archive.ubuntu.com/ubuntu/ oneiric-proposed main restricted universe multiverse deb-src http://jp.archive.ubuntu.com/ubuntu/ oneiric-proposed main restricted universe multivers ...
# apt-get update # apt-get install ruby-sinatra
Sinatra DSL の Hello World なファイルを作る。
続きを読むUbuntu Oneiric の /etc/uwsgi/{apps-available,apps-enabled}
前回は upstart を使って uwsgi を起動したけど、パッケージの仕組みに沿った方法を使ってみる。
Debian 系の基本通り、 /etc/uwsgi/apps-available/ に設定をファイルを置いて /etc/uwsgi/apps-enabled/ からシンボリックリンクする。
/etc/uwsgi/apps-available の設定は --inherit /usr/lib/uwsgi/conf/default.ini オプション付きで実行されるので、デフォルトの内容も確認しておく(継承するデフォルト設定ファイルのパスは /etc/default/uwsgi 内で設定されている) *1。
$ dpkg -l uwsgi ... ii uwsgi 0.9.8.1-1 fast, self-healing application container server $ uwsgi --version uWSGI 0.9.8.1-debian $ sudo -s # cat /usr/lib/uwsgi/conf/default.ini # 出力結果からコメント削除済み [uwsgi] autoload = true master = true workers = 2 no-orphans = true pidfile = /run/uwsgi/%n/pid socket = /run/uwsgi/%n/socket chmod-socket = 660 log-date = true uid = www-data gid = www-data
pidfile と socket の %n プレースホルダには、設定ファイル名から拡張子を除いた文字列が入る。以下のように hello.ini を作ると /run/uwsgi/hello/socket というソケットが作られることになる。
# vi /etc/uwsgi/apps-available/hello.ini
デフォルトを意識して最低限の設定だけ。
[uwsgi] plugins = python logto = /var/log/uwsgi/hello.log mount = /hello=/home/cu39/code/python/hello.py
リンク作成、起動、確認。
# ln -sv /etc/uwsgi/apps-available/hello.ini /etc/uwsgi/apps-enabled/ `/etc/uwsgi/apps-enabled/hello.ini' -> `/etc/uwsgi/apps-available/hello.ini' # /etc/init.d/uwsgi start hello * Starting app server(s) uwsgi [ OK ] # ls -F /run/uwsgi/hello pid socket= # ps -Af | grep uwsgi www-data 6779 1 0 Jan18 ? 00:00:03 /usr/bin/uwsgi --ini /etc/uwsgi/apps-enabled/hello.ini --daemonize /var/log/uwsgi/hello.log --inherit /usr/lib/uwsgi/conf/default.ini www-data 6787 6779 0 Jan18 ? 00:00:00 /usr/bin/uwsgi --ini /etc/uwsgi/apps-enabled/hello.ini --daemonize /var/log/uwsgi/hello.log --inherit /usr/lib/uwsgi/conf/default.ini www-data 6788 6779 0 Jan18 ? 00:00:00 /usr/bin/uwsgi --ini /etc/uwsgi/apps-enabled/hello.ini --daemonize /var/log/uwsgi/hello.log --inherit /usr/lib/uwsgi/conf/default.ini
*1:このあたりの詳しい挙動は /etc/init.d/uwsgi や /usr/lib/uwsgi/init/do_command あたりを参照。
Ubuntu Oneiric + nginx + uwsgi + moin
インストール
nginx は PPA から入れる。
$ sudo -s # nginx=stable # add-apt-repository ppa:nginx/$nginx # apt-get update # apt-get install nginx
uwsgi 関連もインストール。
# apt-get install uwsgi uwsgi-plugin-python
バージョン確認。
# nginx -v nginx version: nginx/1.0.11 # uwsgi --version uWSGI 0.9.8.1-debian # python -V Python 2.7.2+
hello world!
helloworld してみる。 /etc/nginx/sites-available/default を以下のように設定、テスト。
# vi /etc/nginx/sites-available/default
server { server_name localhost; location / { include uwsgi_params; uwsgi_pass 127.0.0.1:9090; } }
# /etc/init.d/nginx configtest
Testing nginx configuration: nginx.