前言 1.之前有人给我留言说想要了解一下分布式,今天呢,我们就来简单的说一下SpringCloud分布式并且实现一个简单的demo。 2.最近更新变少了,因为工作中也没有遇到什么有意思的知识点,希望大家可以提供一些想要了解的知识,私信或者评论都可以。 我理解的SpringCloud 1.首先,我们的分布式系统都需要有一个服务注册中心,来将所有提供服务的系统都注册到系统中。在我了解的两种分布式框架:Double(阿里)、SpringCloud(Spring),在这两种里面,我选择了Spring。我认为SpringCloud更加简捷方便一些。 2.其次,有了注册中心,那我们就需要有服务的提供者,也就是我们所说的微服务,只需要在项目中加入几个简单的配置,就可以将服务注册到注册中心,供其他客户端使用。 3.最后呢,我们还需要注册消费者,通过消费者来消费注册中心中的服务接口。 SpringCloud代码实现 一、SpringCloud服务注册中心 1.使用IntelliJIDEA或者是其他的JavaIDE创建一个Springboot项目,命名为eureka-server,当然这个自由选择哈。 2.等待MAVEN构建好项目之后,打开pom.xml进行配置,并添加如下依赖。 3.打开主类,也就是启动类,添加如下注解,将该项目注册为服务注册中心。 4.打开项目中的application.properties我会将其重命名为application.yml,其实两种格式并没有什么分别,只是个人喜好而已。 5.修改application.yml配置,如下。 6.它的配置还有很多,比如 配置有很多,大家可以去官方文档查看一下,按需配置。 7.自此注册中心算是配置完善,启动项目后,访问对应端口即可看到如下页面。 二、SpringCloud服务提供者 1.同上创建Springboot项目,选择创建为WEB项目,名为service-test可以选择常用的持久化框架mybatis、JAP等等,选择数据库驱动。当然持久化框架可以不选,待MAVEN构建好项目之后可以手动加入自己的持久化,比如我常用的mybatis-plus或者hibernate、JDBC等等。 2.打开pom.xml添加依赖 3.打开启动类,添加注释 EnableEurekaClient注册成为服务提供者。4.配置application.yml 5.启动项目后,可以在服务注册中心的日志中看到如下结果: 也可以在浏览器打开服务注册中心查看服务是否注册成功: 6.如上即为可提供服务,接下来就可以编写我们的服务代码,这里我们简单的以返回字符串为例子。TestController 三、SpringCloud服务消费 1.由上面的Java代码可以看出,我们的service-test服务者提供了一个/test/testOne的服务,那我们接下来就来创建一个消费者来消费该服务。 2.依旧创建Springboot项目,命名为consumer添加同上依赖,在application.yml中添加如下配置 3.在启动类中添加如下注解,注册为消费者。 4.编写ConsumerService.java接口,以此消费我们service-test中提供的服务。代码如下: 5.编写ConsumerController.java 6.启动项目后同样可以在服务注册中心的控制台以及页面查看注册信息。 7.查看到服务注册成功之后,我们正常访问,localhost:端口/test。就可以看到页面会返回成功进入的字样,即代表我们的服务消费成功。 四、SpringCloud分布式服务器部署测试 1.正好手头有不少服务器,我们来部署测试一下,是否实现了简单的分布式。 2.首先将我们的三个项目打包为jar文件上传至服务器当中。具体操作如下 3.待命令执行完后,可以在项目的target目录中看到生成的jar文件。 4.通过scp命令将jar包上传至服务器目录 5.接下来就是启动jar包 6.待项目全部部署完毕,我们先来看一下服务注册中心。 可以看到两个服务均注册成功,我们运行看一下。 与本地运行相同,但我们的三个项目时部署到不同的服务器当中的,以此也就实现了简单的分布式部署。 五、SpringCloud、Ribbon开启负载均衡 1.我们需要启动同一个服务两次,在不同的端口或者是服务器。 2.项目启动后可以在注册中心看到同名为service-test的服务有两个。 3.在消费者的主类中添加如下代码开启负载均衡。 4.这样,他会根据访问的次序,自动的将用户分配到不同的服务器或者端口。 最后说几句 1.当然这只是最基础的一部分。我也还在不断的学习和深入了解当中。 2.至于这样部署的好处嘛,不仅减轻了服务器的负担,同样降低了耦合,如果我们只是下线一部分功能或者对功能进行升级,不会对整体造成影响。 3.感谢大家的
|