当前位置:   article > 正文

Docker学习篇——使用Docker部署账单微服务项目_docker 账单

docker 账单

Docker概念

  1. Docker 是一个开源的应用容器引擎
  2. 诞生于 2013 年初,基于 Go 语言实现, dotCloud 公司出品(后改名为Docker Inc)
  3. Docker 可以让开发者打包他们的应用以及依赖包到一个轻量级、可移植的容器中,然后发布到任何流行的Linux 机器上
  4. 容器是完全使用沙箱机制,相互隔离
  5. 容器性能开销极低
  6. Docker 从 17.03 版本之后分为 CE(Community Edition: 社区版)和 EE(Enterprise Edition: 企业版)

总结:docker是一种能解决容器款环境迁移问题的容器技术。

本次任务旨在使用Docker部署账单微服务项目,具体任务过程需要在虚拟机CentOS7里部署MySQL、Eureka Server、账单微服务、网关微服务、配置微服务。在虚拟机中部署需先在外部机上部署测试好,外部机上具体实现步骤可参考Spring Cloud重构个人记账项目(账单微服务、网关微服务、配置微服务)

虚拟机上发布spring boot项目需要使用到dockerfile

Dockerfile概念

  1. Dockerfile 是一个文本文件
  2. 包含了一条条的指令
  3. 每一条指令构建一层,基于基础镜像,最终构建出一个新的镜像
  4. 对于开发人员:可以为开发团队提供一个完全一致的开发环境
  5. 对于测试人员:可以直接拿开发时所构建的镜像或者通过Dockerfile文件构建一个新的镜像开始工作了
  6. 对于运维人员:在部署时,可以实现应用的无缝移植

部署MySQL

  1. 搜索mysql镜像
docker search mysql
  • 1
  1. 拉取mysql镜像
docker pull mysql:5.6
  • 1
  1. 创建容器,设置端口映射、目录映射
# 在/root目录下创建mysql目录用于存储mysql数据信息
mkdir ~/mysql
cd ~/mysql
docker run -id \
-p 3306:3306 \
--name=c_mysql \
-v $PWD/conf:/etc/mysql/conf.d \
-v $PWD/logs:/logs \
-v $PWD/data:/var/lib/mysql \
-e MYSQL_ROOT_PASSWORD=123456 \
mysql:5.6
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11

参数说明:

  • -p 3307:3306:将容器的3306端口映射到宿主机的3306端口。
  • -v $PWD/conf:/etc/mysql/conf.d:将主机当前目录下的 conf/my.cnf 挂载到容器的/etc/mysql/my.cnf。配置目录
  • -v $PWD/logs:/logs:将主机当前目录下的 logs 目录挂载到容器的 /logs。日志目录
  • -v $PWD/data:/var/lib/mysql :将主机当前目录下的data目录挂载到容器的 /var/lib/mysql 。数据目录
  • -e MYSQL_ROOT_PASSWORD=123456:初始化 root 用户的密码。
  1. 进入容器,操作mysql
docker exec -it c_mysql /bin/bash
mysql -uroot -p123456
show databases;
create database db1;
  • 1
  • 2
  • 3
  • 4
  1. 使用外部机器连接容器中的mysql

这里我用Navicat通过端口映射连接容器内的数据库c_mysql,将外部机里的两张表(bill_、bill_type_)直接拷了过来:
在这里插入图片描述
dockerfile发布eureka-server

install编译eureka-server项目,成功后将jar包拷出来
在这里插入图片描述
jar包拷进虚拟机里的/root/docker-files目录下,输入:

vim eureka_file
  • 1

文件按如下编辑:
在这里插入图片描述
镜像文件(eureka_file)说明:

  • 定义父镜像:FROM java:8
  • 定义作者信息:MAINTAINER wcf wcf@163.com
  • 将jar包添加到容器: ADD eureka.jar eureka.jar
  • 定义容器启动执行的命令:CMD [“java”,"-jar",“eureka.jar”]

build

docker bulid –f ./eureka_file –t eureka .
  • 1

启动容器

docker run -id -p 9000:10086 eureka
  • 1

在这里插入图片描述
到这里,eureka就在虚拟机里部署好了。

现在到了比较关键的一步(很坑,亲测过多次,一定要做,不然其他的微服务就没办法注册进eureka注册中心):

使用 docker exec -it eureka的id /bin/bash 进入eureka的docker容器中,然后使用cat /etc/hosts命令查看容器的IP地址:
在这里插入图片描述
将这个eureka的ip地址写入到config-server的yml文件
在这里插入图片描述
PS:其余两个微服务(bill-gateway、bill-service)的yml文件对应也都要改,eureka-server也改。总之就是4个微服务的yml文件都对应改过来!其中bill-service要改的多一些,注意配置文件中数据库的url要改成刚部署好的虚拟机容器内的mysql。
在这里插入图片描述
config-server、bill-service、bill-gateway的部署方式跟eureka-server类似,都是打jar包上传,修改dockerfile文件,构建镜像,创建并启动容器这几步,就不再赘述。

最终4个微服务在Docker中部署完成后如下:
在这里插入图片描述
成功实现3项微服务均注册进eureka注册中心:
在这里插入图片描述
网页查询账单列表也能顺利返回所期待的json格式数据列表:
在这里插入图片描述

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/盐析白兔/article/detail/696129
推荐阅读
相关标签
  

闽ICP备14008679号