Docker安装MySQL、nginx并且部署SpringBoot项目前后端(超详细版)_docker desktop 整合 nginx 和spring-程序员宅基地

技术标签: spring boot  容器  SpringBoot3.0 从入门到精通  Doker  docker  

注意:下面的教程主要是针对 Centos7 的,如果使用的其他发行版会有细微的差别,请查看官方文档。


一、安装Docker

1.卸载旧版

  • 首先如果系统中已经存在旧的Docker,则先卸载:
    yum remove docker \
    	docker-client \
    	docker-client-latest \
    	docker-common \
    	docker-latest-logrotate \
    	docker-logrotate \
    	docker-engine
    

2.配置Docker的yum库

  • 首先安装一个yum工具

    yum install -y yum-utils
    
  • 安装成功后,执行命令,配置Dockeryum源

    yum-config-manager --add-repo https://download.docker.com/linux/centos/docker-ce.repo
    

3.安装Docker

  • 安装Docker
    yum install -y docker-ce docker-ce-cli containerd.io docker-buildx-plugin docker-compose-plugin
    docker --version
    

4.设置开机自启动

  • 设置Docker开机自启动,并且重启
    systemctl enable docker
    systemctl restart docker
    

5.配置镜像加速

  • 这个也可以不用配置,只是让下载镜像的速度更快而已。
  • 这里需要注册一个阿里云的账号,每个人的地址都是唯一的。
    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述

二、安装MySQL容器

  • 创建MySQL文件的存放位置
    mkdir -p ~/dev/mysql
    cd ~/dev/mysql
    mkdir data
    mkdir conf
    mkdir init
    mkdir file
    ll
    cd ~   
    
  • 初始化SQL脚本放置在 init 目录下(没有可以不放)
  • 注意:这个只有在第一次创建MySQL容器的时候才会初始化,并且一定要在SQL脚本文件中选择database。
    在这里插入图片描述
  • 安装MySQL镜像
    docker run -d \
    --name mysql \
    -p 3306:3306 \
    -e TZ=Asia/Shanghai \
    -e MYSQL_ROOT_PASSWORD=123456 \
    -v /root/dev/mysql/data:/var/lib/mysql \
    -v /root/dev/mysql/init:/docker-entrypoint-initdb.d \
    -v /root/dev/mysql/conf:/etc/mysql/conf.d \
    -v /home/dev/mysql/file:/var/lib/mysql-files \
    mysql
    
  • 创建一个网络并且将MySQL加入网络中
    docker network create GDB
    docker network connect GDB mysql
    

三、安装Nginx容器

1.创建Nginx配置文件

  • 启动前需要先创建 Nginx 外部挂载的配置文件(~/dev/nginx/conf/nginx.conf)
  • 之所以要先创建,是因为 Nginx 容器本身只存在 etc/nginx 目录,本身就不创建 nginx.conf 文件,当服务器和容器都不存在 nginx.conf 文件时,执行启动命令的时候 dokcer 会将 nginx.conf 作为目录创建,这并不是我们想要的结果。
    # 创建挂载目录
    mkdir -p ~/dev/nginx/conf
    mkdir -p ~/dev/nginx/log
    mkdir -p ~/dev/nginx/html
    
  • 将容器中的 nginx.conf 文件和conf.d文件夹复制到宿主机。
    # 生成容器
    docker run --name nginx -p 8801:80 -d nginx
    # 将容器nginx.conf文件复制到宿主机
    docker cp nginx:/etc/nginx/nginx.conf ~/dev/nginx/conf/nginx.conf
    # 将容器conf.d文件夹下内容复制到宿主机
    docker cp nginx:/etc/nginx/conf.d ~/dev/nginx/conf/conf.d
    # 将容器中的html文件夹复制到宿主机
    docker cp nginx:/usr/share/nginx/html ~/dev/nginx/
    
  • 删除前面安装的nginx容器
    docker stop nginx # 关闭该容器
    docker rm nginx # 删除该容器
    

