长期支持版本

    混部隔离示例

    环境准备

    查看内核是否支持混部隔离功能

    # 查看/boot/config-<kernel version>系统配置是否开启混部隔离功能
    # 若CONFIG_QOS_SCHED=y则说明使能了混部隔离功能,例如:
    cat /boot/config-5.10.0-60.18.0.50.oe2203.x86_64 | grep CONFIG_QOS
    CONFIG_QOS_SCHED=y
    

    安装docker容器引擎

    yum install -y docker-engine
    docker version
    # 如下为docker version显示结果
    Client:
     Version:           18.09.0
     EulerVersion:      18.09.0.300
     API version:       1.39
     Go version:        go1.17.3
     Git commit:        aa1eee8
     Built:             Wed Mar 30 05:07:38 2022
     OS/Arch:           linux/amd64
     Experimental:      false
    
    Server:
     Engine:
      Version:          18.09.0
      EulerVersion:     18.09.0.300
      API version:      1.39 (minimum version 1.12)
      Go version:       go1.17.3
      Git commit:       aa1eee8
      Built:            Tue Mar 22 00:00:00 2022
      OS/Arch:          linux/amd64
      Experimental:     false
    

    混部业务

    在线业务(clickhouse)

    使用clickhouse-benchmark测试工具进行性能测试,统计出QPS/P50/P90/P99等相关性能指标,用法参考:https://clickhouse.com/docs/zh/operations/utilities/clickhouse-benchmark/

    离线业务(stress)

    stress是一个CPU密集型测试工具,可以通过指定--cpu参数启动多个并发CPU密集型任务给系统环境加压。

    使用说明

    1)启动一个clickhouse容器(在线业务)。

    2)进入容器内执行clickhouse-benchmark命令,设置并发线程数为10个、查询10000次、查询总时间30s。

    3)同时启动一个stress容器(离线业务),并发执行10个CPU密集型任务对环境进行加压。

    4)clickhouse-benchmark执行完后输出一个性能测试报告。

    混部隔离测试脚本(test_demo.sh)如下:

    #!/bin/bash
    
    with_offline=${1:-no_offline}
    enable_isolation=${2:-no_isolation}
    stress_num=${3:-10}
    concurrency=10
    timeout=30
    output=/tmp/result.json
    online_container=
    offline_container=
    
    exec_sql="echo \"SELECT * FROM system.numbers LIMIT 10000000 OFFSET 10000000\" | clickhouse-benchmark -i 10000 -c $concurrency -t $timeout"
    
    function prepare()
    {
        echo "Launch clickhouse container."
        online_container=$(docker run -itd \
                -v /tmp:/tmp:rw \
                --ulimit nofile=262144:262144 \
                -p 34424:34424 \
                yandex/clickhouse-server)
    
        sleep 3
        echo "Clickhouse container lauched."
    }
    
    function clickhouse()
    {
        echo "Start clickhouse benchmark test."
        docker exec $online_container bash -c "$exec_sql --json $output"
        echo "Clickhouse benchmark test done."
    }
    
    function stress()
    {
        echo "Launch stress container."
        offline_container=$(docker run -itd joedval/stress --cpu $stress_num)
        echo "Stress container launched."
    
        if [ $enable_isolation == "enable_isolation" ]; then
            echo "Set stress container qos level to -1."
            echo -1 > /sys/fs/cgroup/cpu/docker/$offline_container/cpu.qos_level
        fi
    }
    
    function benchmark()
    {
        if [ $with_offline == "with_offline" ]; then
        	stress
        	sleep 3
    	fi
        clickhouse
        echo "Remove test containers."
        docker rm -f $online_container
        docker rm -f $offline_container
        echo "Finish benchmark test for clickhouse(online) and stress(offline) colocation."
        echo "===============================clickhouse benchmark=================================================="
        cat $output
        echo "===============================clickhouse benchmark=================================================="
    }
    
    prepare
    benchmark
    

    测试结果

    单独执行clickhouse在线业务

    sh test_demo.sh no_offline no_isolation
    

    得到在线业务的QoS(QPS/P50/P90/P99等指标)基线数据如下:

    {
    "localhost:9000": {
    "statistics": {
    "QPS": 1.8853412284364512,
    ......
    },
    "query_time_percentiles": {
    ......
    "50": 0.484905256,
    "60": 0.519641313,
    "70": 0.570876148,
    "80": 0.632544937,
    "90": 0.728295525,
    "95": 0.808700418,
    "99": 0.873945121,
    ......
    }
    }
    }
    

    启用stress离线业务,未开启混部隔离功能下,执行test_demo.sh测试脚本

    # with_offline参数表示启用stress离线业务
    # no_isolation参数表示未开启混部隔离功能
    sh test_demo.sh with_offline no_isolation
    

    未开启混部隔离的情况下,clickhouse业务QoS数据(QPS/P80/P90/P99等指标)如下:

    {
    "localhost:9000": {
    "statistics": {
    "QPS": 0.9424028693636205,
    ......
    },
    "query_time_percentiles": {
    ......
    "50": 0.840476774,
    "60": 1.304607373,
    "70": 1.393591017,
    "80": 1.41277543,
    "90": 1.430316688,
    "95": 1.457534764,
    "99": 1.555646855,
    ......
    }
    }
    

    启用stress离线业务,开启混部隔离功能下,执行test_demo.sh测试脚本

    # with_offline参数表示启用stress离线业务
    # enable_isolation参数表示开启混部隔离功能
    sh test_demo.sh with_offline enable_isolation
    

    开启混部隔离功能的情况下,clickhouse业务QoS数据(QPS/P80/P90/P99等指标)如下:

    {
    "localhost:9000": {
    "statistics": {
    "QPS": 1.8825798759270718,
    ......
    },
    "query_time_percentiles": {
    ......
    "50": 0.485725185,
    "60": 0.512629901,
    "70": 0.55656488,
    "80": 0.636395956,
    "90": 0.734695906,
    "95": 0.804118275,
    "99": 0.887807409,
    ......
    }
    }
    }
    

    从上面的测试结果整理出一个表格如下:

    业务部署方式QPSP50P90P99
    单独运行clickhouse在线业务(基线)1.8850.4850.7280.874
    clickhouse+stress(未开启混部隔离功能)0.942(-50%)0.840(-42%)1.430(-49%)1.556(-44%)
    clickhouse+stress(开启混部隔离功能)1.883(-0.11%)0.486(-0.21%)0.735(-0.96%)0.888(-1.58%)

    在未开启混部隔离功能的情况下,在线业务clickhouse的QPS从1.9下降到0.9,同时业务的响应时延(P90)也从0.7s增大到1.4s,在线业务QoS下降了50%左右;而在开启混部隔离功能的情况下,不管是在线业务的QPS还是响应时延(P50/P90/P99)相比于基线值下降不到2%,在线业务QoS基本没有变化。

    文档捉虫

    “有虫”文档片段

    问题描述

    提交类型 issue

    有点复杂...

    找人问问吧。

    PR

    小问题,全程线上修改...

    一键搞定!

    问题类型
    规范和低错类

    ● 错别字或拼写错误;标点符号使用错误;

    ● 链接错误、空单元格、格式错误;

    ● 英文中包含中文字符;

    ● 界面和描述不一致,但不影响操作;

    ● 表述不通顺,但不影响理解;

    ● 版本号不匹配:如软件包名称、界面版本号;

    易用性

    ● 关键步骤错误或缺失,无法指导用户完成任务;

    ● 缺少必要的前提条件、注意事项等;

    ● 图形、表格、文字等晦涩难懂;

    ● 逻辑不清晰,该分类、分项、分步骤的没有给出;

    正确性

    ● 技术原理、功能、规格等描述和软件不一致,存在错误;

    ● 原理图、架构图等存在错误;

    ● 命令、命令参数等错误;

    ● 代码片段错误;

    ● 命令无法完成对应功能;

    ● 界面错误,无法指导操作;

    风险提示

    ● 对重要数据或系统存在风险的操作,缺少安全提示;

    内容合规

    ● 违反法律法规,涉及政治、领土主权等敏感词;

    ● 内容侵权;

    您对文档的总体满意度

    非常不满意
    非常满意
    提交
    根据您的反馈,会自动生成issue模板。您只需点击按钮,创建issue即可。
    文档捉虫
    编组 3备份