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

黄页网络的推广网站有哪些好怎样搭建一个个人网站

黄页网络的推广网站有哪些好,怎样搭建一个个人网站,达州高端网站建设,二手车网站开发PPT前言 SpringCloud 是微服务中的翘楚#xff0c;最佳的落地方案。 使用 SpringCloud 的Hystrix Dashboard 组件可以监控单个应用服务的调用情况#xff0c;但如果是集群环境#xff0c;可能就 不能满足需求了#xff0c;这时就用到了SpringCloud 另一个组件#xff1a;T…前言 SpringCloud 是微服务中的翘楚最佳的落地方案。 使用 SpringCloud 的Hystrix Dashboard 组件可以监控单个应用服务的调用情况但如果是集群环境可能就 不能满足需求了这时就用到了SpringCloud 另一个组件Turbine。 Turbine 将每个应用服务的调用情况聚合在一起展示出来。 如果了解过Hystrix Dashboard那么可以简单认为 Turbine 就相当于另起了一个工程把其他工程的监控情况 全部显示到了 Turbine 工程中。 源码 GitHub地址https://github.com/intomylife/SpringCloud 环境 JDK 1.8.0 Maven 3.0 SpringBoot 2.0.3SpringCloud Finchley.RELEASE 开发工具 IntelliJ IDEA 正文 commons 工程 commons 工程 - POM 文件 ?xml version1.0 encodingUTF-8? project xmlnshttp://maven.apache.org/POM/4.0.0 xmlns:xsihttp://www.w3.org/2001/XMLSchema-instancexsi:schemaLocationhttp://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsdmodelVersion4.0.0/modelVersion!-- 三坐标 --groupIdcom.zwc/groupIdartifactIdspringcloud-turbine-commons/artifactIdversion1.0/version!-- 工程名称和描述 --namespringcloud-turbine-commons/namedescription公用工程/description!-- 打包方式 --packagingjar/packaging!-- 在 properties下声明相应的版本信息然后在dependency下引用的时候用 ${} 就可以引入该版本jar包了 --properties!-- 编码 --project.build.sourceEncodingUTF-8/project.build.sourceEncoding!-- jdk --java.version1.8/java.version!-- SpringBoot --platform-bom.versionCairo-SR3/platform-bom.version!-- SpringCloud --spring-cloud-dependencies.versionFinchley.RELEASE/spring-cloud-dependencies.version/properties!-- 加入依赖 --dependencies/dependencies!-- 依赖 jar 包版本管理的管理器 --!-- 如果 dependencies 里的 dependency 自己没有声明 version 元素那么 maven 就此处来找版本声明。 --!-- 如果有就会继承它如果没有就会报错告诉你没有版本信息 --!-- 优先级如果 dependencies 里的 dependency 已经声明了版本信息就不会生效此处的版本信息了 --dependencyManagementdependencies!-- SpringBoot --dependencygroupIdio.spring.platform/groupIdartifactIdplatform-bom/artifactIdversion${platform-bom.version}/versiontypepom/typescopeimport/scope/dependency!-- SpringCloud --dependencygroupIdorg.springframework.cloud/groupIdartifactIdspring-cloud-dependencies/artifactIdversion${spring-cloud-dependencies.version}/versiontypepom/typescopeimport/scope/dependency/dependencies/dependencyManagement!-- 插件依赖 --buildpluginsplugingroupIdorg.springframework.boot/groupIdartifactIdspring-boot-maven-plugin/artifactId/plugin/plugins/build/project配置一些共用依赖 commons 工程 - 项目结构 service 工程 ① 此工程下有五个模块一个注册中心一个聚合监控中心以及服务 A、B、C ② A 提供服务并且调用服务 B、B 提供服务并且调用服务 C 以及 C 提供服务 registry-service注册中心 registry-service - POM 文件 ?xml version1.0 encodingUTF-8? project xmlnshttp://maven.apache.org/POM/4.0.0 xmlns:xsihttp://www.w3.org/2001/XMLSchema-instancexsi:schemaLocationhttp://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsdmodelVersion4.0.0/modelVersion!-- 继承父 --parentgroupIdcom.zwc/groupIdartifactIdspringcloud-turbine-service/artifactIdversion1.0/version/parent!-- 三坐标 --groupIdcom.zwc/groupIdartifactIdspringcloud-turbine-registry-service/artifactIdversion1.0/version!-- 工程名称描述 --namespringcloud-turbine-registry-service/namedescription注册中心/description!-- 打包方式 --packagingjar/packaging!-- 在 properties下声明相应的版本信息然后在dependency下引用的时候用 ${} 就可以引入该版本jar包了 --properties/properties!-- 加入依赖 --dependencies!-- commons工程 依赖 --dependencygroupIdcom.zwc/groupIdartifactIdspringcloud-turbine-commons/artifactIdversion1.0/version/dependency!-- 服务注册中心 --dependencygroupIdorg.springframework.cloud/groupIdartifactIdspring-cloud-starter-netflix-eureka-server/artifactId/dependency/dependencies!-- 插件依赖 --buildpluginsplugingroupIdorg.springframework.boot/groupIdartifactIdspring-boot-maven-plugin/artifactId/plugin/plugins/build/project主要是加入spring-cloud-starter-netflix-eureka-server依赖 registry-service - application.yml配置文件 # 端口 server:port: 8761# 应用名称 spring:application:name: eureka-servereureka:instance:# 使用 ip 代替实例名prefer-ip-address: true# 实例的主机名hostname: ${spring.cloud.client.ip-address}# 实例的 ID 规则instance-id: ${spring.cloud.client.ip-address}:${spring.application.name}:${server.port}client:# 是否向注册中心注册自己registerWithEureka: false# 是否向注册中心获取注册信息fetchRegistry: falseserviceUrl:# 注册中心地址defaultZone: http://${eureka.instance.hostname}:${server.port}/eureka/这里使用了默认的 8761 端口当然也可以更改不过在发现调用服务端的注册中心地址端口要与它一致 registry-service - 启动类 package com.zwc;import org.springframework.boot.SpringApplication; import org.springframework.boot.autoconfigure.SpringBootApplication; import org.springframework.cloud.netflix.eureka.server.EnableEurekaServer;SpringBootApplication EnableEurekaServer public class SpringcloudTurbineRegistryServiceApplication {public static void main(String[] args) {SpringApplication.run(SpringcloudTurbineRegistryServiceApplication.class, args);}}在启动类中添加 EnableEurekaServer 注解表示此工程是注册中心 registry-service - 启动项目 1. 项目启动成功后访问http://localhost:8761/即可看到eureka-server 主页面 master-service聚合监控中心 master-service - POM 文件 ?xml version1.0 encodingUTF-8? project xmlnshttp://maven.apache.org/POM/4.0.0 xmlns:xsihttp://www.w3.org/2001/XMLSchema-instancexsi:schemaLocationhttp://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsdmodelVersion4.0.0/modelVersion!-- 继承父 --parentgroupIdcom.zwc/groupIdartifactIdspringcloud-turbine-service/artifactIdversion1.0/version/parent!-- 三坐标 --groupIdcom.zwc/groupIdartifactIdspringcloud-turbine-master-service/artifactIdversion1.0/version!-- 工程名称描述 --namespringcloud-turbine-master-service/namedescription集群监控/description!-- 打包方式 --packagingjar/packaging!-- 在 properties下声明相应的版本信息然后在dependency下引用的时候用 ${} 就可以引入该版本jar包了 --properties/properties!-- 加入依赖 --dependencies!-- commons工程 依赖 --dependencygroupIdcom.zwc/groupIdartifactIdspringcloud-turbine-commons/artifactIdversion1.0/version/dependency!-- 提供者消费者 --dependencygroupIdorg.springframework.cloud/groupIdartifactIdspring-cloud-starter-netflix-eureka-client/artifactId/dependency!-- actuator --dependencygroupIdorg.springframework.boot/groupIdartifactIdspring-boot-starter-actuator/artifactId/dependency!-- hystrix --dependencygroupIdorg.springframework.cloud/groupIdartifactIdspring-cloud-starter-netflix-hystrix/artifactId/dependency!-- dashboard --dependencygroupIdorg.springframework.cloud/groupIdartifactIdspring-cloud-starter-netflix-hystrix-dashboard/artifactId/dependency!-- turbine --dependencygroupIdorg.springframework.cloud/groupIdartifactIdspring-cloud-netflix-turbine/artifactId/dependency/dependencies!-- 插件依赖 --buildpluginsplugingroupIdorg.springframework.boot/groupIdartifactIdspring-boot-maven-plugin/artifactId/plugin/plugins/build/project加入spring-cloud-starter-netflix-eureka-client依赖提供和注册服务加入依赖 spring-boot-starter-actuator开启并配置端点加入依赖 spring-cloud-starter-netflix-hystrix熔断器加入依赖 spring-cloud-starter-netflix-hystrix-dashboard熔断监控加入依赖spring-cloud-netflix-turbine监控数据聚合 master-service - application.yml配置文件 # 端口 server:port: 8762# 应用名称 spring:application:name: hystrix-dashboard-turbineeureka:instance:# 使用 ip 代替实例名prefer-ip-address: true# 实例的主机名hostname: ${spring.cloud.client.ip-address}# 实例的 ID 规则instance-id: ${spring.cloud.client.ip-address}:${spring.application.name}:${server.port}client:serviceUrl:# 注册中心地址defaultZone: http://${eureka.instance.hostname}:8761/eureka/turbine:# 监控的应用名称多个以逗号隔开app-config: turbine-a,turbine-baggregator:# 指定聚合哪些集群默认为 defaultclusterConfig: default# 指定集群名称为 defaultclusterNameExpression: new String(default)注意此处配置注册中心地址的端口为 8761 也就是上面注册中心工程配置的端口此工程需要和应用服务指定同一个注册中心地址配置的app-config 中的应用名称都将会被此工程监控 master-service - 启动类 package com.zwc;import org.springframework.boot.SpringApplication; import org.springframework.boot.autoconfigure.SpringBootApplication; import org.springframework.cloud.netflix.eureka.EnableEurekaClient; import org.springframework.cloud.netflix.hystrix.EnableHystrix; import org.springframework.cloud.netflix.hystrix.dashboard.EnableHystrixDashboard; import org.springframework.cloud.netflix.turbine.EnableTurbine;SpringBootApplication EnableEurekaClient EnableHystrix EnableHystrixDashboard EnableTurbine public class SpringcloudTurbineMasterServiceApplication {public static void main(String[] args) {SpringApplication.run(SpringcloudTurbineMasterServiceApplication.class, args);}}添加 EnableEurekaClient 注解表示此工程可以向注册中心提供服务添加EnableHystrix 注解表示开启熔断器添加 EnableHystrixDashboard 注解表示开启熔断监控添加EnableTurbine 注解表示开启监控数据聚合 master-server - 启动项目 1. 项目启动成功后访问http://localhost:8762/hystrix可以看到 2. 在中间的输入框中输入http://127.0.0.1:8762/turbine.stream?点击Monitor Stream 按钮可以看到 3. 此时还未调用服务所以一直显示 ‘Loading …’ 服务工程 A提供者和消费者 服务工程 A- POM 文件 ?xml version1.0 encodingUTF-8? project xmlnshttp://maven.apache.org/POM/4.0.0 xmlns:xsihttp://www.w3.org/2001/XMLSchema-instancexsi:schemaLocationhttp://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsdmodelVersion4.0.0/modelVersion!-- 继承父 --parentgroupIdcom.zwc/groupIdartifactIdspringcloud-turbine-a-service/artifactIdversion1.0/version/parent!-- 三坐标 --groupIdcom.zwc/groupIdartifactIdspringcloud-turbine-a-service-core/artifactIdversion1.0/version!-- 工程名称描述 --namespringcloud-turbine-a-service-core/namedescription服务工程 - A 核心/description!-- 打包方式 --packagingjar/packaging!-- 在 properties下声明相应的版本信息然后在dependency下引用的时候用 ${} 就可以引入该版本jar包了 --properties/properties!-- 加入依赖 --dependencies!-- commons工程 依赖 --dependencygroupIdcom.zwc/groupIdartifactIdspringcloud-turbine-commons/artifactIdversion1.0/version/dependency!-- api工程 依赖 --dependencygroupIdcom.zwc/groupIdartifactIdspringcloud-turbine-a-service-api/artifactIdversion1.0/version/dependency!-- 提供者消费者 --dependencygroupIdorg.springframework.cloud/groupIdartifactIdspring-cloud-starter-netflix-eureka-client/artifactId/dependency!-- feign --dependencygroupIdorg.springframework.cloud/groupIdartifactIdspring-cloud-starter-openfeign/artifactId/dependency!-- actuator --dependencygroupIdorg.springframework.boot/groupIdartifactIdspring-boot-starter-actuator/artifactId/dependency!-- hystrix --dependencygroupIdorg.springframework.cloud/groupIdartifactIdspring-cloud-starter-netflix-hystrix/artifactId/dependency!-- dashboard --dependencygroupIdorg.springframework.cloud/groupIdartifactIdspring-cloud-starter-netflix-hystrix-dashboard/artifactId/dependency/dependencies!-- 插件依赖 --buildpluginsplugingroupIdorg.springframework.boot/groupIdartifactIdspring-boot-maven-plugin/artifactId/plugin/plugins/build/project加入spring-cloud-starter-netflix-eureka-client依赖提供和注册服务加入 Feign 的起步依赖spring-cloud-starter-openfeign消费服务加入依赖 spring-boot-starter-actuator开启并配置端点加入依赖 spring-cloud-starter-netflix-hystrix熔断器加入依赖 spring-cloud-starter-netflix-hystrix-dashboard熔断监控 服务工程 A- application.yml配置文件 # 端口 server:port: 8090# 应用名称 spring:application:name: turbine-aeureka:instance:# 使用 ip 代替实例名prefer-ip-address: true# 实例的主机名hostname: ${spring.cloud.client.ip-address}# 实例的 ID 规则instance-id: ${spring.cloud.client.ip-address}:${spring.application.name}:${server.port}client:serviceUrl:# 注册中心地址defaultZone: http://${eureka.instance.hostname}:8761/eureka/management:endpoints:web:exposure:# 开启监控端点include: hystrix.stream注意此处配置注册中心地址的端口为 8761 也就是上面注册中心工程配置的端口spring.application.name应用名称被消费者调用时需要用到它在消费的同时也可以被消费服务工程 B 和服务工程 C 配置与此类似只是端口和应用名称不一样不再赘述在 2.0 后需要主动开启端点 hystrix.stream否则 404 服务工程 A- application.properties注意 # 开启断路器 feign.hystrix.enabledtrue断路器要主动开启服务调用失败时才会熔断此处有一个坑把此配置写到 yml 中熔断不会生效A 和 B 工程都有此配置此次搭建中 C 工程只提供服务没有消费服务。所以 C 工程不用该配置application.properties 和bootstrap.yml 二选一就行 服务工程 A- bootstrap.yml注意 feign:hystrix:# 开启断路器enabled: true断路器要主动开启服务调用失败时才会熔断此处有一个坑把此配置写到 application.yml中熔断不会生效application.properties 和bootstrap.yml 二选一就行 服务工程 A- controller 前端控制器提供服务 package com.zwc.a.controller;import org.springframework.beans.factory.annotation.Value; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RestController;/** ClassName ASayHelloController* Desc TODO Say Hello* Date 2019/5/20 23:24* Version 1.0*/ RestController public class ASayHelloController {/** ClassName ASayHelloController* Desc TODO 读取配置文件中的端口* Date 2019/5/20 23:24* Version 1.0*/Value(${server.port})private String port;/** ClassName ASayHelloController* Desc TODO Say Hello* Date 2019/5/20 23:24* Version 1.0*/RequestMapping(/a)public String a(){return HelloIm a. port port;}}提供一个服务输出 Hello 和端口 服务工程 A- 服务调用 package com.zwc.a.api.feign;import com.zwc.a.api.impl.FeignApiFallBack; import org.springframework.cloud.openfeign.FeignClient; import org.springframework.web.bind.annotation.RequestMapping;/** ClassName FeignApi* Desc TODO 使用 Feign 调用 b - 接口* Date 2019/5/20 23:21* Version 1.0*/ FeignClient(value turbine-b , fallback FeignApiFallBack.class) public interface FeignApi {/** ClassName FeignApi* Desc TODO 通过 turbine-b 服务名调用 b() 方法* Date 2019/5/20 23:21* Version 1.0*/RequestMapping(/b)String b();}通过 FeignClient 注解中 value “turbine-b” 来指定调用哪个服务turbine-b 就是提供者的spring.application.name应用名称通过 FeignClient 注解中 fallback FeignApiFallBack.class 来指定熔断时调用的方法FeignApiFallBack 就是此接口FeignApi的实现类对应的实现方法就是熔断时调用的方法b()此方法是 B 工程中提供的服务在这里定义成接口注意要与提供者具有相同返回值相同方法名以及相同参数 服务工程 A- FallbackFeignApiFallBack package com.zwc.a.api.impl;import com.zwc.a.api.feign.FeignApi; import org.springframework.stereotype.Component;/** ClassName FeignApi* Desc TODO fallback* Date 2019/5/20 23:21* Version 1.0*/ Component public class FeignApiFallBack implements FeignApi {/** ClassName FeignApiFallBack* Desc TODO 调用 turbine-b 服务中的 b() 方法失败时执行* Date 2019/5/20 23:31* Version 1.0*/Overridepublic String b() {return HelloaUseB fail;} }使用Component 注解把此类交给 Spring 管理实现了FeignApi 接口提供熔断时对应的方法 服务工程 A- controller 前端控制器消费服务 package com.zwc.a.controller;import com.zwc.a.api.feign.FeignApi; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RestController;/** ClassName AUseBFeignController* Desc TODO 使用 Feign 调用 b - 前端控制器* Date 2019/5/20 23:23* Version 1.0*/ RestController public class AUseBFeignController {Autowired(required false)private FeignApi feignApi;/** ClassName FeignController* Desc TODO 通过 turbine-b 服务名调用 b() 方法* Date 2019/5/20 23:13* Version 1.0*/RequestMapping(/aUseB)public String aUseB(){return feignApi.b();}}使用 Autowired 注解装配 Bean通过此 Bean 中的方法调用服务此类对外暴露接口调用的实则是提供者的服务 服务工程 A- 启动类 package com.zwc;import org.springframework.boot.SpringApplication; import org.springframework.boot.autoconfigure.SpringBootApplication; import org.springframework.cloud.netflix.eureka.EnableEurekaClient; import org.springframework.cloud.netflix.hystrix.EnableHystrix; import org.springframework.cloud.netflix.hystrix.dashboard.EnableHystrixDashboard; import org.springframework.cloud.openfeign.EnableFeignClients;SpringBootApplication EnableEurekaClient EnableFeignClients EnableHystrix EnableHystrixDashboard public class SpringcloudTurbineAServiceCoreApplication {public static void main(String[] args) {SpringApplication.run(SpringcloudTurbineAServiceCoreApplication.class, args);}}添加 EnableEurekaClient 注解表示此工程可以向注册中心提供服务添加EnableFeignClients 注解表示开启 Feign 功能进行远程调用添加EnableHystrix 注解表示开启熔断器添加 EnableHystrixDashboard 注解表示开启熔断监控 服务工程 A- 启动项目 1.项目启动成功后访问http://localhost:8090/a调用自己的服务 2. 输出内容‘HelloI’m a. port8090’ 3. 访问地址http://localhost:8090/aUseB调用 B 工程的服务 4. 输出内容‘HelloaUseB fail’ 此时因为 B 工程还未启动所以调用了 fallback中的方法 5. 这时再回到master-server 工程的 ‘Loading …’ 页面发现刚刚服务调用失败已经被监控到了 6. 如果还是显示的 ‘Loading …’ 请再稍等一会 7. 启动服务工程 B项目启动成功后再次访问http://localhost:8090/aUseB调用 B 工程的服务 8.输出内容‘HelloI’m b. port8091’ 如果还未调用成功等待一会再刷新试试 9. 这时再回到 master-server 工程可以看到 10. 另起页面访问http://localhost:8091/bUseC调用 C 工程的服务 11.输出内容‘HellobUseC fail’ 此时因为 C 工程还未启动所以调用了 fallback中的方法 12. 这时再回到 master-server 工程可以看到调用 C 工程也被监控到了 13.红色的百分比表示失败率 14.左边的六个数字对应着页面右上角的六个状态Success、Short-Circuited… service 工程 -项目结构 把多工程项目使用 IntelliJ IDEA 打开 把项目从 GitHub 中下载到你的本地打开IntelliJ IDEA点击 File - Open打开你下载到本地的项目目录springcloud-turbine -springcloud-turbine-service选择打开此工程打开 service 工程后再次点击 File - Project Structrue选择 Modules点击 ‘’ 符号点击 ImportModule还是打开你下载到本地的项目目录springcloud-turbine -springcloud-turbine-commons - pom.xml点击 OK点击 NextFinish点击 ApplyOK 希望能够帮助到你 over
http://www.tj-hxxt.cn/news/218435.html

