Docker学习篇——使用Docker部署账单微服务项目
Docker概念Docker 是一个开源的应用容器引擎诞生于 2013 年初,基于 Go 语言实现, dotCloud 公司出品(后改名为Docker Inc)Docker 可以让开发者打包他们的应用以及依赖包到一个轻量级、可移植的容器中,然后发布到任何流行的Linux 机器上容器是完全使用沙箱机制,相互隔离容器性能开销极低Docker 从 17.03 版本之后分为 CE(Community Ed
Docker概念
- Docker 是一个开源的应用容器引擎
- 诞生于 2013 年初,基于 Go 语言实现, dotCloud 公司出品(后改名为Docker Inc)
- Docker 可以让开发者打包他们的应用以及依赖包到一个轻量级、可移植的容器中,然后发布到任何流行的Linux 机器上
- 容器是完全使用沙箱机制,相互隔离
- 容器性能开销极低
- Docker 从 17.03 版本之后分为 CE(Community Edition: 社区版)和 EE(Enterprise Edition: 企业版)
总结:docker是一种能解决容器款环境迁移问题的容器技术。
本次任务旨在使用Docker部署账单微服务项目,具体任务过程需要在虚拟机CentOS7里部署MySQL、Eureka Server、账单微服务、网关微服务、配置微服务。在虚拟机中部署需先在外部机上部署测试好,外部机上具体实现步骤可参考Spring Cloud重构个人记账项目(账单微服务、网关微服务、配置微服务)
虚拟机上发布spring boot项目需要使用到dockerfile
Dockerfile概念
- Dockerfile 是一个文本文件
- 包含了一条条的指令
- 每一条指令构建一层,基于基础镜像,最终构建出一个新的镜像
- 对于开发人员:可以为开发团队提供一个完全一致的开发环境
- 对于测试人员:可以直接拿开发时所构建的镜像或者通过Dockerfile文件构建一个新的镜像开始工作了
- 对于运维人员:在部署时,可以实现应用的无缝移植
部署MySQL
- 搜索mysql镜像
docker search mysql
- 拉取mysql镜像
docker pull mysql:5.6
- 创建容器,设置端口映射、目录映射
# 在/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
参数说明:
- -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 用户的密码。
- 进入容器,操作mysql
docker exec -it c_mysql /bin/bash
mysql -uroot -p123456
show databases;
create database db1;
- 使用外部机器连接容器中的mysql
这里我用Navicat通过端口映射连接容器内的数据库c_mysql,将外部机里的两张表(bill_、bill_type_)直接拷了过来:
dockerfile发布eureka-server
install编译eureka-server项目,成功后将jar包拷出来
jar包拷进虚拟机里的/root/docker-files目录下,输入:
vim eureka_file
文件按如下编辑:
镜像文件(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 .
启动容器
docker run -id -p 9000:10086 eureka
到这里,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格式数据列表:
更多推荐
所有评论(0)