字节三面:到底知不知道什么是Eureka?

作者&投稿:苗钞 (若有异议请与网页底部的电邮联系)
~

什么是服务注册?

首先我们来了解下,服务注册、服务发现和服务注册中心的之间的关系。

举个形象的例子,三者之间的关系就好像是供货商,顾客和商店。

首先各地的供货商会将各种商品提供给商店,然后顾客需要商品的时候会去商店购买。

注册中心就好比是这个商店,供货商的动作就是服务注册,商品就是注册的服务。

当部署的服务启动后,会注册到注册中心,消费者需要什么样的服务,就自己去注册中心拉取。

那么到底什么是服务注册,为什么要将服务注册到注册中心呢?

服务注册指的是服务在启动时将服务的信息注册到注册中心中,由注册中心统一对所有的注册的服务进行管理。

现在我们想想,假如你是消费者,你需要买一个商品,你可以去商店,也可以直接去供货商。

但是如果今天你要买很多商品,而且我们并不知道每个商品对应的供应商的地址,那么你就得挨家挨户的去跑供货商购买商品。

是不是就很麻烦了,倘若此时有一家商店,汇总了多家供货商的商品,那你是不是只需要去这一家商店就能购买到你需要的所有的商品了呢?

这样是不是就方便了。

在我们现实开发中,比如我们需要获取用户信息的时候,而此时,我们的用户服务只部署了一个节点,那我们就可以使用IP+端口的形式访问服务。

当此时我们的服务部署了10个节点后,我们可以通过域名访问,通过nginx转发到某一个节点上,访问该节点的服务。

使用过nginx的小伙伴们都知道,每当我们需要新增一个节点的时候,我们就需要去修改nginx的配置文件,一旦服务部署的节点过多,频繁修改配置文件就变成了一件极其麻烦的事情。

这个时候,我们的注册中心,就应该粉墨登场了。

注册中心一登场,我们就尽管部署服务节点,部署完成后,服务启动,服务的信息就会被注册到注册中心,我们就不需要担心是不是又要去修改配置文件了。

什么是服务发现?

服务发现有两种模式:一种是客户端发现模式,一种是服务端发现模式。Eureka采用的是客户端发现模式。

客户端发现模式就好比我是一个土豪顾客,我去了商店,我把所有的商品都买回家,需要的时候在这些商品里面寻找。

因为我是土豪,所以我当然不能忍受商店里有新品上架,而我却没有,所以我每隔一段时间就会商店增量获取最新的商品。

这就是Eureka中的Fetch Registry,抓取注册信息。

Eureka Client 从 Eureka Server 获取注册表信息并在本地缓存。

这里我们注意一下,Eureka Client并不是直接去服务注册表中获取数据,而是从ReadOnly缓存中获取数据。

并且会通过在上一个获取周期和当前获取周期之间获取增量更新,这些信息会定期更新(每30秒更新一次)。

获取的时候可能返回相同的实例。Eureka Client会自动处理重复信息。

因为我的土豪行为,我已经被商店老板记录在它的VVIP名单上了。可惜天有不测风云,我破产了,我再也不能这么土豪了,没办法,我告诉了老板我破产了,老板听了我的话,想都没想,直接从他的VVIP名单上将我的名字给剔除了,社会就是这么现实。

这就是Eureka中的Cancel,取消。

每一个微服务节点关闭时,Eureka Client会向Eureka Server发送一个取消请求。

Eureka Server收到你的取消请求后,就会将你从服务注册表中给剔除。

商店老板是个傲娇的人,她制定了一个规则,如果你是她VVIP名单上的人,你必须每隔一段时间就要去商店采购商品。

一旦你在一段时间内没有来采购,她就觉得你已经没有购买能力,不适合在她的VVIP名单上存在了。

她就会狠心的将你从她的VVIP名单上将我的名字给剔除了。

这就是Eureka中的Renew(更新 / 续借)

Eureka Client 内部具备一个内置的负载均衡器,它使用轮训(round-robin)负载算法。

在服务启动后,每隔一定周期(默认30秒)向Eureka Server发送心跳。

如果Eureka Server在多个心跳周期内(默认90秒)没有收到Eureka Client发送过来的心跳,Eureka Server将会在服务注册表中将该节点剔除。

当然了,服务发现去注册中心拉取的是服务的信息,然后需要从服务信息中获取到服务部署的节点信息,然后通过域名地址访问到该节点的服务。