2.创建 Nginx 容器并运行

  • docker 创建 Nginx 容器
    docker run \
    -p 8801:80 \
    --name nginx \
    -v ~/dev/nginx/conf/nginx.conf:/etc/nginx/nginx.conf \
    -v ~/dev/nginx/conf/conf.d:/etc/nginx/conf.d \
    -v ~/dev/nginx/log:/var/log/nginx \
    -v ~/dev/nginx/html:/usr/share/nginx/html \
    -d nginx
    

3.将 Nginx 加入到自己定义的网络中

  • 如果你的Nginx做了反向代理并且需要和宿主机上的服务器进行通信,就需要将 Nginx 加入和通信服务到一个网络中。
    docker network connect GDB nginx
    

四、自定义镜像

  • 创建存放应用的目录
    mkdir -p ~/myapp/olive-app
    cd ~/myapp/olive-app
    
  • 编写Dockerfile文件,自定义镜像
    # 基础镜像
    FROM openjdk:17
    #设定时区
    ENV TZ=Asia/Shanghai
    RUN ln -snf /usr/share/zoneinfo/$TZ /etc/localtime && echo $TZ > /etc/timezone
    # 拷贝项目
    COPY olive-0.1.jar /olive.jar
    # 入口
    ENTRYPOINT ["java", "-jar", "/olive.jar"]
    
  • xxx.jarDockerfile 一起上传到服务器
    在这里插入图片描述
  • 构建自己应用的镜像
    docker build -t olive .
    
  • 利用镜像生成容器并且加入到前面创建的网络中与MySQL通信
    docker run -d --name olive -p 8800:8800 --network GDB olive
    
  • ② 这种方式是在上面的方式上增加了两个挂载目录(我这里是用来存放项目图片的,看自己的需要选择使用哪一条命令)
    docker run -d --name olive -v /root/myapp/olive-app/images/avatar:/images/avatar -v /root/myapp/olive-app/images/debug:/images/debug -p 8800:8800 --network GDB olive
    

五、参考

[1]. 镜像仓库
[2]. Dockerfile的copy复制文件夹
[3]. Docker 安装Nginx容器 (完整详细版)

1.不使用docker安装MySQl和Nginx

[1]. 在Linux实例中安装MySQL数据库
[2]. 【亲测可用】通过Navicat for MySQL远程连接的时候报错mysql 1130的解决方法
[3]. LINUX安装nginx详细步骤


版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/weixin_65032328/article/details/137062011

智能推荐

sqlite创建索引最佳实践-程序员宅基地

文章浏览阅读2.2k次。创建索引可以使 SQLite 数据库更快地执行查询,但是也会增加插入、更新和删除的时间。因此,在创建索引时,应该考虑查询和修改操作的平衡。在创建索引时,有几点可以遵循的最佳实践:使用 WHERE 子句中经常出现的列创建索引。使用列上的唯一约束或主键创建唯一索引。这有助于防止重复的值。避免使用过于长的索引,因为这会增加存储和维护索引的成本。如果表中有大量的 INSERT、UPDAT..._sqlite 创建索引

%d输出float类型,%f输出int类型_int型能用%f输出吗-程序员宅基地

文章浏览阅读3.6k次,点赞3次,收藏22次。// 输出格式与类型不一致,输出结果实际上与存储有关 // 1.int以%f格式输出,结果一般为0.000000 // 2.long long 类型的很大的数,用printf(“%f”)打印出来可能为一个小数; // 3.double、float以%d格式输出(输出时,float会转化为double存储形式;%d取低32位) // (1)结果一般为绝对值很大的数(当浮点数不能精确表示时,低32位不为0) // _int型能用%f输出吗

目标检测标注数据的检查和可视化_目标标注信息统计可视化-程序员宅基地

文章浏览阅读4.6k次。标注数据是一件十分枯燥的重复性工作。在标注数据时,有时因为数据量大,类别多,会出现错标、误标的情况,这时就需要对标注数据进行检查并且修改。_目标标注信息统计可视化

