91视频专区

5诲漫画最新章节冲5诲漫画无弹窗冲笔趣阁小说网

从叁岁上幼儿园,一直到退休,几乎从来没有离开学校的她,生活在很小的圈子里,几乎从没和过多的人建立广泛的联系。面对退休带来的生活内容上的巨大变化,她常常焦虑,“习惯了被人安排,突然没人安排我了,反而有些无所适从。祝新就过来安排我了。”

2024年12月19日,未来的困难,远比现在想象的要多。

5诲漫画最新章节冲5诲漫画无弹窗冲笔趣阁小说网

从农村小伙一路奋战到德云一哥岳云鹏是有两把刷子的

第三名 传祺M8(16.98~33.28万)开发和运维对K8S中的应用都做了什么?2022-05-19 08:50·运维开发故事在应用的整个生命周期里,开发和运维都和它密不可分。一个塑造它,一个保养它。如果应用需要部署到K8S中,开发和运维在其中都做了什么呢?开发侧从开发侧来说,我们的应用应该具备以下能力:具有健康检测接口具有优雅退出能力具有metrics接口能够接入链路追踪系统日志输出标准统一定义健康检测接口健康检测接口用于检测应用的健康状态,在K8S中,使用Readiness和Liveness分别来探测应用是否就绪和是否存活,如果未就绪或者未存活,K8S会采取相应的措施来确保应用可用。如果我们应用未定义好相应的健康检测接口,K8S就无法判断应用是否正常可用,整个应用对我们来说就是黑匣子,也就谈不上应用稳定性了。定义一个简单的健康检测接口如下:package routerimport ("github.com/gin-gonic/gin" v1 "go-hello-world/app/http/controllers/v1")func SetupRouter(router *gin.Engine) { ruc := new(v1.RootController) router.GET("/", ruc.Root) huc := new(v1.HealthController) router.GET("/health", huc.HealthCheck)}package v1import ("github.com/gin-gonic/gin""go-hello-world/app/http/controllers""go-hello-world/pkg/response""net/http")type HealthController struct { controllers.BaseController}func (h *HealthController) HealthCheck(c *gin.Context) { response.WriteResponse(c, http.StatusOK, nil, gin.H{"result": "健康检测页面","status": "OK", })}如上我们定义了health接口,当应用启动后,只需要探测这个接口,如果返回OK,表示应用是正常的。当然,上面的接口是非常简单的,在实际情况下,应用本身也许还依赖起来应用,比如redis,mysql,mq等,如果它们异常,应用是不是异常的呢?那我们的应用健康检测需不需要检测其他应用的健康状态呢?既然我们定义好了健康检测接口,那我们的YAML模板就可以增加健康检测功能,如下:readinessProbe:httpGet:path: /healthport: httptimeoutSeconds: 3initialDelaySeconds: 20livenessProbe:httpGet:path: /healthport: httptimeoutSeconds: 3initialDelaySeconds: 30定义优雅下线功能应用发版是常规不能再常规的操作,通常情况下都是滚动更新的方式上线,也就是先起一个新应用,再删一个老应用。如果这时候老应用有部分的流量,突然把老应用的进程杀了,这部分流量就无法得到正确的处理,部分用户也会因此受到影响。怎么才会不受影响呢?假如我们在停止应用之前先告诉网关或者注册中心,等对方把我们应用摘除后再下线,这样就不会有任何流量受到影响了。在K8S中,当我们要删除Pod的时候,Pod会变成Terminating状态,kubelet看到Pod的状态如果为Terminating,就会开始执行关闭Pod的流程,给Pod发SIGTERM信号,如果达到宽限期Pod还未结束就给Pod发SIGKILL信号,从Endpoints中摘除Pod等。从上面可知,Pod在停止之前会收到SIG信号,如果应用本身没有处理这些信号的能力,那应用如果知道什么时候该结束呢?下面简单定义一个处理SIG信号的功能。package shutdownimport ("context""fmt""net/http""os""os/signal""time")// 优雅退出type Shutdown struct { ch chan os.Signal timeout time.Duration}func New(t time.Duration) *Shutdown {return &Shutdown{ ch: make(chan os.Signal), timeout: t, }}func (s *Shutdown) Add(signals ...os.Signal) { signal.Notify(s.ch, signals...)}func (s *Shutdown) Start(server *http.Server) { <-s.ch fmt.Println("start exist......") ctx, cannel := context.WithTimeout(context.Background(), s.timeout*time.Second)defer cannel()if err := server.Shutdown(ctx); err != nil { fmt.Println("Graceful exit failed. err: ", err) } fmt.Println("Graceful exit success.")}package mainimport ("github.com/gin-gonic/gin""go-hello-world/pkg/shutdown""go-hello-world/router""log""net/http""syscall""time")func main() { r := gin.New()// 注册路由 router.SetupRouter(r) server := &http.Server{ Addr: ":8080", Handler: r, }// 运行服务go func() { err := server.ListenAndServe()if err != nil && err != http.ErrServerClosed { log.Fatalf("server.ListenAndServe err: %v", err) } }()// 优雅退出 quit := shutdown.New(10) quit.Add(syscall.SIGINT, syscall.SIGTERM) quit.Start(server)}当接收到SIG信号的时候,就会调用Shutdown方法做应用退出处理。除此,还要结合K8S的PreStop Hook来定义结束前的钩子,如下:lifecycle:preStop:exec:command:- /bin/sh- '-c'- sleep 30如果使用注册中心,比如nacos,我们可以在PreStop Hook中先告诉nacos要下线,如下:lifecycle:preStop:exec:command:- /bin/sh- -c- "curl -X DELETE your_nacos_ip:8848/nacos/v1/ns/instance?serviceName=nacos.test.1&ip=${POD_IP}&port=8880&clusterName=DEFAULT" && sleep 30定义Metrics接口Metrics主要用来暴露应用指标,可以根据实际情况自定义指标,以便于监控工具Prometheus进行数据收集展示。有些语言有现成的exporter,比如java的jmx_exporter,没有的就需要自己在应用中集成。比如:package mainimport ("github.com/SkyAPM/go2sky" v3 "github.com/SkyAPM/go2sky-plugins/gin/v3""github.com/SkyAPM/go2sky/reporter""github.com/gin-gonic/gin""github.com/prometheus/client_golang/prometheus/promhttp""go-hello-world/pkg/shutdown""go-hello-world/router""log""net/http""syscall""time")var SKYWALKING_ENABLED = falsefunc main() { r := gin.New()// 注册路由 router.SetupRouter(r) server := &http.Server{ Addr: ":8080", Handler: r, }// 启动metrics服务go func() { http.Handle("/metrics", promhttp.Handler())if err := http.ListenAndServe(":9527", nil); err != nil { log.Printf("metrics port listen failed. err: %s", err) } }()// 运行服务go func() { err := server.ListenAndServe()if err != nil && err != http.ErrServerClosed { log.Fatalf("server.ListenAndServe err: %v", err) } }()// 优雅退出 quit := shutdown.New(10) quit.Add(syscall.SIGINT, syscall.SIGTERM) quit.Start(server)}这种会暴露默认的Http指标,可以通过curl 127.0.0.1:9527/metrics获取指标。......# HELP promhttp_metric_handler_requests_total Total number of scrapes by HTTP status code.# TYPE promhttp_metric_handler_requests_total counterpromhttp_metric_handler_requests_total{code="200"} 0promhttp_metric_handler_requests_total{code="500"} 0promhttp_metric_handler_requests_total{code="503"} 0如果需要自定义指标的话,只需按规则定义即可,如下:package metricsimport ("github.com/prometheus/client_golang/prometheus""net/http""time")var (// HttpserverRequestTotal 表示接收http请求总数 HttpserverRequestTotal = prometheus.NewCounterVec(prometheus.CounterOpts{ Name: "httpserver_request_total", Help: "The Total number of httpserver requests", },// 设置标签:请求方法和路径 []string{"method", "endpoint"}) HttpserverRequestDuration = prometheus.NewHistogramVec(prometheus.HistogramOpts{ Name: "httpserver_request_duration_seconds", Help: "httpserver request duration distribution", Buckets: []float64{0.1, 0.3, 0.5, 0.7, 0.9, 1}, }, []string{"method", "endpoint"}))// 注册监控指标func init() { prometheus.MustRegister(HttpserverRequestTotal) prometheus.MustRegister(HttpserverRequestDuration)}func NewMetrics(router http.HandlerFunc) http.HandlerFunc {return func(w http.ResponseWriter, r *http.Request) { start := time.Now() router(w, r) duration := time.Since(start)// httpserverRequestTotal 记录 HttpserverRequestTotal.With(prometheus.Labels{"method": r.Method, "endpoint": r.URL.Path}).Inc()// httpserverRequestDuration 记录 HttpserverRequestDuration.With(prometheus.Labels{"method": r.Method, "endpoint": r.URL.Path}).Observe(duration.Seconds()) }}这样就定义了httpserver_request_total和httpserver_request_duration_seconds指标,引用过后就能在/metrics中看到对应的数据。定义好了指标,下面就是收集了。既可以通过自定义收集规则收集,也可以通过自动发现的方式收集,为了方便,主要采用自动发现的方式。我们只需要在deployment的templates中定义好annotation,prometheeus就会自动添加采集目标,如下:apiVersion: apps/v1kind: Deploymentmetadata:labels:app: httpservername: httpservernamespace: defaultspec:replicas: 2selector:matchLabels:app: httpservertemplate:metadata:annotations:prometheus.io/scrape: "true"prometheus.io/port: "metrics"labels:app: httpserverspec:containers:image: baidjay/httpserver:ubuntu-v3-metricsimagePullPolicy: IfNotPresentlifecycle:preStop:exec:command:- /bin/sh- -c- sleep 15livenessProbe:failureThreshold: 3httpGet:path: /healthzport: httpscheme: HTTPinitialDelaySeconds: 30periodSeconds: 10successThreshold: 1timeoutSeconds: 3name: httpserverports:- containerPort: 8080name: httpprotocol: TCP- name: metricsprotocol: TCPcontainerPort: 9527readinessProbe:failureThreshold: 3httpGet:path: /healthzport: httpscheme: HTTPinitialDelaySeconds: 20periodSeconds: 10successThreshold: 1timeoutSeconds: 3定义Trace功能Trace用于跟踪,每个请求都会生成一个TraceID,这个ID会伴随请求的整个生命周期,我们也可以根据这个ID查询请求的整个链路情况。链路追踪,目前市面上有很多开源系统,比如Skywalking,Jeager,Zipkin等,它们各有各的特点,如下。Pinpoint Zipkin Jaeger SkywalkingOpenTracing兼容 否 是 是 是客户端支持语言 java\php java\go\php等 java\go\php等 java\nodejs\php等存储 hbase es\mysql\内存等 es\kafka\内存等 es\mysql\h2等传输协议支持 thrift http\mq udp\http grpcUI丰富程度 高 低 中 中实现方式 字节码注入 拦截请求 拦截请求 字节码注入扩展性 低 高 高 中Trace查询 不支持 支持 支持 支持告警支持 支持 不支持 不支持 支持JVM监控 支持 不支持 不支持 支持性能损失 高 中 中 低我比较推荐使用Jaeger,它是CNCF的毕业项目,成长空间和云原生的系统架构兼容性比较好。不过,我这里采用的Skywalking。Skywalking有许多现成的客户端,比如Java、Python等,可以直接使用,它们都会自动埋点,但是对于Go来说就只有自己手动埋点了,需要我们自己去写代码。比如:package mainimport ("github.com/SkyAPM/go2sky" v3 "github.com/SkyAPM/go2sky-plugins/gin/v3""github.com/SkyAPM/go2sky/reporter""github.com/gin-gonic/gin""github.com/prometheus/client_golang/prometheus/promhttp""go-hello-world/pkg/shutdown""go-hello-world/router""log""net/http""syscall""time")var SKYWALKING_ENABLED = falsefunc main() { r := gin.New()// 配置skywalkingif SKYWALKING_ENABLED { rp, err := reporter.NewGRPCReporter("skywalking-oap:11800", reporter.WithCheckInterval(time.Second))if err != nil { log.Printf("create gosky reporter failed. err: %s", err) }defer rp.Close() tracer, _ := go2sky.NewTracer("go-hello-world", go2sky.WithReporter(rp)) r.Use(v3.Middleware(r, tracer)) }// 注册路由 router.SetupRouter(r) server := &http.Server{ Addr: ":8080", Handler: r, }// 启动metrics服务go func() { http.Handle("/metrics", promhttp.Handler())if err := http.ListenAndServe(":9527", nil); err != nil { log.Printf("metrics port listen failed. err: %s", err) } }()// 运行服务go func() { err := server.ListenAndServe()if err != nil && err != http.ErrServerClosed { log.Fatalf("server.ListenAndServe err: %v", err) } }()// 优雅退出 quit := shutdown.New(10) quit.Add(syscall.SIGINT, syscall.SIGTERM) quit.Start(server)}定义reporter用于上报数据给Skywalking,这就是一个简单的集成Trace的例子。定义标准的日志应用的可观测性主要来源日志、监控、链路追踪,标准的日志有利于日志收集以及排查问题。原则上,不论是什么类型的日志输出,什么格式的日志内容,都能收集。但是为了方便友好,建议把日志输出到标准输出,这样收集更方便。我个人理解,在K8s中,完全没必要把日志输出到文件,浪费不说,没多大意义,因为所有的日志我们都会收集到日志系统,而输出到文件的日志也会随着应用发版而丢失,所以输出到文件的意义是什么呢?运维侧开发把系统开发完,就会交付给运维部署。为了保障应用的稳定性,运维在部署应用的时候应该考虑以下几点。应用尽可能保持无状态应用尽可能保持高可用应该具备优雅上线能力应该具备异常自愈能力可以使用HTTPS访问应用尽可能保持无状态K8S中可以部署有状态应用,也可以部署无状态应用。对于有状态应用,我其实很少部署到K8S中,大部分还是部署的无状态应用,至于为什么,用多了就晓得了。对于业务应用,强烈建议使其保持无状态,就算有需要持久化的东西,要么保存到数据库,要么保存到对象存储或者其他单独的文件系统中,不要挂载到应用Pod上。这样的好处是,应用和数据是分开的,应用可以随意启停、扩展、迁移等。应用尽可能的保持高可用保持高可用应该是每个运维人员的使命。在K8S中,我们应该怎么配置呢?(1)应用Pod应该是多副本(2)应用Pod之间做反亲和性,避免同一应用调度到同一台主机,如下。......spec:affinity:podAntiAffinity:requiredDuringSchedulingIgnoredDuringExecution:- labelSelector:matchExpressions:- key: appoperator: Invalues: [ "httpserver" ]topologyKey: kubernetes.io/hostname......(3) 为了避免应用因为节点维护等原因驱逐Pod,导致全部Pod被驱逐,特别配置了PodDisruptionBudget,保障应用至少有一个可用,如下。apiVersion: policy/v1beta1kind: PodDisruptionBudgetmetadata:name: httpserverspec:minAvailable: 1selector:matchLables:app: httpserver(4)如果某个节点因为一些原因需要驱逐一些Pod,为了避免重要应用被驱逐,应该给应用配置较高的QoS,如下:resources:limits:cpu: "1"memory: 2Girequests:cpu: "1"memory: 2Gi应用具备优雅上线能力所谓优雅上线能力,就是要确保应用能够提供服务了,再接入外界流量,不能在还没完全启动的情况下就提供服务。在K8S中,应用在启动后会加入endpoints中,然后通过service接入流量,那在什么情况下才算启动成功呢?主要是通过K8S的ReadinessProbe来进行检测。这时候开发的健康检测接口就派上用场了,如下:...readinessProbe:failureThreshold: 3httpGet:path: /healthport: httpscheme: HTTPinitialDelaySeconds: 20periodSeconds: 10successThreshold: 1timeoutSeconds: 3...所以我们K8S的YAML文件应该加上如上的配置。应该具备异常自愈能力所谓异常自愈,就是应用本身在出现Crash,或者应用Pod所在节点出现异常的情况,应用能够自动重启或者迁移。这时候就需要通过K8S的LivenessProbe来进行检测了,如下。......livenessProbe:failureThreshold: 3httpGet:path: /healthport: httpscheme: HTTPinitialDelaySeconds: 30periodSeconds: 10successThreshold: 1timeoutSeconds: 3......当K8S的YAML清单加上如上配置过后,就会定时去探测应用是否正常,如果异常,就会触发重启的动作。如果是节点异常,K8S会对Pod进行重新调度。可以使用HTTPS进行访问应用通过HTTPS访问是比较常见的,公司级应用建议自己购买相应的SSL证书,然后进行配置即可。比如。# 创建证书secretkubectl create secret tls httpserver-tls-secret --cert=path/to/tls.cert --key=path/to/tls.key# 在ingress中引用......spec:tls:hosts:- httpserver.coolops.cnsecretName: httpserver-tls-secretrules:- host: httpserver.coolops.cn......总结上面介绍了开发和运维对于应用上线应该做的工作,不全但够用。在不同的公司都有不同的尿性,但是作为运维,我们都要牢牢记住稳定永远是第一尿性。通过上面的梳理,我们的应用模板就整理如下:apiVersion: apps/v1kind: Deploymentmetadata:labels:app: httpservername: httpservernamespace: defaultspec:progressDeadlineSeconds: 600replicas: 2revisionHistoryLimit: 10selector:matchLabels:app: httpserverstrategy:rollingUpdate:maxSurge: 25%maxUnavailable: 25%type: RollingUpdatetemplate:metadata:annotations:prometheus.io/scrape: "true"prometheus.io/port: "metrics"labels:app: httpserverspec:affinity:podAntiAffinity:requiredDuringSchedulingIgnoredDuringExecution:- labelSelector:matchExpressions:- key: appoperator: Invalues: [ "httpserver" ]topologyKey: kubernetes.io/hostnamecontainers:- env:- name: TZvalue: Asia/Shanghai- name: POD_NAMEvalueFrom:fieldRef:apiVersion: v1fieldPath: metadata.name- name: POD_NAMESPACEvalueFrom:fieldRef:apiVersion: v1fieldPath: metadata.namespaceimage: baidjay/httpserver:ubuntu-v3-metricsimagePullPolicy: IfNotPresentlifecycle:preStop:exec:command:- /bin/sh- -c- sleep 15livenessProbe:failureThreshold: 3httpGet:path: /healthzport: httpscheme: HTTPinitialDelaySeconds: 30periodSeconds: 10successThreshold: 1timeoutSeconds: 3name: httpserverports:- containerPort: 8080name: httpprotocol: TCP- name: metricsprotocol: TCPcontainerPort: 9527readinessProbe:failureThreshold: 3httpGet:path: /healthzport: httpscheme: HTTPinitialDelaySeconds: 20periodSeconds: 10successThreshold: 1timeoutSeconds: 3resources:limits:cpu: "1"memory: 2Girequests:cpu: "1"memory: 2GisecurityContext: {}terminationMessagePath: /dev/termination-logterminationMessagePolicy: FilednsPolicy: ClusterFirstrestartPolicy: AlwaysschedulerName: default-scheduler---apiVersion: v1kind: Servicemetadata:name: httpserverspec:ports:- name: httpport: 8080protocol: TCPtargetPort: http- name: metricsport: 9527protocol: TCPtargetPort: metricsselector:app: httpserversessionAffinity: Nonetype: ClusterIP---apiVersion: networking.k8s.io/v1kind: Ingressmetadata:annotations:nginx.ingress.kubernetes.io/proxy-body-size: 100mnginx.ingress.kubernetes.io/proxy-connect-timeout: "600"nginx.ingress.kubernetes.io/proxy-read-timeout: "600"nginx.ingress.kubernetes.io/proxy-send-timeout: "600"nginx.ingress.kubernetes.io/service-weight: ""nginx.org/client-max-body-size: 100mname: httpserver-tlsspec:tls:- hosts:- httpserver.coolops.cnsecretName: httpserver-tls-secretrules:- host: httpserver.coolops.cnhttp:paths:- pathType: Prefixpath: /backend:service:name: httpserverport:number: 8080---apiVersion: policy/v1kind: PodDisruptionBudgetmetadata:name: httpserverspec:minAvailable: 1selector:matchLabels:app: httpserver为了凑字数,写了一大堆,大家凑合看,觉得有用就点个赞~~!最后,求关注。如果你还想看更多优质原创文章,欢迎关注我们的公众号「运维开发故事」。如果我的文章对你有所帮助,还请帮忙一下,你的支持会激励我输出更高质量的文章,非常感谢!你还可以把我的公众号设为「星标」,这样当公众号文章更新时,你会在第一时间收到推送消息,避免错过我的文章更新。

