Spring Cloud CLI簡單介紹
1.簡介
在本文中,我們將介紹Spring Boot Cloud CLI(或簡稱Cloud CLI)。該工具為Spring Boot CLI提供了一組命令行增強(qiáng)功能,有助于進(jìn)一步抽象和簡化Spring Cloud部署。
CLI于2016年底推出,允許使用命令行、.yml配置文件和Groovy腳本快速自動(dòng)配置和部署標(biāo)準(zhǔn)Spring Cloud服務(wù)。
2.安裝
Spring Boot Cloud CLI 1.3.x需要Spring Boot CLI 1.5.x,因此請(qǐng)務(wù)必從Maven Central獲取最新版本的Spring Boot CLI (安裝說明)以及Maven資源庫中的最新版本的Cloud CLI (官方Spring存儲(chǔ)庫)!
本文中使用的是spring-boot-cli 1.5.18.RELEASE,spring-cloud-cli 1.3.2.RELEASE。
1、首先安裝Spring Boot CLI并可以使用,驗(yàn)證只需運(yùn)行:
$ spring --version
2、然后安裝最新的穩(wěn)定版Cloud CLI:
$ spring installorg.springframework.cloud:spring-cloud-cli:1.3.2.RELEASE
3、最后驗(yàn)證Cloud CLI:
$ spring cloud --version
可以在官方Cloud CLI 頁面上找到更多安裝說明!
3.默認(rèn)服務(wù)和配置
CLI提供七種核心服務(wù),可以使用單行命令運(yùn)行和部署。
在http://localhost:8888上啟動(dòng)Cloud Config服務(wù)器:
$ spring cloud configserver
http://localhost:8761上啟動(dòng)Eureka服務(wù)器:
$ spring cloud eureka
在http://localhost:9095上啟動(dòng)H2服務(wù)器:
$ spring cloud h2
在http://localhost:9091上啟動(dòng)Kafka服務(wù)器:
$ spring cloud kafka
在http://localhost:9411上啟動(dòng)Zipkin服務(wù)器:
$ spring cloud zipkin
在http://localhost:9393上啟動(dòng)Dataflow服務(wù)器:
$ spring cloud dataflow
在http://localhost:7979上啟動(dòng)Hystrix儀表板:
$ spring cloud hystrixdashboard
列出可部署的應(yīng)用服務(wù):
$ spring cloud --list
幫助命令:
$ spring help cloud
有關(guān)這些命令的更多詳細(xì)信息,請(qǐng)查看官方博客。
4.使用YML自定義云服務(wù)
還可以使用相應(yīng)命名的.yml文件配置可通過Cloud CLI部署的云服務(wù):
spring: profiles: active: git cloud: config: server: git: uri: https://github.com/spring-cloud-samples/config-repo
這是一個(gè)簡單的配置文件,我們可以使用它來啟動(dòng)Cloud Config Server。
上面的例子中,我們指定一個(gè)Git存儲(chǔ)庫作為URI源,當(dāng)我們發(fā)出'spring cloud configserver'命令時(shí),它將被自動(dòng)克隆和部署。
Cloud CLI使用Spring Cloud Launcher。這意味著Cloud CLI支持大多數(shù)Spring Boot配置機(jī)制。這是Spring Boot屬性的官方列表。
Spring Cloud配置符合'spring.cloud … '約定??梢栽诖?a rel="external nofollow" target="_blank" >鏈接中找到Spring Cloud和Spring Config Server的設(shè)置。
我們還可以直接在下面的yml文件中指定幾個(gè)不同的模塊和服務(wù):
spring: cloud: launcher: deployables: - name: configserver coordinates: maven://...:spring-cloud-launcher-configserver:1.3.2.RELEASE port: 8888 waitUntilStarted: true order: -10 - name: eureka coordinates: maven:/...:spring-cloud-launcher-eureka:1.3.2.RELEASE port: 8761
該yml允許通過使用Maven或Git庫,添加自定義的服務(wù)或模塊。
5.運(yùn)行自定義Groovy腳本
自定義組件可以用Groovy編寫并高效部署,因?yàn)镃loud CLI可以編譯和部署Groovy代碼。
這是一個(gè)非常簡單的REST API實(shí)現(xiàn)示例:
@RestController
@RequestMapping('/api')
class api {
@GetMapping('/get')
def get() { [message: 'Hello'] }
}
假設(shè)腳本保存為restapi.groovy,我們可以像這樣啟動(dòng)我們的服務(wù):
$ spring run restapi.groovy
訪問http://localhost:8080/api/get應(yīng)該顯示:
{"message":"Hello"}
6.加密/解密
Cloud CLI還提供了加密和解密工具(可在org.springframework.cloud.cli.command.*中找到),可以直接通過命令行使用,也可以通過將值傳遞給Cloud Config Server端點(diǎn)來間接使用。
讓我們?cè)O(shè)置它,看看如何使用它。
6.1 安裝
Cloud CLI和Spring Cloud Config Server都使用org.springframework.security.crypto.encrypt.* 來處理加密和解密的命令。
因此,都需要通過Oracle提供的JCE Unlimited Strength Extension,可在這里找到。
6.2 命令行加密和解密
要通過終端加密' my_value ',請(qǐng)調(diào)用:
$ spring encrypt my_value --key my_key
可以使用“@”后跟路徑(通常用于RSA公鑰)代表文件路徑(替換上面的“ my_key ”):
$ spring encrypt my_value --key @${WORKSPACE}/foos/foo.pub
'my_value'現(xiàn)在將被加密為:
c93cb36ce1d09d7d62dffd156ef742faaa56f97f135ebd05e90355f80290ce6b
可通過命令行進(jìn)行解密:
$ spring decrypt --key my_key c93cb36ce1d09d7d62dffd156ef742faaa56f97f135ebd05e90355f80290ce6b
我們現(xiàn)在還可以在配置YAML或?qū)傩晕募惺褂眉用苤担诩虞d時(shí)它將由Cloud Config Server自動(dòng)解密:
encrypted_credential: "{cipher}c93cb36ce1d09d7d62dffd156ef742faaa56f97f135ebd05e90355f80290ce6b"
6.3 使用Config Server加密和解密
Spring Cloud Config Server公開RESTful端點(diǎn),其中密鑰和加密值對(duì)可以存儲(chǔ)在Java安全存儲(chǔ)或內(nèi)存中。
有關(guān)如何正確設(shè)置和配置Cloud Config Server以接受對(duì)稱或非對(duì)稱加密的詳細(xì)信息,請(qǐng)查看官方文檔。
使用“ spring cloud configserver ”命令配置并運(yùn)行Spring Cloud Config Server后,您就可以調(diào)用其API:
$ curl localhost:8888/encrypt-d mysecret //682bc583f4641835fa2db009355293665d2647dade3375c0ee201de2a49f7bda$ curl localhost:8888/decrypt-d 682bc583f4641835fa2db009355293665d2647dade3375c0ee201de2a49f7bda //mysecret
7.結(jié)論
我們?cè)谶@里專注于Spring Boot Cloud CLI的介紹。有關(guān)更多的信息,請(qǐng)查看官方文檔。
以上就是本文的全部內(nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- 詳解Spring Cloud Stream使用延遲消息實(shí)現(xiàn)定時(shí)任務(wù)(RabbitMQ)
- spring cloud gateway 限流的實(shí)現(xiàn)與原理
- 詳解Spring Cloud微服務(wù)架構(gòu)下的WebSocket解決方案
- SpringCloud Zuul在何種情況下使用Hystrix及問題小結(jié)
- 詳解Spring Cloud Netflix Zuul中的速率限制
- 詳解Spring Cloud Gateway 數(shù)據(jù)庫存儲(chǔ)路由信息的擴(kuò)展方案
- 詳解SpringCloud Finchley Gateway 統(tǒng)一異常處理
- Spring Cloud Ribbon的踩坑記錄與原理詳析
- 使用Servlet處理一個(gè)上傳的文件
- Servlet+MyBatis項(xiàng)目轉(zhuǎn)Spring Cloud微服務(wù),多數(shù)據(jù)源配置修改建議
相關(guān)文章
Spring容器初始化擴(kuò)展點(diǎn)之ApplicationContextInitializer詳解
ApplicationContextInitializer是Spring框架提供的一個(gè)接口,用于在Spring應(yīng)用上下文刷新之前對(duì)其進(jìn)行自定義初始化,本文介紹Spring容器初始化擴(kuò)展點(diǎn)之ApplicationContextInitializer,感興趣的朋友一起看看吧2025-02-02
spring boot基于DRUID實(shí)現(xiàn)數(shù)據(jù)源監(jiān)控過程解析
這篇文章主要介紹了spring boot基于DRUID實(shí)現(xiàn)數(shù)據(jù)源監(jiān)控過程解析,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-12-12
Java 轉(zhuǎn)型(向上或向下轉(zhuǎn)型)詳解及簡單實(shí)例
這篇文章主要介紹了Java 轉(zhuǎn)型(向上或向下轉(zhuǎn)型)詳解及簡單實(shí)例的相關(guān)資料,需要的朋友可以參考下2017-02-02
idea創(chuàng)建springboot項(xiàng)目,java版本只能選擇17和21的解決方案
這篇文章主要介紹了idea創(chuàng)建springboot項(xiàng)目,java版本只能選擇17和21的解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2025-04-04
ThreadPoolExecutor核心線程數(shù)和RocketMQ消費(fèi)線程調(diào)整詳解
這篇文章主要介紹了ThreadPoolExecutor核心線程數(shù)和RocketMQ消費(fèi)線程調(diào)整詳解,Rocketmq 消費(fèi)者在高峰期希望手動(dòng)減少消費(fèi)線程數(shù),通過DefaultMQPushConsumer.updateCorePoolSize方法可以調(diào)用內(nèi)部的setCorePoolSize設(shè)置多線程核心線程數(shù),需要的朋友可以參考下2023-10-10
Java 語言實(shí)現(xiàn)清除帶 html 標(biāo)簽的內(nèi)容方法
下面小編就為大家?guī)硪黄狫ava 語言實(shí)現(xiàn)清除帶 html 標(biāo)簽的內(nèi)容方法。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-02-02

