网站首页 > 技术文章 正文
在Linux中使用Nginx实现本地Web服务和Docker应用共用80端口
在现代开发中,多个应用程序和服务可能会共用同一个端口,尤其是对于 Web 应用,它们通常会监听 80端口。但是在同一台机器上运行多个应用时,如何避免端口冲突,并使得不同应用能够共享同一个 80端口,成为了一个常见的问题。通过 Nginx 反向代理,我们可以轻松实现本地Web服务和Docker容器共用 80端口 的需求。
目录
- 安装Nginx
- 配置本地Web服务
- 配置Docker应用
- 配置Nginx
- 重启Nginx并测试
- 总结
Step 1:安装Nginx
首先,我们需要在Linux系统中安装 Nginx,这是一个非常高效且广泛使用的Web服务器。我们以 Ubuntu 为例,使用 apt 包管理工具进行安装:
sudo apt update
sudo apt install nginx
解释:
- sudo apt update:更新系统中的软件包索引。
- sudo apt install nginx:安装 Nginx Web 服务器。
安装完成后,Nginx 会自动启动,您可以通过访问 http://localhost 来检查 Nginx 是否正常工作。
Step 2:配置本地Web服务
假设您已经在本地搭建了一个Web服务,如使用 Node.js 或 Python 等框架。为了避免和 80端口 冲突,我们将把本地Web服务的端口更改为 8080。
以Node.js为例:
- 找到应用的入口文件(例如 app.js 或 index.js)。
- 修改端口号为 8080:
const port = 8080;
app.listen(port, () => {
console.log(`Server is running on port ${port}`);
});
- 重启Node.js应用,使端口更改生效。
解释:
- 修改端口:通过将应用监听端口从 80 改为 8080,避免与系统默认的 80端口 冲突。
Step 3:配置Docker应用
假设您有一个 Docker 容器运行一个Web应用,并且这个容器也想监听 80端口。为了避免端口冲突,我们需要将容器的 80端口 映射到宿主机的 8081 端口。
在启动容器时,使用以下命令:
docker run -d -p 8081:80 your_docker_image
解释:
- -d:让容器在后台运行。
- -p 8081:80:将 Docker 容器的 80端口 映射到宿主机的 8081端口,避免冲突。
Step 4:配置Nginx
现在,我们已经有了两个应用:
- 本地Web服务(监听 8080 端口)。
- Docker应用(监听 8081 端口)。
为了让这两个应用共享 80端口,我们需要配置 Nginx 作为反向代理。Nginx 将接收到的 HTTP 请求转发到不同的后端服务,根据不同的 URL 路径区分。
编辑 Nginx 配置文件:
sudo nano /etc/nginx/sites-available/default
在配置文件中,添加以下内容:
server {
listen 80;
server_name your_domain_name; # 替换为你的域名或IP地址
# 本地Web服务
location / {
proxy_pass http://localhost:8080; # 将请求转发到本地Web服务的8080端口
}
# Docker Web应用
location /docker/ {
proxy_pass http://localhost:8081; # 将请求转发到Docker容器的8081端口
}
}
解析:
- listen 80;:指定Nginx监听 80端口。
- server_name:指定服务器的域名或IP地址,这里使用的是本地地址。
- location / {}:表示根路径的请求(例如 http://your_domain_name/),会转发到本地 Web 服务。
- location /docker/ {}:当请求路径为 /docker/ 时,Nginx 将请求转发到 Docker 容器的 8081端口。
这样配置后,您可以通过不同的路径来访问两个服务:
- 访问 http://your_domain_name/ 会访问本地 Web 服务。
- 访问 http://your_domain_name/docker/ 会访问 Docker 容器中的 Web 应用。
Step 5:重启Nginx并测试
完成配置后,您需要重启 Nginx 服务,使配置生效。
sudo service nginx restart
解释:
- sudo service nginx restart:重启 Nginx 服务以加载新的配置文件。
测试:
- 在浏览器中访问 http://your_domain_name/,查看是否可以成功访问本地Web服务。
- 访问 http://your_domain_name/docker/,确认 Docker 应用是否可以通过 Nginx 正常访问。
Step 6:总结
通过 Nginx 的反向代理配置,我们成功实现了 本地Web服务 和 Docker应用 共用同一个 80端口。这一配置使得用户可以通过访问不同的 URL 路径来访问不同的服务,从而避免了端口冲突,并简化了服务管理。
配置总结表:
步骤 | 说明 | 命令/配置文件 |
安装Nginx | 使用 apt 安装 Nginx Web 服务器 | sudo apt install nginx |
配置本地Web服务 | 修改本地Web服务端口为 8080 | 修改应用配置文件中的端口为 8080 |
配置Docker应用 | 将Docker容器的端口映射为 8081 | docker run -d -p 8081:80 your_docker_image |
配置Nginx | 编辑 Nginx 配置文件,将请求转发到不同的服务 | /etc/nginx/sites-available/default |
重启Nginx | 重启 Nginx 服务,使配置生效 | sudo service nginx restart |
通过这种方式,您可以高效地管理多个应用,并通过单一的入口(80端口)提供服务,从而优化了系统架构,提升了开发和运维的效率。
猜你喜欢
- 2025-01-15 IT运维面试问题总结-运维(Ceph、Docker、Apache、Nginx等
- 2025-01-15 用Nginx反向代理Docker化你的IP地理定位服务
- 2025-01-15 zabbix通过自定义脚本监控Linux服务、docker nginx容器,图文详细
- 2025-01-15 将.NET Core 微服务和 Kubernetes 、 NGINX、Docker进行部署集成
- 2025-01-15 docker环境的nginx,配置了一个反向代理后端服务,访问 404,解决
- 2025-01-15 Nginx Proxy Manager - Docker 建站最佳伴侣
- 2025-01-15 Docker实战-使用NGINX实现4层的负载均衡
- 2025-01-15 Nginx日志切割方法(包含docker容器中nginx日志的切割)
- 2025-01-15 docker安装nginx搭建简单文件共享服务
- 2025-01-15 Docker部署web服务器之Nginx与PHP联合篇(三)
你 发表评论:
欢迎- 最近发表
- 标签列表
-
- oraclesql优化 (66)
- 类的加载机制 (75)
- feignclient (62)
- 一致性hash算法 (71)
- dockfile (66)
- 锁机制 (57)
- javaresponse (60)
- 查看hive版本 (59)
- phpworkerman (57)
- spark算子 (58)
- vue双向绑定的原理 (68)
- springbootget请求 (58)
- docker网络三种模式 (67)
- spring控制反转 (71)
- data:image/jpeg (69)
- base64 (69)
- java分页 (64)
- kibanadocker (60)
- qabstracttablemodel (62)
- java生成pdf文件 (69)
- deletelater (62)
- com.aspose.words (58)
- android.mk (62)
- qopengl (73)
- epoch_millis (61)
本文暂时没有评论,来添加一个吧(●'◡'●)