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
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)