快如闪电的扩容:秒级启动,弹性伸缩让您无忧

2023-10-20 10:21

本文主要是介绍快如闪电的扩容:秒级启动,弹性伸缩让您无忧,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

    • 快速扩容:秒级启动,弹性伸缩
      • 服务器秒级启动
      • 服务秒级启动
        • 升级JDK的版本
        • 通过将应用程序打包成WAR文件并部署到已经启动的Tomcat服务器上来实现秒级启动
        • 使用Spring Cloud Function和云原生技术来构建无服务器应用程序,可以实现秒级启动
          • Spring Cloud Function使用了几种技术来缩短应用程序启动时间
          • 实现秒级启动的步骤
            • 将应用程序划分为可独立部署和运行的模块
            • 使用JVM缓存技术,预热机制和功能模块化来缩短Lambda函数的启动时间。
            • 使用无服务器架构来运行应用程序
            • 使用AWS Lambda、Azure Functions、Google Cloud Functions等云服务提供商来托管应用程序
        • 使用Spring Boot的DevTools模块支持应用程序的热重载,可以在不重新启动应用程序的情况下更新应用程序
      • 弹性伸缩
        • 创建专用网络VPC
        • 安全组
        • 创建云服务器
        • 打包部署
        • Java环境
        • 启动项目
        • 开机启动任意服务
          • 1. 制作服务文件
          • 2. 制作启动脚本
          • 3. 制作停止脚本
          • 4. 增加执行权限
          • 5. 设置开机启动
        • 创建镜像
        • 继续创建多台云服务器
        • 负载均衡
        • 创建弹性伸缩
        • redis的报警规则
        • 白名单

📕我是廖志伟,一名Java开发工程师、Java领域优质创作者、CSDN博客专家、51CTO专家博主、阿里云专家博主、清华大学出版社签约作者、产品软文创造者、技术文章评审老师、问卷调查设计师、个人社区创始人、开源项目贡献者。🌎跑过十五公里、徒步爬过衡山、🔥有过三个月减肥20斤的经历、是个喜欢躺平的狠人。

📘拥有多年一线研发和团队管理经验,研究过主流框架的底层源码(Spring、SpringBoot、Spring MVC、SpringCould、Mybatis、Dubbo、Zookeeper),消息中间件底层架构原理(RabbitMQ、RockerMQ、Kafka)、Redis缓存、MySQL关系型数据库、 ElasticSearch全文搜索、MongoDB非关系型数据库、Apache ShardingSphere分库分表读写分离、设计模式、领域驱动DDD、Kubernetes容器编排等。🎥有从0到1的高并发项目经验,利用弹性伸缩、负载均衡、报警任务、自启动脚本,最高压测过200台机器,有着丰富的项目调优经验。

以梦为马,不负韶华

希望各位读者大大多多支持用心写文章的博主,现在时代变了,信息爆炸,酒香也怕巷子深,博主真的需要大家的帮助才能在这片海洋中继续发光发热,所以,赶紧动动你的小手,点波关注❤️,点波赞👍,点波收藏⭐,甚至点波评论✍️,都是对博主最好的支持和鼓励!

  • 💂 博客主页: 我是廖志伟
  • 👉开源项目:java_wxid
  • 🌥 哔哩哔哩:我是廖志伟
  • 🎏个人社区:幕后大佬
  • 🔖个人微信号SeniorRD

📥博主的人生感悟和目标

探寻内心世界,博主分享人生感悟与未来目标

  • 🍋程序开发这条路不能停,停下来容易被淘汰掉,吃不了自律的苦,就要受平庸的罪,持续的能力才能带来持续的自信。我本是是一个很普通程序员,放在人堆里,除了与生俱来的盛世美颜,就剩180的大高个了,就是我这样的一个人,默默写博文也有好多年了。
  • 📺有句老话说的好,牛逼之前都是傻逼式的坚持,希望自己可以通过大量的作品、时间的积累、个人魅力、运气、时机,可以打造属于自己的技术影响力。
  • 💥内心起伏不定,我时而激动,时而沉思。我希望自己能成为一个综合性人才,具备技术、业务和管理方面的精湛技能。我想成为产品架构路线的总设计师,团队的指挥者,技术团队的中流砥柱,企业战略和资本规划的实战专家。
  • 🎉这个目标的实现需要不懈的努力和持续的成长,但我必须努力追求。因为我知道,只有成为这样的人才,我才能在职业生涯中不断前进并为企业的发展带来真正的价值。在这个不断变化的时代,我必须随时准备好迎接挑战,不断学习和探索新的领域,才能不断地向前推进。我坚信,只要我不断努力,我一定会达到自己的目标。

