自建邮局poste.io踩坑填坑(文末有彩蛋)

项目需求

要自建邮局,要有web管理界面,要原生支持docker,还不能占用太多的资源,挑来挑去,就剩下这款poste.io能用了。

快速安装

由于同台服务器上有其他的web服务,为了避免端口冲突,我们只暴露邮局服务端口,web界面通过其他web服务里的nginx进行代理。关于dns配置官网有详细的说明,这里就跳过了,只讲下服务器部署的坑。

  • 禁用反病毒功能(DISABLE_CLAMAV=TRUE)、禁用反垃圾邮件功能(DISABLE_RSPAMD=TRUE),可以大幅减低内存和CPU占用,请酌情设置禁用选项。

  • 禁用WEB收发功能(DISABLE_ROUNDCUBE=TRUE),可以进一步减少资源占用,不过非必要不建议禁止。

使用脚本时,请注意修改里面的域名和存储路径。

docker run --name mailer -d \
    --restart unless-stopped \
    --hostname "mail.example.org" \
    --publish 25:25 \
    --publish 110:110 \
    --publish 143:143 \
    --publish 465:465 \
    --publish 587:587 \
    --publish 993:993 \
    --publish 995:995 \
    --publish 4910:4910 \
    --env "TZ=Asia/Shanghai" \
    --env "DISABLE_CLAMAV=TRUE" \
    --env "DISABLE_RSPAMD=FALSE" \
    --env "DISABLE_ROUNDCUBE=FALSE" \
    --volume ./mailer:/data \
    analogic/poste.io

代理WEB界面

这是完整的nginx代理配置,请注意你需要将mailer连接到web服务所在的容器,才能使用$scheme://mailer进行反向代理,否则请使用mailer容器的ip地址。

使用脚本时,请注意修改里面的域名和证书路径。文件必须保存为UTF-8编码。

server {

    listen 80;
    listen [::]:80;

    listen 443 ssl http2;
    listen [::]:443 ssl http2;
    ssl_certificate certs/default.cer;
    ssl_certificate_key certs/default.key;

    server_name mail.example.org;

    location / {
        proxy_pass $scheme://mailer;
        proxy_set_header Host $host;
        # real-ip
        proxy_set_header X-Real-IP $remote_addr;
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
        proxy_set_header REMOTE-HOST $remote_addr;
        # websocket
        proxy_set_header Upgrade $http_upgrade;
        proxy_set_header Connection 'upgrade';
        proxy_read_timeout 86400;
        ## replace content ##
        sub_filter_once  off;
        sub_filter '撰写新邮件' '写信';
        sub_filter 'Dark mode' '深色';
        sub_filter 'Light mode' '浅色';
        sub_filter '[Administration]' '控制台';
        sub_filter '>Administration<' '>控制台<';
        sub_filter 'Trusted Senders' '可信发件人';
        sub_filter 'Collected Recipients' '收件人集合';
        sub_filter '</style>' '\n.pro,.brand,.nav-sidebar p.alert{display:none !important}\n</style>';
    }

}

惊喜彩蛋

细心的小伙伴应该发现了,nginx代理配置中有一段sub_filter代码。这就是我要说的彩蛋:

  • 隐藏付费的pro菜单,使界面更加清爽。
  • 修改部分WEB收发界面的英文菜单或描述。

隐藏pro菜单前

608.png

隐藏pro菜单后

559.png

WEB收发信界面

149.png

文章作者: 若海; 原文链接: https://www.rehiy.com/post/509/; 转载需声明来自技术写真 - 若海

已有 4 条评论

  1. 作者好顶,我不知道说什么, 反正nginx 替换后,用着比官方的付费版都要牛逼。
    官方的pro 就是鸡肋。 。。。
    若海, PLUS!!!

    1. 只是隐藏了一些没用的界面而已 ......

  2. ls

    我用宝塔面板,怎么都无法实现 https 面板反向代理也不行 可以提供下技术支持吗?

    1. $scheme 改成 http 试试?

添加新评论