dockerfile-pom打包及docker feign调用

1.打包发布到本地

 			<plugin>
                <groupId>com.spotify</groupId>
                <artifactId>dockerfile-maven-plugin</artifactId>
                <version>1.4.10</version>
                <configuration>
                    <dockerfile>DockerFile</dockerfile>
                    <repository>${docker.image.prefix}/${project.artifactId}</repository>
                    <buildArgs>
                        <JAR_FILE>target/${project.build.finalName}.jar</JAR_FILE>
                    </buildArgs>
                </configuration>
            </plugin>

pom添加此dockerfile插件。
若版本为1.4以下会出现 ,
Could not acquire image ID or digest following build
<dockerfile>标签为指定dockerfile文件目录,在不指定情况下根目录新建Dockerfile可能会找不到而报错:
Could not acquire image ID or digest following build
根目录新建Dockerfile(pom同级)

FROM java:8
EXPOSE 10012
ARG JAR_FILE
ADD ${JAR_FILE} /server-sync.jar
ENTRYPOINT ["java", "-jar","/server-sync.jar"]

这里根据需求写。

打开docker的Expose daemon on tcp://localhost:2375 without TLS
我这边使用的时windows直接勾选就行。
docker端口打开

然后执行

mvn clean package dockerfile:build -Dskiptests

就是maven clean+mvn package+dockerfile打包到容器,跳过测试。

feign调用

feign时springcloud的一个组件,服务通过注册到eureka发现服务,然后使用feign时,会自动去寻找对应的服务的地址端口。比resttemplate方便的地方在于不用写服务地址,就算服务地址改变了也不用更改任何代码。

docker说白了就是虚拟机,在系统下构建一块虚拟机linux,那docker首先会从网卡中分出一个网段,docker默认为桥接。然后分配到各个docker容器(虚拟机)下。
相当于docker在主机下面重新开了一个路由器,然后由docker分配ip,
那么当docker容器处于同一个主机时,我们只需要配置

eureka:
  instance:
	prefer-ip-address: true

把真实ip显示出来就行,此ip为docker分配给容器的ip。那么feign获得的此ip可以直接使用。

当服务处于不同主机时,使用此IP肯定时无法访问,不同主机之间应该使用主机ip来访问,docker通过映射端口也可以通过主机地址访问内到容器。

我们可以指定环境变量

EUREKA_INSTANCE_IP-ADDRESS=192.168.0.58

192.168.0.58 ip为主机ip,
可以在docker启动时配置,也可以写在dockerfile中
启动时添加参数

-e "EUREKA_INSTANCE_IP-ADDRESS=192.168.0.58"

dockerfile添加参数

ENV EUREKA_INSTANCE_IP-ADDRESS 192.168.0.58

192.168.0.58 ip为主机ip,

当然 nginx也是不错的选择,在此部一一赘述。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值