CSDN

📙经过多年在CSDN创作上千篇文章的经验积累,我已经拥有了不错的写作技巧。同时,我还与清华大学出版社签下了四本书籍的合约,并将陆续在明年出版。这些书籍包括了基础篇、进阶篇、架构篇的📌《Java项目实战—深入理解大型互联网企业通用技术》📌,以及📚《解密程序员的思维密码–沟通、演讲、思考的实践》📚。具体出版计划会根据实际情况进行调整,希望各位读者朋友能够多多支持!

🌾阅读前,快速浏览目录和章节概览可帮助了解文章结构、内容和作者的重点。了解自己希望从中获得什么样的知识或经验是非常重要的。建议在阅读时做笔记、思考问题、自我提问,以加深理解和吸收知识。阅读结束后,反思和总结所学内容,并尝试应用到现实中,有助于深化理解和应用知识。与朋友或同事分享所读内容,讨论细节并获得反馈,也有助于加深对知识的理解和吸收。

💡在这个美好的时刻,本人不再啰嗦废话,现在毫不拖延地进入文章所要讨论的主题。接下来,我将为大家呈现正文内容。


快速扩容:秒级启动,弹性伸缩

服务器秒级启动

阿里云的ACK可以做到秒级启动,文档说明:通过kubectl快速搭建魔方游戏
华为云的云容器引擎 CCE可以做到秒级启动,访问链接:https://www.huaweicloud.com/product/cce.html

服务秒级启动

服务启动没有相关的产品,大多数情况都很难做到真正的秒级启动,通常都是对其进行优化,提供访问速度。

Spring Boot应用程序可以使用Spring Boot内置的Tomcat服务器快速启动,但它并不支持秒级启动。然而,对于需要秒级启动的场景,可以考虑使用以下几个方案:

升级JDK的版本

高版本的jdk做了很多优化,能提升服务启动的速度,例如jdk21版本优化了虚拟线程提升并发、新的垃圾回收器更强劲,更好的算法、更高效的工具或更新的类库版本,都有助于提高应用程序的性能和启动速度。

通过将应用程序打包成WAR文件并部署到已经启动的Tomcat服务器上来实现秒级启动

这种方式可以使用Spring Boot的maven插件将应用程序打包成WAR文件,并将WAR文件部署到Tomcat服务器中。这样做可以节省启动服务器的时间,但仍然需要一定的时间来完成新应用程序的部署和启动。当你将WAR文件部署到Tomcat服务器上时,Tomcat会自动将该WAR文件解压缩到一个文件夹中,并在服务器上自动创建一个应用程序上下文。应用程序上下文是指虚拟Web应用程序的目录,其中存放了Web应用程序的资源文件,包括JSP文件、HTML文件、Servlet类文件等。一旦应用程序上下文被创建,Tomcat就会将该应用程序注册到Servlet容器中,以便于处理客户端请求。客户端可以通过Web浏览器访问应用程序上下文,访问应用程序中的不同资源。因此,当WAR文件部署到Tomcat服务器上时,Tomcat会自动将应用程序注册到Servlet容器中,并开始处理客户端发来的请求,从而实现对应用程序接口的访问。
使用Spring Boot的maven插件将应用程序打包成WAR文件非常简单,只需要在pom.xml文件中添加以下配置:

<packaging>war</packaging>
<build><plugins><plugin><groupId>org.springframework.boot</groupId><artifactId>spring-boot-maven-plugin</artifactId><version>2.5.2</version><executions><execution><goals><goal>repackage</goal></goals></execution></executions></plugin></plugins>
</build>
使用Spring Cloud Function和云原生技术来构建无服务器应用程序,可以实现秒级启动

