Docker安装(Docker上部署一个SpringBoot项目含MySql)

Docker

Docker 是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的镜像中,然后发布到任何流行的 LinuxWindows操作系统的机器上,也可以实现虚拟化。容器是完全使用沙箱机制,相互之间不会有任何接口。

官网:https://www.docker.com/
文档:https://docs.docker.com/
hub:https://hub.docker.com/
docker图标

Docker 安装\卸载

安装Docker

/var/lib/docker 是docker默认的安装路径

# 1、卸载旧版本
yum remove docker \
			docker-client \
			docker-client-latest \
			docker-common \
			docker-latest \
			docker-latest-logrotate \
			docker-logrotate \
			docker-engine
                  
# 2、安装
yum install -y yum-utils

# 3、配置镜像仓库(推荐选阿里云镜像,速度快!)
yum-config-manager \
    --add-repo \
    https://download.docker.com/linux/centos/docker-ce.repo # 默认是国外的
    
yum-config-manager \
    --add-repo \
    http://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo # 阿里云的
        
# 更新yum软件包索引
yum makecache fast

# 4、安装docker 相关 docker-ce 社区版 docker-ee企业版
yum install docker-ce docker-ce-cli containerd.io

# 5、启动docker
systemctl start docker

# 6、查看docker版本
docker version

安装完成后可以看到docker的版本信息
在这里插入图片描述
接下来测试Docker,运行官方给的hello world示例进行测试(会先在远程仓库拉去镜像,再运行)

# 7、hello world
docker run hello-world

在这里插入图片描述
到这Docker 的安装和测试就已经完成了!!!!!!!!

卸载Docker

# 9、卸载docker
yum remove docker-ce docker-ce-cli containerd.io
rm -rf /var/lib/docker
rm -rf /var/lib/containerd

链接: Docker 常用命令.

Docker上部署一个SpringBoot项目(含MySql)

一、先在Docker 上完成 MySql 的启动和配置

拉取 MySql 5.7 版本的镜像

docker pull mysql:5.7

在这里插入图片描述
此时可以在本地的镜像仓库中查看到已经拉取下来的mysql
在这里插入图片描述

运行mysql镜像(创建容器)

docker run -d -p 3306:3306 -v mysql_conf:/etc/mysql/conf.d -v mysql_data:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=123456 --name mysql01 mysql:5.7

参数说明:

-d 后台运行
-p 端口映射
-v 卷挂载
-e MYSQL_ROOT_PASSWORD=123456 配置mysql登录密码:[123456]为密码
-name 容器的名字

查看mysql容器已经启动
在这里插入图片描述

导入mysql数据库文件.sql (也可以使用本地工具连接服务器的mysql进行创新数据库)

.sql文件需要保存在mysql容器内部,之前运行时使用了卷挂载的技术,所以将.sql文件放在当前linux系统下的对应目录下,数据即可和容器共享

查看卷挂在的目录
在这里插入图片描述
进入该目录,将.sql文件放到该目录下
在这里插入图片描述
执行容器,进入mysql,导入数据库

docker exec -it mysql01 /bin/bash

在这里插入图片描述
.sql文件已经导入完成。

二、Dockerfile构建(将jar包构建成一个镜像)

项目打包

使用Maven工具打包,先clean --> package
在这里插入图片描述

创建Dockerfile文件

FROM java:8

VOLUME /tmp

ADD application-form-1.0-SNAPSHOT.jar app.jar

EXPOSE 80

ENTRYPOINT ["java","-Djava.security.egd=file:/dev/./urandom","-jar","/app.jar"]

在这里插入图片描述

上传文件到linux系统上

自己创建一个文件夹,用于保存此项目相关的文件
在这里插入图片描述

构建Dockerfile

docker build -t application-form:1.0 .

后面的 . 不要忘记加

第一次构建需要下载java8环境,会比较慢,运行完成后可以在本地镜像仓库中看到已经构建好的镜像
在这里插入图片描述

运行application-form镜像(创建容器)

docker run -d -p 80:80 --name application-form01 application-form:1.0

在这里插入图片描述

三、在浏览器中查看在这里插入图片描述

用户登录成功,mysql配置没有问题
在这里插入图片描述

  • 3
    点赞
  • 17
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
要使用dockerspringboot+MySQL项目,可以按照以下步骤进行操作: 1. 编写Dockerfile文件,指定基础镜像、安装JDK和MySQL等依赖,将项目打包成jar包并复制到镜像中。 ```dockerfile FROM openjdk:11-jdk-slim VOLUME /tmp ARG JAR_FILE=target/*.jar COPY ${JAR_FILE} app.jar RUN mkdir -p /var/lib/mysql RUN apt-get update && apt-get install -y mysql-server RUN echo "bind-address = 0.0.0.0" >> /etc/mysql/mysql.conf.d/mysqld.cnf RUN service mysql start && \ mysql -uroot -e "CREATE DATABASE db_name" && \ mysql -uroot -e "CREATE USER 'username'@'%' IDENTIFIED BY 'password'" && \ mysql -uroot -e "GRANT ALL PRIVILEGES ON db_name.* TO 'username'@'%';" EXPOSE 8080 ENTRYPOINT ["java","-Djava.security.egd=file:/dev/./urandom","-jar","/app.jar"] ``` 2. 构建镜像 在Dockerfile的目录下执行以下命令: ```shell docker build -t springboot-mysql . ``` 这里将镜像命名为springboot-mysql。 3. 运行容器 执行以下命令运行容器: ```shell docker run -d -p 8080:8080 -p 3306:3306 -e MYSQL_ROOT_PASSWORD=password -e MYSQL_DATABASE=db_name -e MYSQL_USER=username -e MYSQL_PASSWORD=password springboot-mysql ``` 这里将容器的8080端口映射到主机的8080端口,3306端口映射到主机的3306端口,并指定MySQL的root密码、数据库名、用户名和密码。 4. 访问应用 在浏览器中访问http://localhost:8080,即可访问应用。 注意:如果使用docker-compose进行部,可以在docker-compose.yml文件中指定MySQL的配置,更加方便和灵活。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值