Autocert (Let's Encrypt) and multiple services per machine?

agolangf · 2018-03-26 09:30:21 · 539 次点击    
这是一个分享于 2018-03-26 09:30:21 的资源,其中的信息可能已经有所发展或是发生改变。

From the way I understand, autocert package needs port 80 open to perform http challenge, does it mean it is impossible to run more than one service on the same machine?

Lets say there's one service listening on 443, and another on 8080. Both need certificates, but if first service already listening on port 80, then second service will be unable get its own certificate since port is already taken.

Is there a way around it?


评论:

mwholt:

Autocert is nice for simple use cases, but doesn't handle advanced use very well. For more advanced ACME use cases like yours, use lego: https://github.com/xenolf/lego - it allows you to wrap the ACME layer with your own challenge providers and customize the .

But if you can just put a single service in front, and reverse proxy, that would be simpler. For that, you can use Caddy (which uses lego), which can even coordinate ACME certificates in a fleet configuration very easily (just by sharing the same ~/.caddy/acme folder), so if you do need more than one instance or machine or container or whatever, they can all share the same certificates, and Caddy can reverse-proxy to your backend services. (I'm biased of course, but this is still good advice.)

(You could also configure the DNS challenge to avoid having the CA contact your server at all -- but autocert doesn't support the DNS challenge, you'd have to use the underlying acme package or, as I recommended, use lego. lego's been around longer and has better support for DNS challenge.)

tv64738:

You can either front all your services with a single autocert instance, or use a name-based reverse proxy.

tialaramex:

Another option that may be applicable where several services have the same machine names is to issue certificates for the names once, but use the same cert (and associated private key) in all these services.

This will not be appropriate for situations which prioritise security, as compromise of one service would get the private key that could be leveraged against the other services, but it may be simpler in some scenarios and often if everything shares a machine any security partitioning is pretty flimsy anyway.


入群交流(和以上内容无关):加入Go大咖交流群,或添加微信:liuxiaoyan-s 备注:入群;或加QQ群:692541889

539 次点击  
加入收藏 微博
暂无回复
添加一条新回复 (您需要 登录 后才能回复 没有账号 ?)
  • 请尽量让自己的回复能够对别人有帮助
  • 支持 Markdown 格式, **粗体**、~~删除线~~、`单行代码`
  • 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
  • 图片支持拖拽、截图粘贴等方式上传