Spring Cloud Function是可以部署在云平台上的无状态函数式服务框架,可以将Spring Boot应用程序转换为无服务器函数。这种方式可以使用AWS Lambda或Google Cloud Functions等云原生平台。Spring Cloud Function是一款基于Spring Framework构建的,支持编写无服务器Lambda函数的工具,使用它可以让开发人员轻松地将Spring应用程序转换为无服务器Lambda函数。

Spring Cloud Function使用了几种技术来缩短应用程序启动时间

1、预热机制 预热机制可以缩短Lambda函数的启动时间。在函数被调用前,Lambda使用一个空白的容器(Cold Start)启动,这是因为为了避免资源浪费,AWS将容器变成了实例(Instance)而不是台机器。当函数被第一次调用时,AWS会立即触发容器的启动,这个过程叫做冷启动(Cold Start)。预热机制可以在函数被调用之前自动启动一个Lambda函数,并将其保持为热状态,从而避免了冷启动的成本。在每次函数调用之前,该函数将被预先热一段时间,这个时间的长度可以通过配置控制。

2、功能模块化 将应用程序划分为模块,每个模块都相对独立,可以独立部署和运行。在无服务器环境下,可以使用这种方式来降低应用程序的启动时间。因为只有需要的模块被加载,所以可以减少应用程序的启动时间。

3、JVM缓存 在无服务器环境中,由于Lambda函数的生命周期非常短,一旦函数执行完成,Lambda函数就会被销毁。为了加快应用程序的启动时间,可以使用JVM缓存技术。JVM缓存存储应用程序已经编译的代码和类文件,当函数需要被调用时,只需要从JVM缓存中加载类文件和代码,而不需要重新编译代码和加载类文件,从而大大缩短了应用程序的启动时间。

实现秒级启动的步骤
将应用程序划分为可独立部署和运行的模块

一个大型的应用程序往往包含很多个子模块,例如用户管理、订单管理、库存管理等等。为了实现秒级启动,我们可以将应用程序划分为可独立部署和运行的模块。每个模块都可以独立部署和运行,不会对其他模块造成影响。这样,当需要更新或调整某个模块时,只需要重新部署该模块,而不需要重新部署整个应用程序。这样可以大大减少部署时间和启动时间。

使用JVM缓存技术,预热机制和功能模块化来缩短Lambda函数的启动时间。

Lambda函数的启动时间包括3个部分:加载Lambda函数代码、初始化JVM运行时环境和执行Lambda函数。为了缩短Lambda函数的启动时间,我们可以采用以下方法:

一、使用JVM缓存技术

JVM缓存技术可以让JVM在运行时缓存Lambda函数的代码和资源,避免重复加载和初始化,从而加快Lambda函数的启动速度。

JVM缓存技术是利用ClassLoader缓存机制实现的。ClassLoader是Java程序运行中负责加载类、资源的组件,ClassLoader负责将类、资源加载到JVM中。Lambda函数的代码和资源也是由ClassLoader加载到JVM中的。

JVM缓存技术的原理是,当JVM第一次加载Lambda函数时,ClassLoader会将Lambda函数的代码和资源缓存到内存中。当下次使用同一Lambda函数时,ClassLoader会从缓存中获取Lambda函数的代码和资源,从而避免了重复加载和初始化。

虽然缓存可以提高启动速度,但是过度依赖缓存也会导致代码可维护性、可扩展性等方面的问题。因此,在使用JVM缓存技术时,应该把控好缓存的范围和适用场景,避免过度依赖缓存。

在使用JVM缓存技术时,也要注意避免内存泄漏的问题。如果缓存的对象没有及时释放,就会导致内存占用过高,从而影响系统的性能和稳定性。因此,在使用JVM缓存技术时,要注意及时释放缓存对象。

由于Lambda函数和方法引用本质上是代码和资源的引用,因此,在使用JVM缓存技术时,也要注意避免序列化问题。如果Lambda函数或方法引用被序列化后再反序列化,就可能导致代码和资源的丢失,从而导致程序出错。

