Docker 部署项目,真的太雅了~

news2024/10/24 3:23:36

大家好,我是南城余! 最近在找工作,正好手里有台服务器,之前项目上线用的宝塔部署项目上线,在公司实习了一年后,发现如今项目部署都使用的是容器化部署方案,也就是类似于和 Docker 一样的部署方案。今天一篇文章带大家用 Docker 部署前后端项目。

前端分别用域名和无域名实现了下。具体可以见下方步骤描述: <a name="LkpKO"></a>

1、后端

IDEA 打包,如下图:

image.png

<a name="zFeJ5"></a>

1.1、dockerfile

在任意目录下创建 Dockerfile 文件,如 /app,并上传这两个文件。

image.png

# 使用官方 Java 镜像作为基础镜像
FROM openjdk:8-jdk
​
# 设置容器内的工作目录
WORKDIR /app
​
# 复制本地文件到容器内的工作目录
COPY ./*.jar /app/app.jar
​
# 指定容器启动后执行的命令,这里使用 java 命令运行 Spring Boot 应用
CMD ["java", "-jar", "app.jar"]
​
# 暴露端口,如果 Spring Boot 应用使用了不同的端口,需要修改
EXPOSE 8001

<a name="T4Owj"></a>

1.2、构建镜像包

创建完成后,用docker build -t techmindwave-backend:1.0 .构建镜像包。 <a name="K9ImQ"></a>

1.3、启动容器

docker run -p 8001:8001 -d techmindwave-backend:1.0

此处,按照上方已经成功部署 若是云服务器,记得开放相应端口

image.png

<a name="RLmq5"></a>

2、前端(无域名)

<a name="K7oh3"></a>

2.1、Dockerfile

nginx.conf

# 使用官方 Nginx 镜像作为基础镜像
FROM nginx:latest
​
# 将本地的 Nginx 配置文件复制到镜像的配置文件目录
COPY ./nginx.conf /etc/nginx/nginx.conf
​
# 将构建好的前端静态文件复制到 Nginx 的 www 目录下
COPY ./dist /usr/share/nginx/html
​
events {}
​
http {
    server {
        listen 800; # 监听 800 端口
    ## 添加上这个配置
​
    location / {
        try_files $uri $uri/ @router;
        index index.html;
      }
​
    location @router {
        rewrite ^.*$ /index.html last;
      }
​
        # 静态文件服务
        root /usr/share/nginx/html;
        index index.html;
​
        # 配置反向代理
        location /api {
            proxy_pass http://106.14.202.122:8001/;  # 将请求转发到指定地址
            proxy_set_header Host $host;
            proxy_set_header X-Real-IP $remote_addr;
            proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
            proxy_set_header X-Forwarded-Proto $scheme;
        }
    }
}
​

<a name="z5Pm0"></a>

2.2、构建镜像包

创建完成后,用docker build -t techmindwave-frontend:1.0 .构建镜像包。 <a name="HzZbg"></a>

2.3、启动容器

docker run -p 800:800 -d techmindwave-frontend:1.0

<a name="LluvQ"></a>

3、前端(有域名)

<a name="yS10S"></a>

3.1、Dockerfile
# 使用官方 Nginx 镜像作为基础镜像
FROM nginx:latest
​
# 将本地的 Nginx 配置文件复制到镜像的配置文件目录
COPY ./nginx.conf /etc/nginx/nginx.conf
​
# 将构建好的前端静态文件复制到 Nginx 的 www 目录下
COPY ./dist /usr/share/nginx/html
​
COPY ./default.conf /etc/nginx/conf.d/default.conf
​
#将ssl证书复制到容器中
copy ./certificates /etc/nginx/ssl
​
​
# Expose ports 80 and 443
EXPOSE 80
EXPOSE 443

** default.conf **

server {
    listen 80;
    server_name techmindwave.nanchengyu.cn;
​
    # Redirect HTTP to HTTPS
    return 301 https://$host$request_uri;
}
​
server {
    listen 443 ssl;
    server_name techmindwave.nanchengyu.cn;
​
    ssl_certificate /etc/nginx/ssl/nginx.pem;
    ssl_certificate_key /etc/nginx/ssl/nginx.key;
​
    ssl_protocols TLSv1.2 TLSv1.3;
    ssl_ciphers HIGH:!aNULL:!MD5;
​
    root /usr/share/nginx/html;
    index index.html;
​
    location / {
        try_files $uri $uri/ /index.html;
    }
    # 配置反向代理
     location /api {
            proxy_pass http://106.14.202.122:8001/;  # 将请求转发到指定地址
            proxy_set_header Host $host;
            proxy_set_header X-Real-IP $remote_addr;
            proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
            proxy_set_header X-Forwarded-Proto $scheme;
        }
}
​

nginx.conf

user  nginx;
worker_processes  auto;
​
error_log  /var/log/nginx/error.log warn;
pid        /var/run/nginx.pid;
​
events {
    worker_connections  1024;
}
​
http {
    include       /etc/nginx/mime.types;
    default_type  application/octet-stream;
​
    log_format  main  '$remote_addr - $remote_user [$time_local] "$request" '
                      '$status $body_bytes_sent "$http_referer" '
                      '"$http_user_agent" "$http_x_forwarded_for"';
​
    access_log  /var/log/nginx/access.log  main;
​
    sendfile        on;
    keepalive_timeout  65;
​
    include /etc/nginx/conf.d/*.conf;
}
​

<a name="y1LHf"></a>

3.2、构建镜像包

创建完成后,用docker build -t techmindwave-frontend:3.0 .构建镜像包。 <a name="ZgYtF"></a>

3.3、启动容器
docker run -d -p 80:80 -p 443:443 \
    -v ./certificates/nginx.pem:/etc/nginx/ssl/nginx.pem \
    -v ./certificates/nginx.key:/etc/nginx/ssl/nginx.key \
    --name my-nginx-container techmindwave-frontend:3.0

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1843022.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

PFC 离散元数值模拟仿真技术与应用

近几年&#xff0c;随着计算能力的提高和算法的优化&#xff0c;离散元仿真技术得到了快速发展&#xff0c;并在学术界产生了大量研究成果。在 PFC 离散元计算中无需给定材料的宏观本构关系和对应的参数&#xff0c;这些传统的参数和力学特性在程序中可以自动得到。据调查&…

【绝对有用】刚刚开通的GPT-4o计算这种数学题目出现问题了

欢迎关注如何解决以上问题的方法&#xff1a;查看个人简介中的链接的具体解决方案

Matlab数学建模实战应用:案例2 - 传染病传播

目录 前言 一、问题分析 二、模型建立 三、Matlab代码实现 四、模型验证 灵敏度分析 五、模型应用 实例总结 总结 前言 传染病传播模型是公共卫生和流行病学的重要研究内容&#xff0c;通过数学建模可以帮助我们理解传染病的传播规律和趋势&#xff0c;以便制定有效的…

【2024最新华为OD-C/D卷试题汇总】[支持在线评测] 机器人搬砖(100分) - 三语言AC题解(Python/Java/Cpp)

&#x1f36d; 大家好这里是清隆学长 &#xff0c;一枚热爱算法的程序员 ✨ 本系列打算持续跟新华为OD-C/D卷的三语言AC题解 &#x1f4bb; ACM银牌&#x1f948;| 多次AK大厂笔试 &#xff5c; 编程一对一辅导 &#x1f44f; 感谢大家的订阅➕ 和 喜欢&#x1f497; &#x1f…

全网最易懂,开源时序数据库influxDB,实际应用评测

前言&#xff1a; 当今是信息爆炸的时代&#xff0c;在处理高频数据时&#xff0c;关系型数据库oracle/mysql明显表现出乏力&#xff0c;因秒级、毫秒级高频数据&#xff0c;分分钟可以把关系型数据库的表塞爆。在日常生活工作中&#xff0c;我们经常会遇到哪些需要高频分析的场…

令人震撼的人类智慧的科学领域-AI技术

AI&#xff0c;全称为人工智能&#xff08;Artificial Intelligence&#xff09;&#xff0c;是一门致力于让机器模仿人类智慧的科学领域。其核心技术涵盖了机器学习、自然语言处理、计算机视觉及专家系统等多个方面。AI旨在开发能够感知环境、进行逻辑推理、自主学习并做出决策…

Leetcode 力扣124. 二叉树中的最大路径和 (抖音号:708231408)

二叉树中的 路径 被定义为一条节点序列&#xff0c;序列中每对相邻节点之间都存在一条边。同一个节点在一条路径序列中 至多出现一次 。该路径 至少包含一个 节点&#xff0c;且不一定经过根节点。 路径和 是路径中各节点值的总和。 给你一个二叉树的根节点 root &#xff0c…

基于JSP的二手交易平台网站

开头语&#xff1a; 你好&#xff0c;我是计算机专业的学长猫哥。如果你对二手交易平台感兴趣或有开发相关需求&#xff0c;欢迎联系我&#xff0c;我的联系方式见文末。 开发语言&#xff1a;Java 数据库&#xff1a;MySQL 技术&#xff1a;JSP技术 工具&#xff1a;ECLI…

vue3 antdv Select 实现输入关键词,通过服务器去查询数据,并显示到表格中的实现思路。

实现思路&#xff1a; 1&#xff09;输入关键词&#xff0c;通过Select的查询事件&#xff08;onSearch&#xff09;来到服务器查询数据。 2&#xff09;根据查询到的数据显示到表格中&#xff0c;然后通过表格的&#xff08;cellClickEvent&#xff09;事件来选择相关的用户…

第四届人工智能、机器人和通信国际会议(ICAIRC 2024)

第四届人工智能、机器人和通信国际会议&#xff08;ICAIRC 2024&#xff09; 2024 4th International Conference on Artificial Intelligence, Robotics, and Communication 2024年12月27-29日 | 中国厦门 重要信息 会议官网&#xff1a;www.icairc.net 录用通知时间&…

视觉应用线扫相机速度反馈(倍福CX7000PLC应用)

运动控制实时总线相关内容请参考运动控制专栏,这里不再赘述 1、运动控制常用单位u/s运动控制单位[u/s]介绍_运动控制 unit是什么单位-CSDN博客文章浏览阅读176次。运动控制很多手册上会写这样的单位,这里的u是英文单词unit的缩写,也就是单位的意思,所以这里的单位不是微米…

阿里云服务器提醒漏洞要不要打补丁?

我们自己用的电脑一旦发现漏洞&#xff0c;往往是第一时间进行打补丁重启等等&#xff0c;但是作为服务器而言&#xff0c;往往没有这个习惯&#xff0c;为什么&#xff1f;因为害怕服务器打补丁以后&#xff0c;重启后出现打不开的情况&#xff0c;毕竟稳定的运行似乎在这种情…

免费企业级日志采集工具

免费试用下载: Gitee下载 最新版本 优势: A. 开箱即用. 解压直接运行.不需额外安装. B. 批管理设备. 设备配置均在后台管理. C. 无人值守 客户端自启动,自更新. D. 稳定安全. 架构简单,内存占用小,通过授权访问.

rust数据类型

一&#xff0c;基本类型 1&#xff0c;基本类型 &#xff08;1&#xff09;整数类型 let x111_222_3334;let y:u161123; 整数默认是i32类型&#xff0c;整数中间的下划线可以忽略。 &#xff08;2&#xff09;浮点数 在 Rust 中浮点类型数字也有两种基本类型&#xff1a; …

停车场防逃费设备有哪些,捷曜超眸相机怎么样,有哪些功能?

在当今快速发展的城市交通环境中&#xff0c;车场管理面临着诸多挑战&#xff0c;其中防逃费现象尤为突出。频繁的逃费行为不仅给车场运营带来了经济损失&#xff0c;也严重影响了停车场的正常秩序。对于车场防逃费方案中&#xff0c;超眸相机&#xff0c;以其尖端的高清成像技…

企业微信集成策略:打破壁垒,驱动企业数字化转型

随着全球化和数字化的快速推进&#xff0c;企业如何在激烈的市场竞争中脱颖而出&#xff0c;成为每个企业家和决策者关注的焦点。腾讯推出的企业微信&#xff0c;作为一款集沟通、协作、管理于一体的企业通讯与办公工具&#xff0c;正逐步成为企业数字化转型的得力助手。NetFar…

类型“Element”上不存在属性“ondragstart”

先上一下代码&#xff1a; //初始化拖动源事件function initDragSourceNode() {const moveDom document.querySelector(.drag); //拖动元素// console.log(moveDom:, moveDom);moveDom!.ondragstart function (e) {// console.log(拖动开始);};moveDom.ondrag function (e)…

CRMEB 多门店安装系统配置清单

系统在安装完成之后&#xff0c;需要对系统进行一系列的配置&#xff0c;才能正常使用全部的功能&#xff0c;以下是官方整理的配置清单

SEO之预估流量及价值(二)

初创企业搭建网站的朋友看1号文章&#xff1b;想学习云计算&#xff0c;怎么入门看2号文章谢谢支持&#xff1a; 1、我给不会敲代码又想搭建网站的人建议 2、新手上云 &#xff08;接上一篇。。。。&#xff09; 2、点击率 搜索结果页面各排名位置点击率也不精确。前面介绍的…

【第13章】进阶调试思路:如何安装复杂节点IP-Adapter?(安装/复杂报错/节点详情页/精读)ComfyUI基础入门教程

🎈背景 IP-Adapter这个名字,大家可能听说过,可以让生成的结果从参考图中学习人物、画风的一致性,在目前是比较实用的一个节点,广泛的用于照片绘制、电商作图等方面。 但同时,这个节点也是比较难安装的一个节点。 所以,这节课,我们就通过一个案例,来学习如何在Comf…