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

云时代【4】—— 资源隔离与控制技术

云时代【4】—— 资源隔离与控制技术

  • 二、资源隔离与控制技术
    • (一)NameSpace
      • 1. 基本介绍
      • 2. 相关 Linux 指令
      • 实战1:隔离进程
      • 实战2:隔离文件系统
    • (二)CGroups
      • 1. 基本介绍
      • 2. 相关 Linux 指令
      • 实战1:cgroups 信息查看
      • 实战2:使用 cgroups 对内存进行控制
      • 实战3:使用 cgroups 对 cpu 进行控制

二、资源隔离与控制技术

创建好虚拟机之后,查看 虚拟机 自身的信息

# 该指令是 两个指令的合体
cat /etc/*release*

image.png
image.png

(一)NameSpace

1. 基本介绍

NameSpace 是 Linux 内核用来隔离内核资源的方式。通过 namespace 可以让一些进程只能看到与自己相关的一部分资源,而另外一些进程也只能看到与它们自己相关的资源,这两拨进程根本就感觉不到对方的存在
Linux namespaces 是对全局系统资源的一种封装隔离,使得处于不同 namespace 的 进程拥有独立的全局系统资源,改变一个 namespace 中的系统资源只会影响当前 namespace 里的进程,对其他 namespace 中的进程没有影响。

2. 相关 Linux 指令

(1)dd – 复制文件,根据操作数进行转换和格式化

dd if=/dev/zero of=test.img bs=8k count=1024# /dev/zero 产生连续不断的空白字符流

image.png
image.png

**(2)mkfs – **Make a Linux filesystem.

mkfs -t ext4 ./test.img

image.png

(3)df – 查看文件系统的相关信息
Show information about the file system on which each FILE resides, or all file systems by default.

df

image.png

df -a # -a, --all 查看所有具有 0Bloeks 的文件系统

image.png

df -h # 人类可读的格式

image.png

df -t tmpfs # 列出 tmpfs 类型的文件系统

image.png

df -T # 现实文件系统的形式

image.png

image.png

**(4)unshare – **与父进程进行命名空间的隔离

ll /proc # /proc 是一个虚拟文件系统

image.png

unshare -u /bin/bash # 不共享用户的命名空间hostname testhostname # 通过hostname,可以唯一地标识计算机的位置

image.png

(5)mount – Mount a filesystem
挂载就是:文件的入口

dd if=/dev/zero of=test.img bs=8k count=1024

image.png

mkfs -t ext4 ./test.img# -t 知道文件系统类型

image.png

mount ./test.img /data/testmount

image.png

cd /data/testmymount
echo "hello world" > text.txt
ll -h
cat text.txt

image.png

实战1:隔离进程

**Q1:需要指定子进程 **
当直接 -p 之后 /bin/bash进程 与 父进程完成资源隔离。内部的/bin/bash进程没有自己的父进程,且无法看到外部的父进程,因此报错。

unshare -p /bin/bash

image.png

Q2:当执行ps -ef时发现 PID 依然可以查看到。原因是:**ll /proc**** 下有全部的进程,因此需要提前把 **/proc** 挂载过去**

unshare -p --fork /bin/bash

image.png

unshare -p --fork --mount-proc /bin/bash
ls -l /proc

image.png

ps -ef # ps 是“process status”的缩写,它用于显示当前系统上运行的进程的状态信息。
# -e参数表示显示所有进程,
# -f参数表示全格式显示。

image.png

实战2:隔离文件系统

mkdir -p /data/mymount

image.png

unshare --mount --fork /bin/bash

image.png

dd if=/dev/zero of=/data.img bs=8k count=10240

image.png

mkfs -t ext4 ./data.img

image.png

df -h

image.png

mount -t ext4 ./data.img /data/mymount

image.png

hostnamedf -h

image.png

(二)CGroups

1. 基本介绍

CGroups(Control Groups)是 linux 内核提供的一种机制,这种机制可以根据需求把一系列系统任务及其子任务整合(或分隔)到按资源划分等级的不同组内,从而为系统资源管理提供统一的框架。简单说,CGroups 可以限制、记录任务组所使用的物理资源。本质上来说,cgroups 是内核附加在程序上的一系列钩子(hook),通过程序运行时对资源的调度触发相应的钩子以达到资源追踪和限制的目的。

2. 相关 Linux 指令

**(1)pidstat – **查看各种资源信息

pidstat -u # 显示各个进程CPU使用情况(-u 为默认参数)

image.png

pidstat -r # 现实各进程的内存使用情况

image.png

pidstat -d # 显示各进程的 IO 使用情况

image.png

pidtest -p 1480 # 显示该进程号的资源使用情况

image.png

pidtstat -p 1480pidstat -r -p 1480pidstat -d -p 1480

image.png

image.png

**(2)stress – **压力工具

stress -c 1 # 产生N个进程,每个进程循环调用 sqrt函数 产生CPU压力

image.png

stress -i 1 # 产生N个进程,每个进程循环调用sync将内存缓冲区内容写到磁盘上,产生IO压力。
# 通过系统调用sync刷新内存缓冲区数据到磁盘中,以确保同步。
# 如果缓冲区内数据较少,写到磁盘中的数据也较少,不会产生IO压力。
# 在SSD磁盘环境中尤为明显,很可能iowait总是0,却因为大量调用系统调用sync,导致系统CPU使用率sys升高。

