Docker学习之运行SpringBoot微服务


前言

许久不来一发,很早之前就写过 Dockerfile,只是迟迟没有记录而已。

步骤

这里我们以短信、邮件发送服务为例,演示整个过程,目录下事先生成了相关启动JAR,项目采用 springboot+dubbo对方提供RPC服务。

创建 Dockerfile 文件

# 基础镜像:仓库是java
FROM java:7-jre
# 当前镜像的维护者和联系方式
MAINTAINER itstyle 345849402@qq.com
# 挂载卷
VOLUME /tmp
# 将打包好的springBoot程序拷贝到容器中的指定位置
ADD itstyle_send.jar /opt/app.jar
# 容器对外暴露端口
EXPOSE 8080
# 容器启动后需要执行的命令(ENTRYPOINT ["java","-Djava.security.egd=file:/dev/./urandom","-jar","-Denv=DEV","/opt/app.jar"])
CMD java -Djava.security.egd=file:/dev/./urandom -jar /opt/app.jar

执行 docker build 进行构建

执行docker build命令,docker就会根据Dockerfile里你定义好的命令进行构建新的镜像。

docker build -t itstyle_send:v1 .

构建过程

Sending build context to Docker daemon 100.6 MB
Step 1 : FROM java:7-jre
Trying to pull repository docker.io/library/java ... 
7-jre: Pulling from docker.io/library/java
5040bd298390: Pull complete 
fce5728aad85: Pull complete 
c42794440453: Pull complete 
9789263043d1: Pull complete 
028c93201aa7: Pull complete 
Digest: sha256:6fb55e5ffc4ce926c320faa5fb807ed1bccd84ccbbe278109c67c5b38684e633
 ---> b0006d129082
Step 2 : MAINTAINER itstyle 345849402@qq.com
 ---> Running in 3eb849897209
 ---> 804057905232
Removing intermediate container 3eb849897209
Step 3 : VOLUME /tmp
 ---> Running in 60c526a95e46
 ---> dc3d00181d4a
Removing intermediate container 60c526a95e46
Step 4 : ADD acts_send.jar /opt/app.jar
 ---> e55343642421
Removing intermediate container 09b296b4e9a3
Step 5 : EXPOSE 8080
 ---> Running in fb4d820d9a91
 ---> da660a4e78e3
Removing intermediate container fb4d820d9a91
Step 6 : CMD java -Djava.security.egd=file:/dev/./urandom -jar /opt/app.jar
 ---> Running in adb0a7921410
 ---> 0b7adaac48d9
Removing intermediate container adb0a7921410
Successfully built 0b7adaac48d9

查看镜像

docker images

如果出现以下说明构建成功:

REPOSITORY   TAG   IMAGE ID   CREATED    SIZE
itstyle_send  v1   0b7adaac48d9 7 minutes ago   374.5 MB

开发者可以把自己制作的镜像push到远端仓库,在任何一个系统上pull下来就可以直接部署了,做到一处制作,出处运行。

创建并运行容器

docker run -d --name itstyle_send  -p 8080:8080 itstyle_send:v1

查看日志

docker logs -f itstyle_send

问题

不过这里有一个问题,最终导致服务并没有启动成功。由于服务对外提供 RPC 服务,使用 zookeeper 作为注册中心,而容器并不能访问宿机以及相关内网网段的IP。

宿机网段:192.168..,容器网段:172.17..

解决方案

如果多台服务器在一个局域网,可以把容器跟宿机配置成一个网段。网络配置见:https://blog.52itstyle.com/archives/2328/

如果是外网地址,使用zookeeper中节点digest授权认证或者防火墙安全组。

qrcode_for_gh_bf7a27ade681_258.jpg

作者: 小柒

出处: https://blog.52itstyle.com

分享是快乐的,也见证了个人成长历程,文章大多都是工作经验总结以及平时学习积累,基于自身认知不足之处在所难免,也请大家指正,共同进步。

本文版权归作者所有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出, 如有问题, 可邮件(345849402@qq.com)咨询。