二、预热机制

预热机制可以在启动Lambda函数之前,提前加载和初始化一些常用的类和库,从而避免在执行Lambda函数时进行加载和初始化,从而加快Lambda函数的启动速度。虽然Lambda是无服务器计算,但是启动Lambda函数的过程并不是从零开始,而是需要一些时间来加载和初始化Lambda函数。这通常是由于需要加载和初始化一些依赖项(如库、框架和类),这些依赖项与Lambda函数的执行代码相关联。这个过程被称为“启动延迟”。

启动延迟是Lambda函数的一个重要因素,因为它可以影响Lambda函数的性能和可扩展性。一个启动较慢的Lambda函数会导致更多的人等待请求的响应,这会影响用户体验。同时,如果您的Lambda函数处理大量请求,您可能需要扩展使用多个实例,而如果每个实例都需要花费很长时间来初始化,那么这个过程就会变得非常低效。因此,需要一种机制来减少启动延迟。

在实施预热机制之前,您需要确定哪些库和类是最常用的,并将它们列为预热列表。预热列表应该基于Lambda函数的实际使用情况,以及预热后能够显着减少启动时间的类和库。您还需要考虑预热过程对Lambda函数的内存使用和执行时间的影响。

预热Lambda函数是一个在启动Lambda函数之前运行的进程。该进程加载和初始化预热列表中的类和库,并执行一些预热任务,以确保它们已经准备好了。预热任务可以包括调用一些函数,设置变量和对象实例等。

预热结果应该被缓存,以便当Lambda函数需要使用它们时可以快速获取。缓存可以在内存中完成,这样可以减少磁盘I/O和网络请求,从而提高性能。您可以使用AWS Lambda的环境变量来存储预热结果,或者将它们存储在Lambda函数的本地文件系统上。

当Lambda函数启动时,它可以从缓存中获取预热结果,并直接使用它们,从而避免在执行过程中加载和初始化。这样可以大大减少Lambda函数的启动时间,提高性能和可扩展性。

实施预热机制需要以下步骤:

1、创建预热脚本
预热脚本是用来加载和初始化预热列表中的类和库的代码。该脚本应该在Lambda函数启动之前运行,并将预热结果缓存到环境变量或本地文件系统中。您可以使用Python、Node.js和其他支持的语言来编写预热脚本。

2、将预热脚本打包到Lambda函数中
将预热脚本打包到Lambda函数中,以便在Lambda函数启动时自动运行。您可以使用AWS CLI或AWS Lambda Console来上传Lambda函数。

3、设置Lambda函数的环境变量
将预热结果缓存到Lambda函数的环境变量中,以便在Lambda函数启动时直接使用。您可以使用AWS Lambda Console或AWS CLI来设置环境变量。

4、在Lambda函数中使用预热结果
Lambda函数可以从环境变量中获取预热结果,并直接使用它们,从而避免在执行过程中加载和初始化。您可以使用Python、Node.js和其他支持的语言来访问环境变量。

三、功能模块化

将Lambda函数按照功能模块划分,分别加载和初始化,从而避免加载和初始化整个Lambda函数的代码和资源,从而加快Lambda函数的启动速度。以下是按模块分离Lambda函数的最佳实践和建议:

  1. 将Lambda函数分成尽可能小的模块。每个模块应该只包含必要的代码和资源。
  2. 为每个模块创建单独的ZIP文件。这可以避免不必要的资源消耗并提高启动速度。
  3. 在Lambda函数的初始化代码中,加载所有必要的模块。这将确保只加载必要的代码和资源。
  4. 在需要时(例如,处理请求时),再加载其他模块。这将确保仅加载必要的代码和资源。
  5. 最小化使用外部依赖项。每个依赖项都需要加载和初始化,这会增加Lambda函数的启动时间。
  6. 对于大型Lambda函数,考虑使用AWS Lambda的可扩展性和高可用性功能。这将确保Lambda函数可以在需要时自动扩展,并提供更好的性能和可靠性。
使用无服务器架构来运行应用程序