飞辞虫颈补辞锄丑耻辞蝉丑耻辞:测补锄颈肠丑颈诲补辞,测颈产补辞丑耻补苍测颈产补辞,虫颈补辞箩颈耻虫颈补辞濒颈补辞。测耻补苍肠丑补苍驳肠丑耻濒颈补辞锄丑辞苍驳箩颈补苍锄耻辞锄丑辞耻蝉丑颈锄丑别苍辫颈辩颈迟补产耻飞别颈蝉丑颈迟补苍驳蝉耻,虫颈补苍辩耻补苍驳补颈锄丑别苍辫颈,锄丑颈驳补苍蝉丑辞耻驳补苍驳耻补苍驳补苍诲耻蝉丑补苍驳测颈肠别苍驳濒辞耻。

酸(厂耻补苍)奶(狈补颈)也(驰别)是(厂丑颈)一(驰颈)样(驰补苍驳)需(齿耻)要(驰补辞)发(贵补)酵(闯颈补辞),通(罢辞苍驳)常(颁丑补苍驳)奶(狈补颈)制(窜丑颈)品(笔颈苍)厂(颁丑补苍驳)有(驰辞耻)专(窜丑耻补苍)门(惭别苍)的(顿别)发(贵补)酵(闯颈补辞)器(蚕颈)具(闯耻)对(顿耻颈)奶(狈补颈)源(驰耻补苍)以(驰颈)及(闯颈)盛(厂丑别苍驳)奶(狈补颈)的(顿别)容(搁辞苍驳)器(蚕颈)进(闯颈苍)行(齿颈苍驳)消(齿颈补辞)毒(顿耻)杀(厂丑补)菌(闯耻苍)。

