这期内容当中小编将会给大家带来有关使用Nacos和网关中心的创建是怎样的,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。
Nacos可以用来发现、配置和管理微服务。提供了一组简单易用的特性集,可以快速实现动态服务发现、服务配置、服务元数据及流量管理。
Nacos用来更敏捷和容易地构建、交付和管理微服务平台。Nacos是构建以”服务“为中心的现代应用构架(例如微服务范式、云原生范式)的服务基础设置。
也就是通常我们所说的配置中心和服务发现中心。
Nacos目前版本不支持以Spring boot的形式创建服务,必须以一个Java包的形式单独运行或者以Docker服务的形式运行,我们大概讲解一下本地运行。
下载安装包:
curl https://github.com/alibaba/nacos/releases/download/1.2.1/nacos-server-1.2.1.zipunzip nacos-server-$version.zip 或者 tar -xvf nacos-server-$version.tar.gzcd nacos/bin
使用源码安装:
git clone https://github.com/alibaba/nacos.gitcd nacos/mvn -Prelease-nacos -Dmaven.test.skip=true clean install -Uls -al distribution/target/// change the $version to your actual pathcd distribution/target/nacos-server-$version/nacos/bin
启动:
Linux/Unix/Mac
启动命令(standalone代表着单机模式运行,非集群模式):
sh startup.sh -m standalone
如果您使用的是ubuntu系统,或者运行脚本报错提示[[符号找不到,可尝试如下运行:
bash startup.sh -m standalone
Windows
启动命令:
cmd startup.cmd
或者双击startup.cmd运行文件。
整个的网关服务,我们采用的Spring Cloud Gateway。在Spring Cloud微服务里,整个系统只对外公开了网关,其他的服务是对外不可见的。所以需要设置一个让我们可以用的网关服务。
在 nature/manager下创建一个gateway目录,并添加pom.xml:
<?xml version="1.0" encoding="UTF-8"?><project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"> <parent> <groupId>club.attachie</groupId> <artifactId>manager</artifactId> <version>${revision}</version> </parent> <modelVersion>4.0.0</modelVersion> <groupId>club.attachie</groupId> <artifactId>gateway</artifactId> <packaging>jar</packaging> <version>${revision}</version></project>
在manager下注册该模块:
<modules> <module>gateway</module></modules>
创建完成项目后,需要添加依赖包:
<!-- https://mvnrepository.com/artifact/org.springframework.cloud/spring-cloud-starter-gateway --><dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-gateway</artifactId></dependency>
在gateway项目中,创建如下目录:
├── pom.xml└── src └── main ├── java │ └── club │ └── attachie │ └── gateway │ └── SpringGatewayApplication.java └── resources └── bootstrap.yml
创建 SpringGateAppliction.java文件,代码如下:
package club.attachie.gateway;import org.springframework.boot.SpringApplication;import org.springframework.boot.autoconfigure.SpringBootApplication;import org.springframework.cloud.client.discovery.EnableDiscoveryClient;import org.springframework.cloud.context.config.annotation.RefreshScope;/** * @author attaching */@SpringBootApplication@EnableDiscoveryClient@RefreshScopepublic class SpringGatewayApplication { public static void main(String[] args) { SpringApplication.run(SpringGatewayApplication.class, args); }}
在resource目录下创建 bootstrap.yml:
spring: application: name: gateway
yml 是Spring 的一种配置文件格式,其中名称有application和bootstrap,bootstrap比application先加载。
先在 nature/pom.xml 添加 nacos 版本号:
<nacos.version>2.2.1.RELEASE</nacos.version>
然后在dependencyManagement > dependencies 下添加 nacos相关依赖管理:
<dependency> <groupId>com.alibaba.cloud</groupId> <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId> <version>${nacos.version}</version></dependency><dependency> <groupId>com.alibaba.cloud</groupId> <artifactId>spring-cloud-alibaba-starters</artifactId> <version>${nacos.version}</version></dependency>
在Gateway项目中pom.xml 添加:
<dependency> <groupId>com.alibaba.cloud</groupId> <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId></dependency><dependency> <groupId>com.alibaba.cloud</groupId> <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId></dependency>
然后回过头来,在bootstrap里设置:
spring: application: name: gateway cloud: nacos: config: server-addr: 127.0.0.1:8848
上述就是小编为大家分享的使用Nacos和网关中心的创建是怎样的了,如果刚好有类似的疑惑,不妨参照上述分析进行理解。如果想知道更多相关知识,欢迎关注亿速云行业资讯频道。
亿速云「云服务器」,即开即用、新一代英特尔至强铂金CPU、三副本存储NVMe SSD云盘,价格低至29元/月。点击查看>>
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。
原文链接:https://my.oschina.net/c7jie/blog/4495135