就好像一家商店,因为空间太小,只是存放了一些商品的微缩模型,模型上写着该商品所属的供货商地址,我们去商店拿到该模型后,看到供货商的地址,然后我们就可以直接去供货商那儿直接购买商品了。

什么是注册中心,注册中心的作用?

注册中心就是一个管理器,各个服务提供者将服务注册到注册中心,由注册中心进行统一的存储和管理。

注册中心同时还有着判断服务是否可用,对于不可用的服务进行剔除的功能。

至于如何判断服务的可用性和如何剔除不可用的服务,后续会有详细的讲解。

什么是 Eureka,有什么作用?

Eureka采用CS架构,它分为两大组件。

一个是Eureka Server,注册中心服务端。

当各个微服务节点启动后,Eureka Server 会存储服务提供者注册上来的服务信息,并且提供二层缓存机制来维护整个注册中心。

另一个是Eureka Client,注册中心客户端。

Eureka Client是一个java客户端,它用来简化和Eureka Server交互。

Eureka Client 会拉取、更新和缓存 Eureka Server 中的信息。

因此当所有的 Eureka Server 节点都宕掉,服务消费者依然可以使用缓存中的信息找到服务提供者,但是当服务有更改的时候会出现信息不一致。

Eureka 架构详解

如下图所示,这是官网提供给我们的Eureka的架构图Eureka 的架构,主要分为 Eureka Server 和 Eureka Client 两部分,Eureka Client 又分为 Applicaton Service 和 Application Client,Applicaton Service 就是服务提供者,Application Client 就是服务消费者。

我们首先会在应用程序中依赖 Eureka Client,项目启动后 Eureka Client 会向 Eureka Server 发送请求,进行注册,并将自己的一些信息发送给 Eureka Server。

注册成功后,每隔一定的时间,Eureka Client 会向 Eureka Server 发送心跳来续约服务,也就是汇报健康状态。如果客户端长时间没有续约,那么 Eureka Server 大约将在 90 秒内从服务器注册表中删除客户端的信息。

Eureka Client 还会定期从 Eureka Server 拉取注册表信息,然后根据负载均衡算法得到一个目标,并发起远程调用,关于负载均衡在后面的课时会详细介绍,也就是 Ribbon 组件。

应用停止时也会通知 Eureka Server 移除相关信息,信息成功移除后,对应的客户端会更新服务的信息,这样就不会调用已经下线的服务了,当然这个会有延迟,有可能会调用到已经失效的服务,所以在客户端会开启失败重试功能来避免这个问题。

Eureka Server 会有多个节点组成一个集群,保证高可用。Eureka Server 没有集成其他第三方存储,而是存储在内存中。

所以 Eureka Server 之间会将注册信息复制到集群中的 Eureka Server 的所有节点。

这样数据才是共享状态,任何的 Eureka Client 都可以在任何一个 Eureka Server 节点查找注册表信息。

Eureka 的工作流程

Eureka 的自我保护机制

什么是自我保护机制

官方定义:自我保护模式正是一种针对网络异常波动时的安全保护措施,使用自我保护模式能使Eureka集群更加健壮稳定的运行。

为什么要开启自我保护机制?

如果Eureka Server在一定时间内(默认90s)(可优化)没有收到某一个服务节点的心跳,Eureka Server将会移除该服务实例。

但是在某些时候,遇到网络分区故障,服务节点实际上是正常存活状态,但是却无法和Eureka Server正常通信,此时如果没有引入自我保护机制,Eureka Server就会将该服务节点剔除。

自我保护模式的工作机制

如果15分钟内超过85%的客户端节点都没有正常的心跳,那么Eureka Server就会认为客户端与注册中心发生了网络故障,Eureka Server进入自我保护机制。

自我保护机制的缺点

如果在自我保护机制中,刚好某些服务节点非正常下线,但是Eureka Server并不会剔除该服务节点,服务消费者就会获取到一个无效的服务实例。

解决方案

① :关闭自我保护机制(不推荐)

② :切换请求或断路器,使用负载均衡的方式,设置当一个请求超过多少秒还未得到响应,速度切换请求到下一个注册服务,例如使用Ribbon+Hystrix配置负载均衡和断路器。

Eureka Server 进入自我保护机制后

1、Eureka Server不再从注册表中剔除因为长时间没有和注册中心续约的服务节点

2、Eureka Server仍然能够接受新服务的注册和查询请求,但是不会同步到其他Eureka Server节点上

