• 微服务迁移记(七):使用docker发布 springcloud应用


    本章节,我们通过docker将zyproject-configserver工程发布到服务器。zyproject-configserver的搭建过程见:《微服务迁移记(三):配置中心SpringCloud Config搭建

    一、环境介绍

    docker服务器:192.168.0.12,已搭建好docker环境,并通过端口2375可以正常访问。

    consul服务器:192.168.0.12,8500可正常访问

    WEB服务器:192.168.0.12,与redis和consul同一台服务器。

    数据库服务器:192.168.0.7,3306端口可正常访问。

    二、配置文件

    bootstrap-prd.yml配置:

    spring:
      application:
        name: config-server
      cloud:
        consul:
          host: 192.168.0.12
          port: 8500
          discovery:
            hostname: 192.168.0.12 #web服务和consul在一台服务器上
        config:
          server:
            jdbc:
              sql: SELECT akey,avalue FROM tb_config_server WHERE application=? AND aprofile=? AND label=?
      datasource:
        driver-class-name: com.mysql.jdbc.Driver
        url: jdbc:mysql://192.168.0.6:3306/zyconfig??useUnicode=true&characterEncoding=UTF-8&useSSL=false
        username: root
        password: xxxxx
      profiles:
        active: jdbc
    server:
      port: 9000
    

      

    我们将服务发布至192.168.0.12 容器的 /home/app目录下,并运行。Dockerfile配置

    FROM java:8
    # 下面两行调用不到,先不配置。profile还是配置在bootstrap.yml中 # ARG JRE_FILE # ENV PROFILE prd ADD target/*.jar /home/app/config.jar # EXPOSE命令只是声明了容器应该打开的端口并没有实际上将它打开! # 我们是没有办法在Dockerfile里面进行端口映射的,我们只能在容器启动的时候或者在docker-compose文件中使用ports来指定将要映射的端口 EXPOSE 8000 ENTRYPOINT java ${JAVA_OPTS} -Djava.security.egd=file:/dev/./urandom -Duser.timezone=Asia/Shanghai -Dfile.encoding=UTF-8 -Dspring.profile.active=${PROFILE} -jar /home/app/config.jar

      

    三、docker发布

    1. 在idea中新建一个docker(file->setting->Build,Execution,Deployment->docker),输入服务器地址和端口,并提示“Connection successful”

    2. 父级工程的pom中引用docker相关配置

    <!--docker配置-->
        <build>
            <plugins>
                <!--
            不能在父工程引用插件,在每个需要发布成web服务的工程引用
            common、api接口两个工程不需要发布,不能引用
            <plugin> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-maven-plugin</artifactId> </plugin>-->
    <plugin> <groupId>com.spotify</groupId> <artifactId>docker-maven-plugin</artifactId> <executions> <execution> <id>default</id> <goals> <goal>build</goal> <goal>push</goal> </goals> </execution> </executions> <configuration> <imageName>${project.artifactId}</imageName> <imageTags> <imageTag>latest</imageTag> </imageTags> <buildArgs> <JAR_FILE>${project.build.finalName}.jar</JAR_FILE> </buildArgs> </configuration> </plugin> </plugins> </build>

    zyproject-configserver工程中只需要引用maven插件即可

    <build>
            <plugins>
                <plugin>
                    <groupId>org.springframework.boot</groupId>
                    <artifactId>spring-boot-maven-plugin</artifactId>
                </plugin>
                <plugin>
                    <groupId>com.spotify</groupId>
                    <artifactId>docker-maven-plugin</artifactId>
                </plugin>
            </plugins>

    3. 打包,执行maven clean package

    可以直接在idea右边的maven工具栏中双击clean,再双击package完成jar包生成。

    4. 编辑idea的configuration,新增一个docker发布项

    注意:Dockerfile并不能将容器端口映射至服务器外部端口,所以我们在Configuration中配置端口映射8000->8000(config最好内外一致,否则注册中心会找不到服务)

    6. 开始发布,选择到刚新建的docker运行。可以在下方看到发布和容器内tomcat运行日志

     

    访问:http://192.168.0.12:8000/actuator/health

    {
      status: "UP"
    }

    当然你也可以登录服务器,使用docker命令查看容器的运行状态。

    参考:《服务端docker 常用命令

  • 相关阅读:
    如何提高系统吞吐性能
    若依项目安装注意事项
    VueTreeselect
    【win10 系统】idea 修改 Git 密码和账号方法
    事件总线
    HangFire【一】
    gRPC学习一【基础】
    .NET Core API 网关Ocelot
    Quartz【一】
    .NET Core API 自动生成实体类
  • 原文地址:https://www.cnblogs.com/zhouyu629/p/12508459.html
Copyright © 2020-2023  润新知