前言

AsmBB 是一款由汇编语言编写的轻量级论坛引擎,基于 SQLite 数据库,并通过 FastCGI 接口与 Web 服务器通信。

官方提供了预编译的二进制包,开箱即用,非常适合在个人 VPS 上自托管。本文记录在 Debian 13 的环境下部署 AsmBB 并配置 Nginx 访问的具体步骤。

asmbb.webp

准备环境

安装 Nginx

Debian 13 下 Nginx 的安装与配置可参考 此说明 ,本文不再赘述。

安装基础依赖

1
sudo apt update && sudo apt install wget curl tar unzip vim sqlite3 -y

安装 AsmBB

获取预编译程序

创建网站目录:

1
sudo mkdir -p /var/www/asmbb && cd $_

下载并解压官方预编译二进制软件包:

1
2
3
sudo wget https://asm32.info/fossil/repo/asmbb/doc/trunk/install/asmbb.tar.gz

sudo tar -xvzf asmbb.tar.gz -C /var/www/asmbb --strip-components=1

清理冗余文件:

1
sudo rm -f asmbb.tar.gz .htaccess lighttpd.conf install.txt License.txt manifest.uuid

精简主题模板 [可选]

注意: 必须保留 Urban SunriseWasp 这两个基础主题

1
2
3
cd /var/www/asmbb/templates

sudo rm -rf Light mobile MoLight

添加 NoCSS 模板 [可选]

NoCSS 是作者新增的模板样式,但尚未内置于当前的预编译包中。如需使用,可按以下步骤手动添加:

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
# 拉取 tip 分支最新源码

cd /tmp

sudo wget -O asmbb-src.tar.gz https://asm32.info/fossil/asmbb/tarball/tip/asmbb-src.tar.gz

sudo tar -xzf asmbb-src.tar.gz

sudo mv asmbb-src/www/templates/NoCSS /var/www/asmbb/templates/

sudo rm -rf /tmp/asmbb-src* asmbb-src.tar.gz && cd

# 安装 less 编译器

sudo apt update && apt install node-less

# 编译 CSS 样式表

cd /var/www/asmbb/templates/NoCSS

lessc debug.less debug.css

lessc toaster.less toaster.css

lessc users_online.less users_online.css

NoCSS 模板预览如下:

nocss.webp

配置目录权限

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
sudo chown -R nginx:nginx /var/www/asmbb

sudo find /var/www/asmbb -type d -exec chmod 750 {} \;

sudo find /var/www/asmbb -type f -exec chmod 640 {} \;

sudo chmod 755 /var/www/asmbb/ld-musl-i386.so

sudo chmod 755 /var/www/asmbb/engine

sudo chmod 640 /var/www/asmbb/libsqlite3.so

配置 Systemd 守护进程

1
sudo vim /etc/systemd/system/asmbb.service

写入以下配置:

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
[Service]

Type=simple

User=nginx

Group=nginx

WorkingDirectory=/var/www/asmbb

ExecStart=/var/www/asmbb/engine

Restart=on-failure

RestartSec=5

ProtectSystem=full

PrivateDevices=yes

ProtectKernelTunables=yes

ProtectControlGroups=yes

[Install]

WantedBy=multi-user.target

启动 AsmBB 服务

1
2
3
4
5
6
7
8
9
sudo systemctl daemon-reload

sudo systemctl enable --now asmbb

# 检查运行状态

sudo ls -l /var/www/asmbb/engine.sock

sudo systemctl status asmbb

日常维护命令:

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
# 停止 AsmBB 服务

sudo systemctl stop asmbb

# 启动 AsmBB 服务

sudo systemctl start asmbb

# 重启 AsmBB 服务

sudo systemctl restart asmbb

# 查看日志

sudo journalctl -u asmbb -f

配置 Nginx 访问

AsmBB 通过 FastCGI 接口与 Web 服务器通信,以下是 Nginx 虚拟主机的配置示例:

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
# 将 bbs.your.domain 替换为你的实际域名

upstream asmbb {

    server unix:/var/www/asmbb/engine.sock;

    keepalive 8;

}

server {

    listen 80;

    listen [::]:80;

    server_name bbs.your.domain;

    return 301 https://$host$request_uri;

}

server {

    listen 443 ssl;

    listen [::]:443 ssl;

    http2 on;

    server_name bbs.your.domain;

    root /var/www/asmbb;

    # 指定正确的 SSL 证书

    ssl_certificate     /etc/nginx/cert/bbs.your.domain.pem;

    ssl_certificate_key /etc/nginx/cert/bbs.your.domain.key;

    ssl_protocols TLSv1.2 TLSv1.3;

    ssl_ecdh_curve X25519:P-256:P-384;

    ssl_ciphers 'ECDHE-ECDSA-AES128-GCM-SHA256:ECDHE-ECDSA-CHACHA20-POLY1305:ECDHE-RSA-AES128-GCM-SHA256:ECDHE-RSA-CHACHA20-POLY1305:ECDHE+AES128:RSA+AES128:ECDHE+AES256:RSA+AES256';

    ssl_prefer_server_ciphers off;

    ssl_session_timeout 1d;

    ssl_session_cache shared:MozSSL:10m;

    add_header Strict-Transport-Security "max-age=31536000; includeSubDomains" always;

    access_log /var/log/nginx/bbs.your.domain.access.log;

    error_log /var/log/nginx/bbs.your.domain.error.log;

    add_header X-Frame-Options "SAMEORIGIN" always;

    add_header X-XSS-Protection "1; mode=block" always;

    add_header X-Content-Type-Options "nosniff" always;

    add_header Referrer-Policy "no-referrer-when-downgrade" always;

    add_header Content-Security-Policy "default-src http: 'unsafe-eval' 'unsafe-inline'; object-src 'none'; img-src http: data:" always;

    location / {

        fastcgi_pass asmbb;

        fastcgi_read_timeout 3000;

        fastcgi_keep_conn on;

        include fastcgi_params;

        fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;

        fastcgi_param PATH_INFO $fastcgi_path_info;

        fastcgi_buffer_size 32k;

        fastcgi_buffers 16 16k;

        fastcgi_busy_buffers_size 64k;

        fastcgi_temp_file_write_size 64k;

    }

}