3、网络正常后,当前Eureka Server节点会将新的服务节点信息同步到其他Eureka Server节点上

如何开启自我保护

通过
eureka.server.enable-self-preservation=true/false来开启或关闭自我保护机制。

其他关键配置:

清理失效服务节点的时间间隔:
eureka.server.evication-interval-timer-in-ms默认60s

续约间隔时间:
eureka.instance.lease-renewal-interval-in-seconds默认30s

续约到期时间:
eureka.instance.lease-expiration-duration-in-seconds默认90s

通过源码窥探Eureka是如何开启自我保护机制的

第一步,我们引入Eureka Server 依赖。

第二步,我们找到eureka-core jar包下的路径为com.netflix.eureka下的registry包

第三步,进入AbstractInstanceRegistry 类,找到evict方法,这个是定期剔除任务的线程最终执行的方法

第四步,我们找到isLeaseExpirationEnabled()方法的实现

第五步,我们注意到
numberOfRenewsPerMinThreshold这个变量很关键,它的含义是每分钟最小的续约次数

在服务注册register和服务下线cancel两个方法中会更新这个变量,更新该变量方法如下:

以上就是Eureka开启自我保护的整个逻辑流程。

解除自我保护机制

1.当服务的网络分区故障解除之后,客户端能够和服务进行交互时,在续约的时候,更新每分钟的续约数,当每分钟的续约数大于85%时,则自动解除。

2.重启服务

Eureka 的健康检查

其实很多框架的健康状态监控都是通过 actuator 来管理健康状态的,并且扩展了 health 端点。

所以说我们只要在项目中集成Actuator,我们就能管理监控项目的健康状态。

Eureka也是一样,我们可以将某些不健康的服务节点的状态告知Eureka Server,然后Eureka Server 会主动让其下线。

这个就是Eureka的健康检查。

如何实现Eureka-Actuator健康检查?

首先我们要在pom中依赖
spring-boot-starter-actuator。

第二步,配置文件中添加
eureka.client.healthcheck.enabled=true 配置

原理分析:

首先在 EurekaDiscoveryClientConfiguration 中根据 eureka.client.healthcheck.enabled 的值来决定是否要装配 EurekaHealthCheckHandler ,然后在 EurekaClientAutoConfiguration 中会注册 HealthCheck ,但我们注册完成后会有调用任务来进行状态的更新,在 com.netflix.discovery.InstanceInfoReplicator.run() 中会进行状态更新。

Eureka 的多级缓存机制

什么是多级缓存机制

Eureka Server 为了避免同时读取内存数据造成的并发冲突问题,采用了多级缓存机制提升服务请求的响应速度。

Eureka Server的缓存是通过一个只读,一个读写缓存来实现的。

一级缓存:concurrentHashMap<key,value>readOnlyCacheMap本质是HashMap,无过期时间,保存数据信息对外输出。

readOnlyCacheMap依赖于定时器的更新,通过与readWriteCacheMap的值做对比,以readWriteCacheMap为准。

responseCacheUpdateIntervalMs:readOnlyCacheMap缓存更新间隔,默认30s

二级缓存:LoaDing<key,value>readWriteCacheMap本质是Guava缓存,包含失效机制,保护数据信息对外输出。

responseCacheAutoExpirationInSeconds:readWriteCacheMap 缓存过期时间,默认180s。

当服务节点发生注册,下线,过期,状态变更等变化时

1.在内存中更新注册表信息

2.同时过期掉readWriteCacheMap缓存,缓存清除只是会去清除readWriteCacheMap这个缓存, readOnlyCacheMap 只读 缓存并没有更新,也就说当客户端的信息发生变化之后, 只读缓存不是第一时间感知到的。只读缓存的更新只能依赖那个30秒的定时任务来更新。

3.一段时间后(默认30s),后台线程发现readWriteCacheMap缓存为空,于是也将readOnlyCacheMap中的缓存清空

4.当有服务消费者拉取注册表信息时,会调用ClassLoader的load方法,将内存中的注册表信息加载到各级缓存中,并返回注册表信息。

在Eureka Server 中会有两个线程,一个是定时同步两个缓存的数据,默认30s,一个是定时检测心跳故障,默认90s。

服务拉取

1.服务消费者,默认每30s,拉取注册表信息

2.从readOnlyCacheMap中获取信息,如果获取为空

3.从readWriteCacheMap中获取,如果还是为空

4.调用ClassLoader的load方法,将内存中的注册表信息加载到各级缓存中,并返回注册表信息。

