1.SpringCloud是什么
以前的服务器就像是一个医院只有一个医生,什么病人都要让这个医生看,如果医生觉得太累,自我暴毙了,那整个医院都瘫痪了。而springcloud流行起来之后,就像是医院里面有了外科诊室,内科诊室等,每一个诊室都有一群医生负责,这样不管哪一个医生不行了都不会影响整个医院的运转。把一台或好几台服务器中的众多服务,分类出来,解耦合出来,把他们类似的功能交给同一个集群来做,把互相耦合在一起的功能剥离出来,按业务,按功能来把他们作为一个个微服务放在服务器上,而这个服务器就只提供一个服务,或较少的服务。让一个超大的服务逻辑,解耦合为一个个小服务,均匀的分布在各自的服务器中。这就是springcloud。
2.Eureka是做什么用的
每一个诊室都是一个微服务集群,他们提供的作用都是一样的。注册中心Eureka相当于每个诊室的成员表。
3.Eureka的搭建
在Idea中创建工程:File -> New ->Project -> Empty Project -> Next
点击下一步就完事了
创建Module文件
选择quickstart,点击下一步(这个页面可能要加载一会时间)
组名和文件名自己随便编写,写完一直下一步
配置pom文件
<parent> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-parent</artifactId> <version>1.5.7.RELEASE</version> </parent> <!--server依赖--> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-netflix-eureka-server</artifactId> </dependency> <!--指定下载源和使用springcloud的版本--> <dependencyManagement> <dependencies> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-dependencies</artifactId> <version>Edgware.SR5</version> <type>pom</type> <scope>import</scope> </dependency> </dependencies> </dependencyManagement>
然后就开始导包。。。漫长的等待
在main下创建文件夹resources并设置为资源文件夹
在resources下新建file,并命名为appliaction.yml
配置appliaction.yml
server: port: 8700 # 端口号自己随意 # 指定当前eureka客户端的注册地址,也就是eureka服务的提供方,当前配置的服务的注册服务方 eureka: client: service-url: defaultZone: http://${eureka.instance.hostname}:${server.port}/eureka register-with-eureka: false #自身 不在向eureka注册 fetch-registry: false #启动时禁用client的注册 instance: hostname: localhost #指定应用名称 spring: application: name: eureka-server
在buting文件夹下新建文件EurekaServerAppliaction.java,然后写入以下代码。
@SpringBootApplication @EnableEurekaServer //当前使用eureka的server public class EurekaServerApplication { public static void main(String[] args) { SpringApplication.run(EurekaServerApplication.class,args); System.out.println("2333"); } }
右键点击Debug运行,运行成功后输入http://localhost:8700如果能出现下面这个界面我们第一步就算成功啦。
接下来就该配置客户端啦,它提供的是角色的配置,提供服务在服务注册方(就是我们刚刚配置的server)进行注册
跟上面的步骤一样,我们新建Module文件,需要注意的是上面的两个选为
创建完文件后,我们来配置pom文件,引入以下依赖
<!--引入springboot-parent父项目--> <parent> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-parent</artifactId> <version>1.5.7.RELEASE</version> </parent> <!--引入springcloud的euekea server依赖--> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId> </dependency> <!--指定下载源和使用springcloud的版本--> <dependencyManagement> <dependencies> <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-dependencies</artifactId> <version>Edgware.SR5</version> <type>pom</type> <scope>import</scope> </dependency> </dependencies> </dependencyManagement>
好吧,其实就是把dependency里的server改为client
接着我们创建resources文件夹,创建application.yml文件,里面这样配置
server: port: 8701 # 服务提供方 # 指定当前eureka客户端的注册地址, eureka: client: service-url: defaultZone: http://${eureka.instance.hostname}:8700/eureka instance: hostname: localhost #当前服务名称 spring: application: name: eureka-service pom.xml:
因为搭建的是服务提供者,这里还需编写服务类controller
@RestController @RequestMapping("/Hello") public class Controller { @RequestMapping("/World") public String helloWorld(String s){ System.out.println("传入的值为:"+s); return "传入的值为:"+s; } }
入口类 并运行此微服务
@SpringBootApplication @EnableDiscoveryClient//代表自己是一个服务提供方 public class EurekaServiceApplication { public static void main(String[] args) { SpringApplication.run(EurekaServiceApplication.class,args); } }
右键点击Debug(当然开启此服务时需要先开启server服务 就是我们第一个编写的微服务)等待运行成功后,在进入server页面(进入的是我们第一次配置的页面,不是这个)
在页面中我们可以看到,此时可以看见服务提供者已被注册进 服务注册者
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持易盾网络。