检查并重载 Nginx 配置文件

1
sudo nginx -t && sudo nginx -s reload

然后,访问 bbs.your.domain ,首个注册用户即为管理员。

配置邮件验证

为减少垃圾注册,同时为用户找回密码提供保障,建议开启电子邮件验证。

AsmBB 原生仅支持无身份验证的 SMTP 连接,并未内置带密码认证的 SMTP 客户端。因此,直接连接常规的外部邮件服务并不现实,通常需要借助本地 Postfix 或其他邮件中继。

不过,AsmBB 支持通过外部程序管道 (Pipe the emails through),我们可以配置 msmtp 服务来解决发信难题。

安装 msmtp

1
2
3
sudo apt update

sudo apt install msmtp msmtp-mta ca-certificates

出现以下提示时,选择 No 即可:

apparmor.webp

配置 msmtp 服务

创建 msmtp 全局配置文件

1
sudo vim /etc/msmtprc

写入 SMTP 发信服务器配置:

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
defaults

auth           on

tls            on

tls_trust_file /etc/ssl/certs/ca-certificates.crt

# 指定日志路径

logfile        /var/log/msmtp.log

# 默认账户

account        default

# SMTP 主机名

host           smtp.your.mail

# STARTTLS 加密端口通常为 587 (同时设置 tls_starttls on)

# SSL 强制加密端口通常为 465 (同时设置 tls_starttls off)

# 对于端口:

# STARTTLS 通常为 587 (需设置 tls_starttls on)

# SSL 强制加密通常为 465 (需设置 tls_starttls off)

port           465

tls_starttls   off

# 发信人邮箱

from           noreply@your.mail

# SMTP 用户名

user           noreply@your.mail

# SMTP 密码

password       veryStrongPassWord!

上面配置文件包含明文密码,需严格控制相关文件与目录的权限:

1
2
3
4
5
6
7
8
9
sudo chown root:nginx /etc/msmtprc

sudo chmod 640 /etc/msmtprc

sudo touch /var/log/msmtp.log

sudo chown nginx:nginx /var/log/msmtp.log

sudo chmod 660 /var/log/msmtp.log

测试本地发信

执行以下命令进行测试,将结尾邮件地址替换为自己的收件箱。确认能成功发送邮件后,继续下一步。

1
echo -e "Subject: Test from msmtp\r\n\r\nThis is a test email sent from the command line." | sudo -u nginx msmtp -t test-mail@your.mail

修改邮件模板 [可选]

默认 Urban Sunrise 主题下面的邮件模板有点问题,简单修改一下:

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
# 备份源文件

sudo cp '/var/www/asmbb/templates/Urban Sunrise/activation_email_subject.tpl' '/var/www/asmbb/templates/Urban Sunrise/activation_email_subject.tpl.bak' 

sudo cp '/var/www/asmbb/templates/Urban Sunrise/activation_email_text.tpl' '/var/www/asmbb/templates/Urban Sunrise/activation_email_text.tpl.bak' 

# 修改邮件主题模板

cat << 'EOF' > "/var/www/asmbb/templates/Urban Sunrise/activation_email_subject.tpl"

[case:[operation]|Account activation for|Email change for|Password reset for] [host]

EOF

# 修改邮件内容模板

cat << 'EOF' > "/var/www/asmbb/templates/Urban Sunrise/activation_email_text.tpl"

Hello [nick], / 你好 [nick],

[case:[operation]

|This email was sent to you because you registered an account on https://[host].

If you didn't, please ignore this email.

To activate your account, please visit the following link:

(这是一封注册验证邮件,请点击下方链接激活您的账号。如非本人操作,请忽略。)

https://[host]/!activate/[secret]/

|This email was sent to confirm your new email address.

If you didn't request this change, please ignore this email.

To activate your new email, please visit the following link:

(这是一封邮箱换绑验证邮件,请点击下方链接完成验证。如非本人操作,请忽略。)

https://[host]/!activate/[secret]/

|This email was sent to confirm your password reset request.

If you didn't request a password reset, please ignore this email.

To reset your password, please copy the code below into the password reset form:

(这是一封密码重置验证邮件。如非本人操作,请忽略。重置验证码如下:)

[secret]

]

Best regards, / 祝好,

The Zsh BBS Team

EOF

启用邮件验证

在 AsmBB 后台管理设置里,将发信服务器配置为 msmtp 外部程序管道,并开启注册邮件验证功能。

email-settings.webp

结语

AsmBB 是一款几乎理想的论坛引擎,我喜欢它的小巧、轻量和快速。尽管对中文支持还不太好,但是瑕不掩瑜。

zsh-bbs.webp