应用层网关调研与基础测试
背景
故事的开始还是源于现阶段各个平台之间有些许的接口调用,但是各个平台之间又相对比较独立,并没有将各个平台整合成一组微服务的需求。现在面临的问题就是各个平台直接都有互相调用的需求,如果各个平台有业务升级的情况下,不一定能察觉到是否会影响到对提供给其他系统使用的API,而且还有一个问题就是大家好像都不是太清楚哪些平台调用了哪些接口,某个平台对外提供了哪些接口,而且在一些脚本使用的过程中如果部署的系统迁移而需要重新修改访问的地址,基于这些原因考虑搭建一个openapi相关的服务,主要是来管理与监控各个调用链,本次就先测试对比一下openapi的技术模型的选择。
技术对比
由于本人的技术栈相对比较局限,针对一些管理性能要求不高的项目用Python,golang通常都是用于不紧急的项目开发,会一丢丢的rust(入门水平)。本次的对比测试主要选用golang,Python。
本次测试的环境是一台八核,6G内存的虚拟机(虚拟机不要太较真性能)。
服务器端性能测试对比
Flask测试
测试代码如下;
from flask import Flask, jsonifyimport requestsapp = Flask(__name__)@app.route('/api/test_api/')
def hello_world():return jsonify({"detail": "ok"})if __name__ == '__main__':app.run()
虽然代码简单了点,但是我们用gunicorn来部署测试;
gunicorn -w 8 -b 0.0.0.0:5001 flask_server:app -k gevent
压测结果
wrk -t4 -c1000 -d60s -T60s --latency http://127.0.0.1:5001/api/test_api/
Running 1m test @ http://127.0.0.1:5001/api/test_api/4 threads and 1000 connectionsThread Stats Avg Stdev Max +/- StdevLatency 225.39ms 89.72ms 864.75ms 71.70%Req/Sec 1.11k 138.23 2.50k 70.48%Latency Distribution50% 199.30ms75% 269.94ms90% 358.11ms99% 453.80ms265775 requests in 1.00m, 43.85MB read
Requests/sec: 4423.37
Transfer/sec: 747.31KB
可以看出在开启多进程服务的情况下,qps达到了4423。并且性能响应基本上在毫秒级别。
Tornado测试
tornado测试代码如下;
from tornado.ioloop import IOLoop
import tornado.web
import tornado.httpserver
import aiohttp
from tornado.platform.asyncio import AsyncIOMainLoop
import asyncioclass MainHandler(tornado.web.RequestHandler):async def get(self):self.write({"detail": "ok"})if __name__ == "__main__":app = tornado.web.Application([(r"/api/test_api/", MainHandler),])server = tornado.httpserver.HTTPServer(app)server.bind(5002, '127.0.0.1')server.start(8)AsyncIOMainLoop().install()IOLoop.current().start()
启动脚本并压测
wrk -t4 -c1000 -d60s -T60s --latency http://127.0.0.1:5002/api/test_api/
Running 1m test @ http://127.0.0.1:5002/api/test_api/4 threads and 1000 connectionsThread Stats Avg Stdev Max +/- StdevLatency 207.38ms 57.48ms 468.47ms 67.41%Req/Sec 1.20k 298.66 2.13k 68.44%Latency Distribution50% 205.08ms75% 239.01ms90% 280.76ms99% 367.11ms286385 requests in 1.00m, 59.54MB read
Requests/sec: 4764.90
Transfer/sec: 0.99MB
从数据上来看比flask部署之后达到的qps相比还是要高大约三百左右的qps,在本运行的实例代码中,开启了八个工作进程来进行处理任务,并且在flask的部署过程中也选用了异步io,在work进程数相同的情况下,qps相差不多也算是情理之中。
golang测试
在golang的测试就不选用现成的web框架了,直接通过http库来测试。
package mainimport ("fmt""encoding/json""log""net/http"
)func handler(w http.ResponseWriter, r *http.Request) {var res map[string]stringres = make(map[string]string)res["detail"] = "ok"js, err := json.Marshal(res)if err != nil {fmt.Println("erro ", err)http.Error(w, err.Error(), http.StatusInternalServerError)return}w.Header().Set("Content-type", "application/json")w.Write(js)
}func main() {http.HandleFunc("/api/test_api/", handler)log.Fatal(http.ListenAndServe(":5003", nil))
}
运行并压测;
/wrk -t4 -c1000 -d60s -T60s --latency http://127.0.0.1:5003/api/test_api/
Running 1m test @ http://127.0.0.1:5003/api/test_api/4 threads and 1000 connectionsThread Stats Avg Stdev Max +/- StdevLatency 20.91ms 19.55ms 316.02ms 83.64%Req/Sec 13.48k 2.66k 23.70k 69.61%Latency Distribution50% 14.44ms75% 26.04ms90% 46.21ms99% 94.57ms3221474 requests in 1.00m, 377.89MB read
Requests/sec: 53597.81
Transfer/sec: 6.29MB
这样对比来看qps达到了53597,性能相对比较强悍。不可否认在服务端方面go的性能还是比较厉害的。通过三种服务端的测试来看,在Python中按照常见的部署模式来部署flask和tornado进行压测,测试数据基本上在四千多左右,在golang中仅用库来实现服务qps就达到五万了。
应用层API网关测试
使用的openapi说到底目前也是利用应用层来转发的,此时我们依然来通过不同的方法来测试。
在本次的测试用,默认测试的API就是刚刚测试的golang作为后端服务,只不过部署的端口更改为8084.
Flask测试
测试代码如下
from flask import Flask, jsonifyimport requestsapp = Flask(__name__)@app.route('/api/test_api/')
def hello_world():resp = requests.get("http://192.168.10.205:8084/api/test_api/")return jsonify(resp.json())if __name__ == '__main__':app.run()
作为网关服务主要向后端转发请求并获取返回请求并将结果返回。此时的部署方式仍然如下,其中192.168.10.205:8084就是刚刚启动的golang的后端;
gunicorn -w 8 -b 0.0.0.0:5001 flask_gateway:app -k gevent
进行压测
wrk -t4 -c1000 -d60s -T60s --latency http://127.0.0.1:5001/api/test_api/
Running 1m test @ http://127.0.0.1:5001/api/test_api/4 threads and 1000 connectionsThread Stats Avg Stdev Max +/- StdevLatency 1.45s 534.19ms 4.31s 86.27%Req/Sec 174.11 49.82 356.00 68.96%Latency Distribution50% 1.29s75% 1.48s90% 2.44s99% 3.24s41188 requests in 1.00m, 6.80MB read
Requests/sec: 685.89
Transfer/sec: 115.88KB
通过压测结果可知,对应的sqs为675左右。
Tornado测试
tornado测试的时候选用异步编程的方式来进行测试
from tornado.ioloop import IOLoop
import tornado.web
import tornado.httpserver
import aiohttp
from tornado.platform.asyncio import AsyncIOMainLoop
import asyncioclass MainHandler(tornado.web.RequestHandler):async def get(self):async with aiohttp.ClientSession() as session:async with session.get('http://192.168.10.205:8084/api/test_api/') as resp:text = await resp.text()self.write(text)if __name__ == "__main__":app = tornado.web.Application([(r"/api/test_api/", MainHandler),])server = tornado.httpserver.HTTPServer(app)server.bind(5002, '127.0.0.1')server.start(8)AsyncIOMainLoop().install()IOLoop.current().start()
此时运行该脚本并压测
wrk -t4 -c1000 -d60s -T60s --latency http://127.0.0.1:5002/api/test_api/
Running 1m test @ http://127.0.0.1:5002/api/test_api/4 threads and 1000 connectionsThread Stats Avg Stdev Max +/- StdevLatency 2.59s 4.26s 21.13s 86.18%Req/Sec 295.72 209.62 1.00k 59.10%Latency Distribution50% 736.92ms75% 1.19s90% 9.51s99% 17.92s60957 requests in 1.00m, 12.27MB readNon-2xx or 3xx responses: 1283
Requests/sec: 1014.86
Transfer/sec: 209.11KB
压测的数据显示大约的qps在一千左右,但是在测试过程中会出现连接耗尽的情况,主要是session没有复用导致每次都重新创建。
golang测试
package mainimport ("fmt""io/ioutil""net/http"
)func TestHandler(w http.ResponseWriter, r *http.Request){// 访问其他apiresp, err := http.Get("http://192.168.10.205:8084/api/test_api/")if err != nil {fmt.Println("error ", err)http.Error(w, err.Error(), http.StatusInternalServerError)return}defer resp.Body.Close()body, _ := ioutil.ReadAll(resp.Body)w.Header().Set("Content-type", "application/json")w.Write(body)}func main(){http.HandleFunc("/api/test_api/", TestHandler)http.ListenAndServe(":5003", nil)
}
压测结果如下,同样在压测过程中也会报连接耗尽的情况。
wrk -t4 -c1000 -d60s -T60s --latency http://127.0.0.1:5003/api/test_api/
Running 1m test @ http://127.0.0.1:5003/api/test_api/4 threads and 1000 connectionsThread Stats Avg Stdev Max +/- StdevLatency 2.21s 3.11s 18.58s 81.84%Req/Sec 705.42 0.99k 3.09k 72.16%Latency Distribution50% 181.07ms75% 3.85s90% 7.26s99% 11.84s89857 requests in 1.00m, 11.21MB readNon-2xx or 3xx responses: 4312
Requests/sec: 1495.52
Transfer/sec: 191.13KB
在三种情况下的压测结果表明,flask的网关转发效果较差,只有六百多,在tornado和golang的压测过程中,会出现connect: cannot assign requested address的错误,就是可用的连接不够用了,这再一定程度上影响了压测的结果,不过这个问题不在本次的套路范围里面,因为在这次压测的代码里面就没有优化每次访问api时重用连接的情况。以tornado为例,我们修改成复用连接的情况看一下效果是否会好一些(只是举例有一定代码上可以优化的空间)
from tornado.ioloop import IOLoop
import tornado.web
import tornado.httpserver
import aiohttp
from tornado.platform.asyncio import AsyncIOMainLoop
import asynciosession_global = Noneclass MainHandler(tornado.web.RequestHandler):async def get(self):global session_globalif session_global is None:session = aiohttp.ClientSession()session_global = sessionresp = await session_global.get("http://192.168.10.205:8084/api/test_api/")self.write(await resp.text())if __name__ == "__main__":app = tornado.web.Application([(r"/api/test_api/", MainHandler),])server = tornado.httpserver.HTTPServer(app)server.bind(5002, '127.0.0.1')server.start(8)AsyncIOMainLoop().install()IOLoop.current().start()
然后压测一下
wrk -t4 -c1000 -d60s -T60s --latency http://127.0.0.1:5002/api/test_api/
Running 1m test @ http://127.0.0.1:5002/api/test_api/4 threads and 1000 connectionsThread Stats Avg Stdev Max +/- StdevLatency 434.61ms 109.19ms 1.23s 67.93%Req/Sec 568.01 170.52 1.27k 70.68%Latency Distribution50% 434.11ms75% 506.77ms90% 572.08ms99% 718.92ms135647 requests in 1.00m, 27.17MB read
Requests/sec: 2257.32
Transfer/sec: 462.93KB
可以看出如果优化了连接的话,qps上升了大约一倍。假如再修改一下golang版本的复用问题;
package mainimport ("time""fmt""io/ioutil""net/http"
)var netClient *http.Clientfunc TestHandler(w http.ResponseWriter, r *http.Request){// 访问其他apiresp, err := netClient.Get("http://192.168.10.205:8084/api/test_api/")if err != nil {fmt.Println("error ", err)http.Error(w, err.Error(), http.StatusInternalServerError)return}defer resp.Body.Close()body, _ := ioutil.ReadAll(resp.Body)w.Header().Set("Content-type", "application/json")w.Write(body)}func main(){netClient = &http.Client{Transport: &http.Transport{MaxIdleConnsPerHost: 300},Timeout: time.Duration(30) * time.Second}http.HandleFunc("/api/test_api/", TestHandler)http.ListenAndServe(":5003", nil)
}
此时再压测;
wrk -t4 -c1000 -d60s -T60s --latency http://127.0.0.1:5003/api/test_api/
Running 1m test @ http://127.0.0.1:5003/api/test_api/4 threads and 1000 connectionsThread Stats Avg Stdev Max +/- StdevLatency 78.84ms 34.58ms 430.97ms 76.15%Req/Sec 3.20k 441.89 4.69k 71.33%Latency Distribution50% 87.34ms75% 99.63ms90% 110.86ms99% 155.67ms763434 requests in 1.00m, 89.55MB read
Requests/sec: 12703.00
Transfer/sec: 1.49MB
可以看到优化之后的qps能够达到一万两千多,当然这个优化只是针对单个后端服务的访问,并没有太大的实用意义。
其中这三个版本对应的情况可能不太一样,Flask在当做应用层网关转发的时候,主要就是通过阻塞IO去访问后端的接口的,虽然在Flask接受请求的时候利用的异步IO,但是接受到请求之后又同步阻塞去请求这样会影响性能,而在Tornado的版本中,则全部都使用了异步IO来进行数据的处理,这样通过全部异步操作来提升响应速度,从压测结果来看Tornado的异步版本相比Flask提升了快一倍,最后查看的golang的版本在代码上无需异步处理,运行的过程中就是全部异步处理,想过也是比较好,响应比Tornado快了好几倍,如果考虑最后的连接复用的情况下,快了大概有6倍。通过不同版本的测试对比,可以看出如果做网关或者服务在并发要求较高的情况下,选择golang是比较好的选择。
总结
本文主要是对比了再服务端,特别是Python中Flask和Tornado的常规的部署情况下的一个压测情况,并且在应用层网关的压测过程中对比了一下,API网关设计的过程中的基本情况,对比了Python的阻塞转发,异步转发,最后也压测了golang版本的情况。初步来看的话,如果选择设计API网关如果性能要求很高可以选择golang这个方向来继续调研,如果针对内部系统qps不高、追求开发效率的话,Python也是一个备选方案。由于本人才疏学浅,如有错误请批评指正。
如若内容造成侵权/违法违规/事实不符,请联系编程学习网邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
相关文章
- vue+element-ui实现多选框绑定数组对象。为什么不能回显
本来的逻辑是点全选获取全部单选的绑定值的数组。就可以让下面所有的选中。但是如果下面单选绑定的不是一个值。而是一个对象的话。即使点击全选获取所有单选对象组成的数组也不能回显。直接按照官网的例子修改一下.让他绑定的值是对象。发现你写了checkedCities选中的对象内容…...
2024/4/24 12:30:06 - android属性动画实践及原理
动画 首先明确啥是动画?你可以理解成若干不同图片随着时间不断交替成为焦点的过程,说简单点就是"量子阅读法",你还可以把动画理解成使用某多种手段将一张图片进行各种变换。那么这两种理解方式对应android里的动画就是帧动画和属性动画,当然帧动画和补间动画属于…...
2024/5/9 0:22:40 - 转载:SRT传输库评估报告(V1.0.0)
原文地址:https://blog.csdn.net/mediapro/article/details/105790057,感谢大神;SRT传输库评估报告(V1.0.0)www.mediapro.ccSRT传输库简介 SRT是Haivision开源的一套集FEC前向纠错、ACK、NAK选择性重传、JitterBuff、拥塞控制、传输安全保障等技术于一体的实时传输解决方案。…...
2024/5/9 2:01:41 - linux更换aliyun源
linux更换国内源CentOS更换为阿里云的源 什么是国内源,通俗讲就是应用市场,Android系统有Android应用市场,Apple系统有Apple应用市场,Linux系统也有Linux应用市场。 Linux的国内源根据不同的版本分,主要有: CentOS版本:yum源 Ubuntu版本:apt-get源 注1:如果只是…...
2024/4/24 12:30:03 - 南京大学2020软工专硕初试第一经验分享
写在前面:以下的所有经验都是我自己备考中亲身经历得出的,不存在想象或者编造的情况,但由于我自己的性格,我对于不喜欢的人或事的印象极难改变,所以你会看到我对一些老师相当负面的评价。 另外由于每个人的实际情况不同,当然每个人最适合的复习策略也不同,我会尽可能的介…...
2024/5/8 13:46:45 - CAT1域格模块常见问题部分设计参考
天线部分 CLM920_RC3 的 49 脚为主集天线接口,为方便天线调试需要在主板上增加π型匹 配电路,走 50 欧阻抗线。 CLM920_RC3 的 47 脚为 GNSS 天线接口,为方便天线调试需要在主板上增加π型 匹配电路,走 50 欧阻抗线 主天线与分集天线之间需要保持一定的间距 CLM920_RC3 模块…...
2024/4/15 4:33:30 - MySQL数据库笔记10——视图、DBA命令、数据库设计三范式
1.视图 1.1 什么是视图?站在不同的角度去看待数据,即同一张表的数据,通过不同的角度去看待。 1.2 怎么创建视图?怎么删除视图? create view myview as select empno,ename from emp; drop view myview; 注意:只有DQL语句才能以视图对象的方式创建出来。 1.3 对视图进行增…...
2024/4/15 4:33:27 - 从0开始手动配置redis主从复制
手动配置redis主从复制主从复制的概念主从复制的特点开始搭建1、下载redis:可以通过把下载好的redis安装包上传到服务器上,也可以通过yum,wget方式进行安装,我这里是通过wget方式进行安装的。2、开始搭建主从复制3、配置完毕,开始测试 主从复制的概念 1、在主从复制模型中…...
2024/4/23 0:55:17 - liunx自学第三天
文章目录更改用户组 chgrp常用环境变量常用文件管理命令df命令 更改用户组 chgrp chgrp 123456 123 123456这里代表的就是更改用户组的名称,123就是你的文件敲完命令之后:常用环境变量 DISPLAY 用来设置将图形显示到何处。 HOME 当前用户的主目录。 IFS …...
2024/4/15 4:33:25 - IntelliJ IDEA彻底删除项目
IDEA彻底删除项目 1.在项目上单击右键选择Remove Module,也可以直接在项目上按下delete键 2.提示我们工程只是从工作空间移除,但是磁盘上的不会删除,选择remove 3.到磁盘的工作空间Project中,删除项目即可彻底删除。...
2024/4/17 7:38:06 - 线程中介之Java线程池
在云计算、5G技术快速发展的互联网世界,为了快速响应用户的请求,宏观上除了团队内部实行DevOps机制管理、使用微服务架构进行技术设计、使用Docker或K8s进行应用部署外,微观上在程序开发中使用并行计算的能力也是必不可少的。而在Java开发中,最常用的便是通过线程池来最大程…...
2024/4/19 14:18:33 - 【Java】java 的!file.exists()与 file !=null使用场景/区别
1.exists()方法使用//这里使用new 创建实例,所以f不可能为null File f = new File("D:/xyz/hashdog.text")//用exists()方法判断 if(!f.exists()){System.out.print("该文件不存在") }2.!=null条件使用//这里使用new 创建实例,所以f不可能为null File f ; …...
2024/4/15 4:33:23 - php神秘的函数应用
话不多说,直接上代码: // 获取数组中某个键值对应的总个数 $list = array(array(id => 1, userId => 5),array(id => 2, userId => 5),array(id => 2, userId => 6), );// $userId = 5; $arr=array_column($list,userId);//把值提取出来转成一维数组 $arr=a…...
2024/4/24 12:30:02 - Mysql的锁和并发参数的介绍
Mysql的锁和并发参数的介绍 一、Mysql并发参数调整从实现上来说,MySQL Server 是多线程结构,包括后台线程和客户服务线程。多线程可以有效利用服务器资源,提高数据库的并发性能。在Mysql中,控制并发连接和线程的主要参数包括 max_connections、back_log、thread_cache_size…...
2024/4/24 12:30:04 - S=A-BIS-dS+u2w2I+u1w1E数模作业
给定模型S=A-BIS-dS+u2w2I+u1w1E,E=BIS-dE-eE-w1E,I=eE-dI-aI-w2I,给出潜伏者和感染者在t属于0~100上时间序列图。其中,点表示S,E,I分别关于时间t的导数。 (注意是左边S,E,I,因为我就是在这给坑了下,仔细看左边S,E,I和右边的确实不同,那右边S,E,I表示何物?表示原方程。…...
2024/4/24 12:30:01 - 企业级Redis安装部署(非常详细,更适合学习使用)
导游前言更新GCC下载安装Redis系统环境优化1.修改文件最大打开数2&3修改/etc/sysctl.conf文件4.关闭透明巨页启动Redis登录测试Redis环境优化关闭Redis 前言 此篇安装Redis适用于企业,对于安装环境进行了优化,使Redis能够发挥更好的性能。 更新GCC 系统版本CentOS7.7 cat…...
2024/4/24 12:30:00 - 搞清clientHeight、offsetHeight、scrollHeight、offsetTop、scrollTop
转载自:https://www.imooc.com/article/17571网页可见区域高:document.body.clientHeight网页正文全文高:document.body.scrollHeight网页可见区域高(包括边线的高):document.body.offsetHeight网页被卷去的高:document.body.scrollTop屏幕分辨率高:window.screen.heig…...
2024/5/6 13:22:07 - 深浅拷贝的区别既处理
一、栈和堆概念栈:一般用来存变量名和地址,空间小,不可修改堆:一般用来存值(变量的值...如)空间大,可修改关系1.一一对应:一个栈对应一个堆2.多对一:多个栈对应一个堆存取规则栈:先进后出堆:先进先出二、数据类型分类1.基本类型:特点:1. 数据存在栈中,默认深拷贝,…...
2024/4/24 12:29:57 - 计算机组成原理--指令系统
只有操作码,没有地址码...
2024/4/24 12:29:57 - java理论知识
一 八大基本类型数据类型类型长度取值范围包装类byte整型1字节8bit(位)10000000(-128)到 01111111(127)Byteshort整型2字节16bit(位)10000000 00000000(-32768)到 01111111 11111111(32767)Shortint整型4字节32bit(位)-2^31 (-2,147,483,648)到 2^31-1(2,147,483,64…...
2024/4/24 12:29:57
最新文章
- TS学习-类的继承
目录 1,继承的作用2,成员的重写 Override3,类型匹配(兼容性)4,修饰符5,单根性和传递性 接这篇文章 TS学习-类 1,继承的作用 继承可以描述类与类之间的关系。 如果A和B都是类&#…...
2024/5/9 7:47:27 - 梯度消失和梯度爆炸的一些处理方法
在这里是记录一下梯度消失或梯度爆炸的一些处理技巧。全当学习总结了如有错误还请留言,在此感激不尽。 权重和梯度的更新公式如下: w w − η ⋅ ∇ w w w - \eta \cdot \nabla w ww−η⋅∇w 个人通俗的理解梯度消失就是网络模型在反向求导的时候出…...
2024/5/7 10:36:02 - CTK插件框架学习-事件监听(04)
CTK插件框架学习-插件注册调用(03)https://mp.csdn.net/mp_blog/creation/editor/136989802 一、主要流程 发送者注册消息事件接收者订阅消息事件接收者相应消息事件 事件监听比插件接口调用耦合性更弱,事件由框架维护,不需要指定发送方和接收方 二、…...
2024/5/6 8:34:00 - 比nestjs更优雅的ts控制反转策略-依赖查找
一、Cabloy5.0内测预告 Cabloy5.0采用TS对整个全栈框架进行了脱胎换骨般的大重构,并且提供了更加优雅的ts控制反转策略,让我们的业务开发更加快捷顺畅 1. 新旧技术栈对比: 后端前端旧版js、egg2.0、mysqljs、vue2、framework7新版ts、egg3…...
2024/5/6 2:59:50 - 【外汇早评】美通胀数据走低,美元调整
原标题:【外汇早评】美通胀数据走低,美元调整昨日美国方面公布了新一期的核心PCE物价指数数据,同比增长1.6%,低于前值和预期值的1.7%,距离美联储的通胀目标2%继续走低,通胀压力较低,且此前美国一季度GDP初值中的消费部分下滑明显,因此市场对美联储后续更可能降息的政策…...
2024/5/8 6:01:22 - 【原油贵金属周评】原油多头拥挤,价格调整
原标题:【原油贵金属周评】原油多头拥挤,价格调整本周国际劳动节,我们喜迎四天假期,但是整个金融市场确实流动性充沛,大事频发,各个商品波动剧烈。美国方面,在本周四凌晨公布5月份的利率决议和新闻发布会,维持联邦基金利率在2.25%-2.50%不变,符合市场预期。同时美联储…...
2024/5/7 9:45:25 - 【外汇周评】靓丽非农不及疲软通胀影响
原标题:【外汇周评】靓丽非农不及疲软通胀影响在刚结束的周五,美国方面公布了新一期的非农就业数据,大幅好于前值和预期,新增就业重新回到20万以上。具体数据: 美国4月非农就业人口变动 26.3万人,预期 19万人,前值 19.6万人。 美国4月失业率 3.6%,预期 3.8%,前值 3…...
2024/5/4 23:54:56 - 【原油贵金属早评】库存继续增加,油价收跌
原标题:【原油贵金属早评】库存继续增加,油价收跌周三清晨公布美国当周API原油库存数据,上周原油库存增加281万桶至4.692亿桶,增幅超过预期的74.4万桶。且有消息人士称,沙特阿美据悉将于6月向亚洲炼油厂额外出售更多原油,印度炼油商预计将每日获得至多20万桶的额外原油供…...
2024/5/9 4:20:59 - 【外汇早评】日本央行会议纪要不改日元强势
原标题:【外汇早评】日本央行会议纪要不改日元强势近两日日元大幅走强与近期市场风险情绪上升,避险资金回流日元有关,也与前一段时间的美日贸易谈判给日本缓冲期,日本方面对汇率问题也避免继续贬值有关。虽然今日早间日本央行公布的利率会议纪要仍然是支持宽松政策,但这符…...
2024/5/4 23:54:56 - 【原油贵金属早评】欧佩克稳定市场,填补伊朗问题的影响
原标题:【原油贵金属早评】欧佩克稳定市场,填补伊朗问题的影响近日伊朗局势升温,导致市场担忧影响原油供给,油价试图反弹。此时OPEC表态稳定市场。据消息人士透露,沙特6月石油出口料将低于700万桶/日,沙特已经收到石油消费国提出的6月份扩大出口的“适度要求”,沙特将满…...
2024/5/4 23:55:05 - 【外汇早评】美欲与伊朗重谈协议
原标题:【外汇早评】美欲与伊朗重谈协议美国对伊朗的制裁遭到伊朗的抗议,昨日伊朗方面提出将部分退出伊核协议。而此行为又遭到欧洲方面对伊朗的谴责和警告,伊朗外长昨日回应称,欧洲国家履行它们的义务,伊核协议就能保证存续。据传闻伊朗的导弹已经对准了以色列和美国的航…...
2024/5/4 23:54:56 - 【原油贵金属早评】波动率飙升,市场情绪动荡
原标题:【原油贵金属早评】波动率飙升,市场情绪动荡因中美贸易谈判不安情绪影响,金融市场各资产品种出现明显的波动。随着美国与中方开启第十一轮谈判之际,美国按照既定计划向中国2000亿商品征收25%的关税,市场情绪有所平复,已经开始接受这一事实。虽然波动率-恐慌指数VI…...
2024/5/7 11:36:39 - 【原油贵金属周评】伊朗局势升温,黄金多头跃跃欲试
原标题:【原油贵金属周评】伊朗局势升温,黄金多头跃跃欲试美国和伊朗的局势继续升温,市场风险情绪上升,避险黄金有向上突破阻力的迹象。原油方面稍显平稳,近期美国和OPEC加大供给及市场需求回落的影响,伊朗局势并未推升油价走强。近期中美贸易谈判摩擦再度升级,美国对中…...
2024/5/4 23:54:56 - 【原油贵金属早评】市场情绪继续恶化,黄金上破
原标题:【原油贵金属早评】市场情绪继续恶化,黄金上破周初中国针对于美国加征关税的进行的反制措施引发市场情绪的大幅波动,人民币汇率出现大幅的贬值动能,金融市场受到非常明显的冲击。尤其是波动率起来之后,对于股市的表现尤其不安。隔夜美国股市出现明显的下行走势,这…...
2024/5/6 1:40:42 - 【外汇早评】美伊僵持,风险情绪继续升温
原标题:【外汇早评】美伊僵持,风险情绪继续升温昨日沙特两艘油轮再次发生爆炸事件,导致波斯湾局势进一步恶化,市场担忧美伊可能会出现摩擦生火,避险品种获得支撑,黄金和日元大幅走强。美指受中美贸易问题影响而在低位震荡。继5月12日,四艘商船在阿联酋领海附近的阿曼湾、…...
2024/5/4 23:54:56 - 【原油贵金属早评】贸易冲突导致需求低迷,油价弱势
原标题:【原油贵金属早评】贸易冲突导致需求低迷,油价弱势近日虽然伊朗局势升温,中东地区几起油船被袭击事件影响,但油价并未走高,而是出于调整结构中。由于市场预期局势失控的可能性较低,而中美贸易问题导致的全球经济衰退风险更大,需求会持续低迷,因此油价调整压力较…...
2024/5/8 20:48:49 - 氧生福地 玩美北湖(上)——为时光守候两千年
原标题:氧生福地 玩美北湖(上)——为时光守候两千年一次说走就走的旅行,只有一张高铁票的距离~ 所以,湖南郴州,我来了~ 从广州南站出发,一个半小时就到达郴州西站了。在动车上,同时改票的南风兄和我居然被分到了一个车厢,所以一路非常愉快地聊了过来。 挺好,最起…...
2024/5/7 9:26:26 - 氧生福地 玩美北湖(中)——永春梯田里的美与鲜
原标题:氧生福地 玩美北湖(中)——永春梯田里的美与鲜一觉醒来,因为大家太爱“美”照,在柳毅山庄去寻找龙女而错过了早餐时间。近十点,向导坏坏还是带着饥肠辘辘的我们去吃郴州最富有盛名的“鱼头粉”。说这是“十二分推荐”,到郴州必吃的美食之一。 哇塞!那个味美香甜…...
2024/5/4 23:54:56 - 氧生福地 玩美北湖(下)——奔跑吧骚年!
原标题:氧生福地 玩美北湖(下)——奔跑吧骚年!让我们红尘做伴 活得潇潇洒洒 策马奔腾共享人世繁华 对酒当歌唱出心中喜悦 轰轰烈烈把握青春年华 让我们红尘做伴 活得潇潇洒洒 策马奔腾共享人世繁华 对酒当歌唱出心中喜悦 轰轰烈烈把握青春年华 啊……啊……啊 两…...
2024/5/8 19:33:07 - 扒开伪装医用面膜,翻六倍价格宰客,小姐姐注意了!
原标题:扒开伪装医用面膜,翻六倍价格宰客,小姐姐注意了!扒开伪装医用面膜,翻六倍价格宰客!当行业里的某一品项火爆了,就会有很多商家蹭热度,装逼忽悠,最近火爆朋友圈的医用面膜,被沾上了污点,到底怎么回事呢? “比普通面膜安全、效果好!痘痘、痘印、敏感肌都能用…...
2024/5/5 8:13:33 - 「发现」铁皮石斛仙草之神奇功效用于医用面膜
原标题:「发现」铁皮石斛仙草之神奇功效用于医用面膜丽彦妆铁皮石斛医用面膜|石斛多糖无菌修护补水贴19大优势: 1、铁皮石斛:自唐宋以来,一直被列为皇室贡品,铁皮石斛生于海拔1600米的悬崖峭壁之上,繁殖力差,产量极低,所以古代仅供皇室、贵族享用 2、铁皮石斛自古民间…...
2024/5/8 20:38:49 - 丽彦妆\医用面膜\冷敷贴轻奢医学护肤引导者
原标题:丽彦妆\医用面膜\冷敷贴轻奢医学护肤引导者【公司简介】 广州华彬企业隶属香港华彬集团有限公司,专注美业21年,其旗下品牌: 「圣茵美」私密荷尔蒙抗衰,产后修复 「圣仪轩」私密荷尔蒙抗衰,产后修复 「花茵莳」私密荷尔蒙抗衰,产后修复 「丽彦妆」专注医学护…...
2024/5/4 23:54:58 - 广州械字号面膜生产厂家OEM/ODM4项须知!
原标题:广州械字号面膜生产厂家OEM/ODM4项须知!广州械字号面膜生产厂家OEM/ODM流程及注意事项解读: 械字号医用面膜,其实在我国并没有严格的定义,通常我们说的医美面膜指的应该是一种「医用敷料」,也就是说,医用面膜其实算作「医疗器械」的一种,又称「医用冷敷贴」。 …...
2024/5/9 7:32:17 - 械字号医用眼膜缓解用眼过度到底有无作用?
原标题:械字号医用眼膜缓解用眼过度到底有无作用?医用眼膜/械字号眼膜/医用冷敷眼贴 凝胶层为亲水高分子材料,含70%以上的水分。体表皮肤温度传导到本产品的凝胶层,热量被凝胶内水分子吸收,通过水分的蒸发带走大量的热量,可迅速地降低体表皮肤局部温度,减轻局部皮肤的灼…...
2024/5/4 23:54:56 - 配置失败还原请勿关闭计算机,电脑开机屏幕上面显示,配置失败还原更改 请勿关闭计算机 开不了机 这个问题怎么办...
解析如下:1、长按电脑电源键直至关机,然后再按一次电源健重启电脑,按F8健进入安全模式2、安全模式下进入Windows系统桌面后,按住“winR”打开运行窗口,输入“services.msc”打开服务设置3、在服务界面,选中…...
2022/11/19 21:17:18 - 错误使用 reshape要执行 RESHAPE,请勿更改元素数目。
%读入6幅图像(每一幅图像的大小是564*564) f1 imread(WashingtonDC_Band1_564.tif); subplot(3,2,1),imshow(f1); f2 imread(WashingtonDC_Band2_564.tif); subplot(3,2,2),imshow(f2); f3 imread(WashingtonDC_Band3_564.tif); subplot(3,2,3),imsho…...
2022/11/19 21:17:16 - 配置 已完成 请勿关闭计算机,win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机...
win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机”问题的解决方法在win7系统关机时如果有升级系统的或者其他需要会直接进入一个 等待界面,在等待界面中我们需要等待操作结束才能关机,虽然这比较麻烦,但是对系统进行配置和升级…...
2022/11/19 21:17:15 - 台式电脑显示配置100%请勿关闭计算机,“准备配置windows 请勿关闭计算机”的解决方法...
有不少用户在重装Win7系统或更新系统后会遇到“准备配置windows,请勿关闭计算机”的提示,要过很久才能进入系统,有的用户甚至几个小时也无法进入,下面就教大家这个问题的解决方法。第一种方法:我们首先在左下角的“开始…...
2022/11/19 21:17:14 - win7 正在配置 请勿关闭计算机,怎么办Win7开机显示正在配置Windows Update请勿关机...
置信有很多用户都跟小编一样遇到过这样的问题,电脑时发现开机屏幕显现“正在配置Windows Update,请勿关机”(如下图所示),而且还需求等大约5分钟才干进入系统。这是怎样回事呢?一切都是正常操作的,为什么开时机呈现“正…...
2022/11/19 21:17:13 - 准备配置windows 请勿关闭计算机 蓝屏,Win7开机总是出现提示“配置Windows请勿关机”...
Win7系统开机启动时总是出现“配置Windows请勿关机”的提示,没过几秒后电脑自动重启,每次开机都这样无法进入系统,此时碰到这种现象的用户就可以使用以下5种方法解决问题。方法一:开机按下F8,在出现的Windows高级启动选…...
2022/11/19 21:17:12 - 准备windows请勿关闭计算机要多久,windows10系统提示正在准备windows请勿关闭计算机怎么办...
有不少windows10系统用户反映说碰到这样一个情况,就是电脑提示正在准备windows请勿关闭计算机,碰到这样的问题该怎么解决呢,现在小编就给大家分享一下windows10系统提示正在准备windows请勿关闭计算机的具体第一种方法:1、2、依次…...
2022/11/19 21:17:11 - 配置 已完成 请勿关闭计算机,win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机”的解决方法...
今天和大家分享一下win7系统重装了Win7旗舰版系统后,每次关机的时候桌面上都会显示一个“配置Windows Update的界面,提示请勿关闭计算机”,每次停留好几分钟才能正常关机,导致什么情况引起的呢?出现配置Windows Update…...
2022/11/19 21:17:10 - 电脑桌面一直是清理请关闭计算机,windows7一直卡在清理 请勿关闭计算机-win7清理请勿关机,win7配置更新35%不动...
只能是等着,别无他法。说是卡着如果你看硬盘灯应该在读写。如果从 Win 10 无法正常回滚,只能是考虑备份数据后重装系统了。解决来方案一:管理员运行cmd:net stop WuAuServcd %windir%ren SoftwareDistribution SDoldnet start WuA…...
2022/11/19 21:17:09 - 计算机配置更新不起,电脑提示“配置Windows Update请勿关闭计算机”怎么办?
原标题:电脑提示“配置Windows Update请勿关闭计算机”怎么办?win7系统中在开机与关闭的时候总是显示“配置windows update请勿关闭计算机”相信有不少朋友都曾遇到过一次两次还能忍但经常遇到就叫人感到心烦了遇到这种问题怎么办呢?一般的方…...
2022/11/19 21:17:08 - 计算机正在配置无法关机,关机提示 windows7 正在配置windows 请勿关闭计算机 ,然后等了一晚上也没有关掉。现在电脑无法正常关机...
关机提示 windows7 正在配置windows 请勿关闭计算机 ,然后等了一晚上也没有关掉。现在电脑无法正常关机以下文字资料是由(历史新知网www.lishixinzhi.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!关机提示 windows7 正在配…...
2022/11/19 21:17:05 - 钉钉提示请勿通过开发者调试模式_钉钉请勿通过开发者调试模式是真的吗好不好用...
钉钉请勿通过开发者调试模式是真的吗好不好用 更新时间:2020-04-20 22:24:19 浏览次数:729次 区域: 南阳 > 卧龙 列举网提醒您:为保障您的权益,请不要提前支付任何费用! 虚拟位置外设器!!轨迹模拟&虚拟位置外设神器 专业用于:钉钉,外勤365,红圈通,企业微信和…...
2022/11/19 21:17:05 - 配置失败还原请勿关闭计算机怎么办,win7系统出现“配置windows update失败 还原更改 请勿关闭计算机”,长时间没反应,无法进入系统的解决方案...
前几天班里有位学生电脑(windows 7系统)出问题了,具体表现是开机时一直停留在“配置windows update失败 还原更改 请勿关闭计算机”这个界面,长时间没反应,无法进入系统。这个问题原来帮其他同学也解决过,网上搜了不少资料&#x…...
2022/11/19 21:17:04 - 一个电脑无法关闭计算机你应该怎么办,电脑显示“清理请勿关闭计算机”怎么办?...
本文为你提供了3个有效解决电脑显示“清理请勿关闭计算机”问题的方法,并在最后教给你1种保护系统安全的好方法,一起来看看!电脑出现“清理请勿关闭计算机”在Windows 7(SP1)和Windows Server 2008 R2 SP1中,添加了1个新功能在“磁…...
2022/11/19 21:17:03 - 请勿关闭计算机还原更改要多久,电脑显示:配置windows更新失败,正在还原更改,请勿关闭计算机怎么办...
许多用户在长期不使用电脑的时候,开启电脑发现电脑显示:配置windows更新失败,正在还原更改,请勿关闭计算机。。.这要怎么办呢?下面小编就带着大家一起看看吧!如果能够正常进入系统,建议您暂时移…...
2022/11/19 21:17:02 - 还原更改请勿关闭计算机 要多久,配置windows update失败 还原更改 请勿关闭计算机,电脑开机后一直显示以...
配置windows update失败 还原更改 请勿关闭计算机,电脑开机后一直显示以以下文字资料是由(历史新知网www.lishixinzhi.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!配置windows update失败 还原更改 请勿关闭计算机&#x…...
2022/11/19 21:17:01 - 电脑配置中请勿关闭计算机怎么办,准备配置windows请勿关闭计算机一直显示怎么办【图解】...
不知道大家有没有遇到过这样的一个问题,就是我们的win7系统在关机的时候,总是喜欢显示“准备配置windows,请勿关机”这样的一个页面,没有什么大碍,但是如果一直等着的话就要两个小时甚至更久都关不了机,非常…...
2022/11/19 21:17:00 - 正在准备配置请勿关闭计算机,正在准备配置windows请勿关闭计算机时间长了解决教程...
当电脑出现正在准备配置windows请勿关闭计算机时,一般是您正对windows进行升级,但是这个要是长时间没有反应,我们不能再傻等下去了。可能是电脑出了别的问题了,来看看教程的说法。正在准备配置windows请勿关闭计算机时间长了方法一…...
2022/11/19 21:16:59 - 配置失败还原请勿关闭计算机,配置Windows Update失败,还原更改请勿关闭计算机...
我们使用电脑的过程中有时会遇到这种情况,当我们打开电脑之后,发现一直停留在一个界面:“配置Windows Update失败,还原更改请勿关闭计算机”,等了许久还是无法进入系统。如果我们遇到此类问题应该如何解决呢࿰…...
2022/11/19 21:16:58 - 如何在iPhone上关闭“请勿打扰”
Apple’s “Do Not Disturb While Driving” is a potentially lifesaving iPhone feature, but it doesn’t always turn on automatically at the appropriate time. For example, you might be a passenger in a moving car, but your iPhone may think you’re the one dri…...
2022/11/19 21:16:57