nginx-代理多个服务

该文详细介绍了如何在Linux环境中配置单网卡多IP,包括查看网络信息、添加IP及修改Nginx配置。接着,它展示了如何通过Nginx设置多端口服务,以及通过不同端口访问不同内容。最后,文章讲解了多域名代理的配置方法,通过修改Nginx配置文件实现对多个域名的代理服务。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

目录

1.主机多Ip

1.1单网卡多ip主机配置

1.2修改default.conf

1.3server1.conf

1.3server2.conf

1.4测试文件

1.4重启测试

2.主机多端口

2.1server1.conf

2.2server2.conf

3.多域名代理

3.1server1.conf

3.2server2.conf


1.主机多Ip

1.1单网卡多ip主机配置

# 查看网络信息 1: lo: 本地  2: enp0s3:添加ip的网卡位置,名字可能不一样 
# inet 192.168.1.124 虚拟机ip
[root@localhost html]# ip a

1: lo: <LOOPBACK,UP,LOWER_UP> mtu 65536 qdisc noqueue state UNKNOWN group default qlen 1000
    link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00
    inet 127.0.0.1/8 scope host lo
       valid_lft forever preferred_lft forever
    inet6 ::1/128 scope host 
       valid_lft forever preferred_lft forever
2: enp0s3: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc pfifo_fast state UP group default qlen 1000
    link/ether 08:00:27:8a:00:a7 brd ff:ff:ff:ff:ff:ff
    inet 192.168.1.124/24 brd 192.168.1.255 scope global noprefixroute dynamic enp0s3
       valid_lft 988sec preferred_lft 988sec
    inet6 fe80::e09e:e70e:87c8:45f2/64 scope link noprefixroute 
       valid_lft forever preferred_lft forever
# 对于 enp0s3 添加另外的ip/掩码,添加的ip在局域网内不能被使用的,不确定可以使用ping命令
ip a add 192.168.1.125/24  dev enp0s3



# ip a 可以看到多了一个地址
[root@localhost html]# ip a

1: lo: <LOOPBACK,UP,LOWER_UP> mtu 65536 qdisc noqueue state UNKNOWN group default qlen 1000
    link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00
    inet 127.0.0.1/8 scope host lo
       valid_lft forever preferred_lft forever
    inet6 ::1/128 scope host 
       valid_lft forever preferred_lft forever
2: enp0s3: <BROADCAST,MULTICAST,UP,LOWER_UP> mtu 1500 qdisc pfifo_fast state UP group default qlen 1000
    link/ether 08:00:27:8a:00:a7 brd ff:ff:ff:ff:ff:ff
    inet 192.168.1.124/24 brd 192.168.1.255 scope global noprefixroute dynamic enp0s3
       valid_lft 6895sec preferred_lft 6895sec
    inet 192.168.1.125/24 scope global secondary enp0s3
       valid_lft forever preferred_lft forever
    inet6 fe80::e09e:e70e:87c8:45f2/64 scope link noprefixroute 
       valid_lft forever preferred_lft forever

1.2修改default.conf

cd /etc/nginx/conf.d/
# 备份
cp default.conf  /opt/backup/default.conf
# 重命名default名称
mv default.conf server1.conf
# 复制一份
cp server1.conf server2.conf
vi /etc/nginx/conf.d/server1.conf
vi /etc/nginx/conf.d/server2.conf

1.3server1.conf

server {
    listen      192.168.1.124:80;
    server_name  localhost;
    location / {
        root   /opt/app/server1;
        index  server2.html;
    }
    error_page   500 502 503 504 /50x.html;
    error_page   404 /404x.html;
    location = /50x.html {
        root   /usr/share/nginx/html;
    }
    location = /404x.html {
        root  /usr/share/nginx/html;
    }
}

1.3server2.conf

server {
    listen      192.168.1.125:80;
    server_name  localhost;
    location / {
        root   /opt/app/server2;
        index  server2.html;
    }
    error_page   500 502 503 504 /50x.html;
    error_page   404 /404x.html;
    location = /50x.html {
        root   /usr/share/nginx/html;
    }
    location = /404x.html {
        root  /usr/share/nginx/html;
    }
}

