• 原文地址:Writing fast and safe native Node.js modules with Rust
  • 原文作者:Peter Czibik
  • 译文出自:掘金翻译计划
  • 本文永久链接:github.com/xitu/gold-m…
  • 译者:LeopPro
  • 校对者:Serendipity96

使用 Rust 编写快速安全的原生 Node.js 模块

内容梗概 - 使用 Rust 代替 C++ 开发原生 Node.js 模块!

RisingStack 去年面临一件棘手的事:我们已经尽可能让 Node.js 发挥出最高的性能,然而我们的服务器开销还是达到的最高限度。为了提高我们应用的性能(并且降低成本),我们决定彻底重写它,并将系统迁移到其他的基础设施上 - 毫无疑问,这个工作量很大,这里不详叙了。 后来我发现,我们只要写一个原生模块就行了!

那时候,我们还没意识到有更好的方法来解决我们的性能问题。就在几周前,我发现有另外一个方案可行 采用 Rust 代替 C ++ 来实现原生模块。 我发现这是一个很好的选择,这要归功于它提供的安全性和易用性。

在这篇 Rust 教程中,我将手把手教你写一个先进、快速、安全的原生模块。

Node.js 服务器的性能问题

我们的问题在 2016 年末的时候暴露出来,当时我们一直在研究 Node.js 的监控产品 Trace,该产品于2017年10月与 Keymetrics 合并。 像当时的其他科技创业公司一样,我们将服务部署到 Heroku 上以节省一些基础设施成本和维护费用。我们一直在构建微服务架构应用程序,这意味着我们很多服务都是通过 HTTP(S) 进行通信的。

棘手的问题来了: 我们想让各服务之间进行安全的通信,但是 Heroku 不支持私有网络,所以我们不得不实现一个自己的方案。因此,我们查阅了一些安全认证方案,最终选定了 HTTP 签名。

简要地解释一下:HTTP 签名基于非对称密码体系。要创建一个 HTTP 签名,你需要获取一个请求的所有部分:URL、请求头、请求体,使用你的私钥对其签名。然后,你可以将公钥发给将会收到签名请求的设备,以便它们验证。

随时间流逝,我们发现在大多数 HTTP 服务器进程中,CPU 利用率已经达到了极限。显然,一个原因引起我们怀疑 - 如果你想加密,那就会发生这样的问题。

然而,在对 v8-profiler 进行了严格分析之后,我们发现问题不是由加密引起的!是 URL 解析占用 CPU 最多的时间。为什么?因为要进行验证,就必须解析 URL 来验证请求签名。

为了解决这个问题,我们决定放弃 Heroku(这其中也有其他因素),我们创建了一个包含 Kubernetes 和内部网络的 Google 云基础设施,而不是优化我们的 URL 解析。

是什么原因促使我写这个故事(教程)呢?就在几周前,我意识到我们可以用另一种方法优化 URL 解析 —— 使用 Rust 写一个原生库。

编写原生模块 - 需要一个 Rust 模块

编写原生代码应该不那么难,对吧?

在 RisingStack,我们奉行工欲善其事,必先利其器的宗旨。我们经常对更好的软件构件方式做调查,在必要的时候,也使用 C++ 来编写原生模块。

恬不知耻地说一句:我也在博客上写了我的学习历程 原生 Node.js 模块之旅。去看一看!

在此之前,我认为在绝大多数业务场景中,C++ 是编写一个快速有效的软件的正确选择。然而现在我们有了现代化的工具(本例中 - Rust),我们可以用它花费比以前都少的人力成本来编写更有效、更安全、更快速的代码。

让我们回到最初的问题:解析一个 URL 难道很困难么?它包括协议、主机、查询参数……


(出自 Node.js documentation)

这看起来真复杂。当我通读 the URL standard 之后,我发现我不想自己实现它,所以我开始寻找替代品。

我确信我不是唯一一个想要解析 URL 的人。浏览器可能已经解决了这个问题,所以我搜索了 Chromium 的解决方案:谷歌链接。尽管使用 N-API 可以很容易地从 Node.js 调用这个实现,但是有几个原因让我不这样做:

  • 更新: 当我只是从网上复制粘贴代码的时候,我立即感到了不安。长久以来,人们一直这样做,而且总有许多原因使它们不能很好地工作……没有什么好的方法去更新代码库中的大段代码。
  • 安全性: 一个没有丰富 C++ 编程经验的人是无法验证代码是否正确的,但是我们又不得不将它运行在我们服务器上。C++ 学习曲线过于陡峭,人们需要花费很长时间掌握它。
  • 私密性: 我们都听说过可用的 C++ 代码是存在的,然而我宁愿避免复用 C++ 代码,因为我没办法独自审计它。使用维护良好的开源模块给了我足够的信心,我不必担心它的私密性。

所以我更倾向于一门更易于使用的,具有简易更新机制和现代化的语言:Rust!

关于 Rust 简单说两句

Rust 允许我们编写快速有效的代码。

所有的 Rust 工程由 cargo 管理 —— 就是 Rust 界的 npmcargo 可以安装工程依赖,并且有一个注册表包含了所有你需要使用的包。

我发现了一个可以在我们例子中使用的库 - rust-url,非常感谢 Servo 团队所做的工作。

我们也要使用 Rust FFI!两年前我已经写过一个相关的博客 using Rust FFI with Node.js。从那时到现在,Rust 生态系统已经发生了很多改变。

我们有了一个可以工作的库(rust-url),让我们试着去编译它吧!

如何编译一个 Rust 应用?