Eureka的区域配置

当用户地理分布范围很广的时候,比如公司在上海、杭州、青岛等都有分公司的时候,一般都会有多个机房。

那么对于用户而言,当然是希望调用本地分公司的机房中的微服务应用。

比如:上海用户A,调用OAuth2服务,用户A当然希望调用上海机房里面的微服务应用。如果上海用户A调用杭州机房的OAuth2服务,就增加的延时时间。

所以我们希望一个机房内的服务优先调用同一个机房内的服务,当同一个机房的服务不可用的时候,再去调用其它机房的服务,以达到减少延时的作用。

为此,eureka提供了region和zone两个概念来进行分区,Eureka基于Amazon设计的,所以对于地域的区分也与Amazon一致,Amazon分为多个region,每个region包含多个zone,所以Eureka设计时也是可以设置region与zone,请求时可以优先选择与请求服务在同一个zone的服务。

基本配置

此时无论我们调用多少次,调用的都是shanghai下面的zone1下面的服务。

一般来说我们都会结合Ribbon来实现微服务的负载均衡,而Ribbon内部会有一些专门的负载策略算法,虽然刚刚我们说过会优先请求的是指定region下指定 Zone 区域的服务实例。

但有些时候比如当在Region=shanghai下没有可用的zone,系统会默认加载 DEFAULT_ZONE,或者说或者同区域的服务负载过高...等等,也会自动切换成其他区域的服务。

Eureka的重试机制

由于 Spring Cloud Eureka 实现的服务治理机制强调了 CAP 原理中的 AP,即可用性与可靠性,牺牲了一定的一致性(在极端情况下它宁愿接受故障实例也不要丢掉"健康"实例,如同如我们上面所说的自我保护机制)。

但不论是由于触发了保护机制还是服务剔除的延迟,引起服务调用到这些不正常的服务,调用就会失败,从而导致其它服务不能正常工作!

这显然不是我们愿意看到的,我们还是希望能够增强对这类问题的容错。所以,我们在实现服务调用的时候通常会加入一些重试机制。

从 Camden SR2 版本开始,Spring Cloud 就整合了 Spring Retry 来增强 RestTemplate 的重试能力,对于开发者来说只需通过简单的配置,原来那些通过 RestTemplate 实现的服务访问就会自动根据配置来实现重试策略。

开启Eureka的重试机制很简单,首先我们在pom中引入Spring Retry的依赖:

然后在配置文件中配置
spring.cloud.loadbalancer.retry.enabled参数来控制重试机制的开关,因为 Spring Retry默认是开启的,所以说我们只要引入依赖即可,如果说我们想要关闭的话只需要将 spring.cloud.loadbalancer.retry.enabled设置为false即可。

其实在SpringCloud的架构组件中无论是Fegin,Ribbon,还是Zuul都提供了重试机制,这些暂且不论,后续再讲到具体的组件时再进行具体的分析。

实战 Eureka 注册中心的部署

Eureka Server 项目搭建

1、创建一个 springcloud-eureka-server 的项目,然后在 pom 中增加
spring-cloud-starter-netflix-eureka-server 的依赖。

2.在pom.xml文件中新增
spring-cloud-starter-netflix-eureka-server依赖

3.在启动类
SpringcloudEurekaServerApplication上使用 @EnableEurekaServer 开启 EurekaServer 的自动装配功能。

4.添加配置文件application.properties

5.启动项目,然后访问 http://localhost:8761/ ,可以看到 Eureka 的管理页面,表示 Eureka 启动成功了。

1、创建一个 springcloud-eureka-client 的项目,然后在 pom 中增加
spring-cloud-starter-netflix-eureka-client 的依赖。

2.在启动类
SpringcloudEurekaClientApplication上使用 @EnableEurekaClient 开启 EurekaServer 的自动装配功能。

配置
eureka.client.serviceUrl.defaultZone 的地址,也就是刚刚启动的 Eureka Server 的地址, http://localhost:8761/eureka/ 。

启动客户端,然后刷新刚刚打开的Eureka主页,我们发现服务已经注册成功。

Eureka 注册中心添加密码认证

上面我们看到我们搭建好Eureka Server 后访问 http://localhost:8761/ ,没有登陆就可以直接看到 Eureka 的管理页面。

如果在实际使用中,注册中心地址有公网 IP 的话,必然能直接访问到,这样是不安全的。所以我们需要对 Eureka 进行改造,通过集成 Spring-Security 来进行安全认证,加上权限认证来保证安全性。

