将域指向 OS X 服务器上的 Web 应用程序 运行(例如 Kitura、perfect、vapor 服务器)

Point domain to a Web Application running on OS X Server (ex. Kitura, perfect, vapour server)

使用 OS X 服务器应用程序,我可以将多个域指向各种网站。所有域名可以同时使用80端口,OSX会解析使用哪个网站。

当我启动我的 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

OSX 服务器已在使用端口 80 侦听传入连接。因此,Kitura 在 OSX 服务器正在使用端口 80 时无法使用它。要在端口 80 上使用 Kitura,您需要关闭 OSX 服务器以释放端口 80。或者,您可以设置 OSX 服务器将对您网站的请求路由到您的 Kitura 应用程序。但我不知道如何使用 OSX 服务器具体执行此操作。

使您的应用程序可以通过 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 描述了一个所谓的网络应用程序,它可以在 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 文件中 select 编辑的文件(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 替换为应用程序的端口)。

重要提示:这两个文件必须是 created/edited 使用 sudo nano,并且它们必须由 root 所有。

步骤 3:在 OS X Server 应用程序中,转到 Websites,select 域您要使用(双击或单击编辑符号),然后单击编辑高级设置。如果一切顺利,您新创建的 webapp 将出现在 Make these webapps available under this website 下。选中您的网络应用程序的框,然后保存。

通常不需要重新启动网络服务器(服务器应用程序会为您完成)。

第 4 步:测试是否可以访问该域下的应用程序。

注意:可能需要以某种方式配置应用程序,以便它知道它在反向代理后面运行。

乍一看,这可能有点复杂,但实际上并非如此,据我所知,这是现在唯一接受的在 OS X 服务器上配置反向代理的方法.