【Docker】安装Nginx容器并部署前后端分离项目

这篇具有很好参考价值的文章主要介绍了【Docker】安装Nginx容器并部署前后端分离项目。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

【Docker】安装Nginx容器并部署前后端分离项目,Docker实战,docker,容器,运维

🎉🎉欢迎来到我的CSDN主页!🎉🎉

🏅我是Java方文山,一个在CSDN分享笔记的博主。📚📚

🌟推荐给大家我的专栏《Docker实战》。🎯🎯

👉点击这里,就可以查看我的主页啦!👇👇

Java方文山的个人主页

🎁如果感觉还不错的话请给我点赞吧!🎁🎁

💖期待你的加入,一起学习,一起进步!💖💖

【Docker】安装Nginx容器并部署前后端分离项目,Docker实战,docker,容器,运维

一、Nginx的简介

Nginx是一个高性能的开源Web服务器和反向代理服务器,也可以用作负载均衡器、HTTP缓存、邮件代理(IMAP/POP3)等。它最初由俄罗斯的工程师Igor Sysoev开发,并于2004年首次公开发布。

Nginx因其简洁、高效和可靠的特点而备受欢迎。相比传统的Apache服务器,Nginx使用更少的系统资源,可以处理更多的并发连接。它采用事件驱动的异步架构,能够有效地处理高并发请求和大量的并行连接。

Nginx的主要特点包括:

  1. 高性能:Nginx采用了非阻塞的事件驱动模型,在同等硬件条件下能够处理更多的并发连接,具有出色的性能表现。

  2. 轻量级:Nginx的代码精简,内存占用较少,启动速度快,适用于资源受限的环境。

  3. 反向代理:Nginx可以作为反向代理服务器,接收客户端请求并将其转发给后端服务器,实现负载均衡和提高网站性能。

  4. 静态文件服务:Nginx可以快速、可靠地提供静态文件的访问服务,减轻后端应用服务器的负载。

  5. 动态内容处理:Nginx提供了强大的模块化架构,可以与各种后端应用服务器(如PHP、Python、Node.js)集成,处理动态内容的访问请求。

  6. 高可靠性:Nginx具备高度稳定性和可靠性,在大规模的互联网应用中被广泛使用。

【Docker】安装Nginx容器并部署前后端分离项目,Docker实战,docker,容器,运维

二、创建Mysql容器

创建mysql之前需要做一个事情,mysql需要一个my.cnf的配置文件,目前我们还没有所以需要在宿主机上创建一个将该文件放入到目录中

mkdir  -p /mysql/{conf,data}

【Docker】安装Nginx容器并部署前后端分离项目,Docker实战,docker,容器,运维

为了让我们的容器之间可以相互访问,所以我们创建一个网络

docker network create --subnet 172.18.0.0/16 --gateway 172.18.1.1 net

 现在创建容器就需要为它指定我们的自定义网络

docker run \
--name m1 \
-v /mysql/conf/my.cnf:/etc/my.cnf \
-v /mysql/data:/var/lib/mysql \
--privileged=true \
-e MYSQL_ROOT_PASSWORD=123456 \
--net net \
--ip 172.18.0.1 \
-d mysql/mysql-server:5.7

进入我们的mysql容器进行登录

docker exec -it m1 bash


mysql -uroot -p

【Docker】安装Nginx容器并部署前后端分离项目,Docker实战,docker,容器,运维

 登录成功以后,我们现在需要一个账户进行远程连接所以创建一个账户并赋予权限

grant all on *.* to root@'%' identified by '密码'

【Docker】安装Nginx容器并部署前后端分离项目,Docker实战,docker,容器,运维

创建所需的数据库或者使用远程工具连接创建一下也可以,我这里就一张表就不那么麻烦了

create database shop

【Docker】安装Nginx容器并部署前后端分离项目,Docker实战,docker,容器,运维

在mysql/data目录下将sql脚本放入到里面去,因为前面做了目录挂载所以容器也会有这个脚本

【Docker】安装Nginx容器并部署前后端分离项目,Docker实战,docker,容器,运维

use shop
 
source /var/lib/mysql/book.sql

【Docker】安装Nginx容器并部署前后端分离项目,Docker实战,docker,容器,运维

查询表验证一下

【Docker】安装Nginx容器并部署前后端分离项目,Docker实战,docker,容器,运维

没有问题退出后记得重启一下docker restart m1

三、创建Tomcat容器

为了切合我们的主题Nginx负载均衡,所以这里肯定不止创建一个tomcat容器,但是每次创建一个容器就需要手动启动项目太麻烦了,我们就手动创建一个镜像