首先,在 pom.xml 中引入 Spring-Security 的依赖

然后在 application.properties 中加上认证的配置信息

最后增加Spring Security 配置类

这样我们启动Eureka Server成功后在访问 http://localhost:8761/ ,此时浏览器会提示你输入用户名和密码,输入正确后才能继续访问 Eureka 提供的管理页面。

总结

本章我们主要学习了Eureka相关知识,虽然Eureka已经停更了,但是很多公司还在使用它,而它也足够稳定,它所提供的功能也足够大多数公司使用。所以说现在面试中,Eureka相关题目还是经常出现的。反正学到了就是自己的。

祝愿大家早日成为大牛,有一头乌黑秀发的大牛。




清明节的美文摘抄加赏析
一提起清明节还得从介子推的故事说起。 相传春秋战国时代,重耳在外流浪19年,介子推一直跟着,立下了大功,重耳回国做了君主,就是春秋五霸之一晋文公。晋文公要给介子推做官,介子推不愿意做,已经背着老母躲进了绵山。 晋文公便让他的御林军上绵山搜索,没有找到。于是,有人出了个主意说,不如放火烧山,三面点火,...

关于落花和流水的诗句
译文:曾经到临过沧海,别处的水就不足为顾;除了巫山,别处的云便不称其为云。 3、玲珑骰子安红豆,入骨相思知不知。___唐 温庭筠《南歌子词二首 \/ 新...北固山前三面水。 碧琼梳拥青螺髻。14、一纸乡书来万里。 问我何年,真个成归计。白首送春拼一醉。 东风吹破千行泪。15、醉别西楼醒不记。 春梦...

清明节源于介子推的传说,介子推有什么故事吗?
准确地说,寒食节源于介子推的传说。介子推(出生不详——公元前636年),又名介之推、介推,后人尊为介子,春秋时期晋国人,因“割股奉君”,隐居“不言禄”之壮举,深得世人怀念。死后葬于介休绵山。晋文公重耳深为愧疚,遂改绵山为介山,并立庙祭祀,由此产生了“寒食节”(清明节前一天),历代诗家文人留有大量吟咏缅...

请大家帮我找找关于红豆的诗句
春来发几枝。愿君多采撷,此物最相思。=== 红豆生南国,是很遥远的事情。相思算什么,早已无人在意。醉卧不夜城,处处霓虹。酒杯中好一片滥滥风情。最堪忘却古人诗,最不屑一顾是相思,守着爱怕人笑还怕人看轻,春又来看红豆开,竟不见有情人去采。烟花拥着风流,真情不在。=== 红豆南天出...

寒食节为什么不能扫墓?
问题八:寒食节到底是怎么回事 寒食节亦称“禁烟节”、“冷节”、“百五节”,在夏历冬至后一百零五日,清明节前一二日。是日初为节时,禁烟火,只吃冷食。并在后世的发展中逐渐增加了祭扫、踏青、秋千、蹴鞠、牵勾、斗卵等风俗,寒食节前后绵延两千余年,曾被称为民间第一大祭日。 寒食节的具体日期,古俗讲究在...

描写树 的古诗,对联,成语,歇后语,每样至少四个
不知细叶谁裁出,二月春风似剪刀。 柳 【唐】李商隐 曾逐东风拂舞筵,乐游春苑断肠天。 如何肯到清秋日,已带斜阳又带蝉。 柳 【唐】罗隐 一簇青烟锁玉楼,半垂阑畔半垂沟。 明年更有新条在,绕乱春风卒未休。 1庭前垂柳飞叶翠,屋后新蕊落花红 2四面荷花三面柳,一城山色半城湖 3绿柳舒眉辞旧岁,红桃开...

张甲林诗选(二)
云巘晴开三面网,石塘绿涨半篙纹。 风牵蚯穴闲吟句,壁走蜗涎自篆文。 纵遣客愁归远岫,山城独立...独怜亲殁空赍恨,未识泉台知不知。 其四 架帙缥缃填荜庐,经华世代做菑畲。 眼看蠹食残香冷,何日...节近重九,人怀千里。去年师弟一堂,赋诗上寿,熙熙雍雍,其乐何极。今则天各一方,别又经年,时物怆怀,...