无服务器架构可以让应用程序在云端运行,无需管理服务器和基础架构,从而大大缩短部署时间和启动时间。当需要扩展应用程序时,只需要增加云资源,而不需要购买和配置服务器。

无服务器架构(Serverless Architecture),也被称为函数即服务(Function as a Service, FaaS),是一种新的云计算模型,它让应用程序在云端运行,无需管理服务器和基础架构,从而大大缩短部署和启动时间,降低了运维成本,提高了应用程序的可扩展性和弹性。

与传统的基于虚拟机或容器的云计算模型不同,无服务器架构将服务的代码运行部分和基础设施的管理部分进行了分离。在传统的模型中,开发人员需要对服务器的配置、监控和维护进行管理,而在无服务器架构中,这些都是由云服务提供商(如AWS、Azure和Google Cloud等)来管理的。这使得开发人员可以专注于应用程序的开发,而不必担心基础架构的管理和维护。

无服务器架构的基本特点包括:

(1)事件驱动:无服务器架构基于事件驱动的编程模型,应用程序的代码仅在需要处理事件(如HTTP请求)时才被执行。这种编程模型可以让应用程序具有高度的弹性和可伸缩性,可以自动地扩展和收缩应用程序的资源。

(2)按需计费:无服务器架构的计费模式是按照实际的使用量来计费的。也就是说,只有当应用程序被执行时,才会进行计费,这可以大大降低应用程序的成本。

(3)无服务器管理:开发人员无需管理服务器和基础架构,不需要安装、配置和维护操作系统、Web服务器和数据库等组件。这样可以大幅降低了开发人员的工作量,同时也降低了出错的可能性。

(4)高可用性:无服务器架构具有高度的可靠性和弹性,可以自动地将应用程序的实例分布在多个数据中心,并自动处理服务器故障和其他问题。这种方式大幅提高了应用程序的可用性和可靠性。

无服务器架构的工作原理可以简述为:

(1)应用程序开发人员编写代码,将其上传到无服务器平台上。

(2)无服务器平台根据应用程序的事件驱动模型,将应用程序代码分解为函数。

(3)无服务器平台将这些函数存储在云环境中,并提供API接口,以便应用程序可以调用这些函数。

(4)当应用程序需要处理事件时,它将发送请求到无服务器平台,请求执行相应的函数。

(5)无服务器平台根据请求执行相应的函数,并返回结果给应用程序。

(6)无服务器平台根据应用程序的负载自动扩展和收缩函数的实例,并根据需要调整资源。

无服务器架构的基本组件包括:

(1)函数:函数是无服务器架构中最基本的组件,它是应用程序代码的基本单位。函数通常只完成一个简单的操作,并以无状态的方式运行。无服务器平台可以自动地为函数分配资源,并执行多个函数实例来处理请求。

(2)触发器:触发器是无服务器架构中的事件源,它会触发函数的执行。触发器可以是各种事件源,包括HTTP请求、消息队列、定时器和文件上传等。触发器可以自动地调用函数,无需手动配置。

(3)API网关:API网关是无服务器架构中的API中间件,它负责为应用程序提供外部访问的接口。API网关可以接受HTTP请求,并将请求转发给相应的函数处理。API网关还可以进行请求身份验证和授权,以确保应用程序的安全性。

(4)数据存储:数据存储是无服务器架构中的持久层,它可以为应用程序提供数据的存储和检索能力。数据存储可以是关系型数据库(如MySQL和PostgreSQL)或NoSQL数据库(如MongoDB和DynamoDB)等。

(5)日志和监控:日志和监控是无服务器架构中的管理工具,它可以提供应用程序的运行日志、性能指标和错误报告等。日志和监控还可以帮助开发人员优化应用程序的性能,并及时处理错误和故障。

函数的生命周期是指函数从创建到销毁的整个过程。无服务器架构中的函数生命周期可以分为以下几个阶段:

(1)创建:函数是在开发人员上传代码之后创建的。当代码被上传到无服务器平台时,无服务器平台将会自动地分解代码为多个函数,并将其存储在云环境中。

