ืืืื ืื ืื ื ืจืืฆืื ืืืืจ ืขื ืืื ืืืขืืืื ืื ืืืืจืื ืื ืืืขืจืืช ืฉืจืืืง [ืืื ืืฉืืื ืืขื ืืืฆืืขืื ืืืืืื ืืืื ืืืจืกืืืช ืกืื ืคืืจื - ืืขืจื. trans.], ืื ืฉืืืืฅ ืืฉืืขืืชืืช ืืช ืจืืฉืื ืืงืืฆืื ืืกืคืจืืืช ืขื ืืกืคืจ ืจื ืฉื ืขืจืืื.
ืื ืืืื ืืืืืจืื ืจืืืืื, ืื ืืืชืจ ืืืืื ืฉื ืืืคื ืื ืขื ืืืืคื ืฉืื ืื ื ืขืืืืื ืืืืคื ืงืืืข ืขื ืฉืจืืืง ืืื ืืฉืืืจ ืขืืื ืืคืขืื ืืืืืื ืขืืืจ ืืืฉืชืืฉืื ืฉืื ื. ืื ื ืืงืืืื ืืคืจืกื ืืืืจืื ื ืืกืคืื ืืื ืื ืืขืชืื.
ืจืืฉืื ืงืืฆืื ืจืืื ืืืงื ืืื
ืืื ืืชืืื ืืฉืืืช ืชืืืื ืืื ืืช ืฉื ืืฉืชืืฉ. ืืื ืืืืื ืขื ืืืขืื ืฉืืืืฆืื ืืืืจื ls
ืืืงื ืืื ืืงืืช ืืกืคืจืืื ืขื ืืืขืื ื-15 ืขืจืืื $SCRATCH
[ืกืคืจืืื ืืงืืฆืื ืืื ืืื - ื. ื ืชืื].
ืืืคื ืงืืฆืื ืืกืคืจืืื ืืืช ืืืืืื ืืืจื ืืื ืขืืืก ืขื ืืขืจืืช ืืงืืฆืื ืืืืืื ืื ืืืืืฅ. ืืืฉืชืืฉ ืืืข ืืืช ืืืืื ืฉืื ืื ืืื, ืืื ืฆืืื ืฉืืจืืฉืื ืืืืจ ืคื 1000 ืืืืฉื ืื ืืื ืฉืื ืืืฉืจ ืฉืจืืืง. ืืืืื ืฉืื ืคืืข ืื ื. ืื ืืกืชืืื ื ืืขืืืง.
ืื ืื ื ืจืื ื ืืื
ืืืงื ื ืื ืื ืขืืฉื ืืคืืขื ls
ืืขืช ืจืืฉืื ืกืคืจืืื, ืืืืืข ืืชืืืื ืืืงื ืื ืื ืืจืื ืืื. ืืจืื ืืืคืฆืืช ืืืืืจื ืืืช ls
ืืืจืืจืช ืืืื ืืื ืคืืขื ื ls --color=auto
, ืื ืืืื ืืืืืื ืืช ืืฆืืขืื.
ืืื ืืฆืืขืื ืืคืื ืืฉ ืืืืจ: ืืื ืงืืืฅ ls
ืืืื ืืงืื ืืืืข ืขื ืกืื ืืงืืืฅ, ืืจืฉืืืชืื, ืืืืื, ืชืืื ืืช ืืืจืืืืช ืืืืืื ืขื ืื ืช ืืืืืจ ืืช ืืฆืืข ืืืชืืื.
ืคืชืจืื ืคืฉืื ืืื ืืืขืื ืืื ืืืฉืืืช ืืช ืืฆืืข ื-ls ืืืืืืื, ืืื ืชืืจื ืืขืฆืืื ืืช ืืืขื ืฉื ืืืฉืชืืฉืื. ืืฉืื ืคื ืื ืืืืคื ืืกืืจ ืืงืืช ืืช ืคืื ืืฆืืข, ืื ืื ื ืื ืืคืืฆืืช.
ืื ืืกืชืืื ื ืืขืืืง. ls
ืขืจืืื ืฉื ืฆืืขืื ืืืืฆืขืืช ืืฉืชื ื ืกืืืื LS_COLORS
, ืืฉืจ ื ืงืืข dircolors(1)
ืืืืกืก ืขื ืงืืืฅ ืชืฆืืจื dir_colors(5)
... ืื,
ืืืื ื ืกืชืื ืืงืจืื
ืืื ืืงืืืข ืืืื ืขืจืืช ืฆืืขืื ืืืจืืช ืืืืื, ืืฆืจื ื ืกืืืืช ื ืืกืื:
$ mkdir $SCRATCH/dont
$ touch $SCRATCH/dont/{1..10000} # don't try this at home!
$ time ls --color=always $SCRATCH/dont | wc -l
10000
real 0m12.758s
user 0m0.104s
sys 0m0.699s
12,7 ืฉื ืืืช ืขืืืจ 10 ืงืืฆืื, ืื ืืื ืืืืืื.
ืืจื ืืื, ืื ืื ื ืฆืจืืืื ืืื
--color=always
: ืืืจืืช ืฉืืื ืคืื ื ืls --color=auto
ืืืls
ืืืื ืืืฉืจ ืืื ืืื ื ืืืืืจ ืืืกืืฃ (ืืืฉื ืืืืฆืขืืช ืฆืื ืืจ ืื ืขื ื ืืชืื ืืืืฉ ืฉื ืคืื) ืืืฉืืืช ืืช ืืฆืืืขื ืื ืืืืืจ ื-auto
. ืืืืจ ืืื.
ืื ืื ืืืงื ืื ืื ืืจืื ืืื? ืืกืชืืื ื ืขื strace
:
$ strace -c ls --color=always $SCRATCH/dont | wc -l
10000
% time seconds usecs/call calls errors syscall
------ ----------- ----------- --------- --------- ----------------
44.21 0.186617 19 10000 lstat
42.60 0.179807 18 10000 10000 getxattr
12.19 0.051438 5 10000 capget
0.71 0.003002 38 80 getdents
0.07 0.000305 10 30 mmap
0.05 0.000217 12 18 mprotect
0.03 0.000135 14 10 read
0.03 0.000123 11 11 open
0.02 0.000082 6 14 close
[...]
ืืืื: 10 ืฉืืืืช lstat()
, 10 ืฉืืืืช getxattr()
(ืฉืืืื ื ืืฉืืื ืื ืืกืืืื ืฉืื ื ืืื ืืช ืืชืืื ืืช ืฉืื ื ืืืคืฉ), 10 ืฉืืืืช capget()
.
ืืื ืกืคืง ืฉืืคืฉืจ ืืืืขื ืืช ืื.
ืชืืื ืช ืืืืืืช? ืื
ืืขืงืืืช ืขืฆืืช
$ eval $(dircolors -b | sed s/ca=[^:]*:/ca=:/)
$ time strace -c ls --color=always $SCRATCH/dont | wc -l
10000
% time seconds usecs/call calls errors syscall
------ ----------- ----------- --------- --------- ----------------
98.95 0.423443 42 10000 lstat
0.78 0.003353 42 80 getdents
0.04 0.000188 10 18 mprotect
0.04 0.000181 6 30 mmap
0.02 0.000085 9 10 read
0.02 0.000084 28 3 mremap
0.02 0.000077 7 11 open
0.02 0.000066 5 14 close
[...]
------ ----------- ----------- --------- --------- ----------------
100.00 0.427920 10221 6 total
real 0m8.160s
user 0m0.115s
sys 0m0.961s
ืืืื, ืขื 8 ืฉื ืืืช ืฉื ืืืฆื! ื ืคืืจื ื ืืื ืืฉืืืืช ืืืงืจืืช ืืืื getxattr()
, ืืืชืืจืื capget()
ืื ื ืขืื, ื ืืืจ.
ืืื ืขืืืื ืืฉ ืืช ืืฉืืืืช ืืืขืฆืื ืืช ืืืื lstat()
, ืืืจืืช ืฉโฆ
ืืื ืคืจืืื ืืชื ืฆืจืื?
ืืื, ืืืงื ื ืืงืจืื LS_COLORS
.
ืจืืฉืืช ืคืฉืื ืืฉืืชื ื ืืช ืืืฉืชื ื ืืื:
$ echo $LS_COLORS rs=0:di=01;34:ln=01;36:mh=00:pi=40;33:so=01;35:do=01;35:bd=40;33;01:cd=40;33;01:or=40;31;01:su=37;41:sg=30;43:ca=:tw=30;42:ow=34;42:st=37;44:ex=01;32:*.tar=01;31:*.tgz=01;31:*.arc=01;31:*.arj=01;31:*.taz=01;31:*.lha=01;31:*.lz4=01;31:*.lzh=01;31:*.lzma=01;31:*.tlz=01;31:*.txz=01;31:*.tzo=01;31:*.t7z=01;31:*.zip=01;31:*.z=01;31:*.Z=01;31:*.dz=01;31:*.gz=01;31:*.lrz=01;31:*.lz=01;31:*.lzo=01;31:*.xz=01;31:*.bz2=01;31:*.bz=01;31:*.tbz=01;31:*.tbz2=01;31:*.tz=01;31:*.deb=01;31:*.rpm=01;31:*.jar=01;31:*.war=01;31:*.ear=01;31:*.sar=01;31:*.rar=01;31:*.alz=01;31:*.ace=01;31:*.zoo=01;31:*.cpio=01;31:*.7z=01;31:*.rz=01;31:*.cab=01;31:*.jpg=01;35:*.jpeg=01;35:*.gif=01;35:*.bmp=01;35:*.pbm=01;35:*.pgm=01;35:*.ppm=01;35:*.tga=01;35:*.xbm=01;35:*.xpm=01;35:*.tif=01;35:*.tiff=01;35:*.png=01;35:*.svg=01;35:*.svgz=01;35:*.mng=01;35:*.pcx=01;35:*.mov=01;35:*.mpg=01;35:*.mpeg=01;35:*.m2v=01;35:*.mkv=01;35:*.webm=01;35:*.ogm=01;35:*.mp4=01;35:*.m4v=01;35:*.mp4v=01;35:*.vob=01;35:*.qt=01;35:*.nuv=01;35:*.wmv=01;35:*.asf=01;35:*.rm=01;35:*.rmvb=01;35:*.flc=01;35:*.avi=01;35:*.fli=01;35:*.flv=01;35:*.gl=01;35:*.dl=01;35:*.xcf=01;35:*.xwd=01;35:*.yuv=01;35:*.cgm=01;35:*.emf=01;35:*.axv=01;35:*.anx=01;35:*.ogv=01;35:*.ogx=01;35:*.aac=00;36:*.au=00;36:*.flac=00;36:*.mid=00;36:*.midi=00;36:*.mka=00;36:*.mp3=00;36:*.mpc=00;36:*.ogg=00;36:*.ra=00;36:*.wav=00;36:*.axa=00;36:*.oga=00;36:*.spx=00;36:*.xspf=00;36: $ unset LS_COLORS $ echo $LS_COLORS $ time ls --color=always $SCRATCH/dont | wc -l 10000 real 0m13.037s user 0m0.077s sys 0m1.092s
ืื!?! ืขืืืื 13 ืฉื ืืืช?
ืืกืชืืจ ืฉืืืฉืจ ืืฉืชื ื ืืกืืืื LS_COLORS
ืจืง ืืื ืืืืืื ืืื ืฉืื ืืื ื ืืืืืจ ืื ืืกืจ <type>=color:
, ืืื ืืฉืชืืฉ ืืืกื ืื ืชืื ืื ืืืืื ื ืืืจืืจืช ืืืื ืืขืืืื ืืฉืชืืฉ ืืฆืืขืื. ืื ืื ืืชื ืจืืฆื ืืืฉืืืช ืืช ืืฆืืืขื ืขืืืจ ืกืื ืงืืืฅ ืืกืืื, ืืชื ืฆืจืื ืืขืงืืฃ ืืืชื ืขื <type>=:
ืื <type> 00
ืืงืืืฅ DIR_COLORS
.
ืืืืจ ืืจืื ื ืืกืื ืืืขืืื, ืฆืืฆืื ื ืืช ืืืืคืืฉ ืฉืื ื ืืืื:
EXEC 00
SETUID 00
SETGID 00
CAPABILITY 00
ืฉื ืืชื ื
LS_COLORS='ex=00:su=00:sg=00:ca=00:'
ืื ืืืืจ: ืื ืชืฆืืข ืงืืฆืื ืืคื ืชืืื ื.
, ืื ืื ืขื ืืื
ืื ืื ื ืืืืฆืื ls
ืืื ืืชื ืื ืขืืฉื ืืฃ ืืืช ืืืืืืงืืช ืืืื, ืื ืชืชืงืฉืจ lstat()
ืืืืขืื, ืืขืืฉืื ืื ืขื ืืื ืืืจ ืืืืจื:
$ export LS_COLORS='ex=00:su=00:sg=00:ca=00:'
$ time strace -c ls --color=always $SCRATCH/dont | wc -l
10000
% time seconds usecs/call calls errors syscall
------ ----------- ----------- --------- --------- ----------------
63.02 0.002865 36 80 getdents
8.10 0.000368 12 30 mmap
5.72 0.000260 14 18 mprotect
3.72 0.000169 15 11 open
2.79 0.000127 13 10 read
[...]
------ ----------- ----------- --------- --------- ----------------
100.00 0.004546 221 6 total
real 0m0.337s
user 0m0.032s
sys 0m0.029s
0,3 ืฉื ืืืช ืืจืฉืืื ืฉื 10 ืงืืฆืื, ืฉืื.
ืืืืจืช ืฉืจืืืง
ื-13 ืฉื ืืืช ืขื ืืืืจืืช ืืจืืจืช ืืืื ืืขื 0,3 ืฉื ืืืช ืขื ืืชืืืืช ืงืืืช LS_COLORS
ืคืืจืืฉื ืืืฆื ืฉื ืคื 40 ืขืงื ืืืขืืจ setuid
/ setgid
ืืงืืฆื ืืคืขืื ืฆืืขืื ืืื. ืื ืืคืกื ืืื ืืืื.
ืืืืื, ืื ืืืืืจ ืืขืช ื-Serlock ืขืืืจ ืื ืืฉืชืืฉ.
ืืื ืื ืืชื ืจืืฆื ืืืืืืจ ืืช ืืฆืืืขื, ืืชื ืืืื ืคืฉืื ืืืืืจ ืืืืืจืืช ืืจืืจืช ืืืืื:
$ unset LS_COLORS
ืืื ืื ืืกืคืจืืืช ืขื ืืจืื ืงืืฆืื, ืืงืคื ืืืฉื ืงืคื ืืืื ืฉืืื ืคืืขื ls
.
ืืงืืจ: www.habr.com