我一直在通过构建它来运行我的 Crystal webapp,然后运行可执行文件。但是,它始终侦听端口 3000。
如何在 80 和 443 上构建/运行 Crystal webapps?
我也在使用凯末尔。这是我的示例应用程序。
require "kemal"
get "/" do
"Hello World!"
end
Kemal.run
建造:
crystal build src/myapp.cr
跑步:
./myapp
我一直在通过构建它来运行我的 Crystal webapp,然后运行可执行文件。但是,它始终侦听端口 3000。
如何在 80 和 443 上构建/运行 Crystal webapps?
我也在使用凯末尔。这是我的示例应用程序。
require "kemal"
get "/" do
"Hello World!"
end
Kemal.run
建造:
crystal build src/myapp.cr
跑步:
./myapp
只需将端口传递给Kemal.run
:
require "kemal"
get "/" do
"Hello World!"
end
port = ARGV[0]?.try &.to_i?
Kemal.run port
建造:
crystal build src/myapp.cr
跑:
./myapp # default port 3000
./myapp 80
./myapp 443
首先,确保在发布模式下构建二进制文件:
crystal build --release src/myapp.cr
要覆盖端口和绑定(例如0.0.0.0
),您可以使用此示例配置:
Kemal.config.port = (ENV["PORT"]? || 8080).to_i
Kemal.config.host_binding = ENV["HOST_BINDING"]? || "127.0.0.1"
Kemal.config.env = "production"
Kemal.config.powered_by_header = false
笔记:
Kemal.config.env
,您还可以通过设置启用生产模式KEMAL_ENV=production ./myapp
。powered_by_header
是可选的。它本身不是安全风险,但揭示您正在运行的服务器类型可以帮助攻击者。因此,建议避免所有不必要的信息。它还将略微减少流量以省略标头。但是,在对系统进行故障排除时,包括标头可能是有益的。