chmod -x chmod的N种解法
在SlidesShare.net上有这么一个幻灯片,其说了如下的一个面试题:
如果某天你的Unix/Linux系统上的chomd命令被某人去掉了x属性(执行属性),
那么,你如何恢复呢?
下面是一些答案:
1)重新安装。对于Debian的系统:
1 | sudo apt-get install --reinstall coreutils |
2)使用语言级的chmod。
- Perl:perl-e ‘chmod 0755, “/bin/chmod”‘
- Python:python -c “import os;os.chmod(‘/bin/chmod’, 0755)”
- Node.js:require(“fs”).chmodSync(“/bin/chmod”, 0755);
- C程序:
1 2 3 4 5 6 | #include <sys/types.h> #include<sys/stat.h> void main() { chmod( "/bin/chmod" , 0000755); } |
3)使用已有的可执行文件。
1 2 3 4 5 6 7 | $ cat - > chmod .c void main(){} ^D $cc chmod .c $ cat /bin/chmod > a.out $. /a .out 0755 /bin/chmod |
1 2 3 | $ cp true > new_chmod $ cat /bin/chmod > new_chmod $. /new_chmod 0755 /bin/chmod |
4)使用GNU tar命令
1 2 | $ tar --mode 0755 -cf chmod . tar /bin/chmod $ tar xvf chmod . tar |
1 | tar --mode 755 -cvf - chmod | tar -xvf - |
5)使用cpio (第19到24字节为file mode – http://4bxf.sl.pt)
1 2 3 4 | echo chmod | cpio -o | perl -pe 's/^(.{21}).../${1}755/' | cpio -i -u |
6)使用hardcore
1 | alias chmod = '/lib/ld-2.11.1.so ./chmod' |
7)使用Emacs
Ctrl+x b > * scratch*
(set-file-modes “/bin/chmod” (string-to-number “0755” 8))
Ctrl+j
嗯,挺强大的,不过为什么不用install命令呢?
1 2 | install -m 755 /bin/chmod /tmp/chmod mv /tmp/chmod /bin/chmod |
各位,你的方法呢?
Linux磁盘使用命令du的改进
我们知道,在Linux下,如果你想知道当前目录下,每个文件或子目录的尺寸,你可以使用du命令来完成这一动作。如:
1 | $ du -sh * |
这个命令可以以K,M,G的方式显示每个文件和子目录的大小。我们把这种方式叫做,human-readable,也就是可以让人读的方式,如下所示:
8.4G Desktop 2.6G Documents 12K keys 12M Pictures 536K scripts
但是,很可惜的是,我们的du并没有提供相关的排序功能,所以,如果在human-readable下,也就是-h参数下,我们很难使用sort命令来排序。因为那变成了字符串排序,小数点,数字的位数,还有单位K,M,G都会让排序变得混乱。那么,我们如何才能即有human-readble这种功能,还能有排序呢。我们得借用一些脚本语言来处理了。
下面是使用了Perl来达到这一功能:
1 2 3 4 5 6 7 8 9 10 11 12 | du -sk * | sort -n | #以 K 字节的方式排序 perl - ne ' #使用Perl来处理 K M 和 G 单位 ($s,$f)= split (m{\t}); #把 尺寸/文件名 分开 for (qw(K M G)) { #以尺寸单位循环 if ($s<1024) { #如果 尺寸<1024 那么就输出 printf ( "%.1f" ,$s); #显示文件尺寸 print "$_\t$f" ; #显示文件名 last #换行 }; $s=$s /1024 #除1024然后进入下一个尺寸单位 } ' |
十个你可能不曾用过的Linux命令
下面可能是你不曾用过后十个Linux的命令。相当的有用。
1)pgrep
pgrep名字前有个p,我们可以猜到这和进程相关,又是grep,当然这是进程相关的grep命令。不过,这个命令主要是用来列举进程ID的。如:
1 2 3 | $ pgrep -u hchen 22441 22444 |
这个命令相当于:
1 | ps -ef | egrep '^hchen' | awk '{print $2}' |
2)pstree
这个命令可以以树形的方式列出进程。如下所示:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 | [hchen@RHELSVR5 ~]$ pstree init-+-acpid |-auditd-+-python | `-{auditd} |-automount---4*[{automount}] |-backup.sh--- sleep |-dbus-daemon |-events /0 |-events /1 |-hald---hald-runner---hald-addon-acpi |-httpd---10*[httpd] |-irqbalance |-khelper |-klogd |-ksoftirqd /0 |-ksoftirqd /1 |-kthread-+-aio /0 | |-aio /1 | |-ata /0 | |-ata /1 | |-ata_aux | |-cqueue /0 | |-cqueue /1 | |-kacpid | |-kauditd | |-kblockd /0 | |-kblockd /1 | |-kedac | |-khubd | |-6*[kjournald] | |-kmirrord | |-kpsmoused | |-kseriod | |-kswapd0 | |-2*[pdflush] | |-scsi_eh_0 | |-scsi_eh_1 | |-xenbus | `-xenwatch |-migration /0 |-migration /1 |-6*[mingetty] |-3*[multilog] |-mysqld_safe---mysqld---9*[{mysqld}] |-smartd |-sshd---sshd---sshd--- bash ---pstree |-svscanboot---svscan-+-3*[supervise---run] | |-supervise---qmail-send-+-qmail-clean | | |-qmail-lspawn | | `-qmail-rspawn | `-2*[supervise---tcpserver] |-syslogd |-udevd |-watchdog /0 |-watchdog /1 `-xinetd |
3)bc
这个命令主要是做一个精度比较高的数学运算的。比如开平方根等。下面是一个我们利用bc命令写的一个脚本(文件名:sqrt)
1 2 3 4 5 6 7 8 | #!/bin/bash if [ $ # -ne 1 ] then echo 'Usage: sqrt number' exit 1 else echo -e "sqrt($1)\nquit\n" | bc -q -i fi |
于是,我们可以这样使用这个脚本进行平方根运算:
1 2 3 4 5 6 | [hchen@RHELSVR5]$ . /sqrt 36 6 [hchen@RHELSVR5]$ . /sqrt 2.0000 1.4142 [hchen@RHELSVR5]$ . /sqrt 10.0000 3.1622 |
4)split
如果你有一个很大的文件,你想把其分割成一些小的文件,那么这个命令就是干这件事的了。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 | [hchen@RHELSVR5 applebak] # ls -l largefile.tar.gz -rw-r--r-- 1 hchen hchen 436774774 04-17 02:00 largefile. tar .gz [hchen@RHELSVR5 applebak] # split -b 50m largefile.tar.gz LF_ [hchen@RHELSVR5] # ls -l LF_* -rw-r--r-- 1 hchen hchen 52428800 05-10 18:34 LF_aa -rw-r--r-- 1 hchen hchen 52428800 05-10 18:34 LF_ab -rw-r--r-- 1 hchen hchen 52428800 05-10 18:34 LF_ac -rw-r--r-- 1 hchen hchen 52428800 05-10 18:34 LF_ad -rw-r--r-- 1 hchen hchen 52428800 05-10 18:34 LF_ae -rw-r--r-- 1 hchen hchen 52428800 05-10 18:35 LF_af -rw-r--r-- 1 hchen hchen 52428800 05-10 18:35 LF_ag -rw-r--r-- 1 hchen hchen 52428800 05-10 18:35 LF_ah -rw-r--r-- 1 hchen hchen 17344374 05-10 18:35 LF_ai |
文件合并只需要使用简单的合并就行了,如:
1 | [hchen@RHELSVR5] # cat LF_* >largefile.tar.gz |
5)nl
nl命令其它和cat命令很像,只不过它会打上行号。如下所示:
1 2 3 4 5 6 7 8 9 10 11 | [hchen@RHELSVR5 include] # nl stdio.h | head -n 10 1 /* Define ISO C stdio on top of C++ iostreams. 2 Copyright (C) 1991,1994-2004,2005,2006 Free Software Foundation, Inc. 3 This file is part of the GNU C Library. 4 The GNU C Library is free software; you can redistribute it and /or 5 modify it under the terms of the GNU Lesser General Public 6 License as published by the Free Software Foundation; either 7 version 2.1 of the License, or (at your option) any later version. 8 The GNU C Library is distributed in the hope that it will be useful, |
6)mkfifo
熟悉Unix的人都应该知道这个是一个创建有名管道的系统调用或命令。平时,我们在命令行上使用竖线“|”把命令串起来是使用无命管道。而我们使用mkfifo则使用的是有名管道。下面是示例:
下面是创建一个有名管道:
1 2 3 4 | [hchen@RHELSVR5 ~] # mkfifo /tmp/hchenpipe [hchen@RHELSVR5 ~] # ls -l /tmp prw-rw-r-- 1 hchen hchen 0 05-10 18:58 hchenpipe |
然后,我们在一个shell中运行如下命令,这个命令不会返回,除非有人从这个有名管道中把信息读走。
1 | [hchen@RHELSVR5 ~] # ls -al > /tmp/hchenpipe |
我们在另一个命令窗口中读取这个管道中的信息:(其会导致上一个命令返回)
1 2 3 4 5 6 7 8 9 10 | [hchen@RHELSVR5 ~] # head /tmp/hchenpipe drwx------ 8 hchen hchen 4096 05-10 18:27 . drwxr-xr-x 7 root root 4096 03-05 00:06 .. drwxr-xr-x 3 hchen hchen 4096 03-01 18:13 backup -rw------- 1 hchen hchen 721 05-05 22:12 .bash_history -rw-r--r-- 1 hchen hchen 24 02-28 22:20 .bash_logout -rw-r--r-- 1 hchen hchen 176 02-28 22:20 .bash_profile -rw-r--r-- 1 hchen hchen 124 02-28 22:20 .bashrc -rw-r--r-- 1 root root 14002 03-07 00:29 index.htm -rw-r--r-- 1 hchen hchen 31465 03-01 23:48 index.php |
7)ldd
这个命令可以知道你的一个可执行文件所使用了动态链接库。如:
1 2 3 4 5 6 7 8 9 10 11 12 | [hchen@RHELSVR5 ~] # ldd /usr/bin/java linux-gate.so.1 => (0x00cd9000) libgij.so.7rh => /usr/lib/libgij .so.7rh (0x00ed3000) libgcj.so.7rh => /usr/lib/libgcj .so.7rh (0x00ed6000) libpthread.so.0 => /lib/i686/nosegneg/libpthread .so.0 (0x00110000) librt.so.1 => /lib/i686/nosegneg/librt .so.1 (0x009c8000) libdl.so.2 => /lib/libdl .so.2 (0x008b5000) libz.so.1 => /usr/lib/libz .so.1 (0x00bee000) libgcc_s.so.1 => /lib/libgcc_s .so.1 (0x00aa7000) libc.so.6 => /lib/i686/nosegneg/libc .so.6 (0x0022f000) libm.so.6 => /lib/i686/nosegneg/libm .so.6 (0x00127000) /lib/ld-linux .so.2 (0x00214000) |
8)col
这个命令可以让你把man文件转成纯文本文件。如下示例:
1 2 | # PAGER=cat # man less | col -b > less.txt |
9)xmlwf
这个命令可以让你检查一下一个XML文档是否是所有的tag都是正常的。如:
1 2 3 4 5 6 7 8 | [hchen@RHELSVR5 ~] # curl 'https://coolshell.cn/?feed=rss2' > cocre.xml % Total % Received % Xferd Average Speed Time Time Time Current Dload Upload Total Spent Left Speed 100 64882 0 64882 0 0 86455 0 --:--:-- --:--:-- --:--:-- 2073k [hchen@RHELSVR5 ~] # xmlwf cocre.xml [hchen@RHELSVR5 ~] # perl -i -pe 's@<link>@<br>@g' cocre.xml [hchen@RHELSVR5 ~] # xmlwf cocre.xml cocre.xml:13:23: mismatched tag |
10)lsof
可以列出打开了的文件。
1 2 3 4 5 6 7 8 9 10 11 | [root@RHELSVR5 ~] # lsof | grep TCP httpd 548 apache 4u IPv6 14300967 TCP *:http (LISTEN) httpd 548 apache 6u IPv6 14300972 TCP *:https (LISTEN) httpd 561 apache 4u IPv6 14300967 TCP *:http (LISTEN) httpd 561 apache 6u IPv6 14300972 TCP *:https (LISTEN) sshd 1764 root 3u IPv6 4993 TCP *: ssh (LISTEN) tcpserver 8965 root 3u IPv4 153795500 TCP *:pop3 (LISTEN) mysqld 10202 mysql 10u IPv4 73819697 TCP *:mysql (LISTEN) sshd 10735 root 3u IPv6 160731956 TCP 210.51.0.232: ssh ->123.117.239.68:31810 (ESTABLISHED) sshd 10767 hchen 3u IPv6 160731956 TCP 210.51.0.232: ssh ->123.117.239.68:31810 (ESTABLISHED) vsftpd 11095 root 3u IPv4 152157957 TCP *: ftp (LISTEN) |