image.png

stress -m 1 --vm-bytes 50m
# -m : 产生N个进程,每个进程循环调用malloc/free函数分配和释放内存。
# --vm-bytes B : 指定分配内存的大小

image.png

stress -d 1 # N:产生N个不断执行write和unlink函数的进程(创建文件,写入内容,删除文件)

image.png

stress -d 1 -t 3
# -t : 在N秒后结束程序
stress -d 1 -t 3 -q
# -q : 程序在运行的过程中不输出信息

image.png

实战1:cgroups 信息查看

cat /proc/filesystems | cg

image.png

cat /proc/cgroups

image.png

mount | grep cgroupll /sys/fs/cgroup/cpu,cpuacct

image.png

查看一个进程上的 cgroup 限制

# $$ 代表当前进程的PID
cat /proc/$$/cgroup mount | grep cgroup# 控制组下的cpu文件 /sys/fs/cgroup/cpu,cpuacct
# 具体进程的cpu控制文件位置 /user.slice
ll /sys/fs/cgroup/cpu,cpuacct/user.slice

image.png
image.png

实战2:使用 cgroups 对内存进行控制

mount | grep cgroupscd /sys/fs/cgroup/memoryll

image.png

mkdir test-memlimitcd /test-memlimitls -l # 自动将配置信息初始化好

image.png

echo "20971520" > memory.limit_in_bytescat memory.limit_in_bytes

image.png

stress -m 1 --vm-bytes 50m

image.png

pidstat -C stress -P ALL -r 2 100000

image.png

echo "xxxx" > tasks

实战3:使用 cgroups 对 cpu 进行控制

cd /sys/fs/cgroup/cpu,cpuacctmkdir test-cpulimitll

image.png

stress -c 1

image.png

pidstat -u -C stress -p ALL 1 100000

image.png

cat cpu.cfs_period_uscat cpu.cfs_quota_usecho "20000" > cpu.cfs_quota_uscat cpu.cfs_quota_us

image.png

echo "xxxxx" > tasks

image.png
image.png

相关文章:

  • 原码,反码,补码
  • 嵌入式烧录报错:板端IP与PC的IP相同
  • STM32控制max30102读取血氧心率数据(keil5工程)
  • js实现文件下载,并传给后端
  • Linux 软链接与硬链接
  • 【MySQL】_自连接与子查询
  • 小项目——学校宿舍楼系统
  • Nest.js权限管理系统开发(二)连接MySQL、Redis
  • Uniapp在IOS系统打包测试流程
  • leetcode 重复的子字符串
  • android开发电子书,android基础编程
  • 服务器数据恢复-服务器RAID5上层XFS文件系统分区数据恢复案例
  • 【vue+element ui】大屏自适应中el-select下拉内容在低分辨率下显示不全问题解决
  • ad18学习笔记十六:如何放置精准焊盘到特定位置,捕抓功能的讲解
  • 如何用golang写一个自己的后端框架
  • [译] 怎样写一个基础的编译器
  • 《Javascript数据结构和算法》笔记-「字典和散列表」
  • 0基础学习移动端适配
  • C语言笔记(第一章:C语言编程)
  • isset在php5.6-和php7.0+的一些差异
  • Java反射-动态类加载和重新加载
  • Java深入 - 深入理解Java集合
  • 初探 Vue 生命周期和钩子函数
  • 分布式事物理论与实践
  • 聚簇索引和非聚簇索引
  • 聊聊hikari连接池的leakDetectionThreshold
  • 容器服务kubernetes弹性伸缩高级用法
  • 要让cordova项目适配iphoneX + ios11.4,总共要几步?三步
  • 异常机制详解
  • 最简单的无缝轮播
  • RDS-Mysql 物理备份恢复到本地数据库上
  • 仓管云——企业云erp功能有哪些?
  • ​LeetCode解法汇总518. 零钱兑换 II
  • ​MPV,汽车产品里一个特殊品类的进化过程
  • # 20155222 2016-2017-2 《Java程序设计》第5周学习总结
  • #1015 : KMP算法
  • #Z2294. 打印树的直径
  • (4)STL算法之比较
  • (LNMP) How To Install Linux, nginx, MySQL, PHP
  • (MATLAB)第五章-矩阵运算
  • (第9篇)大数据的的超级应用——数据挖掘-推荐系统
  • (附源码)ssm基于jsp高校选课系统 毕业设计 291627
  • (十一)c52学习之旅-动态数码管
  • (转) ns2/nam与nam实现相关的文件
  • (转载)从 Java 代码到 Java 堆
  • (自适应手机端)响应式新闻博客知识类pbootcms网站模板 自媒体运营博客网站源码下载
  • .axf 转化 .bin文件 的方法
  • .net 中viewstate的原理和使用
  • .Net开发笔记(二十)创建一个需要授权的第三方组件
  • .NET连接数据库方式
  • /ThinkPHP/Library/Think/Storage/Driver/File.class.php  LINE: 48
  • @ModelAttribute 注解
  • [C#]winform利用seetaface6实现C#人脸检测活体检测口罩检测年龄预测性别判断眼睛状态检测
  • [CareerCup][Google Interview] 实现一个具有get_min的Queue
  • [ffmpeg] aac 音频编码