文章目录

  • 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查看虚拟机当前内存使用情况

    • 安装需要的工具

      • 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+

  • 安装内核: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秒时间让用户选择进入哪个内核:

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

    • 在Advanced options for Ubuntu中选择5.11.0+

  • 查看内核选项

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

使用ghOSt用户空间组件

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

    • 在Ubuntu中安装Bazel

      • 这一步会报错,考虑配置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目录下就可以出现相应的可执行文件

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

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

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

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

基于ghOSt用户调度器的环境搭建相关推荐

  1. Samba平台搭建和用户自行修改密码环境搭建笔记

    Samba 平台搭建和用户自行修改密码环境搭建笔记 系统:CentOS  release  6.5 (Final)x86_64 软件: samba                   #服务端 sam ...

  2. 基于QEMU-aarch64学习UEFI(EDK2)-1环境搭建

    基于QEMU-aarch64学习UEFI(EDK2)-1环境搭建 文章目录 基于QEMU-aarch64学习UEFI(EDK2)-1环境搭建 一.环境搭建 1.虚拟机Ubuntu系统安装 2.dock ...

  3. ESP8266基于WIN10+UBUNTU18.04的开发环境搭建(RTOS 3.2)(比较水)

    ESP8266基于WIN10+UBUNTU18.04的开发环境搭建(RTOS v3.2) 软件基础环境参考 硬件环境参考 软件环境安装的详细内容 软件基础环境参考 WIN10家庭版1803的64位版本 ...

  4. pythonapp自动化_基于python的App UI自动化环境搭建

    Android端Ui 自动化环境搭建 一,安装JDK.SDK 二,添加环境变量 Widows: 1.系统变量→新建 JAVA_HOME 变量 E:\Java\jdk1.7.0 jdk安装目录 2.系统 ...

  5. 基于超分辨率重建算法的环境搭建

    文章目录 @[TOC] 1.CUDA 2.Anaconda3 3.cuDNN和Pytorch安装 这里值得注意的是(30系显卡安装Pytorch时): 4.Fluent Terminal 5.Real ...

  6. web应用如何确定能同时允许多少用户连接?_Web测试环境搭建+测试要点汇总

    一.Web测试环境搭建 软硬件包括:电脑一台.JDK1.6.Tomcat7.0.mysql.IE浏览器.Firefox浏览器.Chrome浏览器.SVN客户端 通过SVN客户端导出最新的Web工程部署 ...

  7. 从零开始 Mask RCNN 实战:基于 Win10 + Anaconda 的 Mask RCNN 环境搭建

    大名鼎鼎的 Mask RCNN 一举夺得 ICCV2017 Best Paper,名声大造.Mask RCNN 是何恺明基于以往的 Faster RCNN 架构提出的新的卷积网络,实现高效地检测图中的 ...

  8. 【深度学习】从零开始 Mask RCNN 实战:基于 Win10 + Anaconda 的 Mask RCNN 环境搭建

    大名鼎鼎的 Mask RCNN 一举夺得 ICCV2017 Best Paper,名声大造.Mask RCNN 是何恺明基于以往的 Faster RCNN 架构提出的新的卷积网络,实现高效地检测图中的 ...

  9. 基于 C++ 和 Python 的 OpenCV 环境搭建

    目录 Ⅰ.VS 中基于 C++ 的 OpenCV 环境搭建(编译源码 cmake + opencv 4.2.0 + opencv_contrib 4.2.0) 1-1. 安装 cmake 1-2. 使 ...

最新文章

  1. win10装机 哪个版本最稳定
  2. DCMTK:DIMSE状态代码和类的测试程序
  3. 计算机过程控制系统教材,过程控制系统-样章试读.PDF
  4. P5713 【深基3.例5】洛谷团队系统(python3实现)
  5. (转) RabbitMQ学习之helloword(java)
  6. 虚假和绝望的生命科学
  7. 大多数可穿戴设备的基本原理总结
  8. 使用Guava retryer优雅的实现接口重试机制
  9. Mego(05) - Mego Tools使用教程
  10. cnsul linux环境后台启动_Linux环境下批量启动、停止或重启jar服务的shell脚本
  11. Flink 生态:一个案例快速上手 PyFlink
  12. 句子匹配 无监督_在无监督的情况下创建可解释的句子表示形式
  13. c语言源程序最多可能由组成,一个c语言源程序是由什么组成_后端开发
  14. win2008使用windows loader激活提示Unsupported partition table
  15. MySQL更新时间的时候生成随机时间
  16. 【前端监控系统】埋点数据上报的3种方式
  17. VS2017中配置QT5.12开发环境
  18. 计算机应用基础第1版前言,《计算机应用基础课件》前言
  19. 在ubuntu安装pycharm及之后要做的事
  20. Python 基础知识整理-1

热门文章

  1. html5画图作品,10款最佳HTML5绘图工具
  2. 小波分解处理非平稳时序数据(降噪)
  3. 正则匹配-URL-域名
  4. 解决virtual下安装的fedora虚拟机和本地互相ping以及访问的问题
  5. android+点九图片+教程,史上最详细的android的点9(.9)图片制作教程,菜鸟看完也保证可以学会...
  6. 电脑故障维修大全 [3]
  7. MAX1480B中文数据手册
  8. 最新斩获2022字节暑期实习生 一二三面(已过|新鲜面经)
  9. 文本自动换行样式word-break: break-all
  10. python--计数算法