空闲磁盘调度;该调度策略是在当前系统没有其他进程需要进行磁盘IO时,才能进行磁盘;因此该策略对当前系统的影响基本为0;当然,该调度策略不能带有任何优先级参数;
是缺省的磁盘IO调度策略;
(1)该调度策略可以指定优先级参数(范围是0~7,数值越小,优先级越高);
(2)针对处于同一优先级的程序将采round-robin方式;
(3)对于best effort调度策略,8个优先级等级可以说明在给定的一个调度窗口中时间片的大小;
(4)目前,普调用户(非root用户)是可以使用该调度策略;
(5)在内核2.6.26之前,没有设置IO优先级的进程会使用“none”作为调度策略,但是这种策略使得进程看起来像是采用了best effort调度策略,因为其优先级是通过关于 cpu nice有关的公式计算得到的:io_priority = (cpu_nice + 20) /5
(6)在内核2.6.26之后,如果当前系统使用的是CFQ调度器,那么如果进程没有设置IO优先级级别,将采用与内核2.6.26之前版本同样的方式,推到出io优先级级别;
实时调度策略,如果设置了该磁盘IO调度策略,则立即访问磁盘,不管系统中其他进程是否有IO。因此使用实时调度策略,需要注意的是,该访问策略可能会使得其他进程处于等待状态;
[root@docker][19:43:12][OK] ~
#yum provides */ionice
Loaded plugins: fastestmirror
Loading mirror speeds from cached hostfile* base: mirrors.aliyun.com* epel: mirror.01link.hk* extras: mirrors.aliyun.com* updates: mirrors.aliyun.com
epel/x86_64/filelists_db | 12 MB 00:00:08
extras/7/x86_64/filelists_db | 276 kB 00:00:01
updates/7/x86_64/filelists_db | 10 MB 00:00:42
util-linux-2.23.2-65.el7.i686 : A collection of basic system utilities
Repo : base
Matched from:
Filename : /usr/bin/ionice
Filename : /usr/share/bash-completion/completions/ioniceutil-linux-2.23.2-65.el7.x86_64 : A collection of basic system utilities
Repo : base
Matched from:
Filename : /usr/bin/ionice
Filename : /usr/share/bash-completion/completions/ioniceutil-linux-2.23.2-65.el7_9.1.i686 : A collection of basic system utilities
Repo : updates
Matched from:
Filename : /usr/bin/ionice
Filename : /usr/share/bash-completion/completions/ioniceutil-linux-2.23.2-65.el7_9.1.x86_64 : A collection of basic system utilities
Repo : updates
Matched from:
Filename : /usr/bin/ionice
Filename : /usr/share/bash-completion/completions/ioniceutil-linux-2.23.2-65.el7.x86_64 : A collection of basic system utilities
Repo : @anaconda
Matched from:
Filename : /usr/bin/ionice
Filename : /usr/share/bash-completion/completions/ionice
安装
yum install util-linux-2.23.2-65.el7_9.1.x86_64 -y
[root@docker][19:35:01][OK] ~
#ionice --helpionice - sets or gets process io scheduling class and priority.Usage:ionice [OPTION] -p PID [PID...]ionice [OPTION] COMMANDOptions:-c, --class scheduling class name or number0: none, 1: realtime, 2: best-effort, 3: idle-n, --classdata scheduling class data0-7 for realtime and best-effort classes-p, --pid=PID view or modify already running process-t, --ignore ignore failures-V, --version output version information and exit-h, --help display this help and exit
—- Deleting Huge Files in Linux —–
# ionice -c 3 rm /var/logs/syslog
# ionice -c 3 rm -rf /var/log/apache
注意:要使用安全的方法删除大档案,我们可以使 shred、wipe 以及 secure-deletion 工具包中的不同工具,而不是 rm 命令。
yum install coreutils-8.22-24.el7_9.2.x86_64 -y
[root@192_168_209_128 ~]# shred --help
Usage: shred [OPTION]... FILE...
Overwrite the specified FILE(s) repeatedly, in order to make it harder
for even very expensive hardware probing to recover the data.
Mandatory arguments to long options are mandatory for short options too.-f, --force change permissions to allow writing if necessary-n, --iterations=N overwrite N times instead of the default (3)--random-source=FILE get random bytes from FILE-s, --size=N shred this many bytes (suffixes like K, M, G accepted)-u, --remove[=HOW] truncate and remove file after overwriting; See below-v, --verbose show progress-x, --exact do not round file sizes up to the next full block;this is the default for non-regular files-z, --zero add a final overwrite with zeros to hide shredding--help display this help and exit--version output version information and exit
选项说明:
- -z- 添加一个带有零的最终覆盖以隐藏切碎。
- -v– 可以显示操作进度。
- -u- 覆盖后截断和删除文件。
- -n– 指定覆盖文件内容的次数(默认为 3)。
shred覆盖文件以隐藏其内容,也可以选择删除它。
[root@docker][19:51:03][OK] ~
#shred -zvu -n 5 cuttingLog_bak
shred: cuttingLog_bak: pass 1/6 (random)...
shred: cuttingLog_bak: pass 2/6 (ffffff)...
shred: cuttingLog_bak: pass 3/6 (random)...
shred: cuttingLog_bak: pass 4/6 (000000)...
shred: cuttingLog_bak: pass 5/6 (random)...
shred: cuttingLog_bak: pass 6/6 (000000)...
shred: cuttingLog_bak: removing
shred: cuttingLog_bak: renamed to 00000000000000
shred: 00000000000000: renamed to 0000000000000
shred: 0000000000000: renamed to 000000000000
shred: 000000000000: renamed to 00000000000
shred: 00000000000: renamed to 0000000000
shred: 0000000000: renamed to 000000000
shred: 000000000: renamed to 00000000
shred: 00000000: renamed to 0000000
shred: 0000000: renamed to 000000
shred: 000000: renamed to 00000
shred: 00000: renamed to 0000
shred: 0000: renamed to 000
shred: 000: renamed to 00
shred: 00: renamed to 0
shred: cuttingLog_bak: removed
介绍:Linux wipe命令可以安全地从磁存储器中擦除文件,从而无法恢复。
rpm -ivh wipe-2.2.0-1.2.el7.rf.x86_64.rpm
[root@docker][19:58:11][OK] ~
#wipe -h
Wipe v2.2.0 - released January 10, 2004
by Tom Vier Usage is wipe [options] [file-list]Options: Default: wipe -ZdntVAkO -S512 -C4096 -l1 -x8 -p1-h -- help - display this screen
-u -- usage
-c -- show copyright and license
-w -- show warranty information
-i and -I -- enable (-i) or disable (-I) interaction - overrides force
-f -- force file wiping and override interaction
-r and -R -- recursion - traverse subdirectories
-s -- silent - disable percentage and error reporting
-v -- force verbose - always show percentage
-V -- verbose - show percentage if file is >= 25K
-d and -D -- delete (-d) or keep (-D) after wiping
-n and -N -- delete (-n) or skip (-N) special files
-k and -K -- lock (-k) or don't lock (-K) files
-z -- zero-out file - single pass of zeroes
-Z -- perform normal wipe passes
-t and -T -- enable (-t) or disable (-T) static passes
-a and -A -- write until out of space (-a) or don't (-A)
-o[size] -O -- write to stdout (-o) or use files (-O)
-B(count) -- block device sector count
-S(size) -- block device sector size - default 512 bytesor stdout write length when used with -A
-C(size) -- chunk size - maximum file buffer size in kilobytes (2^10)
-l[0-2] -- sets wipe secure level
-x[1-32] -X -- sets number of random passes per wipe or disables
-p(1-32) -- wipe file x number of times
-b(0-255) -- overwrite file with this value byte
[root@docker][19:59:50][OK] ~
#wipe -fi cuttingLog_bak
wipe: destroy file `cuttingLog_bak'? y
Secure-delete是一个安全文件删除工具的集合,其中包含srm (secure_deletion) 工具,用于安全删除文件。
yum -y install srm-1.2.15-1.el7.x86_64
[root@docker][20:05:39][OK] ~
#srm --help
Usage: srm [OPTION]... [FILE]...
Overwrite and remove (unlink) the files. By default use the 35-pass Gutmann
method to overwrite files.-d, --directory ignored (for compatability with rm(1))-f, --force ignore nonexistant files, never prompt-i, --interactive prompt before any removal-x, --one-file-system do not cross file system boundaries-s, --simple overwrite with single pass using 0x00 (default)-P, --openbsd overwrite with three passes like OpenBSD rm-D, --dod overwrite with 7 US DoD compliant passes-E, --doe overwrite with 3 US DoE compliant passes-G, --gutmann overwrite with 35-pass Gutmann method-C, --rcmp overwrite with Royal Canadian Mounted Police passes-r, -R, --recursive remove the contents of directories-v, --verbose explain what is being done-h, --help display this help and exit-V, --version display version information and exit
#srm -vf cuttingLog_bal
srm: removing cuttingLog_bal