Swift 将域指向运行在OSX服务器上的Web应用程序(例如Kitura、perfect、Vapor服务器)

Swift 将域指向运行在OSX服务器上的Web应用程序(例如Kitura、perfect、Vapor服务器),swift,osx-server,vapor,perfect,kitura,Swift,Osx Server,Vapor,Perfect,Kitura,使用OSX服务器应用程序,我可以将多个域指向不同的网站。所有域都可以同时使用端口80,OS X将决定使用哪个网站 当我启动kitura服务器时(我想Vapor和Perfect也会发生同样的情况),我必须在一个空闲端口(例如8080)上启动它。如果我从80开始,它将与网站产生冲突,它可能不会接听我的电话 设置Kitura以使端口80与其他服务一起使用的正确方法是什么 我使用以下命令启动kitura服务器: do { let controller = try Controller()

使用OSX服务器应用程序,我可以将多个域指向不同的网站。所有域都可以同时使用端口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

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

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

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

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

如何正确地做到这一点:

步骤1:在
/Library/Server/Web/config/apache2/webapps
中,创建名为
my.application.plist的plist文件(例如)。这个plist描述了一个所谓的webapp,它可以在OSX服务器应用中激活

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.mydomain
替换为要访问应用程序的域(如果应用程序的端口不同,则替换为
8080

重要提示:这两个文件都必须使用
sudo nano
创建/编辑,并且必须归root所有

步骤3:在OS X Server应用程序中,转到网站,选择要使用的域(双击或单击编辑符号),然后单击编辑高级设置。如果一切顺利,您新创建的webapp将显示在“使这些webapp在此网站下可用”下。选中webapp的复选框,然后保存

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

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

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


乍一看,这似乎有点复杂,但事实并非如此。据我所知,这是目前唯一可以接受的在OS X服务器上配置反向代理的方法。

很高兴听到这个消息!如果您将问题的标题从“kitura服务器”更改为“应用程序服务器”,它将反映您问题的一般方面,并帮助其他人找到它。现在应该更通用。如果有更改,因为这不再有效。我可以从任何域访问本地端口。反向代理不工作。必须从OS X服务器中删除网站并再次添加,然后才能工作。奇怪的是,随着服务器5.4和OS X 10.13的发布,这一点有没有改变,因为它不再工作了?如今,苹果变得越来越不稳定
# 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/