根据 rustup.rs 指南,我们可以用 rustc 编译器,但是我们现在更应该关心的是 cargo。我不想深入描述它是如何工作的,如果你感兴趣,请移步至我们以前的 Rust 博文。

创建新的 Rust 工程

创建一个新的 Rust 工程就这么简单:cargo new --lib <工程名>

你可以在我的仓库中查看完整代码 github.com/peteyy/rust…

想要引用 Rust 库,我们只要将它作为一个依赖列在 Cargo.toml 中就可以了。

[package]
name = "ffi"
version = "1.0.0"
authors = ["Peter Czibik <p.czibik@gmail.com>"][dependencies]
url = "1.6"
复制代码

Rust 没有类似 npm install 一样安装依赖的命令 - 你必须自己手动添加它。然而有一个叫做 cargo edit 的 crate 可以实现类似功能。

译者注:crate 是 Rust 中一个类似包(package)的概念,上文中的 rust-url 也属于一个 crate。crates.io 允许全世界的 Rust 开发者搜索或者发布 crate。

Rust FFI

为了从 Node.js 中调用 Rust,我们可以使用 Rust 提供的 FFI。FFI 是外部函数接口(Foreign Function Interface)的缩写。外部函数接口(FFI)是由一种程序语言编写的,能够调用另一种语言编写的例程或使用服务的机制。

为了链接我们的库,我们还需要向 Cargo.toml 中添加两个东西

[lib]
crate-type = ["dylib"][dependencies]
libc = "0.2"
url = "1.6"
复制代码

在这里需要说明:我们的库是动态链接库,文件扩展名为 .dylib,这个库在运行期被加载而不是编译期。

我们还要为工程添加 libc依赖,libc 是遵从 ANSI C 标准的 C 语言标准库。

libc crate 是 Rust 的一个库,它具有与各种系统(包括libc)中常见类型和函数的本地绑定。这允许我们在 Rust 代码中使用 C 语言类型,我们想在 Rust 函数中接收或返回任何 C 类型数据,我们都必须使用它。

我们的代码相当简单 —— 我使用 extern crate 关键字来引用 urllibc crate。我们要把函数标记为 pub extern 使得这些函数可以通过 FFI 被暴漏给外部。我们的函数持有一个代表 Node.js 中 String 类型的 c_char 指针。

我们需要把类型转换标记为 unsafe。被标记了 unsafe 关键字的代码块可以访问非安全的函数或者取消引用在安全函数中的裸指针(raw pointer)。

Rust 使用 Option<T> 类型来表示一个可为空的值。就像 JavaScript 中一个值可以为 null 或者 undefined 一样。每次尝试访问可能为空的值时,都可以(也应该)明确地检查。在 Rust 中,有几种方式可以访问它,但是在这里,我将使用最简单的方式:如果值为空,则将会抛出一个错误(panic in Rust terms)unwrap

当我们搞定了 URL 解析,我们要将结果转化为 CString 才能传回 JavaScript。

extern crate libc;
extern crate url;use std::ffi::{CStr,CString};
use url::{Url};#[no_mangle]
pub extern "C" fn get_query (arg1: *const libc::c_char) -> *const libc::c_char {let s1 = unsafe { CStr::from_ptr(arg1) };let str1 = s1.to_str().unwrap();let parsed_url = Url::parse(str1).unwrap();CString::new(parsed_url.query().unwrap().as_bytes()).unwrap().into_raw()
}
复制代码

要编译这些 Rust 代码,你可以使用 cargo build --release 命令。在编译之前,确认你在 Cargo.toml 的依赖中添加 url 库了!

现在我们可以使用 Node.js 的 ffi 包创建一个用于调用 Rust 代码的模块。

const path = require('path');
const ffi = require('ffi');const library_name = path.resolve(__dirname, './target/release/libffi');
const api = ffi.Library(library_name, {get_query: ['string', ['string']]
});module.exports = {getQuery: api.get_query
};
复制代码

cargo build --release 命令编译出的 .dylib 命名规则是 lib*,其中的 * 是你的库名。

美滋滋:我们已经有了一个可以从 Node.js 调用的 Rust 代码!虽说能拔脓的就是好膏药,但是你应该已经发现了,我们不得不做一大堆类型转换,这将增加我们函数调用的开销。一定有更好的办法将我们的代码与 JavaScript 做整合。

初遇 Neon

用于编写安全、快速的原生 Node.js 模块的 Rust 绑定。

Neon 让我们可以在 Rust 代码中使用 JavaScript 类型。要创建一个新的 Neon 工程,我们可以使用它自带的命令行工具。执行 npm install neon-cli --global 来安装它。

执行 neon new <projectname> 将会创建一个新的没有任何配置 Neon 工程。

创建好 Neon 工程后,我们重写上面的代码如下:

#[macro_use]
extern crate neon;extern crate url;use url::{Url};
use neon::vm::{Call, JsResult};
use neon::js::{JsString, JsObject};fn get_query(call: Call) -> JsResult<JsString> {let scope = call.scope;let url = call.arguments.require(scope, 0)?.check::<JsString>()?.value();let parsed_url = Url::parse(&url).unwrap();Ok(JsString::new(scope, parsed_url.query().unwrap()).unwrap())
}register_module!(m, {m.export("getQuery", get_query)});
复制代码

上述代码中,新类型 JsStringCallJsResult 是对 JavaScript 类型的封装,这样我们就可以接入 JavaScript VM ,执行上面的代码。Scope 将我们的新变量绑定到当前的 JavaScript 域中,这让我们的变量就可以被垃圾收集器回收。