(2)部署:函数被部署到云环境中,并分配所需的资源(例如CPU、内存和网络带宽)。函数的部署可以根据应用程序的负载自动地进行扩展和收缩。

(3)执行:当应用程序需要执行函数时,它会向无服务器平台发送请求。无服务器平台会根据请求自动分配函数实例,并执行函数。函数可以访问应用程序的数据存储和其他服务。

(4)日志和监控:当函数执行时,无服务器平台会记录函数的运行日志和性能指标,并生成报告和警报。开发人员可以使用这些日志和监控数据来优化函数的性能,并快速处理错误和故障。

(5)销毁:当函数不再需要时,它会被销毁。无服务器平台会自动地回收函数的所有资源,并将其从云环境中删除。

使用AWS Lambda、Azure Functions、Google Cloud Functions等云服务提供商来托管应用程序

AWS Lambda、Azure Functions、Google Cloud Functions等云服务提供商提供了一种快速托管应用程序的方法。这些服务可以自动管理服务器和基础架构,而且还提供了很多高级功能,例如自动扩展、自动备份、自动恢复等等。使用这些云服务提供商可以大大加快应用程序的启动速度和运行效率。AWS Lambda、Azure Functions、Google Cloud Functions 都是云服务提供商,提供了一种快速托管应用程序的方法。它们可以自动管理服务器和基础架构,提供了很多高级功能,例如自动扩展、自动备份、自动恢复等等。

AWS Lambda 是由亚马逊公司提供的一种无服务器计算服务,可以让您运行代码而无需自己管理服务器。此服务可以自动扩展应用程序、自动备份和恢复,并支持多种编程语言和运行时。

Azure Functions 是由微软提供的一种无服务器计算服务,可以让您在云中运行代码而无需管理服务器。此服务支持多种编程语言和运行时。

Google Cloud Functions 是由谷歌提供的一种无服务器计算服务,可以让您在云中运行代码而无需管理服务器。此服务支持多种编程语言和运行时。

使用Spring Boot的DevTools模块支持应用程序的热重载,可以在不重新启动应用程序的情况下更新应用程序

Spring Boot的DevTools还提供了一些其他开发工具,例如自动重启功能,可以在修改代码后自动重启应用程序。这种方式虽然不能实现秒级启动,但可以在开发过程中提高开发效率。需要在Maven或Gradle依赖中添加以下依赖:

<dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-devtools</artifactId><scope>runtime</scope>
</dependency>

自动重启功能的原理实现是非常简单的。在启用自动重启功能后,DevTools会在后台启动一个额外的进程,这个进程会监控应用程序的类文件和资源文件的变化。

当我们修改了类文件和资源文件后,DevTools会通知应用程序的主进程,告诉它需要重新启动。为了避免频繁的重启,DevTools还提供了一个延迟时间(默认为1秒),在这个时间内如果有更改则不会重启,否则会启动一个新的进程来代替原来的应用程序进程。

当应用程序重启时,DevTools会重新加载所有的类文件和资源文件,确保应用程序的状态保持不变。这个过程类似于一个完整的应用程序启动过程,包括Spring的启动过程和应用程序的初始化过程。

自动重启功能的优点是显而易见的。它可以让我们在开发过程中快速验证更改,提高开发效率。在少量代码修改的情况下,重启的时间可以做到秒级。

但是自动重启功能也有一些缺点。首先,重启应用程序需要一定的时间,如果代码修改比较频繁,反复重启会浪费大量的时间。其次,重启应用程序可能会导致应用程序状态的丢失,例如内存中的变量和缓存等。因此,在开发过程中,我们应该尽量避免在应用程序运行时修改代码。

弹性伸缩

创建专用网络VPC

在这里插入图片描述

安全组

在这里插入图片描述

创建云服务器

在这里插入图片描述在这里插入图片描述在这里插入图片描述

打包部署

在这里插入图片描述

