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

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

相关知识

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
    作者

    呃,建库时,数据库名为 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
    作者

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