使用OS X服务器应用程序,我可以将多个域指向各种网站。所有域可以同时使用端口80,OS X将解析使用哪个网站。
当我启动我的kitura服务器时(我认为Vapor和Perfect会发生同样的情况)我必须在一个自由端口(例如8080)上启动它。如果我在80开始它会与网站产生冲突,它可能无法接听我的电话。
设置Kitura的正确方法是什么,以便端口80与其他服务一起使用?
我使用以下命令启动kitura服务器:
do {
let controller = try Controller()
Log.info("Server will be started on '\(controller.url)'.")
Kitura.addHTTPServer(onPort: controller.port, with: controller.router)
// Start Kitura-Starter server
Kitura.run()
} catch let error {
Log.error(error.localizedDescription)
Log.error("Oops... something went wrong. Server did not start!")
}
我在日志中得到以下信息:
[2017-06-27T17:57:30.635+03:00] [VERBOSE] [Router.swift:68 init(mergeParameters:)] Router initialized
[2017-06-27T17:57:36.817+03:00] [INFO] [main.swift:37 KiteSpotterServer] Server will be started on 'http://localhost:8080'.
[2017-06-27T17:57:37.588+03:00] [VERBOSE] [Kitura.swift:72 run()] Starting Kitura framework...
[2017-06-27T17:57:38.457+03:00] [VERBOSE] [Kitura.swift:82 start()] Starting an HTTP Server on port 8080...
[2017-06-27T17:57:39.190+03:00] [INFO] [HTTPServer.swift:117 listen(on:)] Listening on port 8080
答案 0 :(得分:1)
使OS X(或macOS)上的端口80可以访问应用程序的最常见且最简单的方法是配置反向代理。
此解决方案适用于任何Web应用程序,而不仅仅是Kitura。
OS X Server应用程序附带一个Apache服务器,可配置为充当反向代理。 Apache反向代理可以在端口80上侦听特定域,然后将所有请求转发到应用程序侦听的内部端口8080,反之亦然。
如何正确地做到这一点:
第1步:在/Library/Server/Web/config/apache2/webapps
中,创建一个名为my.application.plist
的plist文件(例如)。这个plist描述了一个所谓的webapp,它可以在OS X服务器应用程序中激活。
示例webapp plist:
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
<!-- Allow to include a custom Apache configuration file from Server app -->
<plist version="1.0">
<dict>
<key>includeFiles</key>
<array>
<!-- Include files are activated in virtual host when webapp is started -->
<string>/Library/Server/Web/Config/apache2/httpd_webapp_myapp.conf</string>
</array>
<key>name</key>
<string>com.atlassian.webapp.myapp</string>
<key>displayName</key> <!-- Name shown in Server app -->
<string>Reverse proxy for myapp</string>
<key>installationIndicatorFilePath</key> <!-- The presence of this file indicates web app is installed -->
<string>/Library/Server/Web/Config/apache2/httpd_webapp_myapp.conf</string>
<key>sslPolicy</key><!-- Determines webapp SSL behavior -->
<integer>0</integer>
<!-- 0: default, UseSSLWhenEnabled -->
<!-- 1: UseSSLAlways -->
<!-- 2: UseSSLOnlyWhenCertificateIsTrustable -->
<!-- 3: UseSSLNever -->
<!-- 4: UseSSLAndNonSSL -->
</dict>
</plist>
在上面的示例中,请使用您的应用名称替换myapp
。
第2步:接下来,在/Library/Server/Web/Config/apache2
中,使用您在plist文件中选择的名称创建一个文件(在我的示例中为httpd_webapp_myapp.conf
)。该文件将配置反向代理。
示例代理配置文件:
# As described at http://httpd.apache.org/docs/2.2/mod/mod_proxy.html#proxypass
# Service proxy for myapp installation
ProxyRequests Off
ProxyVia Off
<Proxy *>
Require all granted
</Proxy>
ProxyPass / http://myapp.mydomain:8080/
ProxyPassReverse / http://myapp.mydomain:8080/
在上面的示例中,将myapp.mydomain
替换为您希望访问应用程序的域(如果不同,请将8080
替换为应用程序的端口。)
重要提示:必须使用sudo nano
创建/编辑这两个文件,并且这些文件必须由root拥有。
第3步:在OS X Server应用中,转到网站,选择要使用的域(双击或单击编辑符号),然后点击编辑高级设置。如果一切顺利,您新创建的网络应用程序将显示在在此网站下提供这些网络应用程序下。选中您的webapp框,然后保存。
通常没有必要重新启动Web服务器(Server应用程序会为您执行此操作)。
第4步:测试您是否可以在此域下访问您的应用。
注意:可能需要以某种方式配置应用程序,因此它知道它在反向代理后运行。
乍一看,这可能看起来有点复杂,但事实并非如此,据我所知,它现在是在OS X服务器上配置反向代理的唯一可接受方式。
答案 1 :(得分:0)
OSX Server已使用端口80侦听传入连接。因此,当OSX Server使用它时,Kitura无法使用端口80。要在端口80上使用Kitura,您需要关闭OSX Server以释放端口80.或者,您可以设置OSX Server以将请求路由到您的Kitura应用程序。但我不知道如何使用OSX Server专门做到这一点。