nginx-代理多个服务

news/2024/11/7 22:49:22/

目录

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 a1: lo: <LOOPBACK,UP,LOWER_UP> mtu 65536 qdisc noqueue state UNKNOWN group default qlen 1000link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00inet 127.0.0.1/8 scope host lovalid_lft forever preferred_lft foreverinet6 ::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 1000link/ether 08:00:27:8a:00:a7 brd ff:ff:ff:ff:ff:ffinet 192.168.1.124/24 brd 192.168.1.255 scope global noprefixroute dynamic enp0s3valid_lft 988sec preferred_lft 988secinet6 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 a1: lo: <LOOPBACK,UP,LOWER_UP> mtu 65536 qdisc noqueue state UNKNOWN group default qlen 1000link/loopback 00:00:00:00:00:00 brd 00:00:00:00:00:00inet 127.0.0.1/8 scope host lovalid_lft forever preferred_lft foreverinet6 ::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 1000link/ether 08:00:27:8a:00:a7 brd ff:ff:ff:ff:ff:ffinet 192.168.1.124/24 brd 192.168.1.255 scope global noprefixroute dynamic enp0s3valid_lft 6895sec preferred_lft 6895secinet 192.168.1.125/24 scope global secondary enp0s3valid_lft forever preferred_lft foreverinet6 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;}
}


http://www.ppmy.cn/news/45980.html

相关文章

救命,我好像发现了测试工程师面试通关秘籍

一、自我介绍 &#xff08;自我介绍不局限于下面模板&#xff0c;灵活表达&#xff09; 面试官你好&#xff0c;我叫xxx&#xff0c;今年xx岁&#xff0c;家乡是xx省xx市。20xx年毕业后一直从事软件测试工作&#xff0c;到现在已经x年了。 目前为止&#xff0c;经历过x家公司…

2023-04-13 工作记录--CSS/JS-ios 文本渐变色 和 文本超出省略号处理 共用时,出现省略号未显示问题

CSS/JS-ios 文本渐变色 和 文本超出省略号处理 共用时&#xff0c;出现省略号未显示问题 一、前言 ⭐️ 最近写项目&#xff0c;发现一个bug&#xff1a;ios 文本渐变色 和 文本超出省略号处理 共用时&#xff0c;出现省略号未显示问题&#xff0c;如下图&#xff1a;图1是非i…

yolov5训练自己的目标检测模型

yolov5训练自己的目标检测模型 1.克隆项目并配置环境 1.1克隆项目 进入GitHub下载yolov5源码 点此进入 选择分支v5.0&#xff0c;并下载源码 anaconda激活相应环境 activate pytorch进入项目存放的地址 E: cd yolov5-master1.2 yolov5项目结构 ├── data&#xff1a;主…

Vue.js 2.0 状态管理

类 Flux 状态管理的官方实现 由于多个状态分散的跨越在许多组件和交互间各个角落&#xff0c;大型应用复杂度也经常逐渐增长。为了解决这个问题&#xff0c;Vue 提供 vuex&#xff1a; 我们有受到 Elm 启发的状态管理库。vuex 甚至集成到 vue-devtools&#xff0c;无需配置即可…

家用洗地机怎么选?洗地机选购技巧分享

洗地机是一种专业的清洁设备&#xff0c;广泛应用于商业和工业领域。它可以有效地清洗和护理各种硬表面地板&#xff0c;如混凝土、大理石、瓷砖和木地板等。洗地机不仅能够提高清洁效率&#xff0c;还可以使地面更加卫生、美观和持久。而且大部分洗地机还拥有一键自清洁、除菌…

Insomnia 简单使用方法

文章目录 1. 新建工程2. 新建若干文件夹3. 设置环境变量4. 授权以及进行请求的链式调用 (chaining requests)4. 1 解决办法 14. 2 解决办法 2 Insomnia 同 Postman&#xff0c; 用于测试后端 endpoint&#xff0c;很容易使用。 使用步骤如下&#xff1a; 1. 新建工程 2. 新建若…

FreeRTOS 的命名规则

初学 FreeRTOS 的用户对其变量和函数的命名比较迷惑&#xff0c;下面专门做一下介绍&#xff1a; ◆ 变量 ⚫ uint32_t 定义的变量都加上前缀 ul。u 代表 unsigned 无符号&#xff0c;l 代表 long 长整型。 ⚫ uint16_t 定义的变量都加上前缀 us。u 代表 unsigned 无符号&#…

2、Web前端学习规划:HTML - 学习规划系列文章

今天先写Web前端最基本的语言&#xff1a;HTML。目前已经到了HTML5版本&#xff0c;作为Web基本语言&#xff0c;笔者认为这个是最先需要学习的语言。 1、 简介&#xff1b; HTML(HyperText Markup Language)是一种用于创建网页的标记语言。它使用标签和属性来描述网页的结构和…