基于ghOSt用户调度器的环境搭建

news2024/9/26 5:25:05

文章目录

      • ghOSt环境搭建
        • 编译安装ghOSt内核
        • 使用ghOSt用户空间组件

ghOSt环境搭建

  • 资源:

    • ghOSt-kernel:https://github.com/google/ghost-kernel
    • ghOSt-userspace:https://github.com/google/ghost-userspace
    • 论文原文:https://dl.acm.org/doi/abs/10.1145/3477132.3483542
  • 环境:Ubuntu20.04,核心数尽量配大一点 比如12

    • 再安装Ubuntu时,尽量将内存分配大一点(如60G),请确保根目录有近50G的大小,否则后续编译时可能因为空间不够而失败。

      • 可以通过df -TH查看虚拟机当前内存使用情况

        image-20221122135404851

    • 安装需要的工具

      • sudo apt update
      • sudo apt install git fakeroot build-essential ncurses-dev xz-utils libssl-dev bc flex libelf-dev bison dwarves zstd
  • 下载源码至虚拟机中(推荐使用git加速)

    • git clone https://ghproxy.com/https://github.com/google/ghost-kernel.git
    • git clone https://ghproxy.com/https://github.com/google/ghost-userspace.git

编译安装ghOSt内核

  • 进入ghost-kernel,切换到root用户sudo su

  • make menuconfig

    • 然后会在当前目录生成一个隐藏文件.config,对它进行如下修改
      • CONFIG_SYSTEM_TRUSTED_KEYS="debian/canonical-certs.pem"修改为CONFIG_SYSTEM_TRUSTED_KEYS="" (vi编辑器下可以通过/进行查找)
      • 添加CONFIG_SCHED_CLASS_GHOST=y
  • 编译:make -j $(nproc)

    • $(nproc)代表核心数,可以通过echo $(nproc)查看
    • 比如make -j 12 表示启动12个线程编译,会更快一点,这里需要等待长一点时间
    • 编译完成后,会生成vmlinux、modules*、ghost-kernel/arch/x86/boot/中会生成bzImage等
    • 执行如下命令可以查看都生成了哪些模块: find . -name “*.ko”
  • make modules_install

    • 成功之后 /lib/modules中会有刚刚安装好的内核模块 5.11.0+

      image-20221121205103882

  • 安装内核:make install

    • 该命令的作用是将.config,vmlinuz,initrd.img,System.map文件安装到*/boot/*目录
    • 成功之后/boot下会出现5.11.0+相关的文件
  • 修改gurb

    • ubuntu20.04默认情况下,开机看不到grub界面,也就无法选择进入新编译好的内核。因此需要修改/etc/default/grub文件,将其中的“GRUB_TIMEOUT_STYLE=hidden”注释掉,以显示grub界面;CMDLINE设置为text;并且将GRUB_TIMEOUT修改成“GRUB_TIMEOUT = 30”,以留出30秒时间让用户选择进入哪个内核:

    image-20221122133114595

    • 修改完之后,update-grub更新一下grub, 会看到5.11.0的选项
  • 重启之后,选择ghOSt的内核进行启动即可

    • 在Advanced options for Ubuntu中选择5.11.0+

      image-20221121215449595

      image-20221121215409907

  • 查看内核选项

    • uname -r 是5.11.0+,ghOSt内核安装成功

使用ghOSt用户空间组件

  • 首先安装Bazel(谷歌常用的代码构建工具,类似于make,但bazel效率更高、更敏捷)

    • 在Ubuntu中安装Bazel

      • image-20221122173958125

        这一步会报错,考虑配置Ubuntu终端代理,然后在此命令前加上proxychains再试一次

  • 见 ghOSt-userspace

    • 编译/构建调度器:比如说:bazel build -c opt fifo_per_cpu_agent #构建每个CPU的FIFO调度器

      • 高亮处可以替换为agent_bifffifo_centralized_agentagent_expagent_cfsagent_shinjukuagent_sol 【可以在ghost-userspace/BUILD中查找】

      • 构建成功后,bazel-bin目录下就可以出现相应的可执行文件

        image-20221121213135516

    • 启动代理:bazel-bin/fifo_per_cpu_agent --ghost_cpus 0-1可以启动相应的代理,终止的时候可按ctrl-c

      image-20221121215858251

    • 同理,编译simple_exp之后,该文件也会出现在bazel-bin文件夹中,运行它可以测试相应ghOSt调度器

      • bazel-bin/simple_exp或者./bazel-bin/simple_exp也可以
  • bazel-bin文件夹中,运行它可以测试相应ghOSt调度器

    bazel-bin/simple_exp或者./bazel-bin/simple_exp也可以
    image-20221121220517479

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/31663.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

[网络] https是什么?https是怎么保障我们信息传输的安全的?

文章目录前言HTTPs是什么?TLS是什么?协议栈对比:HTTPs vs HTTP万能的TLS协议TLS如何保障我们的通信安全的?对称加密和非对称加密的优缺点对称加密方式密钥易泄露的问题改良版之混合加密TLS中混合加密的应用附:有时候会…

pytorch的buffer学习整理

pytorch模型中的buffer 这段时间忙于做项目,但是在项目中一直在模型构建中遇到buffer数据,所以花点时间整理下模型中的parameter和buffer数据的区别💕 1.torch.nn.Module.named_buffers(prefix‘‘, recurseTrue) 贴上pytorch官网对其的说…

sqli-labs/Less-52

这一关输入几次rand()页面发生了改变 说明这一关的注入类型属于数字型注入 接着尝试一下报错注入 输入如下 sortupdatexml(1,if(11,concat(0x7e,database(),0x7e),1),1)-- 发现没有回显 显然不能使用报错注入 只能使用盲注了 这一关我们通过rand()函数的形式来实现盲注 首先…

HTML+CSS+JavaScript仿京东购物商城网站 web前端制作服装购物商城 html电商购物网站

常见网页设计作业题材有 个人、 美食、 公司、 学校、 旅游、 电商、 宠物、 电器、 茶叶、 家居、 酒店、 舞蹈、 动漫、 服装、 体育、 化妆品、 物流、 环保、 书籍、 婚纱、 游戏、 节日、 戒烟、 电影、 摄影、 文化、 家乡、 鲜花、 礼品、 汽车、 其他等网页设计题目, A…

SPC5777CDK3MMO4 IC MCU 32BIT,SPC5777CDK3MME3

MPC5777C Power Architecture 微控制器是一款高性能多核MCU,优化用于要求先进性能、计时系统、安全性和功能性安全能力的工业和汽车控制应用。MPC5777C设有两个独立的Power Architecture z7内核(运行速度高达300MHz)以及一个z7内核&#xff0…

搜索技术——盲目与启发

如果有兴趣了解更多相关内容,欢迎来我的个人网站看看:瞳孔空间 搜索是人工智能中的一个基本问题,并与推理密切相关。搜索策略的优劣将直接影响到智能系统的性能与推理效率。 一:搜索的基本概念 搜索:根据问题的实际…

Linux openvino 环境搭建遇见的问题

1.编译openvino源码,报错(PythonLibsNew) 通过报错路径结合cmakeLists.txt发现,有个文件夹内容为空导致的,因此需要单独下载对应的文件(这个文件夹藏的比较深,之前没有注意到,只关注openvino/thridparty下&…

(附源码)计算机毕业设计JavaJava毕设项目财务管理系统的设计与实现

项目运行 环境配置: Jdk1.8 Tomcat8.5 Mysql HBuilderX(Webstorm也行) Eclispe(IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持)。 项目技术: Springboot mybatis Maven Vue 等等组成,B/…

膜前氟离子超标的解决方法,除氟离子技术

原水氟化物浓度在150mg/l左右,处理水量大概在30m/h,要求出水氟化物浓度要小于10mg/l,同时呢对出水稳定性方面要求也非常严格。 “预过滤系统离子交换除氟反渗透系统超纯水系统”的工艺,利用季胺1型官能团选择性吸附氟化物&#x…

Nginx负载均衡配置、限流配置、Https配置详解

一. 负载均衡 1. 用法 通过proxy_pass 可以把请求代理至后端服务,但是为了实现更高的负载及性能, 我们的后端服务通常是多个, 这个是时候可以通过upstream 模块实现负载均衡。 使用的模块为:【ngx_http_upstream_module】&#…

股票买卖明细接口是怎样实现查询交易数据的?

股票买卖明细接口作为软件应用而言,很多资源和数据不一定就是由其自身提供的,所以说某些功能还是需要调用第三方提供的服务,这其中就涉及到API接口的调用。也就是说,股票买卖明细接口是与数据端直接挂钩的,通过一些量化…

大数据毕设选题 - 招聘岗位数据分析可视化(python 爬虫)

文章目录1 前言1 课题背景2 实现效果3 项目实现3.1 概述3.2 数据采集3.3 数据清洗与预处理4 数据分析与可视化Flask框架介绍5 最后1 前言 🔥 Hi,大家好,这里是丹成学长的毕设系列文章! 🔥 对毕设有任何疑问都可以问学…

Head First设计模式(阅读笔记)-03.装饰者模式

星巴兹咖啡 咖啡存在许多的种类,同时也有不同的调料。此时用户可以单点咖啡,也可以点咖啡调料,请计算费用(这里咖啡和调料都属于Drink的一类) 简单实现 方案1 每出现一种组合就实现一个类,但是每次增加一个咖啡种类或者一个新的调…

Centos7通过SSH使用密钥实现免密登录

Centos7通过SSH使用密钥实现免密登录 日常开发中,难免会有登录服务器的操作,而通过ssh方式登录无疑是比较方便的一种方式。 如果登录较频繁,使用密钥实现免密登录无疑更是方便中的方便。因此本文就简单说一说如何实现免密登录。一、安装配置ssh服务 默认情况下Centos7是安装…

推荐一款制作精良、功能强大、毫秒级精度的定时任务执行软件

目录 一、定时执行专家 - 功能详细 二、定时执行专家 - 最新版下载 三、定时执行专家 - 更新日志 四、关键字/Keyword 一、定时执行专家 - 功能详细 1、支持多种触发方式(定时方式):倒计时执行、持续执行、键盘鼠标空闲指定时长时执行、…

了解的Java泛型

作者:~小明学编程 文章专栏:JavaSE基础 格言:目之所及皆为回忆,心之所想皆为过往 目录 前言 什么是泛型 为什么要引入泛型 使用泛型 裸类型 泛型类的定义 类型擦除 通配符 什么是通配符 通配符的上下界 通配符的使用 …

Cookie和Session的工作流程以及Servlet中与之相关的API

目录 一、认识Cookie和Session 1、Cookie 2、Session 二、Cookie和Session的工作流程 三、Servlet中与Cookie和Session相关的API 1、HttpServletRequest类中的相关方法 2、HttpServletResponse类中的相关方法 3、HttpSession类中的相关方法 4、Cookie类中的相关方法 …

常用的框架技术-10 Spring Security Spring的企业应用系统提供声明式的安全访问控制解决方案的安全框架

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 文章目录1.Spring Security简介1.1 Spring Security概述1.2 Spring Security历史发展1.3 产品的对比1.3.1 Spring Security1.3.2 Shiro1.4 Spring Security 核心类1.4.1 Auth…

既然有了ES,为何还用ClickHouse——从原理万字总结ClickHouse为何这么快

通过了解 CH 的几大特性了解千亿级企业 ClickHouse 实时处理引擎架构设计、核心技术设计、运行机理全流程。 文章目录1 初始 ClickHouse1.1 什么是 ClickHouse1.2 ClickHouse 的优缺点1.3 谁在用 ClickHouse3 数据引擎3.1 库引擎3.2 表引擎3.3 MergeTree 引擎4 工作原理4.1 数据…

浙大MBA经验分享:在工作生活的缝隙中奋勇上岸

非常高兴可以为大家分享我的浙大MBA备考经验!首先针对我的背景简要介绍一下,我本科毕业于省内的普通大学浙江理工大学,学的是设计专业,就业于一家外企公司。在2022年的联考中获得了综合133,英语75,总分是20…