当前位置: 首页 > news >正文

网站建设的税率今日头条郑州头条新闻

网站建设的税率,今日头条郑州头条新闻,贵州城乡建设部网站,网站开发网页超链接路径文章目录 前言角色(三个) 工程说明基础运行环境工程目录说明启动顺序(建议):运行效果注册与发现中心服务消费者: 代码说明服务注册中心(Register Service)服务提供者(Pro…

文章目录

  • 前言
    • 角色(三个)
  • 工程说明
    • 基础运行环境
    • 工程目录说明
    • 启动顺序(建议):
    • 运行效果
      • 注册与发现中心
      • 服务消费者:
  • 代码说明
    • 服务注册中心(Register Service)
    • 服务提供者(Provider Service)
    • 服务消费者(Consumer Service)
    • 服务提供者SDK(Provider Service sdk)
  • 负载均衡
  • 源码地址

前言

角色(三个)

  • 服务注册中心(Register Service): Eureka Server,提供注册和发现功能;
  • 服务提供者(Provider Service):Eureka Client,将自己提供的服务注册到服务注册中心,以供服务消费者发现和调用;
  • 服务消费者(Consumer Service):Eureka Client,从服务注册中心获取服务列表;

工程说明

基础运行环境

	JDK: jdk-20.0.2spring cloud: 2022.0.4spring boot: 3.1.5

工程目录说明

demo-springcloud-netflix-eureka (父工程)
├── demo-springcloud-netflix-eureka-consumer (服务消费者,端口:8000)
├── demo-springcloud-netflix-eureka-provider-impl1 (服务提供者,端口:9001)
├── demo-springcloud-netflix-eureka-provider-impl2(服务提供者,端口:9002)
├── demo-springcloud-netflix-eureka-provider-sdk(服务端,SDK)
├── demo-springcloud-netflix-eureka-register1(服务注册中心,端口:7001)
└── demo-springcloud-netflix-eureka-register2(服务注册中心,端口:7002)

注意: 示例中,为了方便看效果,服务注册中心服务提供者分别提供两个工程,内部代码都一样,只是端口不同。

启动顺序(建议):

demo-springcloud-netflix-eureka-register1
demo-springcloud-netflix-eureka-register2
demo-springcloud-netflix-eureka-provider-impl1
demo-springcloud-netflix-eureka-provider-impl2
demo-springcloud-netflix-eureka-consumer

运行效果

注册与发现中心

http://localhost:7001 或 http://localhost:7002

注册与发现中心

服务消费者:

访问这个地址,将随机返回结果:http://localhost:8000/main2?name=abc123

hello: abc123, I'm 9001
hello: abc123, I'm 9002

代码说明

服务注册中心(Register Service)

demo-springcloud-netflix-eureka-register1,端口:7001

关键依赖(pom.xml)

<dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-netflix-eureka-server</artifactId>
</dependency>

关键配置(application.properties)

spring.application.name=demo-springcloud-netflix-eureka-register
server.port=7001eureka.instance.hostname=${spring.application.name}
eureka.instance.instance-id=${spring.application.name}:${server.port}
eureka.instance.prefer-ip-address=true# 是否将自己注册到Eureka-Register中,默认的为true,单机设置为false,集群设置为true
eureka.client.register-with-eureka=true# 是否从Eureka-Register中获取服务注册信息,默认为true
eureka.client.fetch-registry=false# 这里是配置
eureka.client.service-url.defaultZone=http://localhost:7001/eureka/,http://localhost:7002/eureka/# 测试时关闭自我保护机制,保证不可用服务及时踢出
eureka.server.enable-self-preservation=false

启动类:

@SpringBootApplication
@EnableEurekaServer
public class SpringCloudNetflixEurekaRegister1 {public static void main(String[] args) {SpringApplication.run(SpringCloudNetflixEurekaRegister1.class, args);}
}

demo-springcloud-netflix-eureka-register2,端口:7002
demo-springcloud-netflix-eureka-register1代码完全一样,只是application.properties中的server.port=7002

spring.application.name=demo-springcloud-netflix-eureka-register
server.port=7002
....

服务提供者(Provider Service)

demo-springcloud-netflix-eureka-provider-impl1,端口:9001

关键依赖(pom.xml)

<dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
</dependency>

关键配置(application.properties)

spring.application.name=demo-springcloud-netflix-eureka-provider
server.port=9001eureka.instance.instance-id=${spring.application.name}:${server.port}
eureka.instance.prefer-ip-address=true# 每间隔2s,向服务端发送一次心跳,证明自己依然”存活“
eureka.instance.lease-renewal-interval-in-seconds=2# 告诉服务端,如果我10s之内没有给你发心跳,就代表我“死”了,将我踢出掉。
eureka.instance.lease-expiration-duration-in-seconds=10# 是否将自己注册到Eureka-Register中,默认的为true
eureka.client.register-with-eureka=true# 是否从Eureka-Server中获取服务注册信息,默认为true
eureka.client.fetch-registry=true
eureka.client.service-url.defaultZone=http://localhost:7001/eureka/,http://localhost:7002/eureka/

启动类:

@SpringBootApplication
@EnableDiscoveryClient
public class SpringcloudNetflixEurekaProvider1 {public static void main(String[] args) {SpringApplication.run(SpringcloudNetflixEurekaProvider1.class, args);}
}

demo-springcloud-netflix-eureka-provider2,端口:9002
demo-springcloud-netflix-eureka-provider1代码完全一样,只是application.properties中的server.port=9002

spring.application.name=demo-springcloud-netflix-eureka-provider
server.port=9002
....

服务消费者(Consumer Service)

demo-springcloud-netflix-eureka-consumer,端口:8000

关键依赖(pom.xml)

<dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
</dependency>

关键配置(application.properties)

spring.application.name=demo-springcloud-netflix-eureka-consumer
server.port=8000eureka.instance.instance-id=${spring.application.name}:${server.port}
eureka.instance.prefer-ip-address=true
eureka.instance.app-group-name=demo-springcloud-eureka-client-a
eureka.instance.lease-renewal-interval-in-seconds=2# 是否将自己注册到Eureka-Server中,默认的为true,这里设置为false,表示不注册,不希望被别的服务发现
eureka.client.register-with-eureka=false
eureka.client.registry-fetch-interval-seconds=2# 是否从Eureka-Server中获取服务注册信息,默认为true
eureka.client.fetch-registry=true
eureka.client.service-url.defaultZone=http://localhost:7001/eureka/,http://localhost:7002/eureka/

启动类:

@SpringBootApplication
@EnableDiscoveryClient
public class SpringCloudNetflixEurekaConsumer {public static void main(String[] args) {SpringApplication.run(SpringCloudNetflixEurekaConsumer.class, args);}
}

服务提供者SDK(Provider Service sdk)

实际工作中,该工程应该由服务提供者开发团队开发,供服务消费者依赖调用,来实现远程调用。本实例使用openfeign。

关键依赖(pom.xml)

<dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-openfeign</artifactId>
</dependency>

关键代码(demo-springcloud-netflix-eureka-provider-sdk工程ProviderService类):

// 接口,无需手写实现类
@Component
@FeignClient(name = ProviderConstants.SERVICE_ID)
public interface ProviderService {// 服务提供者需提供“/sub”接口服务@RequestMapping(value = "/sub")String test(@RequestParam("name") String name);// 其他服务....
}

服务提供者依赖后使用(demo-springcloud-netflix-eureka-provider-impl1工程)

@Service
public class DemoService implements ProviderService {@Autowiredprivate Environment env;public String test(String name) {return "hello: " + name + ", I'm " + env.getProperty("server.port");}
}@Controller
public class DemoController {@Autowiredprivate DemoService service;@ResponseBody@RequestMapping("/sub")public String test(String name) {return service.test(name);}
}

服务消费者依赖后使用(demo-springcloud-netflix-eureka-consumer工程)


@Autowired
private ProviderService providerService;@ResponseBody
@RequestMapping("/main2")
public String main2(String name) {return providerService.test(name);
}

负载均衡

客户端负载:(demo-springcloud-netflix-eureka-consumer工程)

@Configuration(proxyBeanMethods = false)
public class CustomLoadBalancerConfig {@Bean@ConditionalOnMissingBeanpublic ReactorLoadBalancer<ServiceInstance> reactorServiceInstanceLoadBalancer(Environment environment,LoadBalancerClientFactory loadBalancerClientFactory) {var name = ProviderConstants.SERVICE_ID;return new CustomLoadBalancer(loadBalancerClientFactory.getLazyProvider(name, ServiceInstanceListSupplier.class), name);}
}
// CustomLoadBalancer.javaprivate Response<ServiceInstance> getInstanceResponse(List<ServiceInstance> instances) {if (instances.isEmpty()) {if (log.isWarnEnabled()) {log.warn("No servers available for service: " + serviceId);}return new EmptyResponse();}// 随机var index = ThreadLocalRandom.current().nextInt(instances.size());var instance = instances.get(index);return new DefaultResponse(instance);}

源码地址

https://gitee.com/xiaojianhx/demo-springcloud-netflix-eureka

http://www.hkea.cn/news/6235/

相关文章:

  • 公司网站建设行业怎么样关键词在线试听
  • 辽宁大连建设工程信息网站女生学市场营销好吗
  • 做视频在线观看网站微信广告投放收费标准
  • 网站建设联系互联网营销师是什么
  • 恩施网站建设教程北京it培训机构哪家好
  • 某集团中英文双语网站源码seog
  • 汽车logo设计图片创意seo广告平台
  • 交城有做网站的吗厦门seo招聘
  • 世界免费b2b网站大全网页设计代码案例
  • 广告网站留电话不用验证码公司网站建设教程
  • html网站实例上海aso优化公司
  • 环保公司网站模板百度百度一下百度
  • wordpress网站搬家换域名博客网站seo
  • wordpress 更改密码seo优化收费
  • 龙岗网站建设设计服务今天的热搜榜
  • 上海交通大学网站建设网络推广100种方式
  • 凡科建站的怎么取消手机网站中国最新消息新闻
  • 免费做初中试卷的网站长沙seo服务哪个公司好
  • 上海企业自助建站系统宁波seo外包代运营
  • wordpress单页面静态网页怎么优化
  • 武汉网站程序开发公司企业seo顾问
  • 怎么用centos做网站深圳seo排名
  • 客服网站制作建立一个企业网站需要多少钱
  • 深圳自建网站爱站工具包的模块
  • 大学生校园活动策划书荥阳seo推广
  • 做是么网站百度网站推广价格
  • balsamiq网站制作教程域名收录
  • wordpress 改网站介绍廊坊seo网络推广
  • 桐乡市住房建设局网站公示东营网站建设费用
  • 京东店铺转让网站seo源码