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

徐州网站关键词各类手机网站建设

徐州网站关键词,各类手机网站建设,优惠券怎做网站,网站前端设计公司目录 一、项目架构演变过程 1、单体应用架构 2、垂直应用架构 3、分布式服务架构 4、流动计算架构(SOA架构) 5、微服务架构 二、如何实现微服务远程调用 1、HttpClient工具类(springboot中) 形式1:调用第三方…

目录

一、项目架构演变过程

1、单体应用架构

2、垂直应用架构

3、分布式服务架构

4、流动计算架构(SOA架构)

5、微服务架构

二、如何实现微服务远程调用

1、HttpClient工具类(springboot中)

形式1:调用第三方的公开服务

形式2:创建两个微服务,两个服务之间进行远程服务调用

2、RestTemplate工具类(springboot中)

3、openFeign组件(springcloud中)

三、微服务架构的实现方式

1、dubbo(都是java语言开发的)

2、springcloud(不限制语言)

四、SpringCloud的简介

4.1初识SpringCloud

4.2 为什么使用SpringCloud

4.3 SpringCloud相关组件(框架)

五、nacos注册中心

1、搭建nacos注册中心

2、注册微服务到nacos注册中心


一、项目架构演变过程

1、单体应用架构

当网站流量很小时,只需一个应用,将所有功能都部署在一起,以减少部署节点和成本。此

时,用于简化增删改查工作量的数据访问框架(ORM)是关键。

适用于小型网站,小型管理系统,将所有功能都部署到一个功能里,简单易用。

缺点:1、性能扩展比较难 2、协同开发问题 3、不利于升级维护

2、垂直应用架构

当访问量逐渐增大,单一应用增加机器带来的加速度越来越小,将应用拆成互不相干的几个

应用,以提升效率。此时,用于加速前端页面开发的Web框架(MVC)是关键。

通过切分业务来实现各个模块独立部署降低了维护和部署的难度,团队各司其职更易管

理,性能扩展也更方便,更有针对性。

缺点:公用模块无法重复利用,开发性的浪费

3、分布式服务架构

当垂直应用越来越多,应用之间交互不可避免,将核心业务抽取出来,作为独立的服务,逐

形成稳定的服务中心,使前端应用能更快速的响应多变的市场需求。此时,用于提高业务

复用及整合的分布式服务框架是关键。

4、流动计算架构(SOA架构)

当服务越来越多,容量的评估,小服务资源的浪费等问题逐渐显现,此时需增加一个调度中

心基于访问压力实时管理集群容量,提高集群利用率。此时,用于提高机器利用率的资源调

度和治理中心(SOA)[Service Oriented Architecture]是关键

5、微服务架构

微服务架构的特点

单一职责:微服务架构中每一个服务(模块项目)都对应唯一的业务能力,做到单一职责

:微服务的服务拆分粒度很小,例如一个用户管理就可以作为一个服务。每个服务虽小,但“五脏俱全”。

面向服务:面向服务是说每个服务都要对外暴露Restful风格服务接口API。并不关心服务的

技术实现,做到与平台和语言无关,也不限定用什么技术实现,只要提供Restful的接口即可。

自治:自治是说服务间互相独立,互不干扰

  • 团队独立:每个服务都是一个独立的开发团队,人数不能过多。
  • 技术独立:因为是面向服务,提供Restfule接口,使用什么技术没有别人干涉
  • 前后端分离:采用前后端分离开发,提供统一Rest接口,后端不用再为PC、移动段开发不同接口
  • 数据库分离:每个服务都使用自己的数据源
  • 部署独立,服务间虽然有调用,但要做到服务重启不影响其它服务。有利于持续集成和持续交付。每个服务都是独立的组件,可复用,可替换,降低耦合,易维护

二、如何实现微服务远程调用

1、HttpClient工具类(springboot中)

<dependency><groupId>org.apache.httpcomponents</groupId><artifactId>httpclient</artifactId>
</dependency>

形式1:调用第三方的公开服务

