带有Spring Boot和MySQL的Docker:简介(Part 1)
通过优锐课java学习分享中,我们看一下带有Spring Boot和MySQL的Docker教程。非常实用,分享给大家参考学习。
Docker是一种技术,开发人员或DevOps团队可以使用容器来构建,部署和管理应用程序。 Docker是一种开源软件,因此每个人都可以在自己的操作系统上运行该操作系统,该操作系统应支持虚拟化以及适用于Mac / Windows / Linux的Docker。
Docker还将就绪的映像从一台计算机运送到另一台计算机。 Docker容器是与主机OS中其余进程隔离的一组进程。 Docker共享主机操作系统的内核。 另一方面,VM是一种依赖于客户机OS的技术,该客户机与主机OS完全分开。 虚拟机通过虚拟机管理程序与主机OS通信。 VM需要许多硬件资源和进程。 它不是基于容器的技术。
Docker将资源的抽象从硬件级别提升到了操作系统级别。 这就是为什么应用程序可移植性和基础结构分离更容易的原因。
基于容器的技术占用主机系统的资源较少。 大多数时候,基于容器的技术使用主机的内核。 本文的主要目标是通过Spring Boot应用程序和MySQL实现Docker。
基本概念
Docker Engine作为客户端-服务器架构。 Docker守护程序充当服务器,这是Docker的核心部分,并在主机操作系统上运行。 此服务提供了一些可供客户端使用的其余API。 命令行界面(CLI)客户端通过Docker命令使用Docker守护程序提供的服务。
Docker守护程序
重要条款
映像: 映像是Docker内部的可执行应用程序包文件。 它包含运行应用程序所需的一切,包括库,配置文件,运行时等。它是容器的快照。容器: 图像的实例称为容器。 当映像被执行并发生在内存中时,该映像的实例称为容器。 它在完全隔离的环境中执行。
用OOP术语来说,Image是一个类,而容器是该类的实例—运行时对象。
注册表:注册表是存储Docker映像的存储和内容交付系统。 Docker Hub是一个流行的Docker注册表。 我们可以将具有不同标签号的不同版本的图像存储到Docker Hub。
Dockerfile:这是一个文本文件,其中包含用于组装映像的所有命令。
Dockerfile > (Build) > Image > (Run) > Container
安装
在本文中,我们将使用Docker Hub作为Docker注册表。 然后,我们将按照说明设置桌面Docker应用程序。 我使用Mac OS作为主机。 安装后,我们可以看到Docker应用正在运行。 然后,我必须使用
Docker Hub凭据登录。
Docker Desktop安装并登录后
现在,我们可以打开终端以检查一些Docker命令。
docker --version命令应返回Docker版本。 就我而言,此命令返回
Docker版本19.03.2,内部版本6a30dfc
docker info命令应返回主机已安装的Docker计算机的详细信息。 最初,你有零个图像和容器。
docker pull hello-world此命令应从Docker注册表中提取hello-world映像。 再一次,如果我们运行Docker info命令,我们可以看到映像计数为1。但是容器计数仍然为零。
docker run hello-world此命令应创建hello-world映像的实例。 它将返回一条长消息:
你好,Docker!
此消息表明你的安装似乎正常工作。
如果运行Docker info命令,我们可以看到映像计数为1,容器计数也为1。 至此Docker安装完成
安装MySQL
现在,我们将创建并运行MySQL数据库的映像。 在我们的终端上,我们将运行以下命令。 此处,此命令中的-d表示Docker命令将以分离模式运行。
docker run -d -p 6033:3306 --name=docker-mysql --env="MYSQL_ROOT_PASSWORD=root" --env="MYSQL_PASSWORD=root" --env="MYSQL_DATABASE=book_manager" mysql
希望将MySQL映像拉出并作为容器运行。 要检查这一点,我们可以运行
docker image ls和docker container ls命令。 就我而言,这些命令的响应是:
mysql latest b8fd9553f1f0 3 days ago 445MB
hello-world latest fce289e99eb9 8 months ago 1.84kB
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
5db66654ba6a mysql "docker-entrypoint.s…" 13 minutes ago Up 13 minutes 33060/tcp, 0.0.0.0:6033->3306/tcp docker-mysql
现在我们可以通过登录MySQL进行检查。
docker exec -it docker-mysql bash;
它将带我们进入docker-mysql容器。 然后我们将使用密码为root的mysql -uroot -p登录到MySQL。 然后,我们将运行show数据库; 命令以查看数据库设置是否完成。
就我而言,它返回以下结果:
+--------------------+ | Database | +--------------------+ | book_manager | | information_schema | | mysql | | performance_schema | | sys | +--------------------+ 5 rows in set (0.00 sec)
因此,可以说book_manager数据库是在docker容器内创建的。 我们可以通过端口6033从主机外部使用此数据库。现在,我们必须将数据库脚本导入Docker MySQL数据库。 SQL脚本在此处可用。 运行以下命令将此脚本导入到docker-mysql中。
docker exec -i docker-mysql mysql -uroot -proot book_manager <book_manager.sql
希望book_manager脚本成功执行。 你可以通过执行以下命令进行确认。
$ docker exec -it docker-mysql bash; root@5db66654ba6a:/# mysql -uroot -p Enter password: mysql> show databases; +--------------------+ | Database | +--------------------+ | book_manager | | information_schema | | mysql | | performance_schema | | sys | +--------------------+ 5 rows in set (0.00 sec) mysql> use book_manager Database changed mysql> show tables; +------------------------+ | Tables_in_book_manager | +------------------------+ | author | | book | | book_author | | book_publisher | | book_tag | | bookshelf | | publisher | | tag | +------------------------+ 8 rows in set (0.01 sec) mysql>
应用程序克隆和构建项目
我已经将代码推送到GitHub存储库中。 任何人都可以从此处克隆代码库。 我认为你的主机已安装Gradle。 所以现在我们运行gradle build命令来构建项目。 因此,可执行的jar文件是在克隆项目的build / jar目录中创建的。
现在打开Dockerfile。 我们可以看到该文件包含以下命令:
FROM java:8 VOLUME /tmp EXPOSE 10222 ADD /build/libs/book-manager-1.0-SNAPSHOT.jar book-manager-1.0-SNAPSHOT.jar ENTRYPOINT ["java","-jar","book-manager-1.0-SNAPSHOT.jar"]
该文件包含要在docker中执行的顺序命令。 它将创建Java 8的映像,还将jar文件从主机复制到docker映像,然后运行在入口点参数处给出的命令。 现在我们将使用此Dockerfile构建一个Docker映像。
docker build -f Dockerfile -t book_manager_app .
该命令将为Docker计算机创建一个名为book_manager_app的Docker镜像。 -f命令表示Docker文件名。 现在,我们将该图像作为容器运行。
docker run -t --link docker-mysql:mysql -p 10222:10222 book_manager_app
--link命令将允许book_manager_app容器使用MySQL容器的端口,而-t代表--tty,它将分配一个伪终端。
运行此命令后,我们将在主机浏览器中访问http:// localhost:10222 / book,它将返回书籍列表。
这些都是通过简单的Spring Boot实现和MySQL数据库提供的Docker入门知识的。
文章写道这里,如有不足之处,欢迎补充评论。
抽丝剥茧,细说架构那些事--优锐课
带有Spring Boot和MySQL的Docker:简介(Part 1)的更多相关文章
- Spring Boot 2.0(五):Docker Compose + Spring Boot + Nginx + Mysql 实践
我知道大家这段时间看了我写关于 docker 相关的几篇文章,不疼不痒的,仍然没有感受 docker 的便利,是的,我也是这样认为的,I know your felling . 前期了解概念什么的确实 ...
- (转)Spring Boot 2 (五):Docker Compose + Spring Boot + Nginx + Mysql 实践
http://www.ityouknow.com/springboot/2018/03/28/dockercompose-springboot-mysql-nginx.html 我知道大家这段时间看了 ...
- Spring Boot 2 (五):Docker Compose + Spring Boot + Nginx + Mysql 实践
Spring Boot 2 (五):Docker Compose + Spring Boot + Nginx + Mysql 实践 Spring Boot + Nginx + Mysql 是实际工作中 ...
- Docker Compose + Spring Boot + Nginx + Mysql
Docker Compose + Spring Boot + Nginx + Mysql 实践 我知道大家这段时间看了我写关于 docker 相关的几篇文章,不疼不痒的,仍然没有感受 docker 的 ...
- Docker数据持久化及实战(Nginx+Spring Boot项目+MySQL)
Docker数据持久化: Volume: (1)创建mysql数据库的container docker run -d --name mysql01 -e MYSQL_ROOT_PASSWORD= my ...
- 【SFA官方翻译】使用 Kubernetes、Spring Boot 2.0 和 Docker 的微服务快速指南
[SFA官方翻译]使用 Kubernetes.Spring Boot 2.0 和 Docker 的微服务快速指南 原创: Darren Luo SpringForAll社区 今天 原文链接:https ...
- Spring Boot工程发布到Docker
先聊聊闲话 搞过企业级的application运维的同仁肯定深有感触,每个application的功能交叉错杂,数据交换就让人焦头烂额(当然这和顶层业务设计有关系), 几十个application发布 ...
- 【docker】docker部署spring boot服务,但是docker logs查看容器输出控制台日志,没有日志打印,日志未打印,docker logs不打印容器日志
如题: docker部署spring boot服务,但是docker logs查看容器输出控制台日志,没有日志打印,日志未打印,docker logs不打印容器日志 场景再现: docker部署并启动 ...
- 从零开始通过idea插件将一个spring boot项目部署到docker容器里运行
实操:将一个spring boot项目部署到docker容器里运行 实验需要的环境: 腾讯云+Ubuntu 16.04 x64+idea+插件docker integration+daocloud 第 ...
随机推荐
- JavaWeb中的MVC 下
代码较多,请先略过代码,看懂逻辑在研究代码 引入 回顾上一节中的项目,最终的层次结构: 在MVC上中,我们分析了MVC设计模式具备的优点,以及不足,并在其基础上增了Service层用于处理业务逻辑,但 ...
- Java做成Zip文件,Java实现压缩文件
import java.io.FileInputStream; import java.io.FileOutputStream; import java.io.IOException; import ...
- python学习-继承
# 继承# 你的是我的,我的还是我的 class Animal: def __init__(self,name,private_v1): self.name = name self._private_ ...
- 十年Java程序员-带你走进Java虚拟机-类加载机制
类的生命周期 1.加载 将.class文件从磁盘读到内存 2.连接 2.1 验证 验证字节码文件的正确性 2.2 准备 给类的静态变量分配内存,并赋予默认值 2.3 解析 类装载器装入类所引用的其它所 ...
- ACM-ICPC 2018 南京赛区网络预赛 L. Magical Girl Haze (分层dijkstra)
There are NN cities in the country, and MMdirectional roads from uu to v(1\le u, v\le n)v(1≤u,v≤n). ...
- Intent知识详解
Intent知识详解 一.什么是Intent 贴一个官方解释: An intent is an abstract description of an operation to be performed ...
- python 类属性与实例属性
#__author__ = 'juzi_juzi' #类属性与实例属性 #1.无法通过类访问实例属性: #2.类属性归类所所有,但是所有实例都可访问: #3.如果存在相同名称的类属性与实例属性,实例访 ...
- 【CV现状-3.1】图像分割
#磨染的初心--计算机视觉的现状 [这一系列文章是关于计算机视觉的反思,希望能引起一些人的共鸣.可以随意传播,随意喷.所涉及的内容过多,将按如下内容划分章节.已经完成的会逐渐加上链接.] 缘起 三维感 ...
- C# get md5 from bytes
static byte[] GetBytesFromDic(Dictionary<string,string> dic) { if(dic==null || !dic.Any()) { r ...
- C# 中的 bool、char 和 string 类型
上一篇(地址:https://www.vinanysoft.com/c-sharp-basics/data-types/fundamental-numeric-types/)只介绍了基本数值类型,本篇 ...