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

wordpress文章图片弹出效果南宁seo排名收费

wordpress文章图片弹出效果,南宁seo排名收费,网站建设用源码,wordpress菜单添加后然后怎么办tokio 是 rust 生态中流行的异步运行时框架。在实际生产中我们如果希望 tokio 应用程序与特定的 cpu core 绑定该怎么处理呢?这次我们来聊聊这个话题。 首先我们先写一段简单的多任务程序。 use tokio::runtime; pub fn main() {let rt runtime::Builder::new_mu…

tokio 是 rust 生态中流行的异步运行时框架。在实际生产中我们如果希望 tokio 应用程序与特定的 cpu core 绑定该怎么处理呢?这次我们来聊聊这个话题。

首先我们先写一段简单的多任务程序。

use tokio::runtime;
pub fn main() {let rt = runtime::Builder::new_multi_thread().enable_all().build().unwrap();rt.block_on(async {for i in 0..8 {println!("num {}", i);tokio::spawn(async move {loop {let mut sum: i32 = 0;for i in 0..100000000 {sum = sum.overflowing_add(i).0;}println!("sum {}", sum);}});}});
}

程序非常简单,首先构造一个 tokio runtime 环境,然后派生多个 tokio 并发,每个并发执行一个无限循环做 overflowing_add。overflowing_add 函数返回一个加法的元组以及一个表示是否会发生算术溢出的布尔值。如果会发生溢出,那么将返回包装好的值。然后取元祖的第一个元素打印。

这个程序运行在 Ubuntu 20 OS,4 core cpu。通过 nmon 的监控如下:

可以看到每个 core 都有负载。

要想把负载绑定在某一 core 上,需要使用 core_affinity_rs。core_affinity_rs 是一个用于管理 CPU 亲和力的 Rust crate。目前支持 Linux、Mac OSX 和 Windows。官方宣称支持多平台,本人只做了 linux 操作系统的测试。

我们把代码修改一下:

use tokio::runtime;pub fn main() {let core_ids = core_affinity::get_core_ids().unwrap();println!("core num {}", core_ids.len());let core_id = core_ids[1];let rt = runtime::Builder::new_multi_thread().on_thread_start(move || {core_affinity::set_for_current(core_id.clone());}).enable_all().build().unwrap();rt.block_on(async {for i in 0..8 {println!("num {}", i);tokio::spawn(async move { loop {let mut sum: i32 = 0;for i in 0..100000000 {sum = sum.overflowing_add(i).0;}println!("sum {}", sum);           }});}});
}

在构建多线程 runtime 时,在 on_thread_start 设置 cpu 亲和。可以看到负载被绑定到了指定的 core 上。

上面的代码只是把负载绑定到了一个 core 上,那么要绑定多个核怎么办呢?
我们看看下面的代码

pub fn main() {let core_ids = core_affinity::get_core_ids().unwrap();println!("core num {}", core_ids.len());let rt = runtime::Builder::new_multi_thread().enable_all().build().unwrap();let mut idx = 2;rt.block_on(async {for i in 0..8 {println!("num {}", i);let core_id = core_ids[idx];if idx.eq(&(core_ids.len() - 1)) {idx = 2;} else {idx += 1;}tokio::spawn(async move {let res = core_affinity::set_for_current(core_id);println!("{}", res);loop {let mut sum: i32 = 0;for i in 0..100000000 {sum = sum.overflowing_add(i).0;}println!("sum {}", sum);}});}});
}

代码需要把所有负载绑在 core3 和 core4 上。原理是在派生任务中加入 core_affinity 设置。通过调整 idx,将派生并发平均绑定在指定的 core 上。代码运行的监控如下图。

http://www.yayakq.cn/news/838423/

相关文章:

  • 中小企业建网站企业邮箱注册要钱吗
  • 肥城市住房和城乡建设厅网站查域名解析ip
  • 做网站有自己的服务器吗产品视频宣传片
  • 做网站如何调字体格式做公司网站时的英文简介
  • 免费网站建设自带后台管理程序网站建设合同付款方式
  • 优秀企业展示网站重庆广告公司
  • 网站建设平台排行榜wordpress主题更新无法创建目录
  • 湖北省建设工程网站杭州电子商务公司排行
  • 产品类网站模板网页html教程
  • 建模网站素材做网站属于什么备案
  • 怎么设计一个自己的网站北京网站的建设
  • 在线购物网站功能模块没有域名如何访问网站
  • 网站301跳跳转wordpress 备案
  • 做内贸的有哪些网站高明公司搜索seo
  • 怎么做直播网站超管湖南智能网站建设哪家好
  • 网站模板名称海淀区社区建设网站
  • 建设银行网上银行网站可以开通网银无极在线招聘最新消息
  • 苏州网站建设基础型网站建设调查问卷
  • 学校网站模板北京百度推广优化
  • 网站制作用什么语言最好渭南市工程建设项目审批网上办事大厅
  • 网站制作的大公司大学教学应用网站开发现状
  • 铜山微网站开发wordpress界面变宽
  • 玩具网站建设策划书免费开源crm
  • 网站建设需要哪些硬件洪梅镇网站建设
  • 做网站有个名字叫小廖网站自己做还是找公司
  • 做任务佣金的网站俄语网站建设
  • 网站托管服务适合做淘宝网店的运营流程
  • 做网页的素材网站网站结构 扁平结构 树状结构
  • 浦东建设网站网站开发dede
  • 南京做网站找哪家好wordpress 权限管理