flutter 项目实践2_jj2d.top-程序员宅基地

文章浏览阅读2.5k次。本片文章来自与我自己的有道云笔记 要看图片请点击链接文档:Day 4_3 项目实践2.md链接:http://note.youdao.com/noteshare?id=f28e3058fea4d26f1b32bdc21f1a220c&sub=A3757D0FAF4C4BC29A8CF2E6F1C8DBD6上次做了什么我们把框架搭好了IndexedStack 分开了基础的页面制作了简单的首页 读取json文件 然后展示我们的首页基本就算制作完了然后我们想做一些展示home_cont_jj2d.top

elasticsearch-head连接问题_elasticsearch 开启xpack head如何连接-程序员宅基地

文章浏览阅读2.8k次。场景:最近打算使用elasticsearch做日志搜索,使用elasticsearch-head作为一个图形化界面查看index、type、document信息。elasticsearch 7.14.1mobz/elasticsearch-head:5地址:https://github.com/mobz/elasticsearch-head看完这个readme文档后,计划使用docker方式进行部署。1.更改elasticsearch.yml文件,包括xpack等配置,示例如下:_elasticsearch 开启xpack head如何连接

Selenium 根据元素文本内容定位_selenium java根据文字定位-程序员宅基地

文章浏览阅读1.8k次。使用xpath定位元素时,有时候担心元素位置会变,可以考虑使用文本内容来定位的方式。例如图中的【评价】按钮,只有按钮文本没变,就可以定位到该元素。_selenium java根据文字定位

随便推点

jmeter聚个报告怎么看qps_jmeter 聚合报告参数详解及TPS 解析-程序员宅基地

文章浏览阅读2.1k次。1、获得TPS插件https://www.cnblogs.com/beginner-boy/p/7806220.html 参见,已保存百度云盘2、添加后,记得使用调度器——每秒50个并发,持续60秒,观察TPS3、TPS,执行一次事务(包括请求、请求服务器、等待服务器返回等等,比如一个TPS事务,可能触发3个QPS请求)PS:一秒钟处理的事务数。TPS值越大,一秒钟处理的事务数就越多,说明处理速..._jmeter查看qps

浙大 PAT 甲级 1077 Kuchiguse_pat甲级可以用翻译吗-程序员宅基地

文章浏览阅读135次。读题目真是要笑死我了…太不正经了。很简单的20分~将题意翻译成代码即可。#include<iostream>#include<string>using namespace std;int main(){ int N; scanf("%d", &N); getchar(); string base; getlin..._pat甲级可以用翻译吗

centos7 svn服务器搭建_svn co authentication方法-程序员宅基地

文章浏览阅读1.5k次。基于centos7 的svn服务器配置_svn co authentication方法

capilot激活时遇到Sign in failed: Error: network error_sign in failed. reason: could not log in with devi-程序员宅基地

文章浏览阅读922次。capilot激活遇到问题,Sign in failed: Error: network error_sign in failed. reason: could not log in with device flow on cocopilot.org:

mysql 存储过程 序列_Oracle 生成序列号存储过程-程序员宅基地

文章浏览阅读147次。项目中经常要根据年月日规则生成序列号,简单写了个存储过程可根据需要扩展 一、序列号存储表 -- Create tablecreate table SYS_项目中经常要根据年月日规则生成序列号,简单写了个存储过程可根据需要扩展一、序列号存储表-- Create tablecreate table SYS_GENKEY(DATESTR VARCHAR2(50),MAXCOUNT NUMBER,TYP..._mysql 存储过程 序号

java tools.jar包含_无法找到tools.jar-程序员宅基地

文章浏览阅读583次。如果对任何人来说这仍然是一个问题,我对之前的答案有一点澄清。我使用只安装了JDK的ant遇到了同样的问题。虽然,JDK安装程序给了我一个这样的目录结构:Directory of C:\Program Files\Java05/08/2012 09:43 AM .05/08/2012 09:43 AM ..05/08/2012 09:46 A...

推荐文章

热门文章

相关标签