求志园记王世贞文言文
您的记文须依赖我的竹才能写成,而我的竹子也须依靠您的记文才得于不消失,这到底是两相依赖呢?还是...第环三面而水胜甲一郡及馀至而访求其故址所谓水晶宫者葢陆沈于闤闠厘祝之间想象于暮烟春波而不可...赵国知此实情就不给,不知此实情就给;知此实情而惧怕秦国就给,知此实情而不惧怕秦国就不给。 这...

关于思念西湖的诗句有哪些
停阑四面空明里,一面城头三面山。 与颜钱塘登樟亭望潮作[唐]孟浩然百里闻雷震,鸣弦暂辍弹。府中连骑出,江上待潮观。 照日秋空通,浮天渤解党。...—— 王维《相思》玲珑骰子安红豆,入骨相思知不知。--温庭筠《南歌子词二首》欲把相思说似谁,浅情人不知。 —— 晏几道《长相思·长相思》举头望明月,低头...

清明节到底是哪一天,农历是否要比阳历准
介子推不愿见他,已经背着老母躲进了绵山(今山西介休县东南)。晋文公便让他的御林军上绵山搜索,没有找到。于是,有人出了个主意说,不如放火烧山,三面...谁知这场大火却把介子推母子烧死了。为了纪念介子推,晋文公下令每年的这一天,禁止生火,家家户户只能吃生冷的食物,这就是寒食节的来源。 寒食节是在...

水城县14784476760: 硬币的第三个面是什么意思? -
赫步易可: 硬币第三面的爱情含义是指爱情中的不确定性和未知性.就像硬币有两面,但抛出后可能出现的结果是三种:正面、反面或者立起来,爱情的未来发展也充满了未知和不确定性. 在爱情中,人们常常会面临各种选择和决策,而每一个选择都可能...

水城县14784476760: 什么是叫 笔记本电脑的三面 -
赫步易可: 一般指笔记本的散热问题时会说到三面,即笔记本的左或右侧面中的一面,还有后面,再者是底面.总之是指散有散热孔的三个面.像部分联想的机子散热在左侧,后面,底面都有散热孔.

水城县14784476760: 有五种颜色不同的小旗,任意取出3面表示一种信号,共可以表示几种不同的信号?我知道答案,但我想知道为什么这样做有五种颜色不同的小旗,任意取出3... -
赫步易可:[答案] 设这五种小旗的名字分别为ABCDE 则有ABC ABD ABE ACD ACE ADE BCD BCE BDE CDE共10种答案.

水城县14784476760: 男人至少应该有三面,你都知道吗 -
赫步易可: 在此回答所有不知道如何管理老公形象的女生们党老师觉得至少应该有三面~1、商务职场的精英 事业之于男人的重要性我想无需多言,商务场合对男人而言就是最大的战场.男人的职业生涯里,绝大多数时间里需要是一个干练精明,具有十足...

水城县14784476760: 如果两个平面有三个不共线的公共点,那么这两个平面重合这里我想知道 平面重合是个什么概念? -
赫步易可:[答案] 你可以理解为就是一个平面,跟两条线重合,两个点重合是一样的

水城县14784476760: 在基本几何体上求点时,至少要知道其两面投影才能求第三面投影() - 上...
赫步易可: 就和平面图上的象限差不多的概念 例如:一栋楼前两个不同位置的人看到的景象是不同的 具体的可以翻下机械制图 总共有一、二、三、四四种视角, 中国,苏联等常用的是第一视角 西方国家常用第三视角 1 a ------ b 1 a是第一象限又称第一视角 b是第三象限又称第三视角

水城县14784476760: 帮我设计几个句子,要话里有话,我要对别人说,直接说了不好.1、有什么话当着面说多好啊,非得在背后对别人说,别当我什么都不知道.2、不要在别人背... -
赫步易可:[答案] 这别人的话呀,也不一定就是正确的,说不定也是从哪听来的.所以有些话听听就好,别到处说,免得说错了别人笑话的还是你自己.第三个.

水城县14784476760: 金字塔不算底面有几个面?我们一般看的都是3个面的~我的朋友都说是3个面~我就觉得是4个面~到底是3个还是4个啊~ -
赫步易可:[答案] 金字塔模型为 正四凌锥 (底面为正方形,且顶点在底面上的射影是底面中心的角锥体) 正四凌锥,就是底面为正方形,四个侧面为具有公共顶点的等腰三角形的角锥体 (有图片不难看出 除去底面是四面的)

本站内容来自于网友发表,不代表本站立场,仅表示其个人看法,不对其真实性、正确性、有效性作任何的担保
相关事宜请发邮件给我们
© 星空见康网