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

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

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

开启 Docker 远程访问

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

ExecStart=/usr/bin/dockerd -H fd:// --containerd=/run/containerd/containerd.sock -H tcp://0.0.0.0:2376 -H unix:///var/run/docker.sock
systemctl daemon-reload
systemctl restart docker.service

docker-maven-plugin 构建 docker 镜像

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

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

<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>

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

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 指令

mvn clean package docker:build -DskipTests

执行效果如下:
image.png

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

服务正常响应!

使用 docker-compose 启动

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

SpringCloud 的容器化部署还是比较简单的,你也来试试好了!

  • 架构

    我们平时所说的“架构”主要是指软件架构,这是有关软件整体结构与组件的抽象描述,用于指导软件系统各个方面的设计。另外还有“业务架构”、“网络架构”、“硬件架构”等细分领域。

    96 引用 • 390 回帖 • 1 关注
  • Spring

    Spring 是一个开源框架,是于 2003 年兴起的一个轻量级的 Java 开发框架,由 Rod Johnson 在其著作《Expert One-On-One J2EE Development and Design》中阐述的部分理念和原型衍生而来。它是为了解决企业应用开发的复杂性而创建的。框架的主要优势之一就是其分层架构,分层架构允许使用者选择使用哪一个组件,同时为 JavaEE 应用程序开发提供集成的框架。

    732 引用 • 1290 回帖 • 711 关注
  • 微服务

    微服务架构是一种架构模式,它提倡将单一应用划分成一组小的服务。服务之间互相协调,互相配合,为用户提供最终价值。每个服务运行在独立的进程中。服务于服务之间才用轻量级的通信机制互相沟通。每个服务都围绕着具体业务构建,能够被独立的部署。

    64 引用 • 128 回帖 • 11 关注
回帖
请输入回帖内容...