オタク日記
(Mac と Linux, RasPi, 2024Q2)
目次
2024-06-05 (Wed): 外部サーバ(1: とりあえず更新・起動)2024-06-19 (Wed): 外部サーバ(2: 疑似環境の整備)
2024-06-26 (Wed): 外部サーバ(3: Bogofilter)
古い日記:
2019Q3
2019Q2
2019Q1
2018Q4
2018Q3
2018Q2
2018Q1
2017Q4
2017Q3
2017Q2
2017Q1
2016Q4
2016Q3
2016Q2
2016Q1
2015Q4
2015Q3
2015Q2
2015Q1
2014Q4
2014Q3
2014Q2
2014Q1
2024-06-05 (Wed): 外部サーバ (1: とりあえず更新・起動)
そろそろ、オタク日記他を再開しようかな、と思いつつ、ダラダラと 5 年も経ってしまった……今度再開する時はああもして、こうもして、 と思っていたけど、まあ、そのせいでのびのびになったんだろうな。 という事で、とりあえず形式上は何も変えずに書き始める事にした。
waremo.com と otacky.jp を DigitalOcean の droplet (4GB, 80GB) 二個に載せていた。OS は Ubuntu-18.04。これを 5 年も使って(放置して) きたわけだ。
更新を始める前に、これをもうちょっと何とかしてみようと思ったが、
それにあたって色々な方策が有る中で、droplet に login
する度に勧められる、do-release-upgrade をやってみようと……
www.waremo.com
の
server (droplet) の copy を作って、その上で 18.04 →
20.04 → 22.04 と upgrade する訳だ。やってみたら、殆ど問題なくうまく行っ
た。(実は微妙なひっかかりが有ったのだが、詳細は忘れてしまった。)それで
安心して、ホンチャンの droplet で upgrade を実施、その後一月あまり、
www.waremo.com
と
dms.waremo.com
の運用を
続けているが、問題は無さそう。"So Far, So Good."
ところが、otacky.jp の方はそうは易々といかなかった。上と同様に droplet の copy の上で、do-release-upgrade をやるのだが、upgrade 自体に問題が多 い上に、upgrade をなんとか完成させても、httpd も mail、 mailman もうまく働いてくれない。随分難儀したが、mailman はアプリが通常の更新がで きなかったので、これについては一旦は諦めて、ホンチャンの droplet へ移行 する事にした。(しかし、これが大間違い、そう簡単には mailman は動いてく れず、その後一月あまりも mailman が停 止している。)
で、この間 mailman と格闘していたのだが、ふと、Apache (HTTPD server) の不具合も触った方が良いかな等と思ったせいで、また違う横道に逸れてしまっ た。ともあれ、最初の方の困難は忘れてしまったが、
- 文法 check アイコンの href="http" or href="https"
が厳しくなっていて、https でなければ、"No Referer header found"
と言われて文法解析してくれない。ただし、それを https に変更しても、
どうやら check されるのはhttps://www.otacky.jp だけみたいだ。
発信元の URL を check するには、行った先で、手で
URL を入力する必要がある、って事。従来のように、発信元の URL
の診断をさせるのもやり方が有るかも知れないけど、今のところは解らない。
ともあれ、
fukuda@digoc04:/var/www/html% for f1 in *.html sed -i -e 's#http://validator#https://validator#' $f1 fukuda@digoc04:/var/www/html% for f1 in *.html sed -i -e 's#http://jigsaw#https://jigsaw#' $f1
とやって、一応検査ができるようにした。 - page への書込み(出力)無しで、計算だけをやるのに、html ファイルに
<!--#include virtual="/cgi-bin/calc.cgi" -->
とやったのでは、計算はうまく行くが、error message も表示される(page にも error_log にも。)ここは<!--#exec cgi="/cgi-bin/calc.cgi" -->
とする必要がある。
2024-06-19 (Wed): 外部サーバ (2: 疑似環境の整備)
実は、大昔(5 年前?)は、手元のサーバ (OS X, Yosemite, 一つ前の Mac-mini) の上に、よく似た環境を作って、rsync で同期させていた。詳細はよく覚えていないが、 それで結構便利に使えていた。なので、今回も…と考えたのだが、なかなか。
とにかく、Apache をインストールする必要がある。ざっと紹介記事を読んだが、 最新の macOS にはインストールされていないかも、とか有ったので、 念のために
fukuda@octal:~% ps ax | grep apache2
とやってみたが、何もひっかからなかった。しかし、それも当然で、
fukuda@octal:~% ps ax | grep httpd
16549 ?? Ss 0:00.29 /opt/local/sbin/httpd -k start
16550 ?? S 0:00.01 /opt/local/sbin/httpd -k start
.....
16557 ?? S 0:00.00 /opt/local/sbin/httpd -k start
16558 ?? S 0:00.00 /opt/local/sbin/httpd -k start
16883 s000 S+ 0:00.00 grep httpd
てな具合に、apache2 ではなく、httpd に全て置き換わっているのだった。兎に角、
しばらく後に :-) 殺した。
fukuda@octal:~% sudo apachectl stop fukuda@octal:~% ps ax | grep httpd 17512 s000 S+ 0:00.00 grep httpd
で、httpd が動いているのも知らずに MacPorts の Apache2 をインストールする。
fukuda@octal:~% sudo port install apache2 fukuda@octal:~% sudo port load apache2 fukuda@octal:~% ps ax | grep apache 16545 ?? Ss 0:00.02 /opt/local/bin/daemondo --label=apache2 --start-cmd /opt/local/etc/LaunchDaemons/org.macports.apache2/apache2.wrapper start ; --stop-cmd /opt/local/etc/LaunchDaemons/org.macports.apache2/apache2.wrapper stop ; --restart-cmd /opt/local/etc/LaunchDaemons/org.macports.apache2/apache2.wrapper restart ; --pid=none 17538 s000 S+ 0:00.00 grep apacheこの状態で、Firefox の
http://localhost
にアクセスしたら、"It works!" と答えた。
Nice! (httpd は殺した状態で。)
rsync で、サイトの模擬環境を作る。
fukuda@octal:~% resync_web () { rsync -Cuav otacky.jp:/var/www/ /Users/fukuda/public_www } fukuda@octal:~% resync_web fukuda@octal:~% ls -l public_www/html ..... -rw-r--r-- 1 fukuda staff 91240 6 17 18:17 otaku_comm-19Q1.html -rw-r--r-- 1 fukuda staff 90096 6 17 18:17 otaku_comm-19Q2.html -rw-r--r-- 1 fukuda staff 44219 6 17 18:17 otaku_comm-19Q3.html -rw-rw-r-- 1 fukuda staff 11824 6 19 18:11 otaku_comm-24Q2.html ..... fukuda@octal:~% ls -l public_www/cgi-bin total 64 -rwxr-xr-x 1 fukuda staff 8080 6 19 14:47 counter5.cgi* -rwxr-xr-x 1 fukuda staff 7458 9 27 2014 counter_wa.cgi* drwxr-xr-x 12 fukuda staff 384 5 19 07:13 data/ drwxr-xr-x 6 fukuda staff 192 7 15 2013 data_wa/ -rwxr-xr-x 1 fukuda staff 6487 9 1 2018 each_page.cgi* -rwxr-xr-x 1 fukuda staff 5010 5 22 16:35 get_stat_div.cgi* -rwxr-xr-x 1 fukuda _appstore 2060 6 4 12:25 show_graph.cgi*そっかぁ、www-data (元の外部サイトの所有グループ名)なんてものは、 このサイトには無いからな。
しかも、インストールしてみて判ったのだが、apache2
が外部サーバのそれとは随分違う。インストール先が、/opt/local
になっているのは仕方無いにしても、httpd.conf
か
apache2.conf
か、
から始まって、全く違っている。ちょっと気が遠くなるが… ともあれ、
/opt/local/etc/apache2/extra/httpd-vhost.conf
を
<VirtualHost *:80> ServerName localhost serverAlias octal.local ServerAdmin fukuda@otacky.jp DocumentRoot "/Users/fukuda/public_www/html" ScriptAlias /cgi-bin/ /Users/fukuda/public_www/cgi-bin/ <Directory "/Users/fukuda/public_www/html"> Options Indexes FollowSymLinks Includes # AddHandler server-parsed .html # XbitHack On Require all granted </Directory> <Directory "/Users/fukuda/public_www/cgi-bin"> AllowOverride None Options Includes Require all granted </Directory> ErrorLog "/opt/local/var/log/apache2/error.log" CustomLog "/opt/local/var/log/apache2/error.log" combined </VirtualHost>と書き変え、/opt/local/etc/apache2/httpd.conf の
# Virtual hosts #Include etc/apache2/extra/httpd-vhosts.confを uncomment して、
fukuda@octal:~% /opt/local/sbin/apachectl -t AH00557: httpd: apr_sockaddr_info_get() failed for octal AH00558: httpd: Could not reliably determine the server's fully qualified domain name, using 127.0.0.1. Set the 'ServerName' directive globally to suppress this message Syntax OK fukuda@octal:~% sudo port unload apache2 Password: ---> Unloading startupitem 'apache2' for apache2 fukuda@octal:~% sudo port load apache2 ---> Loading startupitem 'apache2' for apache2として、apache の構成(文法)の確認と、リセット(ストップ、スタートによって) する。(以降、構成を変更したら、いつもこれでリセットした。)ここまでで、
<!--#include virtual="xxxx" -->が無視された表示が得られる。つまりは、menu_div や counter の表示が全く無い、 main div のみが表示される。
上のリセットのやり方は、 MacPorts の Apache2 のページ から採ってきた。 同ページには、必須の include file を入れる方法が書いてあり、それをそのまま 当て嵌めて実行したら、少し前進した気がした。
こうなると、元のサーバで Load している .so ファイルをこっち (macOS) でも、
Load すれば良いはずだが、これがなかなか難しい。
なぜなら Ubuntu 22.04 では、conf ファイルの include や mods ファイルの
include は、/etc/apache2/xxxx-available
にあるファイルを /etc/apache2/xxxx-enabled
に link
を作る事で制御していた。
(これも実は Ubuntu 18.04 の方法を、do-release-upgrade
のせいで、
引っぱっているだけかも知れない。)そこで仕方なく、xxxx-enabled
に作られた link
がどんな .conf ファイルや .so ファイルを include しているかを推察して、
/opt/local/etc/apache2/httpd.conf
の対応部分を uncomment して行った。
勿論、httpd.conf
や httpd-vhost.conf
の他の部分の調整も効いているに違いないが、ここまでの結果として、macOS
の側の httpd が、https に未対応である事と、明確な URL を持たない事による制限を
除けば、今のところの問題は、access counter を担っている counter5.cgi
がエラーを返す事くらいだろう。勿論重大な「制限」だが、まあでもこの環境では、
見え方を確認しつつ local の Emacs でページを編集するのが目的なので、
これで良い(としたい。)
counter5.cgi
を色々と書き直していたのだが、
あんまり捗々しくないので、data/count.*
の属性を変えてみた。
fukuda@octal:~% chown fukuda:staff public_www/cgi-bin/data/* fukuda@octal:~% chmod o+w public_www/cgi-bin/data/* fukuda@octal:~% ls -l public_www/cgi-bin/data total 132252 -rw-rw-rw- 1 fukuda staff 20 7 3 05:34 count -rw-rw-rw- 1 fukuda staff 1983 7 3 05:34 count.cache -rw-rw-rw- 1 fukuda staff 0 7 3 05:34 count.lock -rw-rw-rw- 1 fukuda staff 15061094 7 3 05:34 count.stat -rw-r--rw- 1 fukuda staff 27694031 11 9 2013 count.stat-2013-05-22 .....
すると、count.cache
に書けない…」で始まるエラーが無くなった。
そこでさらに調子に乗って、散々弄ってきた counter5.cgi
を、
元の形に戻しても、ちゃんと動く。その時の data/count.cache
を確認してみると次の通り。
fukuda@octal:~% tail ~/public_www/cgi-bin/data/count.cache
1719918507 127.0.0.1 20questions.html
1719918713 127.0.0.1 20questions.html
1719951447 127.0.0.1 index.html
1719951486 127.0.0.1 otaku_comm-24Q2.html
1719951504 127.0.0.1 otaku_comm-24Q2.html
1719952188 127.0.0.1 index.html
1719952239 127.0.0.1 index.html
1719952458 127.0.0.1 otaku_comm-24Q2.html
1719952471 127.0.0.1 index.html
1719952477 127.0.0.1 otaku_comm-24Q2.html
つまりは、data/count*
の属性を変えたら、
os.environ.get('REMOTE_ADDR')
や
os.environ.get('DOCUMENT_NAME')
に正しく値が設定され、
"file lock failed" エラーも起きなくなった。
うーむ、めでたい! が、少しずつ訂正してきた counter5.cgi
が一挙に元に戻ってしまった。
2024-06-26 (Wed): 外部サーバ (3: Bogofilter)
あまりよく覚えていないのだが、
2019年 Q1 の記録によると、
この時に SpamBayes から切り替えたらしい。
しかも、bogofilter-1.2.4+dfsg1
のソースに MeCab
の patch を当ててコンパイルしている。
よし、それでは…と意気込んだが、Ubuntu 22.04
では、
bogofilter-1.2.5
なのに bogofilter-1.2.4+dfsg1
のまま。それでも、再コンパイルすれば MeCab は新しくなるが…
かなり迷ったが、ここは触らずに行く事にする。しかしそうすると、 crontab でフィルターをかけるたびに出てくる email:
To: fukuda@otacky.jp Subject: Cron <fukuda@digoc04> source bogotrain From: root@otacky.jp (Cron Daemon) MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Message-Id: <20240625181001.EB91517C223@digoc04.otacky.jp> Date: Wed, 26 Jun 2024 03:10:01 +0900 (JST) Error: net_connect_unix(/run/dovecot/stats-writer) failed: Permission denied Error: net_connect_unix(/run/dovecot/stats-writer) failed: Permission deniedを何とかしないといけない。
(色々やった馬鹿げたあれこれはさておいて)ちょっと真面目にやったらこうだろう、
というのを書くと、何より 3 時間ごとにエラーメッセージが出力されるので、
crontab
から…
fukuda@digoc04:~% crontab -l
SHELL=/bin/bash
PATH=/usr/local/bin:~/scripts:/usr/bin:/bin
USER=fukuda
.....
57 4 */3 * * python ~/scripts/sitemap_gen.py --config=sitemap/config.xml
10 */3 * * * source bogotrain
この、bogotrain というのは、
fukuda@digoc04:~% cat scripts/bogotrain
#!/bin/bash
bogofilter -s -B ~/Maildir/.spambayes.spam_new
bogofilter -n -B ~/Maildir/.spambayes.ham_new
doveadm move spambayes.spam MAILBOX spambayes.spam_new ALL
doveadm move spambayes.ham MAILBOX spambayes.ham_new ALL
のこと。しかし、この先がどうにも解らない。そもそも、bogofilter
も doveadm
も、その詳細はかなりおぼろになっている。
いろいろ当てずっぽうをやったが、その中で上の email
のエラーメッセージをそのまま Google にかませたら、それらしいサジェスチョンが出てきた。
(勿論、最初から正解はもらえなかったが。)結局、doveadm
の user:goup が問題のようで、
fukuda@digoc04:~% cat /etc/dovecot/dovecot.conf
.....
# A config file can also tried to be included without giving an error if
# it's not found:
!include_try local.conf
service stats {
unix_listener stats-reader {
group = mail
mode = 0666
}
unix_listener stats-writer {
group = mail
mode = 0666
}
}
service anvil {
unix_listener anvil {
group = mail
mode = 0666
}
}
として、bogofilter
のトレーニングがやれて、
なおかつエラー・メッセージが出なくなった。
93/1,798,151 Taka Fukuda Last modified: 2024-06-26 (Wed) 17:58:29 JST