package com.hl.web;
​
import org.apache.http.HttpEntity;
import org.apache.http.client.methods.CloseableHttpResponse;
import org.apache.http.client.methods.HttpGet;
import org.apache.http.impl.client.CloseableHttpClient;
import org.apache.http.impl.client.HttpClientBuilder;
import org.apache.http.util.EntityUtils;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
​
import java.io.IOException;
​
@RestController
public class HelloController {@RequestMapping("/hello")public Object hello() throws IOException {//发起网络请求,调用百度接口//1、构建一个HttpClient对象CloseableHttpClient client = HttpClientBuilder.create().build();//2、封装一个httpGet 或者 post请求HttpGet request = new HttpGet("http://www.baidu.com");//3、发起网络请求,获取响应对象CloseableHttpResponse response = client.execute(request);//4、解析响应结果Integer code = response.getStatusLine().getStatusCode();System.out.println("响应状态码:"+code);HttpEntity entity = response.getEntity();return EntityUtils.toString(entity);}
}

形式2:创建两个微服务,两个服务之间进行远程服务调用

http://localhost:8081/user/info

@RestController
@RequestMapping("/user")
public class UserController {@RequestMapping("/info")public User info(){return new User(1,"admin");}
}
@RequestMapping("/info")
public Object info() throws IOException {//发起网络请求,调用百度接口//1、构建一个HttpClient对象CloseableHttpClient client = HttpClientBuilder.create().build();//2、封装一个httpGet 或者 post请求HttpGet request = new HttpGet("http://localhost:8081/user/info");//3、发起网络请求,获取响应对象CloseableHttpResponse response = client.execute(request);//4、解析响应结果Integer code = response.getStatusLine().getStatusCode();System.out.println("响应状态码:"+code);HttpEntity entity = response.getEntity();String s = EntityUtils.toString(entity);User user = JSONObject.parseObject(s,User.class);return user;
}

2、RestTemplate工具类(springboot中)

@SpringBootApplication
public class ProjectAApplication {@Beanpublic RestTemplate restTemplate(){return new RestTemplate();}
}
@RestController
public class HelloController {@Autowiredprivate RestTemplate restTemplate;
​@RequestMapping("/getUser")public User getUser(){return restTemplate.getForObject("http://localhost:8081/user/info", User.class);}
}

3、openFeign组件(springcloud中)

三、微服务架构的实现方式

1、dubbo(都是java语言开发的)

有Alibaba研发,后转给apache维护。

2、springcloud(不限制语言)

spring组织提供的。 http协议远程调用

四、SpringCloud的简介

4.1初识SpringCloud

微 服 务 是 一 种 架 构 方 式 , 最 终 肯 定 需 要 技 术 架 构 去 实 施 。
微 服 务 的 实 现 方 式 很 多 , 但 是 最 火 的 莫 过 于 Spring Cloud了 。 为 什 么 ?

  • 后台硬:作为Spring家族的一员,有整个Spring全家桶靠山,背景十分强大。
  • 技术强:Spring作为Java领域的前辈,可以说是功力深厚。有强力的技术团队支撑,一般人还真比不了
  • 群众基础好:可以说大多数程序员的成长都伴随着Spring框架,试问:现在有几家公司开发不用Spring?SpringCloud与Spring的各个框架无缝整合,对大家来说一切都是熟悉的配方,熟悉的味道。
  • 使用方便:相信大家都体会到了SpringBoot给我们开发带来的便利,而SpringCloud完全支持SpringBoot的开发,用很少的配置就能完成微服务框架的搭建

4.2 为什么使用SpringCloud

  • SpringCloud是Spring旗下的项目之一,官网地址:http://projects.spring.io/spring-cloud/
  • Spring最擅长的就是集成,把世界上最好的框架拿过来,集成到自己的项目中。
  • SpringCloud也是一样,它将现在非常流行的一些技术整合到一起,实现了诸如:配置管理,服务发现,智能路由,负载均衡,熔断器,控制总线,集群状态等等功能。

4.3 SpringCloud相关组件(框架)

