java微服务自动化部署惨死!

284 阅读1分钟

胎死过程

1.各个微服务模块分别用maven打jar包,然后移到服务器,分开启动。 成功,太low。

2.Dockerfile生成镜像启动。可以配合maven插件使用,直接生成镜像到服务器。也🆗,还是不够爽。

3.Docker-compose启动镜像。需要手启动。就快到自动化了,冲。

4.自动化部署jenkins搭建。 GG啊!

  • 插件初始化,git,maven,jdk等
  • 创建一个工程,配置源代码,构建脚本,构建后,触发钩子等。

因为是本地虚拟机启动的jenkins 配置的源码确实官方gitee的地址,总是超时启动,GG

  • linux配置gitlab服务,配置完毕,结果启动失败,继续GG。

不能验证jenkins和gitlab在同一本地是否可行。。难顶。

dockerfile

FROM java:8
VOLUME /tmp
ADD *.jar app.jar
CMD ["--server.port=9001"]
EXPOSE 9001
ENTRYPOINT ["java","-Djava.security.egd=file:/dev/./urandom","-jar","/app.jar"]

docker-compose.yml

version: "3"
services:
  pay-9001:
    image: pay_9001:1.0-SNAPSHOT
    restart: on-failure
    ports:
      - 9001:9001
    deploy:
      replicas: 1
      restart_policy:
        condition: on-failure
      resources:
        limits:
          cpus: '2'
          memory: 10M
  order-83:
    image: order_83:1.0-SNAPSHOT
    restart: on-failure
    ports:
      - 83:83
    deploy:
      replicas: 1
      restart_policy:
        condition: on-failure
      resources:
        limits:
          cpus: '2'
          memory: 10M

docker的maven插件配置


            <plugin>
                <groupId>com.spotify</groupId>
                <artifactId>docker-maven-plugin</artifactId>
                <version>1.0.0</version>

                <!--将插件绑定在某个phase执行-->
                <executions>
                    <execution>
                        <id>build-image</id>
                        <!--将插件绑定在package这个phase上。也就是说,用户只需执行mvn package ,就会自动执行mvn docker:build-->
                        <phase>package</phase>
                        <goals>
                            <goal>build</goal>
                        </goals>
                    </execution>
                </executions>

                <configuration>
                    <!--指定生成的镜像名-->
                    <imageName>${docker.image.prefix}/${project.artifactId}:${project.version}</imageName>
                    <!--指定标签-->
                    <imageTags>
                        <imageTag>${project.version}</imageTag>
                    </imageTags>
                    <!-- 指定 Dockerfile 路径  ${project.basedir}:项目根路径下-->
                    <dockerDirectory>${project.basedir}</dockerDirectory>

                    <!--指定远程 docker api地址-->
                    <dockerHost>http://192.168.xx.xxx:2375</dockerHost>

                    <!-- 这里是复制 jar 包到 docker 容器指定目录配置 -->
                    <resources>
                        <resource>
                            <targetPath>/</targetPath>
                            <!--jar 包所在的路径  此处配置的 即对应 target 目录-->
                            <directory>${project.build.directory}</directory>
                            <!-- 需要包含的 jar包 ,这里对应的是 Dockerfile中添加的文件名 -->
                            <include>${project.build.finalName}.jar</include>
                        </resource>
                    </resources>

                    <!-- 以下两行是为了docker push到DockerHub使用的。 -->
                    <!--<serverId>docker-hub</serverId>
                    <registryUrl>https://index.docker.io/v1</registryUrl>-->
                </configuration>
            </plugin>

jenkins的构建脚本不知可行否

clean package
docker compose up

参考资料:
blog.csdn.net/qq_37823605…
www.cnblogs.com/lucoo/p/118…
blog.csdn.net/dujiesheng/…


表示裂开好爽