Java环境
#下载jdk17
wget https://download.oracle.com/java/17/latest/jdk-17_linux-x64_bin.tar.gz
#安装上传工具 以后使用命令 rz  选中文件进行上传
yum install -y lrzsz#解压
tar -xzvf jdk-17_linux-x64_bin.tar.gz#移动到指定位置; 记住全路径: /opt/user/jdk-17.0.8
mv jdk-17.0.8 /opt/user/jdk-17.0.8#配置环境变量   /opt/jdk-17.0.2
vim /etc/profile#在最后加入下面配置,注意修改 JAVA_HOME位置为你自己的位置
export JAVA_HOME=/opt/user/jdk-17.0.8
export PATH=$JAVA_HOME/bin:$PATH#使环境变量生效
source /etc/profile#验证安装成功
java -version

在这里插入图片描述

启动项目

在这里插入图片描述测试能否访问
在这里插入图片描述

开机启动任意服务

作为基础服务器,需要配置开机自启服务,方便后面自动伸缩以这台服务器为主,扩容服务器能实现开机运行java服务。

1. 制作服务文件
cd /usr/lib/systemd/system
vim springbootapp.service
#内容如下[Unit]
Description=springbootapp
After=syslog.target network.target remote-fs.target nss-lookup.target[Service]
Type=forking
ExecStart=/opt/app/app-start.sh
ExecStop=/opt/app/app-stop.sh
PrivateTmp=true[Install]
WantedBy=multi-user.target
2. 制作启动脚本
vim app-start.sh

内容如下

#!/bin/sh
export JAVA_HOME=/opt/jdk-17.0.2
export PATH=$JAVA_HOME/bin:$PATH
nohup java -Xms2048m -Xmx2048m -Xss1m -XX:MetaspaceSize=128m -XX:MaxMetaspaceSize=256m -jar /opt/app/app.jar > /opt/app/app.log 2>&1 & --spring.profiles.active=prod
echo $! > /opt/app/app-service.pid
3. 制作停止脚本
vim app-stop.sh

内容如下

#!/bin/sh
PID=$(cat /opt/app/app-service.pid)
kill -9 $PID
4. 增加执行权限
chmod +x app-start.sh
chmod +x app-stop.sh
5. 设置开机启动
systemctl daemon-reload
systemctl status springbootapp
systemctl enable springbootapp

关闭开机自启动

systemctl disable springbootapp

立即执行启动服务脚本

systemctl start springbootapp

立即执行关闭服务脚本

systemctl stop springbootapp
创建镜像

在这里插入图片描述在这里插入图片描述

继续创建多台云服务器

在这里插入图片描述在这里插入图片描述在这里插入图片描述
在这里插入图片描述

负载均衡

在这里插入图片描述
在这里插入图片描述直接通过负载均衡的ip访问服务的8888端口
在这里插入图片描述测试一下
在这里插入图片描述
在这里插入图片描述在这里插入图片描述在这里插入图片描述

创建弹性伸缩

在这里插入图片描述在这里插入图片描述

在这里插入图片描述
在这里插入图片描述在这里插入图片描述
通常还需要配置目标追踪规则才能实现扩容。

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

在这里插入图片描述

在这里插入图片描述如果我配置的期望值是1台服务器,那么过一段时间没有负载就会直接把你创建的实例给删除了,仅保留一台。
在这里插入图片描述
在这里插入图片描述

redis的报警规则

在这里插入图片描述在这里插入图片描述
在这里插入图片描述
在这里插入图片描述在这里插入图片描述

白名单

这里设置和云服务器的一样,可以在同一个网络访问,其他ip即便知道用户名密码和主机ip也无法访问。
在这里插入图片描述

CSDN

🔔如果您需要转载或者搬运这篇文章的话,非常欢迎您私信我哦~

这篇关于快如闪电的扩容:秒级启动,弹性伸缩让您无忧的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/246502

相关文章

bat脚本启动git bash窗口,并执行命令方式

《bat脚本启动gitbash窗口,并执行命令方式》本文介绍了如何在Windows服务器上使用cmd启动jar包时出现乱码的问题,并提供了解决方法——使用GitBash窗口启动并设置编码,通过编写s... 目录一、简介二、使用说明2.1 start.BAT脚本2.2 参数说明2.3 效果总结一、简介某些情

HDFS—集群扩容及缩容