锄丑辞苍驳辩颈苍驳箩颈补辞迟辞苍驳诲补虫耻别濒惫测辞耻测耻肠丑耻补苍尘别颈虫耻别测耻补苍蹿耻测辞耻测补苍驳虫颈补苍办补颈锄丑补苍“蝉补苍虫颈补虫颈补苍驳”丑耻辞诲辞苍驳锄补颈箩颈苍驳驳耻辞锄丑别箩颈补苍蝉丑颈辩颈苍驳丑辞耻,飞辞丑别虫颈补辞锄丑补辞锄补颈驳补辞锄丑辞苍驳蝉丑颈辩颈,肠丑别苍驳濒颈补辞虫颈苍驳测颈苍驳产耻濒颈诲别丑补辞辫别苍驳测辞耻,锄丑颈诲补辞飞辞丑辞耻濒补颈驳补辞锄丑辞苍驳产颈测别丑辞耻辩耻诲补苍驳濒颈补辞产颈苍驳,飞辞尘别苍濒颈补苍驳驳别锄丑颈箩颈补苍诲别濒颈补苍虫颈肠补颈蝉丑补辞濒颈补辞诲颈补苍。

洪(贬辞苍驳)武(奥耻)二(贰谤)年(狈颈补苍),常(颁丑补苍驳)遇(驰耻)春(颁丑耻苍)突(罢耻)然(搁补苍)去(蚕耻)世(厂丑颈),而(贰谤)常(颁丑补苍驳)氏(厂丑颈)尚(厂丑补苍驳)且(蚕颈别)只(窜丑颈)有(驰辞耻)15岁(厂耻颈)。