vim Dockerfile

在Dockerfile文件下进行编辑 并指定数据库地址为m1

FROM openjdk
WORKDIR /project
COPY spring.jar /project
CMD java -jar spring.jar  --mysql.addr=m1

【Docker】安装Nginx容器并部署前后端分离项目,Docker实战,docker,容器,运维

构建镜像

docker build  -t spring:v1.0 .

【Docker】安装Nginx容器并部署前后端分离项目,Docker实战,docker,容器,运维 镜像构建好了,接下来根据我们的镜像创建并启动容器

docker run -itd --name s1 --net net --ip 172.18.0.101 spring:v1.0
docker run -itd --name s2 --net net --ip 172.18.0.102 spring:v1.0
docker run -itd --name s3 --net net --ip 172.18.0.103 spring:v1.0

【Docker】安装Nginx容器并部署前后端分离项目,Docker实战,docker,容器,运维

我们可以查看日志看是否启动成功

docker logs s1

【Docker】安装Nginx容器并部署前后端分离项目,Docker实战,docker,容器,运维

我们可以测试一下看tomcat容器是否访问mysql容器

【Docker】安装Nginx容器并部署前后端分离项目,Docker实战,docker,容器,运维

四、创建Nginx容器

首先我们需要一个nginx镜像

docker pull nginx

【Docker】安装Nginx容器并部署前后端分离项目,Docker实战,docker,容器,运维

我们肯定是需要通过nginx负载均衡和动静分离的,但是容器内不能修改文件,所以我们继续使用目录挂载的形式

①创建nginx的配置文件目录并将配置文件放入

mkdir -p  /soft/nginx/conf.d

【Docker】安装Nginx容器并部署前后端分离项目,Docker实战,docker,容器,运维

 注意:这里的服务器的集群和我们的Tomcat容器IP一致

#服务器的集群
upstream tomcatList {  
    server 172.18.0.101:8080 weight=1; 
    server 172.18.0.102:8080 weight=1; 
    server 172.18.0.103:8080 weight=1; 
} 

②同时将我们的静态文件放入

【Docker】安装Nginx容器并部署前后端分离项目,Docker实战,docker,容器,运维

根据镜像创建容器

docker run -itd \
--name n1 \
-v /soft/nginx/conf.d:/etc/nginx/conf.d \
-v /soft/nginx/html:/etc/nginx/html \
-p 80:80 \
--net net \
--ip 172.18.0.105 \
nginx

现在我们访问一下看看,是可以进行访问的

【Docker】安装Nginx容器并部署前后端分离项目,Docker实战,docker,容器,运维

但是这里还有一个小小的问题如果我们发送请求带有www.zkingedu.com就访问不了所以我们要加映射关系,找到C:\Windows\System32\drivers\etc\hosts添加映射关系【Docker】安装Nginx容器并部署前后端分离项目,Docker实战,docker,容器,运维

因为这里需要的是www.zkingedu.com,我们加的时候就写这个。

【Docker】安装Nginx容器并部署前后端分离项目,Docker实战,docker,容器,运维

现在通过www.zkingedu.com也是可以访问的【Docker】安装Nginx容器并部署前后端分离项目,Docker实战,docker,容器,运维

至此根据nginx的动静分离项目就部署完了

【Docker】安装Nginx容器并部署前后端分离项目,Docker实战,docker,容器,运维

到这里我的分享就结束了,欢迎到评论区探讨交流!!

💖如果觉得有用的话还请点个赞吧 💖

【Docker】安装Nginx容器并部署前后端分离项目,Docker实战,docker,容器,运维文章来源地址https://www.toymoban.com/news/detail-816996.html

