Docker部署JAVA项目

news2025/1/16 5:45:44

一、 Docker安装

1、yum 包更新到最新

yum update

2、安装需要的软件包, yum-util 提供yum-config-manager功能,另外两个是devicemapper驱动依赖的

yum install yum-utils device-mapper-persistent-data lvm2 -y

3、 设置yum源

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

4、 安装docker,出现输入的界面都按 y

yum install -y docker-ce

5、 查看docker版本,验证是否验证成功

docker -v
在这里插入图片描述

6、启动docker

systemctl start docker
在这里插入图片描述

7、拉取docker镜像

docker镜像可以理解为普通的镜像,利用docker镜像来创建我们的docker容器。
依旧是在命令窗口输入以下指令

docker pull nginx
docker pull redis:5.0.3
docker pull openjdk:8
docker pull mysql:8.0.16

二、docker配置mysql

思路:构建一个docker来配置MySQL;并将mysql数据文件布置到宿主机中,稍微麻烦一些,但是安全性得以提高
配置mysql之前,希望大家先在自己的宿主机上安装MySQL,linux上保姆级的mysql安装教程,跟着做就可以了。
之所以这么做,是因为我希望将mysql数据存储在宿主机上,docker中只是配置一个mysql环境,如果将数据库文件存储在docker上,一旦删除容器(通过rm指令),所有的数据文件都会消失,很不安全。
建立宿主机上的MySQL目录(创建文件夹指令mkdir,cd是切换目录指令)

在这里插入图片描述

继续在命令窗口运行以下指令
其中run有着[创建并运行]mysql容器的作用
-p是建立宿主机3307端口与容器3306端口的映射
-v是生成挂载目录,挂载可以理解为共享/同步一个文件目录,冒号前的目录是宿主机目录,冒号后为docker中的MySQL数据目录,即使docker被删除,数据仍然可以保留到宿主机的目录中
值得一提的是 码神的笔记中挂载了三个目录,分别是配置文件,日志,数据文件。我在实际操作中日志一直出错,所以干脆只配置最重要的数据文件
下一步则是指定宿主机MySQL的默认密码,不设置默认密码可能会报错。
docker ps 查看容器是否已经运行
在这里插入图片描述
应该可以看到mysql8.0.16的容器已经在运行
进入容器docker exec -it mysql bash
进入容器中的mysql
在这里插入图片描述
输入密码,如上,我设置的为123456,直接输入就可以。(界面上显示空白,但其实密码已经输入了,按回车键确定。)
接下来的步骤和上面安装宿主机mysql的第10步类似
在这里插入图片描述

show databases;
use mysql;
show tables;
select user,host from user;(可能会报sql错误,加上``包裹字段即可)

可以看到root用户对应的host并不是%,我们要改为%以开放权限。
update user set host =‘%’ where user =‘root’;
update user set host =‘%’ where user =‘root’ and host=‘localhost’;
最好两句都执行下,我当时的情况是有两个root用户,执行的结果是一个root对应host为空,另一个host为%。
(甚至可以开放高级权限grant all privileges on . to root@‘%’ identified by ‘root’ with grant option;)
刷新权限flush privileges;
exit 退出MySQL,再exit退出MySQL的容器
在这里插入图片描述
环境无误后我们需要导入我们的数据库文件blog.sql

cd /mnt/docker/mysql/data
将blog.sql上传至这里
拷贝SQL文件到mysql容器中
docker cp blog.sql mysql:/blog.sql
进入容器docker exec -it mysql bash
mysql -uroot -p123456
mysql> use blog;
Database changed
mysql> source blog.sql;
结果检查
use blog; show tables; select * from ms_admin;
如果能查出来结果(如下图),那就说明我们的部署成功了。

三、docker 配置redis

这个很简单,一条指令搞定
docker run -id --name=redis -p 6379:6379 redis:5.0.3
检查
docker ps 查看当前正在运行的容器,理论上现在可以看到mysql和redis都在运行中了。
docker ps -a 查看所有容器(包括未在运行的)
我们要查看一下redis docker所对应的ip地址docker inspect redis,后面打包项目时要用,我这里就是172.17.0.2

四、Dockerfile构建后端镜像

诸如MySQL ,redis的镜像我们可以直接拉取,但后端项目的镜像需要我们自己打包,构建。
码神对于Dockerfile的解释如下
Dockerfile 是一个文本文件
包含了一条条的指令
每一条指令构建一层,基于基础镜像,最终构建出一个新的镜像
对于开发人员:可以为开发团队提供一个完全一致的开发环境
对于测试人员:可以直接拿开发时所构建的镜像或者通过Dockerfile文件
构建一个新的镜像开始工作了
对于运维人员:在部署时,可以实现应用的无缝移植
1.首先,我们需要在idea上配置参数并且打包
在这里插入图片描述
2.使用maven打包
在这里插入图片描述
接下来,我们需要在 /mnt/docker/app目录下导入jar包,构建镜像的配置文件并运行镜像。

