• 基于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

  • 相关阅读:
    Ompal138+Spartan-6 FPGA开发板硬件数据手册说明书(下)
    Angular异步数据流编程
    iPhone15手机拓展坞方案,支持手机快充+传输数据功能
    JWT 详解,当前主流java token 框架之一
    hdfs笔记
    【python笔记】第十一节 生成器和迭代器
    1.什么是Angular?
    git 命令行回退版本
    ES索引误删的名场面
    【Java 进阶篇】Java Session 原理及快速入门
  • 原文地址:https://blog.csdn.net/weixin_44952783/article/details/128014140