Docker 搭建 Pipe 并配置一级域指南

本贴最后更新于 1510 天前,其中的信息可能已经事过境迁

相关知识

Pipe 是一款小而美的开源博客平台,专为程序员设计。Pipe 有着非常活跃的社区,可将文章作为帖子推送到社区,来自社区的回帖将作为博客评论进行联动(具体细节请浏览 B3log 构思 - 分布式社区网络)。

Docker 部署

#首先服务器要安装好Nginx、MariaDB,用yum安装即可 # docker安装 yum -y install docker # docker 启动 systemctl start docker # 获取最新镜像 docker pull b3log/pipe # 使用 MySQL 先手动建库(库名 `pipe` ,字符集使用 `utf8mb4` ,排序规则 `utf8mb4_general_ci` ),然后启动容器 docker run --detach --name pipe --network=host \ b3log/pipe --mysql="root:123456@(127.0.0.1:3306)/pipe?charset=utf8mb4&parseTime=True&loc=Local&timeout=1s" --runtime_mode=prod --port=5897 --server=https://henryspace.cn

Nginx 反向代理

  • 一级域名打开直接定位到博客首页
  • 配置支持 HTTPS:Nginx 的 HTTPS 配置
    配置中的 server_name、证书密钥、rewrite 目录需要换成自己的
upstream pipe { server localhost:5897; } server { listen 80; server_name henryspace.cn; rewrite ^(.*)$ https://$host$1 permanent; } server { listen 80; server_name www.henryspace.cn; rewrite ^(.*)$ https://henryspace.cn$1 permanent; } server { listen 443 ssl; server_name henryspace.cn; ssl_certificate /etc/nginx/cert/henryspace.pem; ssl_certificate_key /etc/nginx/cert/henryspace.key; ssl_session_timeout 5m; ssl_protocols TLSv1 TLSv1.1 TLSv1.2; ssl_ciphers HIGH:!aNULL:!MD5:!DH; rewrite ^/(?!theme|console|admin|api|init) /blogs/henryspace$uri break; location /{ proxy_pass http://pipe/; proxy_set_header Host $host:$server_port; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; client_max_body_size 10m; } error_log /var/log/blog.log; error_page 404 /404.html; location = /404.html { root /usr/share/nginx/html; } error_page 500 502 503 504 /50x.html; location = /50x.html { root /usr/share/nginx/html; } location ~ /\.ht { deny all; } }

配置好之后直接重启 nginx 即可
systemctl restart nginx

配置已 OK,打开浏览器访问吧 ~

示例:https://henryspace.cn

相关文档:
感谢 D 神 88250
Pipe 用户指南

1 操作
henryspace 在 2021-03-19 17:17:18 更新了该帖

相关帖子

欢迎来到这里!

我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。

注册 关于
请输入回帖内容 ...
  • henryspace via macOS
    作者

    呃,建库时,数据库名为 pipe 不是 pip,自己纠正一下,真是醉了,抄也能抄错

  • henryspace
    作者
    docker启动命令编辑器支持的不好,确认如下
    
    docker run --detach --name pipe --network=host
    b3log/pipe --mysql="root:123456@(127.0.0.1:3306)/pipe?charset=utf8mb4&parseTime=True&loc=Local&timeout=1s" --runtime_mode=prod --port=5897 --server=https://henryspace.cn
    
    
    
    
  • CodeFish

    完全按照这个进行操作,也把参数改了,

    他就是无法访问

    upstream pipe { server localhost:5897; } server { listen 80; server_name javafish.cn; rewrite ^(.*)$ https://$host$1 permanent; } server { listen 80; server_name www.javafish.cn; rewrite ^(.*)$ https://javafish.cn$1 permanent; } server { listen 443; server_name javafish.cn; ssl on; ssl_certificate /etc/nginx/cert/javafish.cn.pem; ssl_certificate_key /etc/nginx/cert/javafish.cn.key; ssl_session_timeout 5m; ssl_ciphers ECDHE-RSA-AES128-GCM-SHA256:ECDHE:ECDH:AES:HIGH:!NULL:!aNULL:!MD5:!ADH:!RC4; ssl_protocols TLSv1 TLSv1.1 TLSv1.2; ssl_prefer_server_ciphers on; rewrite ^/(?!theme|console|admin|api|init) /blogs/henryspace$uri break; location /{ proxy_pass http://pipe/; proxy_set_header Host $host:$server_port; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; client_max_body_size 10m; } error_log /var/log/blog.log; error_page 404 /404.html; location = /404.html { root /usr/share/nginx/html; } error_page 500 502 503 504 /50x.html; location = /50x.html { root /usr/share/nginx/html; } location ~ /\.ht { deny all; } }
    1 回复
  • henryspace via macOS
    作者

    可能是 ssl 加密策略问题,nginx 版本也有关系。上面的配置我修改了下,你可以用上面的试一下