这和我之前写的博文中 使用 C++ 编写原生 Node.js 模块 解释地非常类似。

值得注意的是,#[macro_use] 属性允许我们使用 register_module! 宏,这可以让我们像 Node.js 中的 module.exports 一样创建模块。

唯一棘手的地方是对参数的访问:

let url = call.arguments.require(scope, 0)?.check::<JsString>()?.value();
复制代码

我们得接受所有类型的参数(如同任何 JavaScript 函数一样),所以我们没办法确定参数的数量,这就是我们必须要检查第一个元素是否存在的原因。

除此之外,我们可以摆脱大多数的序列化工作,直接使用 Js 类型就好了。

现在,我们尝试运行它!

如果你事先下载了我的示例代码,你需要进入 ffi 文件夹执行 cargo build --release ,然后进入 neon 文件夹执行 neon build(事先要装好 neon-cli)。

如果你都准备好了,你可以使用 Node.js 的 faker library 生成一个新的 URL 列表。

执行 node generateUrls.js 命令,这将会在你的文件夹中创建一个 urls.json 文件,我们的测试程序一会儿会尝试解析它。搞定了这些后,你可以执行 node urlParser.js 来运行基准测试,如果全部成功了,你将会看到下图:

测试程序解析了100个URL(随机产生),我们的应用只需要一次运行就可以解析出结果。如果你想做基准测试,请增加 URL 数量(urlParser.js 中的 tryCount)或次数(urlGenerator.js 中的 urlLength)。

显而易见,在基准测试中表现最好的是 Rust neon 版本,但是随之数组长度的增加,V8 有越来越多的优化空间,他们之间的成绩会接近。最终它将超过 Rust neon 实现。

这只是一个简单的例子,当然,在这个领域我们还有很多东西要学习,

后续,我们可以进一步优化计算,尽可能的利用并发计算提高性能,一些类似 rayon 的 crates 提供给我们类似的功能。

在 Node.js 中实现 Rust 模块

希望你今天跟我学到了在 Node.js 中实现 Rust 模块的方法,从此你可以从(工具链中的)新工具中受益。我想说的是,虽然这是能解决问题的(而且很有趣),但它并不是解决所有性能问题的银弹。

请记住,在某些场景下,Rust 可能是很便利的解决方案

如果你想看看我在 Rust 匈牙利研讨会上关于本话题的发言,点这里!

如果你有任何问题或评论,请在下面留言,我将在这回复你们!


掘金翻译计划 是一个翻译优质互联网技术文章的社区,文章来源为 掘金 上的英文分享文章。内容覆盖 Android、iOS、前端、后端、区块链、产品、设计、人工智能等领域,想要查看更多优质译文请持续关注 掘金翻译计划、官方微博、知乎专栏。

查看全文
如若内容造成侵权/违法违规/事实不符,请联系编程学习网邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!