相关文章:

  • 刷粉网站推广便宜博客类网站源码
  • 百度seo优化是什么百度seo效果优化
  • 做思维导图的资源网站淘宝网站做推广收费吗
  • 外贸建站优化推广怎么在自己电脑上建设网站
  • 网站建设合同的验收表青浦区网站建设
  • 重庆建设厂招工信息网站商城网站都有什么功能
  • 微网站工程案例展示一家公司做网站需要什么资料
  • 云南建设厅网站安全处网站集约化后如何建设
  • 家具网站php源码小网站推荐一个
  • 网站怎么做第三方支付接口简易微网站模板
  • 怎么管理网站的内容吗wordpress 亲子模板下载
  • 南山网站建设深圳信科威海自适应网站建设
  • 深圳建站公司哪个济南兴田德润简介苏州口碑好的保洁公司
  • 在线教育网站源码深圳网站建设维护服务
  • 电子商务网站模板 html电商代运营十大公司排名
  • 引领网站做网站多久才会有收益
  • 网站模板免费下载网页模板佳木斯 网站建设
  • 威海网站建设是什么网件路由器做网站
  • 如何用ps做网站标识wordpress 菜单 icon
  • 做影视网站需要境外80h tv wordpress主题
  • 织梦网站建设后优化步骤网站更换ico文件位置
  • 英国有哪些做折扣的网站20元备案域名
  • linux wordpress建站教程专门做汽车内饰的网站
  • 电子商务的门户网站做网站是什么职业
  • 衡阳网站页面设计公司溧阳市住房和城乡建设局网站
  • php如何做网站企业网站 备案
  • 青岛英文网站建设服务公司网站优化流程
  • 天水地区建网站小公司简介模板
  • 选择seo网站排名优化网站开发项目需求书
  • 虚拟交易网站开发wap网站建设兴田德润实惠