先新建目录 mkdir /mnt/docker/app
可以使用上传功能的配置yum -y install lrzsz
切换到该目录下cd /mnt/docker/app
上传文件rz
修改名字 mv blog-api-1.0-SNAPSHOT.jar blog_api.jar
配置构建镜像的配置文件
新建文件 touch blog_dockerfile
修改文件内容vim blog_dockerfile
将以下内容粘贴进入即可(个人参数自己修改一下)

FROM java:8
ADD ./blog_api.jar /app.jar
CMD java -jar /app.jar --spring.profiles.active=prod

运行镜像docker build -f ./blog_dockerfile -t app .
检查,docker images应该可以看到app的docker已经在运行了

五、构建前端镜像

修改前端的配置,打包,上传,并微调文件位置。
创建对应的文件夹
[root@localhost app]# mkdir -p /mnt/jia/blog
[root@localhost app]# cd /mnt/jia/blog/
切换到blog目录下cd /mnt/zhang/blog
-上传rz ,把我们的前端dist压缩包上传上去
解压unzip dist.zip
然后移动文件位置,在/mnt/zhang/blog下ls,应该是以下三个文件:dist.zip,index.html,static,其实有用的应该就是index.html以及static

六、Docker-compose服务编排

服务编排主要是利用Docker Compose将springboot和nginx分批启动
Springboot就是我们自己打包的项目
而nginx的作用:①将服务器上的静态文件(如HTML、图片)通过HTTP协议展现给客户端。②反向代理服务器,这里nginx代理的就是前端资源客户端本来可以直接通过HTTP协议访问某网站应用服务器,网站管理员可以在中间加上一个Nginx,客户端请求Nginx,Nginx请求应用服务器,然后将结果返回给客户端。加一层代理可以实现负载均衡、虚拟主机等效果。(具体请看)
首选,我们安装Docker Compose

Compose目前已经完全支持Linux、Mac OS和Windows,在我们安装Compose之前,需要先安装Docker。下面我 们以编译好的二进制包方式安装在Linux系统中。

curl -L https://github.com/docker/compose/releases/download/1.22.0/docker-compose-`uname -s`-`uname -m` -o /usr/local/bin/docker-compose

设置文件可执行权限
[root@localhost blog]# chmod +x /usr/local/bin/docker-compose
[root@localhost blog]# docker-compose -version
docker-compose version 1.22.0, build f46880fe

创建对应的目录,并且把docker-compose.yml配置文件写好
在这里插入图片描述
把以下内容复制到docker-compose.yml中,写完之后先按Esc退出编辑模式,然后输入:wq,就可以保存并退出~

version: '3'
services:
  nginx:
   image: nginx
   container_name: nginx
   ports:
    - 80:80
    - 443:443
   links:
     - app
   depends_on:
    - app
   volumes:
    - /mnt/docker/docker-compose/nginx/:/etc/nginx/
    - /mnt/jia/web:/jia/web
    - /mnt/jia/blog:/jia/blog
   network_mode: "bridge"
  app:
    image: app
    container_name: app
    expose:
      - "8888"
    network_mode: "bridge"

接下来,我们需要配置nginx的文件目录以及内部的相关配置文件
在这里插入图片描述

