Spring Cloud Cloud Foundry 使用教程
项目介绍
Spring Cloud Cloud Foundry 是一个用于在 Cloud Foundry 平台上运行 Spring Cloud 应用的项目。Cloud Foundry 是一个平台即服务(PaaS),它提供了一种“服务”的概念,这些服务可以绑定到应用,本质上是为应用提供包含凭证的环境变量(例如服务的地址和用户名)。
Spring Cloud Cloud Foundry 项目包括以下模块:
- spring-cloud-cloudfoundry-commons:配置基于 Reactor 的 Cloud Foundry Java 客户端 v3.0,可以独立使用。
- spring-cloud-cloudfoundry-web:为 Web 应用提供一些增强功能的基本支持。
- spring-cloud-cloudfoundry-discovery:提供 Spring Cloud Commons DiscoveryClient 的实现,以便可以使用 @EnableDiscoveryClient 并提供凭证,然后直接使用 DiscoveryClient 或通过 LoadBalancerClient。
项目快速启动
环境准备
确保你已经安装了以下工具和环境:
- JDK 1.8 或更高版本
- Maven
- Cloud Foundry CLI
代码示例
以下是一个简单的 Spring Boot 应用示例,展示了如何在 Cloud Foundry 上运行 Spring Cloud 应用。
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.client.discovery.EnableDiscoveryClient;
@SpringBootApplication
@EnableDiscoveryClient
public class CloudFoundryDemoApplication {
public static void main(String[] args) {
SpringApplication.run(CloudFoundryDemoApplication.class, args);
}
}
部署到 Cloud Foundry
-
编译并打包应用:
mvn clean package -
使用 Cloud Foundry CLI 登录并部署应用:
cf login -a https://api.run.pivotal.io cf push my-app -p target/my-app.jar
应用案例和最佳实践
案例一:服务发现
在 Cloud Foundry 上,可以使用 spring-cloud-cloudfoundry-discovery 模块来实现服务发现。以下是一个简单的示例:
import org.springframework.cloud.client.ServiceInstance;
import org.springframework.cloud.client.discovery.DiscoveryClient;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RestController;
import java.util.List;
@RestController
public class DiscoveryController {
private final DiscoveryClient discoveryClient;
public DiscoveryController(DiscoveryClient discoveryClient) {
this.discoveryClient = discoveryClient;
}
@GetMapping("/service-instances/{applicationName}")
public List<ServiceInstance> serviceInstancesByApplicationName(
@PathVariable String applicationName) {
return this.discoveryClient.getInstances(applicationName);
}
}
最佳实践
- 使用环境变量:在 Cloud Foundry 中,使用环境变量来配置应用的凭证和设置。
- 监控和日志:利用 Cloud Foundry 的监控和日志功能来跟踪应用的性能和错误。
典型生态项目
Spring Cloud Connectors
Spring Cloud Connectors 是一个用于简化连接到服务(如数据库、消息队列等)的库。它与 Spring Cloud Cloud Foundry 结合使用,可以更方便地绑定和管理服务。
Spring Cloud Config
Spring Cloud Config 提供外部化配置支持,可以在不重新部署应用的情况下更新配置。它与 Cloud Foundry 结合使用,可以实现动态配置管理。
Spring Cloud Gateway
Spring Cloud Gateway 是一个基于 Spring Framework 5, Project Reactor 和 Spring Boot 2.0 的 API 网关。它可以与 Cloud Foundry 结合使用,提供路由、过滤和负载均衡等功能。
通过以上模块和工具的结合使用,可以构建一个强大且灵活的 Cloud Foundry 上的 Spring Cloud 应用生态系统。
AutoGLM-Phone-9BAutoGLM-Phone-9B是基于AutoGLM构建的移动智能助手框架,依托多模态感知理解手机屏幕并执行自动化操作。Jinja00
Kimi-K2-ThinkingKimi K2 Thinking 是最新、性能最强的开源思维模型。从 Kimi K2 开始,我们将其打造为能够逐步推理并动态调用工具的思维智能体。通过显著提升多步推理深度,并在 200–300 次连续调用中保持稳定的工具使用能力,它在 Humanity's Last Exam (HLE)、BrowseComp 等基准测试中树立了新的技术标杆。同时,K2 Thinking 是原生 INT4 量化模型,具备 256k 上下文窗口,实现了推理延迟和 GPU 内存占用的无损降低。Python00
GLM-4.6V-FP8GLM-4.6V-FP8是GLM-V系列开源模型,支持128K上下文窗口,融合原生多模态函数调用能力,实现从视觉感知到执行的闭环。具备文档理解、图文生成、前端重构等功能,适用于云集群与本地部署,在同类参数规模中视觉理解性能领先。Jinja00
HunyuanOCRHunyuanOCR 是基于混元原生多模态架构打造的领先端到端 OCR 专家级视觉语言模型。它采用仅 10 亿参数的轻量化设计,在业界多项基准测试中取得了当前最佳性能。该模型不仅精通复杂多语言文档解析,还在文本检测与识别、开放域信息抽取、视频字幕提取及图片翻译等实际应用场景中表现卓越。00
GLM-ASR-Nano-2512GLM-ASR-Nano-2512 是一款稳健的开源语音识别模型,参数规模为 15 亿。该模型专为应对真实场景的复杂性而设计,在保持紧凑体量的同时,多项基准测试表现优于 OpenAI Whisper V3。Python00
GLM-TTSGLM-TTS 是一款基于大语言模型的高质量文本转语音(TTS)合成系统,支持零样本语音克隆和流式推理。该系统采用两阶段架构,结合了用于语音 token 生成的大语言模型(LLM)和用于波形合成的流匹配(Flow Matching)模型。 通过引入多奖励强化学习框架,GLM-TTS 显著提升了合成语音的表现力,相比传统 TTS 系统实现了更自然的情感控制。Python00
Spark-Formalizer-X1-7BSpark-Formalizer 是由科大讯飞团队开发的专用大型语言模型,专注于数学自动形式化任务。该模型擅长将自然语言数学问题转化为精确的 Lean4 形式化语句,在形式化语句生成方面达到了业界领先水平。Python00