Spring Cloud Alibaba微服务实战十五 - SpringCloud 容器化部署

作者简介:大家好,我是smart哥,前中兴通讯、美团架构师,现某互联网公司CTO

联系qq:184480602,加我进群,大家一起学习,一起进步,一起对抗互联网寒冬

学习必须往深处挖,挖的越深,基础越扎实!

阶段1、深入多线程

阶段2、深入多线程设计模式

阶段3、深入juc源码解析


阶段4、深入jdk其余源码解析


阶段5、深入jvm源码解析

码哥源码部分

码哥讲源码-原理源码篇【2024年最新大厂关于线程池使用的场景题】

码哥讲源码【炸雷啦!炸雷啦!黄光头他终于跑路啦!】

码哥讲源码-【jvm课程前置知识及c/c++调试环境搭建】

​​​​​​码哥讲源码-原理源码篇【揭秘join方法的唤醒本质上决定于jvm的底层析构函数】

码哥源码-原理源码篇【Doug Lea为什么要将成员变量赋值给局部变量后再操作?】

码哥讲源码【你水不是你的错,但是你胡说八道就是你不对了!】

码哥讲源码【谁再说Spring不支持多线程事务,你给我抽他!】

终结B站没人能讲清楚红黑树的历史,不服等你来踢馆!

打脸系列【020-3小时讲解MESI协议和volatile之间的关系,那些将x86下的验证结果当作最终结果的水货们请闭嘴】

SpringCloud Alibaba 系列文章已经写了 15 篇了,基本框架大体完成,业务相关的逻辑还需要根据项目本身的业务进行梳理改造。今天将是本系列的最后一篇 - SpringCloud 容器化部署(理论上最后一篇,不排除后面会对相关组件进行升级)

看在写了这么多的份上是不是应该点个 在看 呢?

开启 Docker 远程访问

由于我是在 windows 上进行开发没有安装 docker,所以需要找一台安装好 docker 的服务器并开启远程访问。使用 mac 的同学请忽略。

  • 打开 docker 配置文件
    vi /lib/systemd/system/docker.service
  • 开放 2376 端口
    找到ExecStart=/usr/bin/dockerd所在行,在后面追加-H tcp://0.0.0.0:2376 -H unix:///var/run/docker.sock,修改完成的效果如下:
    ExecStart=/usr/bin/dockerd -H fd:// --containerd=/run/containerd/containerd.sock -H tcp://0.0.0.0:2376 -H unix:///var/run/docker.sock
  • 重启 docker 服务
    systemctl daemon-reload
    systemctl restart docker.service
  • 使用 netstat 查看端口
    netstat -nptl

  • 访问/info,确定端口正常开放
    curl http://127.0.0.1:2376/info

docker-maven-plugin 构建 docker 镜像

在开始打包之前一定要先在bomcommon模块执行mvn clean install命令,否则打包不成功。

看过本系列文章的人一定也知道 docker 和 docker-compose 的相关指令了,这里就不再说明。

  • 在需要构建组件的模块引入 docker-maven-plugin 插件
    <plugin>
    	<groupId>com.spotify</groupId>
    	<artifactId>docker-maven-plugin</artifactId>
    	<version>1.2.2</version>
    	<configuration>
    		<imageName>${project.artifactId}</imageName>
    		<imageTags>
    			<imageTag>latest</imageTag>
    		</imageTags>
    		<!--指定Dockerfile路径-->
    		<dockerDirectory>${project.basedir}/src/main/docker</dockerDirectory>
    		<dockerHost>http://xxx.xx.xx.xx:2376</dockerHost>
    		<resources>
    			<resource>
    				<targetPath>/</targetPath>
    				<!--${project.basedir}/target-->
    				<directory>${project.build.directory}</directory>
    				<!--${project.artifactId}-${project.version}-->
    				<include>${project.build.finalName}.jar</include>
    			</resource>
    		</resources>
    	</configuration>
    </plugin>

这里端口与前面开放的端口保持一致。

  • 在模块的 src/main/docker 目录下建立 Dockerfile 文件
    FROM openjdk:8-jdk-alpine
    VOLUME /tmp
    ADD cloud-gateway-1.0.0.jar app.jar
    RUN sh -c 'touch /app.jar'
    ENTRYPOINT ["java","-Djava.security.egd=file:/dev/./urandom","-jar","/app.jar"]

每个模块需要自行修改 ADD 指令

  • 在模块下执行如下命令构建 docker 镜像
    mvn clean package docker:build -DskipTests

执行效果如下:

  • 构建完成后登陆服务器查看 docker 镜像docker images

  • 启动镜像,带上--rm 指令便于删除容器。

    docker run -d -p 5000:5000  --rm auth-service
    docker run -d -p 8010:8010  --rm account-service
    docker run -d -p 8090:8090  --rm cloud-gateway
  • 查看是否正常启动

  • 使用 postman 进行测试

服务正常响应!

使用 docker-compose 启动

  • 创建 cloud-service.yml 文件编排镜像
    version: "3"
    services:
      auth-service:
        container_name: auth-service
        image: auth-service:latest
        ports:
          - "5000:5000"
        restart: always
    
      cloud-gateway:
        container_name: cloud-gateway
        image: cloud-gateway:latest
        ports:
          - "8090:8090"
        restart: always
    
      account-service:
        container_name: account-service
        image: account-service:latest
        ports:
          - "8010:8010"
        restart: always
  • 将文件上传至服务器,使用如下脚本启动服务
    docker-compose -f cloud-service up

  • 使用 postman 进行测试

    服务正常响应!

SpringCloud 的容器化部署还是比较简单的,你还不来试一下?

  • 17
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值