到了这里,关于【Docker】安装Nginx容器并部署前后端分离项目的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 超详细实战Docker+Jenkins部署生产环境前后分离项目

    环境: 本文的所有服务都部署在阿里云ECS服务器(2H4G)上面, 前后端分离项目使用gitee上面的开源项目若依(ruoyi-vue)为例, 从零开始教学 1、先停止服务器, 再重装系统, 用最干净的系统从头教学, 保证大家环境一样 2、系统选择Centos最新版本, 然后开始安装, 等待安装完成 3、安装完

    2024年01月17日
    浏览(39)
  • 【Linux】Nginx安装使用负载均衡及动静分离(前后端项目部署),前端项目打包

             Nginx 是一款高性能的 Web 服务器和 反向代理服务器 ,也可以充当负载均衡器、HTTP 缓存和安全防护设备。它的特点是内存占用小、稳定性高、并发性强、易于扩展,因此在互联网领域得到了广泛的使用。 总结出以下三点: 负载均衡 :流量分摊 反向代理 :处理外

    2024年02月06日
    浏览(44)
  • 前后端分离项目(gin+gorm+vue3)腾讯云部署详细教程(Xshell安装及使用,go,mysql,nginx安装及配置)

    1. 购买服务器 进入腾讯云官网点击最新活动,进入云+校园专区,我购买的是第一个 购买完成后,进入控制台,云产品选择轻量应用服务器,即可查看到自己的服务器,记住自己的公网IP 2. 重置密码 点击进入服务器详情,初次使用需重置密码 点击重置密码按提示操作即可,

    2024年02月06日
    浏览(62)
  • Nginx同一端口部署多个前后端分离的vue项目

    要用nginx容器部署多个前端项目可以采用监听端口,和基于location配置两种方法, 我的nginx是使用docker部署的,启动的时候没有开多余的端口,所以采用location配置 一个server下根据根路径不同分别代理访问不同项目。 下面操练起来,问:把大象放冰箱?总共需要几步:三步!

    2024年02月02日
    浏览(42)
  • Linux-----nginx的简介,nginx搭载负载均衡以及nginx部署前后端分离项目

    目录 nginx的简介 是什么 nginx的特点以及功能 Nginx负载均衡 下载  安装  负载均衡 Nginx 是一个高性能的开源Web服务器和反向代理服务器。它的设计目标是为了解决C10k问题,即在同一时间内支持上万个并发连接。 Nginx采用事件驱动的异步架构,能够高效地处理大量并发请求,同

    2024年02月06日
    浏览(42)
  • 若依前后端分离项目docker部署

    1.centos 7 2.docker 3.mysql5.x 8.x 4.redis 5.nginx 前往 Gitee 下载页面(https://gitee.com/y_project/RuoYi-Vue (opens new window))下载解压到工作目录 3.1 后端 1.下载代码到本地后,解压完成,用idea打开项目 2.创建数据库:ry-vue 3.在创建好数据库后,运行以下两个sql文件生成数据表(quartz.sql、ry_202208

    2024年02月05日
    浏览(42)
  • Unbutu系统-Docker安装、JDK环境配置,Docker常用指令、Docker安装MySQL、Redis、Tomcat、Nginx,前端后分离项目部署

    目录 1、防火墙 1.1、查看防火墙状态 1.2、开启防火墙 1.3、关闭防火墙 1.4、重启防火墙 1.5、查看防火墙版本 2、安装JDK 2.1、官网下载tar包 2.3、解压tar.gz文件 2.4、配置环境变量 2.4.1、查看安装路径 2.4.2、设置环境变量 2.4.3、执行该让环境变量生效 2.4.4、查看JDK版本 3、Docker

    2024年02月04日
    浏览(53)
  • Windows服务器,通过Nginx部署VUE+Django前后端分离项目

    基本说明 安装 Nginx 部署 VUE 前端 部署 Django 后端 Django admin 静态文件(CSS,JS等)丢失的问题 总结 本文介绍了在 windows 服务器下,通过 Nginx 部署 VUE + Django 前后端分离项目。本项目前端运行在 80 端口,服务器端运行在 8000 端口。因此本项目使用 Django 的 runserver 命令进行部署

    2024年02月05日
    浏览(58)
  • 手把手从安装本地虚拟机,基于docker,部署springboot+vue项目(若依框架前后端分离版本演示),基于openjdk的dockerfile

    部署环境提供vm16,和centos7,其中把镜像改成.iso文件就可以了 阿里云链接: https://www.alipan.com/s/BTnpjuHWtEp 为什么用阿里云,不限速啊,秉持着开源白嫖的精神 新建虚拟机 选择镜像 创建用户 设置虚拟机存存放位置 默认下一步 自定义硬件 选了扩大一下内存,扩不扩无所谓 检查

    2024年01月16日
    浏览(66)
  • k8s+docker部署前后端分离项目

    目录 环境准备 1、k8s集群 2、harbor远程仓库 部署前后端分离项目 生成vue镜像(所有子节点都需要操作) 1、将前端vue项目打包得到dist.zip 2、创建nginx的配置文件default.conf 3、创建Dockerfile文件 4、生成vue镜像 5、打标签 6、推到harbor仓库 7、查看生成的镜像 生成jar包镜像(所有子

    2023年04月08日
    浏览(32)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包