1

使用 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
4

2 回答 2

1

在 OS X(或 macOS)上使您的应用程序可通过端口 80 访问的最常见且可能最简单的方法是配置反向代理

此解决方案适用于任何 Web 应用程序,而不仅仅是 Kitura。

OS X Server 应用程序带有一个 Apache 服务器,可以配置为充当反向代理。Apache 反向代理可以侦听特定域的端口 80,然后将所有请求转发到您的应用程序侦听的内部端口 8080,反之亦然。

如何正确执行此操作:

第 1 步:在中,创建一个名为(例如)/Library/Server/Web/config/apache2/webapps的 plist 文件。my.application.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 将出现在Make these webapps available under this website 下。选中您的 web 应用程序的框,然后保存。

通常不需要重新启动 Web 服务器(服务器应用程序会为您执行此操作)。

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

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

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

于 2017-06-27T17:45:55.607 回答
0

OSX Server 已经在使用端口 80 来监听传入的连接。因此,当 OSX Server 使用它时,Kitura 不能使用端口 80。要在端口 80 上使用 Kitura,您需要关闭 OSX Server 以释放端口 80。或者,您可以设置 OSX Server 以将请求路由到您的网站到您的 Kitura 应用程序。但我不知道如何专门用 OSX Server 做到这一点。

于 2017-06-27T16:50:26.703 回答