user nginx;
worker_processes  1;
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;
    #tcp_nopush     on;
    keepalive_timeout  65;
    #gzip  on;
    include /etc/nginx/conf.d/*.conf;
}

新建conf.d文件夹,然后新建blog.conf文件
在这里插入图片描述
修改配置,将以下文件放入到blog.conf中

gzip_min_length 1k;
gzip_buffers 4 16k;
gzip_comp_level 2;
gzip_vary off;
upstream appstream{
        server app:8888;
}
server{
    # 监听端口
    listen  80;
    # 主机名称/地址
    server_name www.mszl.blog mszl.blog;
    index   index.html;
    # 前端服务
     location / {
        root /jia/blog/;
        # 刷新页面后跳转到当前页面
        try_files $uri $uri/ /index.html;
        index index.html;
     }

     # 后端api
     location /api {
                proxy_pass http://appstream;
    }

    location ~* \.(jpg|jpeg|gif|png|swf|rar|zip|css|js|map|svg|woff|ttf|txt)$ {
        root /jia/blog/;
        index index.html;
        add_header Access-Control-Allow-Origin *;
    }
}

大家可以看到还有一个文件叫做mime.types
这个玩意是nginx中必带的东西,我是从网上下载了一个nginx然后拿出mime.types文件然后rz进去的,大家也可以直接新建文件把代码复制进去,代码如下。


types {
    text/html                                        html htm shtml;
    text/css                                         css;
    text/xml                                         xml;
    image/gif                                        gif;
    image/jpeg                                       jpeg jpg;
    application/javascript                           js;
    application/atom+xml                             atom;
    application/rss+xml                              rss;

    text/mathml                                      mml;
    text/plain                                       txt;
    text/vnd.sun.j2me.app-descriptor                 jad;
    text/vnd.wap.wml                                 wml;
    text/x-component                                 htc;

    image/png                                        png;
    image/svg+xml                                    svg svgz;
    image/tiff                                       tif tiff;
    image/vnd.wap.wbmp                               wbmp;
    image/webp                                       webp;
    image/x-icon                                     ico;
    image/x-jng                                      jng;
    image/x-ms-bmp                                   bmp;

    font/woff                                        woff;
    font/woff2                                       woff2;

    application/java-archive                         jar war ear;
    application/json                                 json;
    application/mac-binhex40                         hqx;
    application/msword                               doc;
    application/pdf                                  pdf;
    application/postscript                           ps eps ai;
    application/rtf                                  rtf;
    application/vnd.apple.mpegurl                    m3u8;
    application/vnd.google-earth.kml+xml             kml;
    application/vnd.google-earth.kmz                 kmz;
    application/vnd.ms-excel                         xls;
    application/vnd.ms-fontobject                    eot;
    application/vnd.ms-powerpoint                    ppt;
    application/vnd.oasis.opendocument.graphics      odg;
    application/vnd.oasis.opendocument.presentation  odp;
    application/vnd.oasis.opendocument.spreadsheet   ods;
    application/vnd.oasis.opendocument.text          odt;
    application/vnd.openxmlformats-officedocument.presentationml.presentation
                                                     pptx;
    application/vnd.openxmlformats-officedocument.spreadsheetml.sheet
                                                     xlsx;
    application/vnd.openxmlformats-officedocument.wordprocessingml.document
                                                     docx;
    application/vnd.wap.wmlc                         wmlc;
    application/x-7z-compressed                      7z;
    application/x-cocoa                              cco;
    application/x-java-archive-diff                  jardiff;
    application/x-java-jnlp-file                     jnlp;
    application/x-makeself                           run;
    application/x-perl                               pl pm;
    application/x-pilot                              prc pdb;
    application/x-rar-compressed                     rar;
    application/x-redhat-package-manager             rpm;
    application/x-sea                                sea;
    application/x-shockwave-flash                    swf;
    application/x-stuffit                            sit;
    application/x-tcl                                tcl tk;
    application/x-x509-ca-cert                       der pem crt;
    application/x-xpinstall                          xpi;
    application/xhtml+xml                            xhtml;
    application/xspf+xml                             xspf;
    application/zip                                  zip;

    application/octet-stream                         bin exe dll;
    application/octet-stream                         deb;
    application/octet-stream                         dmg;
    application/octet-stream                         iso img;
    application/octet-stream                         msi msp msm;

    audio/midi                                       mid midi kar;
    audio/mpeg                                       mp3;
    audio/ogg                                        ogg;
    audio/x-m4a                                      m4a;
    audio/x-realaudio                                ra;

    video/3gpp                                       3gpp 3gp;
    video/mp2t                                       ts;
    video/mp4                                        mp4;
    video/mpeg                                       mpeg mpg;
    video/quicktime                                  mov;
    video/webm                                       webm;
    video/x-flv                                      flv;
    video/x-m4v                                      m4v;
    video/x-mng                                      mng;
    video/x-ms-asf                                   asx asf;
    video/x-ms-wmv                                   wmv;
    video/x-msvideo                                  avi;
}

七、运行测试

到这里,我们的部署基本完成了
也可以docker ps检查一下,4个容器都在运行了
在这里插入图片描述
切换到docker-compose目录下,启动容器,下面是一些容器启停的常用指令

docker-compose up #直接启动

docker-compose up -d #代表后台启动

docker-compose down  #停止并删除容器

docker-compose start #启动已有容器

docker-compose stop  #停止运行的容器

一般来说,我们先docker-compose up直接启动看看网站有没有问题,如果有问题,通过以下两个指令来完善。
查看ngix日志:docker logs nginx
查看后端日志:docker-compose logs
当我们觉得部署完全搞定的时候,就可以docker-compose up -d后台启动,这样的话关掉服务器也能运行了。

八、 修改docker容器的时区

修改mysql容器时区和MySQL数据库时区
在这里插入图片描述
1.docker exec -it mysql bash
进去之后,mysql -uroot -p
select now();
发现时区差了八小时
2.在docker容器中,vim /etc/mysql/my.cnf
3.提示vim命令不存在
4.apt-get update
5.apt install vim
然后vim /etc/mysql.my.cnf
在里面添加在这里插入图片描述
6.重启mysql的docker容器

docker restart mysql

7.重新进入mysql容器

docker exec -it mysql bash
mysql -uroot -p
![在这里插入图片描述](https://img-blog.csdnimg.cn/52a40c67e2284d0f89a00f9a3b67346d.png)

![在这里插入图片描述](https://img-blog.csdnimg.cn/8ffd9e0a00154417a93d5bef9698fab2.png)
修改redis容器的时区
![在这里插入图片描述](https://img-blog.csdnimg.cn/f7c49e291b1b485db9438869928a7442.png)
修改nginx时区
![在这里插入图片描述](https://img-blog.csdnimg.cn/fa9bc0c163404b15a81a77f67e42aa19.png)
修改app容器的时区
![在这里插入图片描述](https://img-blog.csdnimg.cn/d393924d896d4acb9058f69c27e478db.png)
重启nginx和app容器项目的时区才能生效
![在这里插入图片描述](https://img-blog.csdnimg.cn/4c3bc71833c34a7293859984089518db.png)


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

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

相关文章

等级保护----1、网络安全等级保护一级安全测评要求

文章目录一、安全测评通用要求1、安全物理环境1.1 物理访问控制1.2 防盗窃和防破坏1.3 防雷击1.4 防火1.5 防水和防潮1.6 温湿度控制1.7 电力供应2、安全通信网络2.1 通信传输2.2 可信验证3、安全区域边界3.1 边界防护3.2 访问控制3.3 可信验证4、安全计算环境4.1 身份鉴别4.2 …

使用关键字like进行模糊查询

【模糊查询】:使用关键字like [支持%或者下划线匹配,%匹配任意多个字符,一个下划线只匹配任意一个字符。] 实例: 查询名字中带有字母o的员工: select * from emp where ename like %o%; 找出名字以T结…

2000-2021.3月土地交易高频数据库(含爬取代码和数据)

2000-2021.3月土地交易高频数据库(含爬取代码和数据) 1、时间跨度:2000-2021年3月1日 2、指标:年份、电子监管号、所在省份、所在城市、所在区县、经度、纬度、项目名称、项目位置、面积、土地来源、土地用途、供地方式、土地使…

Python CV 实现风格化图片转换

前几天遇到一个风格化图片转换的需求,效果像这样: 像这样,需要用纯色圆形填充图像,形成风格化的图片样式。 实现原理 整体原理还是比较简单的,有点类似与马赛克的处理方式。 假设图片宽 w 像素,高 h 像素…

FLStudio21中文版下载及水果软件2023功能介绍

如今,越来越多的音乐人选择使用音乐制作软件来进行音乐的创作,一台电脑、一款软件以及一个外接MIDI就是一个小型的音乐工作站,而如今非常流行的FL Studio(在国内被称为“水果”)成了音乐界无论萌新还是大佬们的首选&am…

二阶微分算子与反锐化屏蔽

二阶微分算子 任意二阶微分必须满足:灰度不变的区域微分值为0;灰度台阶或斜坡的起点处微分值非0;沿着斜坡的微分值为0。由于处理离散值,因此微分用差分近似: 二维图像f(x,y),沿着两个空间坐标轴求解二阶微分&#xff1…

逆向-还原代码之little-or-big (Arm 64)

// 源代码 #include <stdio.h> /* * 2016/9/29 yu liang. */ int test_one(void) { int i1; char *p(char *)&i; if(*p1) printf("Little_endian\n"); // Little_endian else printf("B…

一文弄清楚Vue中的computed与watch的区别

1.实现业务当我们点击按钮&#xff0c;就会切换h1标签的语句内容&#xff0c;再次点击按钮&#xff0c;h1标签的语句内容就会恢复&#xff0c;每次点击按钮&#xff0c;浏览器都会输出一个语句来表达监视到了h1的内容改变2.Vue中的computed计算属性2.1利用Vue中的computed计算属…

Windows server——部署DHCP服务

作者简介&#xff1a;一名云计算网络运维人员、每天分享网络与运维的技术与干货。 座右铭&#xff1a;低头赶路&#xff0c;敬事如仪 个人主页&#xff1a;网络豆的主页​​​​​​ 目录 前言 本章重点 一.DHCP概述 1.DHCP服务的好处 二.DHCP的工作原理 1.DHCP的分配方…

【云原生 | 50】Docker三剑客之Docker Compose第一节

&#x1f341;博主简介&#xff1a; &#x1f3c5;云计算领域优质创作者 &#x1f3c5;2022年CSDN新星计划python赛道第一名 &#x1f3c5;2022年CSDN原力计划优质作者 &#x1f3c5;阿里云ACE认证高级工程师 &#x1f3c5;阿里云开发者社区专…

pinia和vuex的区别

pinia和vuex的区别 什么是“状态管理模式”&#xff1f; const Counter {// 状态data () {return {count: 0}},// 视图template: <div>{{ count }}</div>,// 操作methods: {increment () { this.count}} }createApp(Counter).mount(#app)这个状态自管理应用包含…

字符串题记

经典字符串leetcode题 文章目录经典字符串leetcode题反转字符串第一种方法&#xff1a;使用string里的库函数reverse第二种方法&#xff1a;使用自己写的swap函数第一种swap函数第二种swap函数151.翻转字符串里的单词28. 实现 strStr()KMP算法459.重复的子字符串第一种&#xf…

UE4 后期材质节点学习

以下对应的效果&#xff1a; 材质后期在这里进行设置&#xff1a; 在这里调整场景的整体的饱和度 场景的对比度 灰度系数的调整 高光度/图像增益 灰阶偏移的设置 想了解这些专业名词可以看&#xff1a;相机gain lift gamma offset参数意义_baobei0112的博客-CSDN博客_相机gai…

Redis学习笔记(一)Linux下安装部署Redis

一、下载Redis 1、进入官网&#xff0c;进入download页面 https://redis.io/download&#xff0c;找到“List of all releases and hash digests”&#xff0c;点击“ listing of all previous Redis releases on the releases page”&#xff0c;可以进入所有版本下载页面。 …

STM32——DMA直接存储器访问

文章目录一、DMA直接存储器存取DMA简介二、存储器映像三、DMA框图四、DMA基本结构五、DMA请求&#xff08;触发源&#xff09;六、数据宽度与对齐七、存储器到存储器的DMA转运原理图关键代码八、外设到存储器的DMA转运原理图硬件链接图关键代码九、其他一、DMA直接存储器存取 …

【图像分类】4.ResNet残差模块卷积网络的神

ResNet重要性不必多说了吧&#xff0c;论文引用破10w&#xff0c;是我见过最多的&#xff0c;yyds&#xff01; 在对照博主霹雳吧啦和官方pytorch的代码下&#xff0c;手撸一个resnet。如果没有看着代码写&#xff0c;不确定自己是否能根据论文写出model&#xff0c;而且写优雅…

java学习day69(乐友商城)用户注册

今日目标&#xff1a; 创建用户中心 了解面向接口开发方式 实现数据校验功能 实现短信发送功能 实现注册功能 实现根据用户名和密码查询用户功能 1.创建用户中心 用户搜索到自己心仪的商品&#xff0c;接下来就要去购买&#xff0c;但是购买必须先登录。所以接下来我们编…

STM32MP157驱动开发——Linux IIO驱动(下)

STM32MP157驱动开发——Linux IIO驱动&#xff08;下&#xff09;0.前言一、IIO 触发缓冲区1.IIO 触发器2.申请触发器3.释放触发器4.注册触发器5.注销触发器6. IIO 缓冲区7.向驱动程序添加触发缓冲功能8.驱动编写9.触发缓冲测试10.缓冲区读取二、测试App三、测试结果0.前言 上一…

【C++高阶数据结构】B树、B+树、B*树

&#x1f3c6;个人主页&#xff1a;企鹅不叫的博客 ​ &#x1f308;专栏 C语言初阶和进阶C项目Leetcode刷题初阶数据结构与算法C初阶和进阶《深入理解计算机操作系统》《高质量C/C编程》Linux ⭐️ 博主码云gitee链接&#xff1a;代码仓库地址 ⚡若有帮助可以【关注点赞收藏】…

高等数学(第七版)同济大学 习题11-3 (前7题)个人解答

高等数学&#xff08;第七版&#xff09;同济大学 习题11-3&#xff08;前7题&#xff09; 函数作图软件&#xff1a;Mathematica 1.计算下列曲线积分&#xff0c;并验证格林公式的正确性&#xff1a;\begin{aligned}&1. \ 计算下列曲线积分&#xff0c;并验证格林公式的正…