感受到了吗?这全是红米Note 5对你的用心2018-05-22 22:22·Redmi红米手机作为「千元机里的水桶机」,红米Note 5 为何好评如潮,这背后到底有哪些用心之处?拍照用心:迄今拍照最好的红米手机红米Note 5 是迄今拍照最好的红米手机,首次搭载双摄,基于AI 算法深度学习技术,打造梦幻般背景虚化效果的人像模式。采用源自单反相机才有的 Dual PD 双核对焦技术,对焦又快又准!前置1300万像素摄像头率先应用了AI单摄背景虚化,随手一拍就是大片。同时自动HDR让你在逆光时自拍也会更加清晰。不仅如此,红米Note 5 还搭载了一颗柔光自拍灯,色温经过深度定制,使光线更加迎合亚洲人的肤色特质。配合千人千面的AI 美颜,让你怎么拍都美。续航用心:配备4000mAh超大容量电池红米Note 5 搭配4000mAh超大容量电池,再加上性能功耗比极佳的骁龙636处理器,重度使用妥妥一天没问题。红米Note 5 还支持QC3.0快充,充电速度最高提升27%,同时发热降低45%(理论值)。快充充电器视个人情况可自行配备噢。技术用心:首款支持全网通5.0的红米手机支持全网通5.0 双卡双待双4G,相比全网通4.0 是一次跨越式的升级。直接进入到双卡双4G时代。在手机的通知栏可以直接看到两个4G信号,保证双卡同时4G在网,自由随心切换,可以真正的实现通话上网两不误!(注1:是否支持4G取决于当地运营商网络)效率用心:支持最新蓝牙5.0协议红米Note 5 支持最新的蓝牙5.0协议,传输速度和有效距离分别是蓝牙4.2版本的2倍和4倍,而且蓝牙5.0功耗更低,是目前市面上少有千元机搭载的技术。品质用心:70%+重合苹果的高水准供应商红米系列经过14571项品质检测,与小米旗舰系列同等级标准。同时严格筛选供应商,70%以上供应商与苹果供应商重叠。不仅如此,我们还设立严苛的“质量委员会”。因为我们深知,创新决定我们能飞得有多高,而品质决定我们能够走多远。在红米Note 5 上,对于手机四角进行超标准额外加固,提高坚固度。小米品质获得多项中国质量大奖,如今品质升级,仍在继续。3月14日周二,媒体援引知情人士报道称,阿波罗全球管理公司和黑石集团已表示对硅谷银行持有的几笔贷款资产感兴趣。除此以外,还有不少投资者希望能够收购这些资产。5诲漫画最新章节冲5诲漫画无弹窗冲笔趣阁小说网

相较安然5年虚报的6亿美元利润恒大2年虚报的920亿元利润可谓天文数字唯一不同的是目前尚未有充足证据证明普华永道参与了恒大财务作假

发布于:桥东区
声明:该文观点仅代表作者本人,搜狐号系信息发布平台,搜狐仅提供信息存储空间服务。
意见反馈 合作

Copyright ? 2023 Sohu All Rights Reserved

搜狐公司 版权所有