我是否可以将子域配置为指向我服务器上的特定端口

ale*_*rdy 36 dns port portforwarding

我有一台旧计算机,我将其转换为一个Minecraft服务器.我有2个同时运行的Minecraft服务器,一个在端口25565(默认),另一个在端口25566上.

我买了域some.com并指向我的服务器.现在,在游戏中你输入something.com进入第一台服务器和something.com:25566进入另一台服务器.

有没有办法将one.something.com设置为指向第一台服务器而将two.something.com设置为指向第二台服务器?我拥有(centos)服务器,具有root访问权限,以及其他所有内容.域名由no-ip控制,如果这有所不同.我知道DNS与端口号没有任何关系但是如果有一个程序我可以安装以使其工作?

谢谢 :)

小智 76

如果您有权访问SRV Records,您可以使用它们来获得您想要的:)

例如

记录

Name: mc1.domain.com
Value: <yourIP>

Name: mc2.domain.com
Value: <yourIP>
Run Code Online (Sandbox Code Playgroud)

SRV记录

Name: _minecraft._tcp.mc1.domain.com
Priority: 5
Weight: 5
Port: 25565
Value: mc1.domain.com

Name: _minecraft._tcp.mc2.domain.com
Priority: 5
Weight: 5
Port: 25566
Value: mc2.domain.com
Run Code Online (Sandbox Code Playgroud)

然后在我的世界中你可以使用

mc1.domain.com,它将使用端口25565签入服务器1

mc2.domain.com将使用端口25566签到服务器2

然后在您的路由器上,您可以将它指向25565和25566到两台服务器上的机器和Voilà!

资料来源:这适用于我在同一台机器上运行2台矿用服务器,端口为50500和50501

  • 我不相信这适用于浏览器.因此,您无法使用它将子域指向浏览器中的特定端口.请参阅http://stackoverflow.com/questions/9063378/why-do-browsers-not-use-srv-records. (2认同)
  • 您能否详细说明如何构建像`_minecraft._tcp.mc1.domain.com`这样的SRV记录?这就是我的理解方式:`_something._protocol.subdomain.domain.tld`。该示例中的“ _something”有什么作用?它只是一个友好的名称,还是具有某种相关性,可以使其正常工作? (2认同)
  • 这对于从浏览器访问的普通网站不起作用,因为浏览器不会解析 SRV 记录,并且始终会访问端口 80。您可以执行以下操作:https://superuser.com/a/1103011 (2认同)

Deb*_*Deb 54

如果您想在不同端口的单个服务器中托管多个网站,那么 MRVDOG 提到的方法将不起作用。因为浏览器不会解析 SRV 记录并且总是会点击:80端口。例如,如果您的要求是:

site1.domain.com maps to domain.com:8080
site2.domain.com maps to domain.com:8081
Run Code Online (Sandbox Code Playgroud)

因为您通常希望充分利用您购买的服务器空间。然后您可以尝试以下操作:

第一步: 安装代理服务器。我将在这里使用Nginx

apt-get install nginx
Run Code Online (Sandbox Code Playgroud)

步骤 2: 编辑/etc/nginx/nginx.conf 文件以添加端口映射。为此,请添加以下行:

server {
    listen 80;
    server_name site1.domain.com;

    location / {
        proxy_pass http://localhost:8080;
    }   
}

server {
    listen 80;
    server_name site2.domain.com;

    location / {
        proxy_pass http://localhost:8081;
    }   
}
Run Code Online (Sandbox Code Playgroud)

这很神奇。所以文件最终将如下所示:

user www-data;
worker_processes auto;
pid /run/nginx.pid;
include /etc/nginx/modules-enabled/*.conf;

events {
    worker_connections 768;
    # multi_accept on;
}

http {

    ##
    # Basic Settings
    ##

    sendfile on;
    tcp_nopush on;
    tcp_nodelay on;
    keepalive_timeout 65;
    types_hash_max_size 2048;
    # server_tokens off;

    # server_names_hash_bucket_size 64;
    # server_name_in_redirect off;

    include /etc/nginx/mime.types;
    default_type application/octet-stream;

    ##
    # SSL Settings
    ##

    ssl_protocols TLSv1 TLSv1.1 TLSv1.2; # Dropping SSLv3, ref: POODLE
    ssl_prefer_server_ciphers on;

    ##
    # Logging Settings
    ##

    access_log /var/log/nginx/access.log;
    error_log /var/log/nginx/error.log;

    ##
    # Gzip Settings
    ##

    gzip on;

    # gzip_vary on;
    # gzip_proxied any;
    # gzip_comp_level 6;
    # gzip_buffers 16 8k;
    # gzip_http_version 1.1;
    # gzip_types text/plain text/css application/json application/javascript text/xml application/xml application/xml+rss text/javascript;

    ##
    # Virtual Host Configs
    ##
server {
    listen 80;
    server_name site1.domain.com;

    location / {
        proxy_pass http://localhost:8080;
    }   
}

server {
    listen 80;
    server_name site2.domain.com;

    location / {
        proxy_pass http://localhost:8081;
    }   
}

    include /etc/nginx/conf.d/*.conf;
    include /etc/nginx/sites-enabled/*;
}


#mail {
#   # See sample authentication script at:
#   # http://wiki.nginx.org/ImapAuthenticateWithApachePhpScript
# 
#   # auth_http localhost/auth.php;
#   # pop3_capabilities "TOP" "USER";
#   # imap_capabilities "IMAP4rev1" "UIDPLUS";
# 
#   server {
#       listen     localhost:110;
#       protocol   pop3;
#       proxy      on;
#   }
# 
#   server {
#       listen     localhost:143;
#       protocol   imap;
#       proxy      on;
#   }
#}
Run Code Online (Sandbox Code Playgroud)

第三步: 启动nginx:

/etc/init.d/nginx start.

每当您对配置进行任何更改时,都需要重新启动 nginx:

/etc/init.d/nginx restart

最后:不要忘记在您的 DNS 配置中添加A 记录。所有子域都应该指向域。像这样: 在此处输入图片说明

把你的静态 ip 而不是 111.11.111.111

更多细节:

托管静态网站: 如果您有任何静态网站(如 angular 应用程序),您希望将其部署在 nginx 本身中。将您的 index.html 与其他资源一起放在某个文件夹中,例如/srv/mySite并在 nginx.conf 中添加以下服务器块:

server {
    listen 80;
    server_name staticSite.domain.com;
    root /srv/mySite;
    location / {
       try_files $uri $uri/ /index.html;
    }
}
Run Code Online (Sandbox Code Playgroud)


小智 10

如果您在服务器上只有一个IP,则没有机会这样做.DNS是数字(IP)解析器的简单名称.如果服务器上有两个IP,则可以将每个子域指向每个IP地址,并在每个IP上的默认端口上运行两个服务器.
one.example.com - > 127.0.0.1(服务器:127.0.0.1:
25565 )two.example.com - > 127.0.0.2(服务器:127.0.0.2:25565)

  • 可以做OP所要求的事情。请参阅@Deb 的回复。 (4认同)