想用 docker-gen 和 frp 配合做个类似 jwilder/nginx-proxy 的 docker 镜像,需要一旦有新的容器启动就让 docker-gen 读取模板自动生成新的 frpc.ini,然后现在发现 frpc 需要重新启动才能读取新的配置文件,不知道 frpc 有没有类似 nginx -s reload 这样的方式
看 frp 官方文档只提到服务器端以前的版本有这个功能,客户端这边好像没有
1
yangxuan8282 OP |
2
Leonn 2017-06-11 20:14:51 +08:00
|
3
yangxuan8282 OP @Leonn 发之前看过了,文档里只提了服务器端移除热加载配置文件功能,没有提及客户端是否支持,不过看代码好像也没有这个功能
|
4
yangxuan8282 OP 容器内生成配置文件后自动重启 frpc 的问题解决了,参照 BlackGlory/caddy-proxy 这个镜像用 supervisor 管理 frpc: `supervisorctl restart frpc`,稍后整理一下 docker 文件,不知道其他人会不会有兴趣
|
5
fatedier 2017-06-12 00:50:55 +08:00
@yangxuan8282 可以有,TODO~
|
6
yangxuan8282 OP @fatedier 问下看文档里同时存在 privilege_token 和 auth_token 两种身份认证的方式,不知道这两个有什么区别,auth_token 翻了几个 issues 里的对话得到结论是是针对每个用户的,可以放到 frpc.ini 的 [common] 部分,而 privilege_token 好像对每个用户来说都是一样的,可以放在 frps.ini 的 [common] 部分,如果只为了身份认证的话是不是只留一个 privilege_token 就可以了
|
7
fatedier 2017-06-12 14:49:17 +08:00
@yangxuan8282 目前只有 privilege_token 了,auth_token 取消了,不起作用。
|
8
yangxuan8282 OP @fatedier 把利用 docker-gen 自动配置 frp 的文件建立了个项目,放到 github 上了: https://github.com/yangxuan8282/frpd
目前是监控其它容器启动后自动生成配置文件,然后重启 frpc 来生效,用来把家里的服务暴露到外网挺方便的 |
9
yangxuan8282 OP @fatedier 下一步想尝试在上面的项目里加入 Let's Encrypt 证书自动配置,看文档好像 frp 本身只是传输数据,需要另外的应用来处理 443 端口的访问,看 issues 里大体的思路是 用 nginx 这种 web server 处理证书,然后把 443 端口的访问转发到 80 端口这样,那是不是只要在 nginx.conf 里加入:
``` server { listen 443; server_name _; rewrite ^(.*) http://$host$1 permanent; } ``` 就可以了,还是应该类似这样: ``` server { listen 443; server_name example1.com; location / { proxy_pass http://127.0.0.1:80; } } ``` 另外好像 haproxy 也可以处理证书,不知道哪种方案更好一点 |
10
fatedier 2017-06-14 10:46:32 +08:00
|