相关文章

  1. node.js服务端和QT客户端简单Socket通讯

    很久没写博客了,最近在做一个项目,服务端要用到node.js。客户端用QT来开发。这两种新兴的东西,资料少之又少,一个简单的socket通讯,几乎花了我一周多的时间来完成。遇到了各种各样的问题就不说了(都是泪),直接贴正确的代码,边贴边解释。 首先是服务端: var net = requi…...

    2024/4/19 10:47:52
  2. Node.js博客系统--1.学前要求、项目功能介绍、需求分析

    本系列教程《Node.JS之“个人博客开发实战教程”》你可以学会:深度了解 Nodejs+express+mongodb+mongoose,打造个人博客,娴熟掌握前台的: 用户注册、登陆、博客文章列表、内容预览和评论功能。后台的:注册用户管理、博客分类管理、博客内容以及评论的管理功能。学前要求ht…...

    2024/4/17 7:27:31
  3. 几篇不错的node.js的教程

    文章列表:从文件上传开始, 进入node.js的世界将使用npm管理的node.js项目部署到vCloudLabs用node.js建博客(一) – node.js安装及Express框架简介用node.js建博客(二) – 构建第一个markdown页面用node.js建博客(三) – 用markdown写静态博客用node.js建博客(四) – express中的…...

    2024/4/15 3:59:39
  4. 了解Node.js-to-Angular 套件组件

    Node.js-to-Angular套件最常见的,并且我们相信也是最好的版本是包括MongoDB、Express、Angular和Node.js 的Node.js-to-Angular 套件。 在Node.js-to-Angular 套件中,Node.js 提供了开发的基础平台。后端服务和服务器端脚本都是用Node.js 编写的。MongoDB 提供了网站的数据存…...

    2024/4/15 3:59:38
  5. Node.js 入门之二

    三、构建应用的模块3.1 一个基础的HTTP服务器当我准备开始写我的第一个“真正的”Node.js应用的时候,我不但不知道怎么写Node.js代码,也不知道怎么组织这些代码。 我应该把所有东西都放进一个文件里吗?网上有很多教程都会教你把所有的逻辑都放进一个用Node.js写的基础HTTP服…...

    2024/4/15 3:59:38
  6. 我的Node.js自学之路(一)——安装和布局

    一、下载与配置第一课,我不想说node.js是什么之类的问题,因为所有我看过的教程或者博客,都会以几乎相同的语言描述node.js的功能或者特点。然后以一个简单的HELLO WORLD或者EXPRESS网站做为说明,而从开始学习到现在,我发现最迫切要解决的问题是程序安装,如何找到一个合适…...

    2024/4/19 17:46:34
  7. Node.js 博客实例(十一)文章检索功能

    原教程 https://github.com/nswbmw/N-blog/wiki/_pages的第十一章,由于版本等的原因,在原教程基础上稍加改动即可实现。现在我们来给博客增加文章检索功能,即根据关键字模糊查询文章标题,且字母不区分大小写。 首先,我们修改 header.ejs ,在 </nav> 前添加一行代码…...

    2024/4/15 21:28:02
  8. node.js+vue的全栈之路一

    本文由本作者原创,转载请注明来源。 欢迎关注我的GitHub(PeipeiQ)和个人博客(http://www.peipeiq.cn)iOS开发也有一段时间了,object-c代码写多了,写一点别的代码玩玩。这段时间比较空闲,所以自己用node去搭了个博客的后端服务,后台前端是jq+bootstrap,服务端用的是no…...

    2024/4/18 11:36:38
  9. node.js使用教程(nodejs特性、小知识点、npm使用、express脚手架等)

    node.js使用教程(nodejs特性、小知识点、npm使用、express脚手架等) 目录第一章 简介、三大特点(优点与缺点) 第二章 项目仓库创建文件简介、字符串解析(序列化)与反序列化以及一些小知识点 第三章 npm使用 第四章 express脚手架的使用一、第一章 基础的东西 简介: ​ n…...

    2024/4/17 16:56:46
  10. Vue.js+Node.js+Mongodb+Express+Bootstrap搭建个人博客

    1 概述 花了半年时间学习,然后开发的个人博客,目前我的博客正在使用。博客前端展示页面见这里,顺便安利一波小站,嘻嘻。 文末会给出源码哈,适合新手参考。 后台管理部分如图,实现最基础的增删改查。 后台首页。后台管理,包括博客的删除、修改和是否隐藏。写博客。2 参考…...

    2024/5/2 19:04:58
  11. 学习笔记:node.js搭建web网站

    第一步:先到官网下载并安装nodejs安装教程路径:https://www.runoob.com/nodejs/nodejs-install-setup.html第二步:在编译器中写好http.js文件var http=require(http);http.createServer(function(req,res){res.writeHead(200,{Content-Type:text/plain})res.write(hello worl…...

    2024/4/20 15:56:29
  12. Node.js 10.0和NPM 6发布,强化安全性

    \看新闻很累?看技术新闻更累?试试下载InfoQ手机客户端,每天上下班路上听新闻,有趣还有料!\\\4月24日,Node.js项目发布了10.0.0版本的Node.js,同时npm, Inc发布了node包管理器npm的6.0版本。这两个发布版本都强调了安全性的增强,Node.js升级到了OpenSSL 1.1.0版本,而np…...

    2024/4/15 3:59:30
  13. 从零开始用node.js编写api接口

    今天开始准备自己去探索下 node.js 编写接口,让自己朝着全栈逐渐靠近。 写此博客,就是为了记录下自己的探索以及实现过程。 一、安装 首先安装 node.js,下载地址。下载完成,打开 cmd 输入 node -v,如果显示出了版本号,证明安装成功。 二、初始化 在磁盘中找个合适的位置,…...

    2024/4/24 13:23:42
  14. 如何构建「大型 Node.js 项目」的项目结构?

    项目结构是一个重要的主题,因为您引导应用程序的方式可以决定项目整个生命周期的整个开发体验。在这个 Node.js 项目结构教程中,我将回答 RisingStack 关于构造高级 Node 应用程序的一些最常见的问题,并帮助您构建一个复杂的项目。 这些是我们的目标: 编写易于扩展和维护的…...

    2024/4/24 13:23:41
  15. 介绍一个node创建博客的教程并总结

    接近一个月没写博客了,是因为实在不知道该写什么= =。。。除了完成工作外,这段时间自学了一个教你使用node从0-1创建博客的教程,写的十分详细,教程也重构过几次了,已经相对比较完善,推荐对node感兴趣的同学去学习一下,除了node外最近也在看阮一峰老师的《ES6入门》,内容…...

    2024/4/24 13:23:40
  16. 【转载】node.js - 零基础详细教程(4):node.js事件机制、node异步IO操作

    第四章 建议学习时间2小时 课程共10章学习方式:详细阅读,并手动实现相关代码学习目标:此教程将教会大家 安装Node、搭建服务器、express、mysql、mongodb、编写后台业务逻辑、编写接口,最后完成一个完整的项目后台,预计共10天课程。node.js事件机制node.js是单线程,但是…...

    2024/5/2 10:31:45
  17. Node.js和EMMET简单使用指南(未整理,慎入)

    EMMET首先,以下快捷方式都是在VSCode编辑器中测试的。其他的编辑器概不负责。 1. 新建一个html文件,注意,是html文件。输入!然后按tab键,你就可以得到一个完整的html文档,除了内容。 2. div>p>a = <div><p><a href=""></a>&l…...

    2024/4/24 13:23:38
  18. 【Node.js和模块化】ES6

    本文笔记基于「千古壹号」的GitHub项目:https://github.com/qianguyihao/web 非商业用途自由转载,保持署名,注明出处!文章目录1.问题1.1 暴露方式1.2 导入导出2.举例2.1 初始化2.2 环境配置2.3 编写代码2.4 编译转换 1.问题依赖模块需要编译打包,2个原因:1.考虑浏览器支持…...

    2024/4/24 13:23:37
  19. 【Node】Node.js 入门知识点总结(一)

    一、Node.js 回调函数Node.js 异步编程的直接体现就是回调函数。Node 所有 API 都支持回调函数。回调函数一般作为函数的最后一个参数出现。 例如,我们可以一边读取文件,一边执行其他命令,在文件读取完成后,我们将文件内容作为回调函数的参数返回。这样在执行代码时就没有阻…...

    2024/5/2 7:50:29
  20. Node.js基础—— 如何通过 npm 发布模块

    为了让Node.js的文件可以相互调用,Node.js提供了一个简单的模块系统。模块是Node.js 应用程序的基本组成部分,文件和模块是一一对应的。换言之,一个 Node.js 文件就是一个模块。在 Node.js 中,创建一个模块非常简单,代码如下:var mysql = require(mysql);那么如何通过NPM…...

    2024/5/2 8:50:12

最新文章

  1. HR面试测评,招聘行政部门主管的人才测评方案

    把合适的人放入到合适的岗位中&#xff0c;可以实现双赢&#xff08;企业效益和个人成就&#xff09;&#xff0c;人力资源管理者HR又该如何去发掘行政主管岗位的人才&#xff1f; 行政部门主管属于管理层岗位&#xff0c;在企业发展中有重要的作用&#xff0c;可以协助企业…...

    2024/5/5 16:07:44
  2. 梯度消失和梯度爆炸的一些处理方法

    在这里是记录一下梯度消失或梯度爆炸的一些处理技巧。全当学习总结了如有错误还请留言&#xff0c;在此感激不尽。 权重和梯度的更新公式如下&#xff1a; w w − η ⋅ ∇ w w w - \eta \cdot \nabla w ww−η⋅∇w 个人通俗的理解梯度消失就是网络模型在反向求导的时候出…...

    2024/3/20 10:50:27
  3. 利用Sentinel解决雪崩问题(一)

    1、解决雪崩问题的常见方式有四种: 超时处理:设定超时时间&#xff0c;请求超过一定时间没有响应就返回错误信息&#xff0c;不会无休止等待;舱壁模式:限定每个业务能使用的线程数&#xff0c;避免耗尽整个tomcat的资源&#xff0c;因此也叫线程隔离;熔断降级:由断路器统计业务…...

    2024/5/4 23:53:05
  4. K8S容器空间不足问题分析和解决

    如上图&#xff0c;今天测试环境的K8S平台出现了一个问题&#xff0c;其中的一个容器报错&#xff1a;Free disk space below threshold. Available: 3223552 bytes (threshold: 10485760B)&#xff0c;意思服务器硬盘空间不够了。这个问题怎么产生的&#xff0c;又怎么解决的呢…...

    2024/5/4 14:52:56
  5. 【外汇早评】美通胀数据走低,美元调整

    原标题:【外汇早评】美通胀数据走低,美元调整昨日美国方面公布了新一期的核心PCE物价指数数据,同比增长1.6%,低于前值和预期值的1.7%,距离美联储的通胀目标2%继续走低,通胀压力较低,且此前美国一季度GDP初值中的消费部分下滑明显,因此市场对美联储后续更可能降息的政策…...

    2024/5/4 23:54:56
  6. 【原油贵金属周评】原油多头拥挤,价格调整

    原标题:【原油贵金属周评】原油多头拥挤,价格调整本周国际劳动节,我们喜迎四天假期,但是整个金融市场确实流动性充沛,大事频发,各个商品波动剧烈。美国方面,在本周四凌晨公布5月份的利率决议和新闻发布会,维持联邦基金利率在2.25%-2.50%不变,符合市场预期。同时美联储…...

    2024/5/4 23:54:56
  7. 【外汇周评】靓丽非农不及疲软通胀影响

    原标题:【外汇周评】靓丽非农不及疲软通胀影响在刚结束的周五,美国方面公布了新一期的非农就业数据,大幅好于前值和预期,新增就业重新回到20万以上。具体数据: 美国4月非农就业人口变动 26.3万人,预期 19万人,前值 19.6万人。 美国4月失业率 3.6%,预期 3.8%,前值 3…...

    2024/5/4 23:54:56
  8. 【原油贵金属早评】库存继续增加,油价收跌

    原标题:【原油贵金属早评】库存继续增加,油价收跌周三清晨公布美国当周API原油库存数据,上周原油库存增加281万桶至4.692亿桶,增幅超过预期的74.4万桶。且有消息人士称,沙特阿美据悉将于6月向亚洲炼油厂额外出售更多原油,印度炼油商预计将每日获得至多20万桶的额外原油供…...

    2024/5/4 23:55:17
  9. 【外汇早评】日本央行会议纪要不改日元强势

    原标题:【外汇早评】日本央行会议纪要不改日元强势近两日日元大幅走强与近期市场风险情绪上升,避险资金回流日元有关,也与前一段时间的美日贸易谈判给日本缓冲期,日本方面对汇率问题也避免继续贬值有关。虽然今日早间日本央行公布的利率会议纪要仍然是支持宽松政策,但这符…...

    2024/5/4 23:54:56
  10. 【原油贵金属早评】欧佩克稳定市场,填补伊朗问题的影响

    原标题:【原油贵金属早评】欧佩克稳定市场,填补伊朗问题的影响近日伊朗局势升温,导致市场担忧影响原油供给,油价试图反弹。此时OPEC表态稳定市场。据消息人士透露,沙特6月石油出口料将低于700万桶/日,沙特已经收到石油消费国提出的6月份扩大出口的“适度要求”,沙特将满…...

    2024/5/4 23:55:05
  11. 【外汇早评】美欲与伊朗重谈协议

    原标题:【外汇早评】美欲与伊朗重谈协议美国对伊朗的制裁遭到伊朗的抗议,昨日伊朗方面提出将部分退出伊核协议。而此行为又遭到欧洲方面对伊朗的谴责和警告,伊朗外长昨日回应称,欧洲国家履行它们的义务,伊核协议就能保证存续。据传闻伊朗的导弹已经对准了以色列和美国的航…...

    2024/5/4 23:54:56
  12. 【原油贵金属早评】波动率飙升,市场情绪动荡

    原标题:【原油贵金属早评】波动率飙升,市场情绪动荡因中美贸易谈判不安情绪影响,金融市场各资产品种出现明显的波动。随着美国与中方开启第十一轮谈判之际,美国按照既定计划向中国2000亿商品征收25%的关税,市场情绪有所平复,已经开始接受这一事实。虽然波动率-恐慌指数VI…...

    2024/5/4 23:55:16
  13. 【原油贵金属周评】伊朗局势升温,黄金多头跃跃欲试

    原标题:【原油贵金属周评】伊朗局势升温,黄金多头跃跃欲试美国和伊朗的局势继续升温,市场风险情绪上升,避险黄金有向上突破阻力的迹象。原油方面稍显平稳,近期美国和OPEC加大供给及市场需求回落的影响,伊朗局势并未推升油价走强。近期中美贸易谈判摩擦再度升级,美国对中…...

    2024/5/4 23:54:56
  14. 【原油贵金属早评】市场情绪继续恶化,黄金上破

    原标题:【原油贵金属早评】市场情绪继续恶化,黄金上破周初中国针对于美国加征关税的进行的反制措施引发市场情绪的大幅波动,人民币汇率出现大幅的贬值动能,金融市场受到非常明显的冲击。尤其是波动率起来之后,对于股市的表现尤其不安。隔夜美国股市出现明显的下行走势,这…...

    2024/5/4 18:20:48
  15. 【外汇早评】美伊僵持,风险情绪继续升温

    原标题:【外汇早评】美伊僵持,风险情绪继续升温昨日沙特两艘油轮再次发生爆炸事件,导致波斯湾局势进一步恶化,市场担忧美伊可能会出现摩擦生火,避险品种获得支撑,黄金和日元大幅走强。美指受中美贸易问题影响而在低位震荡。继5月12日,四艘商船在阿联酋领海附近的阿曼湾、…...

    2024/5/4 23:54:56
  16. 【原油贵金属早评】贸易冲突导致需求低迷,油价弱势

    原标题:【原油贵金属早评】贸易冲突导致需求低迷,油价弱势近日虽然伊朗局势升温,中东地区几起油船被袭击事件影响,但油价并未走高,而是出于调整结构中。由于市场预期局势失控的可能性较低,而中美贸易问题导致的全球经济衰退风险更大,需求会持续低迷,因此油价调整压力较…...

    2024/5/4 23:55:17
  17. 氧生福地 玩美北湖(上)——为时光守候两千年

    原标题:氧生福地 玩美北湖(上)——为时光守候两千年一次说走就走的旅行,只有一张高铁票的距离~ 所以,湖南郴州,我来了~ 从广州南站出发,一个半小时就到达郴州西站了。在动车上,同时改票的南风兄和我居然被分到了一个车厢,所以一路非常愉快地聊了过来。 挺好,最起…...

    2024/5/4 23:55:06
  18. 氧生福地 玩美北湖(中)——永春梯田里的美与鲜

    原标题:氧生福地 玩美北湖(中)——永春梯田里的美与鲜一觉醒来,因为大家太爱“美”照,在柳毅山庄去寻找龙女而错过了早餐时间。近十点,向导坏坏还是带着饥肠辘辘的我们去吃郴州最富有盛名的“鱼头粉”。说这是“十二分推荐”,到郴州必吃的美食之一。 哇塞!那个味美香甜…...

    2024/5/4 23:54:56
  19. 氧生福地 玩美北湖(下)——奔跑吧骚年!

    原标题:氧生福地 玩美北湖(下)——奔跑吧骚年!让我们红尘做伴 活得潇潇洒洒 策马奔腾共享人世繁华 对酒当歌唱出心中喜悦 轰轰烈烈把握青春年华 让我们红尘做伴 活得潇潇洒洒 策马奔腾共享人世繁华 对酒当歌唱出心中喜悦 轰轰烈烈把握青春年华 啊……啊……啊 两…...

    2024/5/4 23:55:06
  20. 扒开伪装医用面膜,翻六倍价格宰客,小姐姐注意了!

    原标题:扒开伪装医用面膜,翻六倍价格宰客,小姐姐注意了!扒开伪装医用面膜,翻六倍价格宰客!当行业里的某一品项火爆了,就会有很多商家蹭热度,装逼忽悠,最近火爆朋友圈的医用面膜,被沾上了污点,到底怎么回事呢? “比普通面膜安全、效果好!痘痘、痘印、敏感肌都能用…...

    2024/5/5 8:13:33
  21. 「发现」铁皮石斛仙草之神奇功效用于医用面膜

    原标题:「发现」铁皮石斛仙草之神奇功效用于医用面膜丽彦妆铁皮石斛医用面膜|石斛多糖无菌修护补水贴19大优势: 1、铁皮石斛:自唐宋以来,一直被列为皇室贡品,铁皮石斛生于海拔1600米的悬崖峭壁之上,繁殖力差,产量极低,所以古代仅供皇室、贵族享用 2、铁皮石斛自古民间…...

    2024/5/4 23:55:16
  22. 丽彦妆\医用面膜\冷敷贴轻奢医学护肤引导者

    原标题:丽彦妆\医用面膜\冷敷贴轻奢医学护肤引导者【公司简介】 广州华彬企业隶属香港华彬集团有限公司,专注美业21年,其旗下品牌: 「圣茵美」私密荷尔蒙抗衰,产后修复 「圣仪轩」私密荷尔蒙抗衰,产后修复 「花茵莳」私密荷尔蒙抗衰,产后修复 「丽彦妆」专注医学护…...

    2024/5/4 23:54:58
  23. 广州械字号面膜生产厂家OEM/ODM4项须知!

    原标题:广州械字号面膜生产厂家OEM/ODM4项须知!广州械字号面膜生产厂家OEM/ODM流程及注意事项解读: 械字号医用面膜,其实在我国并没有严格的定义,通常我们说的医美面膜指的应该是一种「医用敷料」,也就是说,医用面膜其实算作「医疗器械」的一种,又称「医用冷敷贴」。 …...

    2024/5/4 23:55:01
  24. 械字号医用眼膜缓解用眼过度到底有无作用?

    原标题:械字号医用眼膜缓解用眼过度到底有无作用?医用眼膜/械字号眼膜/医用冷敷眼贴 凝胶层为亲水高分子材料,含70%以上的水分。体表皮肤温度传导到本产品的凝胶层,热量被凝胶内水分子吸收,通过水分的蒸发带走大量的热量,可迅速地降低体表皮肤局部温度,减轻局部皮肤的灼…...

    2024/5/4 23:54:56
  25. 配置失败还原请勿关闭计算机,电脑开机屏幕上面显示,配置失败还原更改 请勿关闭计算机 开不了机 这个问题怎么办...

    解析如下&#xff1a;1、长按电脑电源键直至关机&#xff0c;然后再按一次电源健重启电脑&#xff0c;按F8健进入安全模式2、安全模式下进入Windows系统桌面后&#xff0c;按住“winR”打开运行窗口&#xff0c;输入“services.msc”打开服务设置3、在服务界面&#xff0c;选中…...

    2022/11/19 21:17:18
  26. 错误使用 reshape要执行 RESHAPE,请勿更改元素数目。

    %读入6幅图像&#xff08;每一幅图像的大小是564*564&#xff09; 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
  27. 配置 已完成 请勿关闭计算机,win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机...

    win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机”问题的解决方法在win7系统关机时如果有升级系统的或者其他需要会直接进入一个 等待界面&#xff0c;在等待界面中我们需要等待操作结束才能关机&#xff0c;虽然这比较麻烦&#xff0c;但是对系统进行配置和升级…...

    2022/11/19 21:17:15
  28. 台式电脑显示配置100%请勿关闭计算机,“准备配置windows 请勿关闭计算机”的解决方法...

    有不少用户在重装Win7系统或更新系统后会遇到“准备配置windows&#xff0c;请勿关闭计算机”的提示&#xff0c;要过很久才能进入系统&#xff0c;有的用户甚至几个小时也无法进入&#xff0c;下面就教大家这个问题的解决方法。第一种方法&#xff1a;我们首先在左下角的“开始…...

    2022/11/19 21:17:14
  29. win7 正在配置 请勿关闭计算机,怎么办Win7开机显示正在配置Windows Update请勿关机...

    置信有很多用户都跟小编一样遇到过这样的问题&#xff0c;电脑时发现开机屏幕显现“正在配置Windows Update&#xff0c;请勿关机”(如下图所示)&#xff0c;而且还需求等大约5分钟才干进入系统。这是怎样回事呢&#xff1f;一切都是正常操作的&#xff0c;为什么开时机呈现“正…...

    2022/11/19 21:17:13
  30. 准备配置windows 请勿关闭计算机 蓝屏,Win7开机总是出现提示“配置Windows请勿关机”...

    Win7系统开机启动时总是出现“配置Windows请勿关机”的提示&#xff0c;没过几秒后电脑自动重启&#xff0c;每次开机都这样无法进入系统&#xff0c;此时碰到这种现象的用户就可以使用以下5种方法解决问题。方法一&#xff1a;开机按下F8&#xff0c;在出现的Windows高级启动选…...

    2022/11/19 21:17:12
  31. 准备windows请勿关闭计算机要多久,windows10系统提示正在准备windows请勿关闭计算机怎么办...

    有不少windows10系统用户反映说碰到这样一个情况&#xff0c;就是电脑提示正在准备windows请勿关闭计算机&#xff0c;碰到这样的问题该怎么解决呢&#xff0c;现在小编就给大家分享一下windows10系统提示正在准备windows请勿关闭计算机的具体第一种方法&#xff1a;1、2、依次…...

    2022/11/19 21:17:11
  32. 配置 已完成 请勿关闭计算机,win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机”的解决方法...

    今天和大家分享一下win7系统重装了Win7旗舰版系统后&#xff0c;每次关机的时候桌面上都会显示一个“配置Windows Update的界面&#xff0c;提示请勿关闭计算机”&#xff0c;每次停留好几分钟才能正常关机&#xff0c;导致什么情况引起的呢&#xff1f;出现配置Windows Update…...

    2022/11/19 21:17:10
  33. 电脑桌面一直是清理请关闭计算机,windows7一直卡在清理 请勿关闭计算机-win7清理请勿关机,win7配置更新35%不动...

    只能是等着&#xff0c;别无他法。说是卡着如果你看硬盘灯应该在读写。如果从 Win 10 无法正常回滚&#xff0c;只能是考虑备份数据后重装系统了。解决来方案一&#xff1a;管理员运行cmd&#xff1a;net stop WuAuServcd %windir%ren SoftwareDistribution SDoldnet start WuA…...

    2022/11/19 21:17:09
  34. 计算机配置更新不起,电脑提示“配置Windows Update请勿关闭计算机”怎么办?

    原标题&#xff1a;电脑提示“配置Windows Update请勿关闭计算机”怎么办&#xff1f;win7系统中在开机与关闭的时候总是显示“配置windows update请勿关闭计算机”相信有不少朋友都曾遇到过一次两次还能忍但经常遇到就叫人感到心烦了遇到这种问题怎么办呢&#xff1f;一般的方…...

    2022/11/19 21:17:08
  35. 计算机正在配置无法关机,关机提示 windows7 正在配置windows 请勿关闭计算机 ,然后等了一晚上也没有关掉。现在电脑无法正常关机...

    关机提示 windows7 正在配置windows 请勿关闭计算机 &#xff0c;然后等了一晚上也没有关掉。现在电脑无法正常关机以下文字资料是由(历史新知网www.lishixinzhi.com)小编为大家搜集整理后发布的内容&#xff0c;让我们赶快一起来看一下吧&#xff01;关机提示 windows7 正在配…...

    2022/11/19 21:17:05
  36. 钉钉提示请勿通过开发者调试模式_钉钉请勿通过开发者调试模式是真的吗好不好用...

    钉钉请勿通过开发者调试模式是真的吗好不好用 更新时间:2020-04-20 22:24:19 浏览次数:729次 区域: 南阳 > 卧龙 列举网提醒您:为保障您的权益,请不要提前支付任何费用! 虚拟位置外设器!!轨迹模拟&虚拟位置外设神器 专业用于:钉钉,外勤365,红圈通,企业微信和…...

    2022/11/19 21:17:05
  37. 配置失败还原请勿关闭计算机怎么办,win7系统出现“配置windows update失败 还原更改 请勿关闭计算机”,长时间没反应,无法进入系统的解决方案...

    前几天班里有位学生电脑(windows 7系统)出问题了&#xff0c;具体表现是开机时一直停留在“配置windows update失败 还原更改 请勿关闭计算机”这个界面&#xff0c;长时间没反应&#xff0c;无法进入系统。这个问题原来帮其他同学也解决过&#xff0c;网上搜了不少资料&#x…...

    2022/11/19 21:17:04
  38. 一个电脑无法关闭计算机你应该怎么办,电脑显示“清理请勿关闭计算机”怎么办?...

    本文为你提供了3个有效解决电脑显示“清理请勿关闭计算机”问题的方法&#xff0c;并在最后教给你1种保护系统安全的好方法&#xff0c;一起来看看&#xff01;电脑出现“清理请勿关闭计算机”在Windows 7(SP1)和Windows Server 2008 R2 SP1中&#xff0c;添加了1个新功能在“磁…...

    2022/11/19 21:17:03
  39. 请勿关闭计算机还原更改要多久,电脑显示:配置windows更新失败,正在还原更改,请勿关闭计算机怎么办...

    许多用户在长期不使用电脑的时候&#xff0c;开启电脑发现电脑显示&#xff1a;配置windows更新失败&#xff0c;正在还原更改&#xff0c;请勿关闭计算机。。.这要怎么办呢&#xff1f;下面小编就带着大家一起看看吧&#xff01;如果能够正常进入系统&#xff0c;建议您暂时移…...

    2022/11/19 21:17:02
  40. 还原更改请勿关闭计算机 要多久,配置windows update失败 还原更改 请勿关闭计算机,电脑开机后一直显示以...

    配置windows update失败 还原更改 请勿关闭计算机&#xff0c;电脑开机后一直显示以以下文字资料是由(历史新知网www.lishixinzhi.com)小编为大家搜集整理后发布的内容&#xff0c;让我们赶快一起来看一下吧&#xff01;配置windows update失败 还原更改 请勿关闭计算机&#x…...

    2022/11/19 21:17:01
  41. 电脑配置中请勿关闭计算机怎么办,准备配置windows请勿关闭计算机一直显示怎么办【图解】...

    不知道大家有没有遇到过这样的一个问题&#xff0c;就是我们的win7系统在关机的时候&#xff0c;总是喜欢显示“准备配置windows&#xff0c;请勿关机”这样的一个页面&#xff0c;没有什么大碍&#xff0c;但是如果一直等着的话就要两个小时甚至更久都关不了机&#xff0c;非常…...

    2022/11/19 21:17:00
  42. 正在准备配置请勿关闭计算机,正在准备配置windows请勿关闭计算机时间长了解决教程...

    当电脑出现正在准备配置windows请勿关闭计算机时&#xff0c;一般是您正对windows进行升级&#xff0c;但是这个要是长时间没有反应&#xff0c;我们不能再傻等下去了。可能是电脑出了别的问题了&#xff0c;来看看教程的说法。正在准备配置windows请勿关闭计算机时间长了方法一…...

    2022/11/19 21:16:59
  43. 配置失败还原请勿关闭计算机,配置Windows Update失败,还原更改请勿关闭计算机...

    我们使用电脑的过程中有时会遇到这种情况&#xff0c;当我们打开电脑之后&#xff0c;发现一直停留在一个界面&#xff1a;“配置Windows Update失败&#xff0c;还原更改请勿关闭计算机”&#xff0c;等了许久还是无法进入系统。如果我们遇到此类问题应该如何解决呢&#xff0…...

    2022/11/19 21:16:58
  44. 如何在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