  • Eureka:服务治理组件,包含服务注册中心,服务注册与发现机制的实现。(服务治理,服务注册/发现) ,类似的产品还有Consul、Nacos
  • Spring Cloud GateWay:网关组件,提供智能路由,访问过滤功能 ,类似产品还有Zuul
  • Ribbon:客户端负载均衡的服务调用组件(客户端负载均衡)
  • Feign:服务调用,给予Ribbon和Hystrix的声明式服务调用组件 (声明式服务调用) (发送Http请求访问)
  • Hystrix:容错管理组件,实现断路器模式,帮助服务依赖中出现的延迟和故障提供强大的容错能力。(熔断、断路器,容错)

nacos注册中心

loadBalancer

openFeign

gateway

nacos配置中心

sentinel

五、nacos注册中心

1、搭建nacos注册中心

下载解压缩到非中文目录

启动nacos服务(默认集群模式启动)

以单机版模式启动服务
​startup.cmd -m standalone

http://localhost:8848/nacos/

用户名nacos 密码nacos

2、注册微服务到nacos注册中心

<dependency><groupId>com.alibaba.cloud</groupId><artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
</dependency>
@SpringBootApplication
@EnableDiscoveryClient //启用服务发现组件的客户端
public class ProjectCApplication {
​public static void main(String[] args) {SpringApplication.run(ProjectCApplication.class, args);}
​
}
# Nacos帮助文档: https://nacos.io/zh-cn/docs/concepts.html
#当前项目在nacos注册中心暴漏的服务名
spring.application.name=projectC
# Nacos认证信息
spring.cloud.nacos.discovery.username=nacos
spring.cloud.nacos.discovery.password=nacos
# Nacos 服务发现与注册配置,其中子属性 server-addr 指定 Nacos 服务器主机和端口
spring.cloud.nacos.discovery.server-addr=localhost:8848
# 注册到 nacos 的指定 namespace,默认为 public
spring.cloud.nacos.discovery.namespace=public
# 应用服务 WEB 访问端口
server.port=8082

http://www.dtcms.com/a/590617.html

相关文章:

  • 做音乐网站赚钱吗中信云做网站
  • 兰州网站建设平台分析指数函数图像
  • 从零掌握U-Net数据集训练:原理到实战的完整指南
  • 石家庄行业网站建设阿里巴巴官网入口
  • 来广营做网站公司游戏平台搭建
  • 【数值分析】12-非线性方程的求根方法-习题(1-8)
  • 焦作网站建设设计公司上海建设工程招投标在什么网站
  • 惠州建设网站开发汕头达濠
  • 位置编码演进史:SIN → ALiBi → RoPE → PI → NTK → YARN
  • 网站建设是必须的吗苏州工业园区两学一做教育网站
  • 鹤峰网站制作win7下使用wordpress
  • ThreadLocal中key为什么是弱引用,value为什么是强引用
  • 天津刘金鹏做网站网站手机版管理链接
  • 天津建设协会网站首页什么叫一级域名二级域名
  • YesPlayMusic v0.4.10 | 一款网易云第三方开源音乐播放器,同时支持切换其他酷我、QQ等音源
  • 手机网站建设浩森宇特网络营销的优势和劣势
  • 哪里学网站建设推广用wordpress建网站
  • 企业网站开发成都网页开发者选项在哪里
  • AI空间低配版?没有新品也能体验,极空间部署Foxel网盘
  • 如何建立内部网站怎么做hello官方网站
  • 常见的营销手段深圳网络营销优化
  • 重庆市公共资源交易中心专业做seo的网站
  • 企业门户网站源码下载做网站协调
  • 网站图片轮播怎么弄网站前端切图做多个页面
  • 目字形布局结构的网站做网站id
  • Modbus通信协议详解:工业自动化的经典协议
  • C++初始继承,继承中构造、析构顺序
  • PyTorch深度学习实战01:全流程体验深度学习
  • 网站建设的人员组织专业网站建设策划
  • 网站首页代码怎么做相亲网站怎么建设