怎么把非springboot项目集成eureka
这篇文章主要介绍"怎么把非springboot项目集成eureka",在日常操作中,相信很多人在怎么把非springboot项目集成eureka问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答"怎么把非springboot项目集成eureka"的疑惑有所帮助!接下来,请跟着小编一起来学习吧!
1 背景
随着SOA架构的演进,越来越多的服务商需要提供一种通用的可以动态伸缩的基础架构,
而对嘻「」来说,亦是如此。并且随着TPS的不断增加,more and more endpoint 需要整合这种分布式基础架构。这里有点类似当年google的Bigtable 的论文刚发表时的案例,对不同业务,或者相同业务不同功能,在或者相同功能实现节点拓展,分布式处理。(要实现分布式处理能力的系统必然伴随这分布式场景的一些问题,这里不做讨论。
2 目的说明
类似Dubbo分布式服务治理,不同的微服务需要依赖注册中心做服务治理与管控,springCloud 也是这样,作为微服务的生态,不同的组件负责不同的功能(例如archaius 做配置and eureka 做服务PUBSUB等...)。
3 方案对比
3.1 directly to register
简单的说.通过分析源码发现DiscoveryClient对象是客户端启动加载的核心类,
它创建的时候就会去注册,如下
在restemplate 调用的过程中需要先通过应用层通信拿到服务器对应spring.application.name 为vipaddress的InstanceInfo,instanceOf里面维护了对应的你将要调用的服务器或者服务如下:
可能会在这里拿不出来实例信息,最后报没有对应服务实例,以上来自Applications Class,
源码后文会详细分析,这里不过多分析只解决问题
****** 4.2 The Error for Register Process******
这里按照官网案例搭建注册环境,可能会出现一切准备就绪然注册不上去的情况。
走一遍注册流程如下:
Archaius会默认加载classpath下的config.properties文件作为当前内存资源配置,也可以改,通过archaius.configurationSource.defaultFileName,当然既然是动态的肯定也是可以做多数据源动态处理,具体不详细说明了
具体配置意义先不考虑,先为了解决问题考虑环境
****** 4.3 eureka/apps for configuration******
手动注册这一截是没有的 显示empty
所以我们需要把这一截加上去,
代码如下:
int port = instanceInfo.getPort();Mapmaps = Maps.newHashMap();maps.put("management.port", String.valueOf(port));//activity-manager:dev-10.0.2.17:8010applicationInfoManager.getInstance().registerAppMetadata(maps);
还有一个细节问题:
Archaius1Utils.initConfig("eureka-client");
这个是在查看报错日志的时候报的,为了更好的兼容框架需要解决,大概意思是说缺少这个配置
在加载此类实现类的时候就会一起初始化该类。很明显组件已经帮我们做了,我们只需要提供对应配置文件即可
依赖为
这里需要注意的两点:
继续DEBUG会看到:
这里开始递归调用拦截器,也就是我们在启动时候放进去的拦截器会在这里调用
当然这里有个细节
这里我们需要关注两个点
1 通过服务serviceId拿到核心instanceInfo ,下面会解释
2 通过对应服务信息选择对应服务调用
分别对应第一二行代码
继续debug
这里需要通过一个serviceId加载一个LloadBalancer,代码如下
Spring 默认会调用以上工厂加载,所以我们点进去会看到
这里也需要注意两点:
1 我们这个lloadbalancer是用的时候才去加载,换句话说懒加载
2 这里有个缓存的 操作 第一个if为false就会返回缓存,换句话说只会创建一次
然后我们进去
这些东西。
以上的clientConfig 就是我们在代码设置进去的EurekaClientConfigBean
现在还没有上面参数,不要紧因为还没有开始初始化。
继续加载完之后开始加载
上
图大概意思就是先加载父类baseLoadbalancer然后加载自己
restOfInit方法就是核心加载方法
上图标红的是比较重要的方法
这里比较重点的如上标红处
进去看到:
他就会走到这里,这是什么呢?
对应一下会从visualHostNameAppMap 里面通过vipAddress那到List
总结一下:
负载均衡实现原理概述为根据配置加载负载均衡拦截器,用户客户端调用遍历处理,通过servceId通过HTTP拿到对应instanceInfo(和dubbo流程差不多,第一次都需要去拿之后缓存在本地。默认90秒把重新调用一次拉取信息)多个需要依算法选取一个然后进行远程调用。
代码如下:
package com.kili.lipapay.nmc.common;import com.google.common.collect.Maps;import com.netflix.appinfo.ApplicationInfoManager;import com.netflix.appinfo.InstanceInfo;import com.netflix.appinfo.providers.EurekaConfigBasedInstanceInfoProvider;import com.netflix.config.ConfigurationManager;import com.netflix.config.DynamicPropertyFactory;import com.netflix.discovery.DefaultEurekaClientConfig;import com.netflix.discovery.DiscoveryClient;import com.netflix.discovery.DiscoveryManager;import com.netflix.discovery.EurekaClient;import org.springframework.stereotype.Component;import javax.annotation.PostConstruct;import java.io.*;import java.net.InetAddress;import java.net.Socket;import java.util.Date;import java.util.Map;import java.util.Properties;@Componentclass SimpleEurakeService { private static final DynamicPropertyFactory configInstance = com.netflix.config.DynamicPropertyFactory .getInstance(); public void registerWithEureka() throws IOException { ApplicationInfoManager applicationInfoManager = null; EurakeInstanceConfig config = null; InstanceInfo instanceInfo = null; // Register with Eureka if (applicationInfoManager == null) { config = new EurakeInstanceConfig(); instanceInfo = new EurekaConfigBasedInstanceInfoProvider(config).get(); applicationInfoManager = new ApplicationInfoManager(config, instanceInfo); } // Archaius1Utils.initConfig("eureka-client"); Properties properties = new Properties(); InputStream inputStream = Thread.currentThread().getContextClassLoader().getResourceAsStream("config.properties"); properties.load(inputStream); properties.setProperty("eureka.ipAddr", InetAddress.getLocalHost().getHostAddress()); String instanceId = applicationInfoManager.getInfo().getAppName() + ":dev-" + properties.getProperty("eureka.ipAddr") + ":" + properties.getProperty("eureka.port"); properties.setProperty("eureka.instanceId", instanceId); ConfigurationManager.loadProperties(properties); int port = instanceInfo.getPort(); Mapmaps = Maps.newHashMap(); maps.put("management.port", String.valueOf(port)); //activity-manager:dev-10.0.2.17:8010 applicationInfoManager.getInstance().registerAppMetadata(maps); applicationInfoManager.getInstance().setInstanceStatus( InstanceInfo.InstanceStatus.UP); EurekaClient eurekaClient = new DiscoveryClient(applicationInfoManager, new DefaultEurekaClientConfig()); String vipAddress = configInstance.getStringProperty( "eureka.vipAddress", "unknown").get(); InstanceInfo nextServerInfo = null; while (nextServerInfo == null) { try { nextServerInfo = eurekaClient .getNextServerFromEureka(vipAddress, false); } catch (Throwable e) { System.out .println("Waiting for service to register with eureka.."); try { Thread.sleep(10000); } catch (InterruptedException e1) { // TODO Auto-generated catch block e1.printStackTrace(); } } } } public void unRegisterWithEureka() { // Un register from eureka. DiscoveryManager.getInstance().shutdownComponent(); } private void processRequest(final Socket s) { try { BufferedReader rd = new BufferedReader(new InputStreamReader( s.getInputStream())); String line = rd.readLine(); if (line != null) { System.out.println("Received the request from the client."); } PrintStream out = new PrintStream(s.getOutputStream()); System.out.println("Sending the response to the client..."); out.println("Reponse at " + new Date()); } catch (Throwable e) { System.err.println("Error processing requests"); } finally { if (s != null) { try { s.close(); } catch (IOException e) { // TODO Auto-generated catch block e.printStackTrace(); } } } } @PostConstruct private void init() throws IOException { SimpleEurakeService sampleEurekaService = new SimpleEurakeService(); sampleEurekaService.registerWithEureka(); }
配置如下:
# note that for a purely client usage (e.g. only used to get information about other services,# there is no need for registration. This property applies to the singleton DiscoveryClient so# if you run a server that is both a service provider and also a service consumer,# then don't set this property to false.#eureka.shouldEnforceRegistrationAtInit=false## configuration related to reaching the eureka serversSSeureka.client.service-url.defaultZone=http://localhost:7025/eurekaeureka.serviceUrl.default=http://localhost:7025/eurekaspring.cloud.config.discovery.enabled=truespring.cloud.config.discovery.service-id=config-servereureka.region=defaultspring.application.name=sampleservice#Name of the application to be identified by other serviceseureka.name=sampleservice#Virtual host name by which the clients identifies this serviceeureka.vipAddress=sampleservice#The port where the service will be running and serving requestseureka.port=8080#For eureka clients running in eureka server, it needs to connect to servers in other zoneseureka.preferSameZone=false#Change this if you want to use a DNS based lookup for determining other eureka servers. For example#of specifying the DNS entries, check the eureka-client-test.properties, eureka-client-prod.propertieseureka.shouldUseDns=falseeureka.us-east-1.availabilityZones=defaulterueka.registration.enabled=true
到此,关于"怎么把非springboot项目集成eureka"的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注网站,小编会继续努力为大家带来更多实用的文章!