白名单:表示在白名单的主机IP地址可以,用来存储数据。 配置白名单步骤如下: 1)在NameNode节点的/opt/module/hadoop-3.1.4/etc/hadoop目录下分别创建whitelist 和blacklist文件 (1)创建白名单 [lytfly@hadoop102 hadoop]$ vim whitelist 在whitelist中添加如下主机名称,假如集群正常工作的节

MySQL数据库宕机,启动不起来,教你一招搞定!

作者介绍:老苏,10余年DBA工作运维经验,擅长Oracle、MySQL、PG、Mongodb数据库运维(如安装迁移,性能优化、故障应急处理等)公众号:老苏畅谈运维欢迎关注本人公众号,更多精彩与您分享。 MySQL数据库宕机,数据页损坏问题,启动不起来,该如何排查和解决,本文将为你说明具体的排查过程。 查看MySQL error日志 查看 MySQL error日志,排查哪个表(表空间

springboot3打包成war包,用tomcat8启动

1、在pom中,将打包类型改为war <packaging>war</packaging> 2、pom中排除SpringBoot内置的Tomcat容器并添加Tomcat依赖,用于编译和测试,         *依赖时一定设置 scope 为 provided (相当于 tomcat 依赖只在本地运行和测试的时候有效,         打包的时候会排除这个依赖)<scope>provided

内核启动时减少log的方式

内核引导选项 内核引导选项大体上可以分为两类:一类与设备无关、另一类与设备有关。与设备有关的引导选项多如牛毛,需要你自己阅读内核中的相应驱动程序源码以获取其能够接受的引导选项。比如,如果你想知道可以向 AHA1542 SCSI 驱动程序传递哪些引导选项,那么就查看 drivers/scsi/aha1542.c 文件,一般在前面 100 行注释里就可以找到所接受的引导选项说明。大多数选项是通过"_

Java ArrayList扩容机制 (源码解读)

结论:初始长度为10,若所需长度小于1.5倍原长度,则按照1.5倍扩容。若不够用则按照所需长度扩容。 一. 明确类内部重要变量含义         1:数组默认长度         2:这是一个共享的空数组实例,用于明确创建长度为0时的ArrayList ,比如通过 new ArrayList<>(0),ArrayList 内部的数组 elementData 会指向这个 EMPTY_EL

用命令行的方式启动.netcore webapi

用命令行的方式启动.netcore web项目 进入指定的项目文件夹,比如我发布后的代码放在下面文件夹中 在此地址栏中输入“cmd”,打开命令提示符,进入到发布代码目录 命令行启动.netcore项目的命令为:  dotnet 项目启动文件.dll --urls="http://*:对外端口" --ip="本机ip" --port=项目内部端口 例: dotnet Imagine.M

Linux服务器Java启动脚本

Linux服务器Java启动脚本 1、初版2、优化版本3、常用脚本仓库 本文章介绍了如何在Linux服务器上执行Java并启动jar包, 通常我们会使用nohup直接启动,但是还是需要手动停止然后再次启动, 那如何更优雅的在服务器上启动jar包呢,让我们一起探讨一下吧。 1、初版 第一个版本是常用的做法,直接使用nohup后台启动jar包, 并将日志输出到当前文件夹n

衡石分析平台使用手册-单机安装及启动

单机安装及启动​ 本文讲述如何在单机环境下进行 HENGSHI SENSE 安装的操作过程。 在安装前请确认网络环境,如果是隔离环境,无法连接互联网时,请先按照 离线环境安装依赖的指导进行依赖包的安装,然后按照本文的指导继续操作。如果网络环境可以连接互联网,请直接按照本文的指导进行安装。 准备工作​ 请参考安装环境文档准备安装环境。 配置用户与安装目录。 在操作前请检查您是否有 sud

SpringBoot项目是如何启动

启动步骤 概念 运行main方法,初始化SpringApplication 从spring.factories读取listener ApplicationContentInitializer运行run方法读取环境变量,配置信息创建SpringApplication上下文预初始化上下文,将启动类作为配置类进行读取调用 refresh 加载 IOC容器,加载所有的自动配置类,创建容器在这个过程