カテゴリー:

log4net.Repository.ILoggerRepository[] repositories = log4net.LogManager.GetAllRepositories();
foreach (log4net.Repository.ILoggerRepository repository in repositories)
{
    foreach (log4net.Appender.IAppender appender in repository.GetAppenders())
    {
        log4net.Appender.FileAppender fileAppender = appender as log4net.Appender.FileAppender;
        if (fileAppender != null)
        {
            appender.File = "log.log"; //出力先ファイルを設定
            appender.ActivateOptions();
        }
    }
}

※ 上記のようにコードでFileを設定する場合も、依然としてXMLの設定にはFileの指定は必要だった。


log4netで設定したログ出力先パス、ファイル名の取得: DOBON.NETプログラミング掲示板過去ログ

log4netでのログ出力について - Insider.NET - @IT)

カテゴリー:

# は、引数を文字列に変換する。
## は二つの識別子を連結させる。

C 言語 マクロ講座 # ## 編: uyota 匠の一手

カテゴリー:

漢(オトコ)のコンピュータ道: 限界までMySQLを使い尽くす!!

SQL文の最大長、データベースの個数、データベースあたりのテーブル数等、MySQLのいろいろな限界について。

カテゴリー:

カテゴリー:

カテゴリー:

RVMでMac OS X LionにRuby1.9.3をインストール後、bundleしたらSegmentation faultが発生。

$ bundle
Fetching source index for https://rubygems.org/
/Users/pistolfly/.rvm/rubies/ruby-1.9.3-p0/lib/ruby/1.9.1/net/http.rb:799: [BUG] Segmentation fault
ruby 1.9.3p0 (2011-10-30 revision 33570) [x86_64-darwin11.3.0]
...

解決方法

$ rvm pkg install openssl
$ rvm install 1.9.3 --with-openssl-dir=$rvm_path/usr


Ruby 1.9.3 + Rails 3.2.1 で segmentation fault -> 解決 - さとうようぞうのblog

RVM: Ruby Version Manager - 'rvm pkg install openssl'

カテゴリー:

Xenの仮想サーバで時刻がずれていた。
ntpdで設定されるようにしているが、ずれたまま。
DomUの時刻は、Dom0からのみ更新できるというXenの仕様によるものらしい。

検閲Tech: XenのDomUでNTPを使う

ということは、Dom0の時刻がずれているのか。

DomUでNTPを使って時刻が設定できるようにした。

# echo 1 > /proc/sys/xen/independent_wallclock
/etc/sysctl.conf
xen.independent_wallclock = 1
$ sudo yum install ntpd
$ sudo /sbin/chkconfig ntpd on
$ sudo /etc/init.d/ntpd start
$ sudo /usr/sbin/ntpdate <ntpサーバ>

ただし注意!

時刻が戻るとdovecotがダウンした。dovecotの仕様らしい。 dovecotのリスタートが必要だった。 /var/log/maillog
Feb 23 19:40:48 mail dovecot: Time just moved backwards by 105 seconds. This might cause a lot of problems, so I'll just kill myself now. http://wiki.dovecot.org/TimeMovedBackwards

カテゴリー:

配列はprintコマンド(p)で参照できるが、配列を引数で受け取った場合などポインタになっている場合は、@演算子を用いるとうまく表示できる。
@演算子は、左項をアドレスとみなし、左項の型のデータを右項の数だけ配列のように表示する。

(gdb) l
34
35	void func(int v[], int len)
36	{
(gdb) p v[0] @ len
$1 = {4470, 5197, 2482, 1016, 4154, 9986, 8313, 6873, 8517, 5857, 9019, 8002, 349, 9817, 365, 1018, 2269, 9759, 7092, 8674, 4902, 3890, 9746, 7668, 792, 3842, 4053, 6422, 630, 4880, 9996, 7164, 8392, 8469, 2959, 8380, 6533, 1795, 4296, 9964, 8259, 7474, 72, 2948, 3681, 501, 3994, 508, 9544, 941, 8054, 2186, 7418, 8684, 3224, 7322, 3822, 5022, 3085, 8341, 2296, 4073, 1034, 9839, 7067, 1197, 739, 7028, 2809, 6610, 8633, 483, 3017, 9634, 4758, 8101, 7604, 4018, 2174, 5014, 6600, 3754, 2854, 4798, 3921, 2124, 9889, 1147, 2409, 6105, 224, 6973, 5937, 2953, 8614, 9101, 3399, 8431, 2226, 3548}


[GDB] int型配列の参照 - printコマンドの場合 | idocsq.net

カテゴリー:

Capfileに
load 'deploy/assets'
を追加すると、デプロイ時にassets:precompileを実行できるが、assets:precompile実行時に、
/usr/bin/env:
ruby
: そのようなファイルやディレクトリはありません
というエラーになってしまった。 ssh経由でのshellの実行時にPATHが通っていないのが原因と思われる。

解決方法

CapistranoでPATH等の環境変数を設定するには、:default_environmentを使う。

	
set :default_environment, {
  'PATH' => "/opt/ruby-enterprise-1.8.7-2011.03/bin:$PATH"
}


Change PATH environment with Rails and Capistrano - pastbedti.me
How do I configure capistrano to use my rvm version of Ruby - Stack Overflow

プリコンパイルする場合、config/environments/production.rbで、
config.assets.compile = false
にするが、assetsにapplication.js, application.css以外のjs、cssを使う場合は、以下のようにconfig.assets.precompileに追加する必要がある。追加しないと、smart_phone.css isn't precompiled のようなエラーになる。

config/environments/production.rb
config.assets.compile = false
# Precompile additional assets (application.js, application.css, and all non-JS/CSS are already added)
config.assets.precompile += %w( smart_phone.css web_app_theme.css )

カテゴリー: