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也是不错的选择,在此部一一赘述。

猜你喜欢

转载自blog.csdn.net/qq_27275851/article/details/110490520