1.4测试文件

mkdir /opt/app/server1
vi  /opt/app/server1/server1.html

<!DOCTYPE html>
<html>
<head>
<title>Welcome to nginx!</title>
<style>
html { color-scheme: light dark; }
body { width: 35em; margin: 0 auto;
font-family: Tahoma, Verdana, Arial, sans-serif; }
</style>
</head>
<body>
<h1>service1</h1>
</body>
</html>
​
mkdir /opt/app/server2
vi  /opt/app/server2/server2.html
<!DOCTYPE html>
<html>
<head>
<title>Welcome to nginx!</title>
<style>
html { color-scheme: light dark; }
body { width: 35em; margin: 0 auto;
font-family: Tahoma, Verdana, Arial, sans-serif; }
</style>
</head>
<body>
<h1>service2</h1>
</body>
</html>

1.4重启测试

systemctl restart nginx.service
http://192.168.1.125/
http://192.168.1.124/

 

2.主机多端口

# 文件在下面
vi /etc/nginx/conf.d/server1.conf
vi /etc/nginx/conf.d/server2.conf
​
firewall-cmd --zone=public --add-port=81/tcp --permanent 
firewall-cmd --zone=public --add-port=82/tcp --permanent 
firewall-cmd --reload
# 检查配置文件语法是否正确
nginx -tc /etc/nginx/nginx.conf
# 重启nginx
sudo systemctl restart nginx.service
​
http://192.168.1.124:81
http://192.168.1.124:82
​
# 查看再用的端口
ss -luntp
​
cp   LISTEN     0      128                                                                 *:81                                                                              *:*                   users:(("nginx",pid=1700,fd=6),("nginx",pid=1699,fd=6))
tcp   LISTEN     0      128                                                                 *:82     

 

2.1server1.conf

server {
    listen      81;
    server_name  localhost;
    location / {
        root   /opt/app/server1;
        index  server2.html;
    }
    error_page   500 502 503 504 /50x.html;
    error_page   404 /404x.html;
    location = /50x.html {
        root   /usr/share/nginx/html;
    }
    location = /404x.html {
        root  /usr/share/nginx/html;
    }
}

2.2server2.conf

server {
    listen      82;
    server_name  localhost;
    location / {
        root   /opt/app/server2;
        index  server2.html;
    }
    error_page   500 502 503 504 /50x.html;
    error_page   404 /404x.html;
    location = /50x.html {
        root   /usr/share/nginx/html;
    }
    location = /404x.html {
        root  /usr/share/nginx/html;
    }
}

3.多域名代理

# 修改主机host文件
192.168.1.124 1.nginx.cn
192.168.1.124 2.nginx.cn
​
# Win+R->C:\windows\System32\drivers\etc
# 记事本管理员权限,编辑hosts文件粘贴在最下面即可,或者复制到桌面然后在复制进去即可
​
# 文件在下面
vi /etc/nginx/conf.d/server1.conf
vi /etc/nginx/conf.d/server2.conf
​
# 检查配置文件语法是否正确
[root@localhost ~]# nginx -tc /etc/nginx/nginx.conf
nginx: the configuration file /etc/nginx/nginx.conf syntax is ok
nginx: configuration file /etc/nginx/nginx.conf test is successful
​
# 重启nginx
sudo systemctl restart nginx.service
​
1.nginx.cn
2.nginx.cn

3.1server1.conf

 

server {
    listen      80;
    server_name  1.nginx.cn;
    location / {
        root   /opt/app/server1;
        index  server2.html;
    }
    error_page   500 502 503 504 /50x.html;
    error_page   404 /404x.html;
    location = /50x.html {
        root   /usr/share/nginx/html;
    }
    location = /404x.html {
        root  /usr/share/nginx/html;
    }
}

3.2server2.conf

server {
    listen      80;
    server_name  2.nginx.cn;
    location / {
        root   /opt/app/server2;
        index  server2.html;
    }
    error_page   500 502 503 504 /50x.html;
    error_page   404 /404x.html;
    location = /50x.html {
        root   /usr/share/nginx/html;
    }
    location = /404x.html {
        root  /usr/share/nginx/html;
    }
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值