写得蛮好的linux学习笔记

linux 目录架构
/   根目录
/bin    常用的命令 binary file 的目錄
/boot   存放系统启动时必须读取的档案,包括核心 (kernel) 在内
     /boot/grub/menu.lst   GRUB 设置
     /boot/vmlinuz   内核
     /boot/initrd     核心解壓縮所需 RAM Disk
/dev    系统周边设备     
/etc    系统相关设定文件
     /etc/DIR_COLORS   设定颜色
     /etc/HOSTNAME   设定用户的节点名
     /etc/NETWORKING   只有 YES 标明网络存在
     /etc/host.conf 文件说明用户的系统如何查询节点名
     /etc/hosts 设定用户自已的 IP 与名字的对应表
     /etc/hosts.allow 设置允许使用 inetd 的机器使用
     /etc/hosts.deny 设置不允许使用 inetd 的机器使用
     /etc/hosts.equiv 设置远端机不用密码
     /etc/inetd.conf 设定系统网络守护进程 inetd 的配置
     /etc/gateways 设定路由器
     /etc/protocols 设定系统支持的协议
     /etc/named.boot 设定本机为名字服务器的配置文件
     /etc/sysconfig/network-scripts/ifcfg-eth0   设置 IP
     /etc/resolv.conf    设置 DNS 
     /etc/X11  X Window 的配置文件 ,xorg.conf XF86Config 這兩個 X Server 的設定檔
     /etc/fstab    记录开机要 mount 的文件系统
     /etc/inittab 设定系统启动时 init 进程将把系统设置成什么样的 runlevel
     /etc/issue 记录用户登录前显示的信息
     /etc/group 设定用户的组名与相关信息
     /etc/passwd 帐号信息
     /etc/shadow 密码信息
     /etc/sudoers 可以 sudo 命令的配置文件
     /etc/securetty 设定哪些终端可以让 root 登录
     /etc/login.defs 所有用户登录时的缺省配置
     /etc/exports 设定 NFS 系统用的
     /etc/init.d/   所有服務的預設啟動 script 都是放在這裡的,例如要啟動或者關閉
     /etc/xinetd.d/  這就是所謂的 super daemon 管理的各項服務的設定檔目錄
     /etc/modprobe.conf   内核模块额外参数设定
     /etc/syslog.conf   日志设置文件
/home   使用者家目录
/lib    系统会使用到的函数库
     /lib/modules   kernel 的相关模块
     /var/lib/rpm   rpm 套件安装处
/lost+found    系統不正常產生錯誤時,會將一些遺失的片段放置於此目錄下
/mnt     外设的挂载点
/media   /mnt 类似
/opt     主机额外安装的软件
/proc    虚拟目录,是内存的映射
      /proc/version   内核版本
       /proc/sys/kernel   系统内核功能
/root    系统管理员的家目录
/sbin    系统管理员才能执行的指令
/srv     一些服務啟動之後,這些服務所需要取用的資料目錄
/tmp     一般使用者或者是正在執行的程序暫時放置檔案的地方
/usr     最大的目录,存许应用程序和文件
    /usr/X11R6    X-Window 目录
    /usr/src     Linux 源代码
    /usr/include :系统头文件
    /usr/openwin 存放 SUN OpenWin
    /usr/man 在线使用手册
    /usr/bin           使用者可執行的 binary file 的目錄
    /usr/local/bin     使用者可執行的 binary file 的目錄
    /usr/lib           系统会使用到的函数库
    /usr/local/lib     系统会使用到的函数库
    /usr/sbin          系统管理员才能执行的指令
    /usr/local/sbin    系统管理员才能执行的指令
/var   日志文件
    /var/log/secure    記錄登入系統存取資料的檔案,例如 pop3, ssh, telnet, ftp 等都會記錄在此檔案中
    /var/log/wtmp      記錄登入者的訊息資料 , last
    /var/log/messages  幾乎系統發生的錯誤訊息
    /var/log/boot.log  記錄開機或者是一些服務啟動的時候,所顯示的啟動或關閉訊息
    /var/log/maillog   紀錄郵件存取或往來 ( sendmail pop3 ) 的使用者記錄
    /var/log/cron      記錄 crontab 這個例行性服務的內容
    /var/log/httpd, /var/log/news, /var/log/mysqld.log, /var/log/samba, /var/log/procmail.log
    分別是幾個不同的網路服務的記錄檔
 
一些常用的基本命令 :
uname -a    查看内核版本       
ls -al    显示所有文件的属性
pwd         显示当前路径        
cd -    返回上一次目录      cd ~    返回主目录
date s      设置时间、日期          
cal      显示日历      cal 2006
bc          计算器具               
man  & info     帮助手册
locale     显示当前字体      locale -a    所有可用字体      /etc/sysconfig/i18n 设置文件
LANG=en    使用英文字体            
sync       将数据同步写入硬盘        
shutdonw -h now & half & poweroff  关机
reboot     重启                   
startx  &  init 5   进入图形介面
/work  & ?work    向上、下查找文档内容
chgrp      改变档案群组   chgrp testing install.log   
chown     改变所属人    chown root:root install.log
chmod      改变属性      chmod 777 install.log     read=4  write=2  execute=1
cp   复制    cp filename
rm   删除文件   rm -rf filename   强制删除文件
rmdir   删除文件夹
mv  移动     mv 123.txt 222.txt  重命名
mkdir     创建文件夹
touch     创建文件   更新当前时间
cat       由第一行开始显示      cat |more  分页
nl        在内容前加行号
more  &  less   一面一面翻动
head -n filename   显示第 N 行内容
tail -n filename  显示后 N 行内容
od        显示非纯文档
df -h 显示分区空间
du  显示目录或文件的大小
fdisk   分区设置     fdisk -l /dev/hda  显示硬盘分区状态
mkfs    建立各种文件系统   mkfs -t ext3  /dev/ram15  
fsck    检查和修复 LINUX 档案
ln      硬链接    ln -s  软件链接
whereis   查找命令
locate    查找
find      查找    find / -name "***.***"
which     查看工具
whoami    显示当前用户
gcc -v    查看 GCC 版本
chattr +i filename  禁止删除    chattr -i filename  取消禁止
lsattr    显示隐藏档属性
updatedb  更新资料库
mke2fs    格式化    mkfs -t ext3
dd if=/etc/passwd of=/tmp/passwd.bak    备份
mount     列出系统所有的分区
mount -t iso9660 /dev/cdrom /mnt/cdrom   挂载光盘
mount -t vfat /dev/fd0 /mnt/floppy       挂载软盘
mount -t vfat -o iocharset=utf8,umask=000 /dev/hda2 /mnt/hda2   挂载 fat32 分区
mount -t ntfs -o nls=utf8,umask=000 /dev/hda3 /mnt/hda3         挂载 ntfs 分区
Linux-NTFS Project: http://linux-ntfs.sourceforge.net/
umount /mnt/hda3  缷载
ifconfig   显示或设置网络设备
service network restart   重启网卡  
ifdown eth0  关闭网卡
ifup eth0    开启网卡
clear    清屏
history    历史记录        !55  执行第 55 个指令
stty   设置终端     stty -a
fdisk /mbr   删除 GRUB
at     僅進行一次的工作排程
crontab   循環執行的例行性命令     [e] 编辑 ,[l] 显示 ,[r] 删除任务
&       后台运行程序     tar -zxvf 123.tar.gz & ---------> 后台运行
jobs    观看后台暂停的程序    jobs -l
fg      将后台程序调到前台    fg n ------>n 是数字 , 可以指定进行那个程序
bg      让工作在后台运行
kill    结束进程     kill -9 PID     [9] 强制结束 ,[15] 正常结束 ,[l] 列出可用的 kill 信号
ps aux  查看后台程序   
top     查看后台程序    top -d 2    每两秒更新一次         top -d 2 -p10604   观看某个 PID
        top -b -n 2 > /tmp/top.txt -----> top 的資訊進行 2 次,然後將結果輸出到 /tmp/top.txt   
pstree   以树状图显示程序     [A] ASCII 來連接 , [u] 列出 PID, [p] 列出帐号
killall   要刪除某個服務     killall -9 httpd
free      显示内存状态      free -m  --------> M 为单位显示
uptime    显示目前系统开机时间
netstat   显示网络状态     netstat -tulnp------> 找出目前系統上已在監聽的網路連線及其 PID
dmesg     显示开机信息     demsg | more
nice      设置优先权       nice -n -5 vi & -----> root 給一個 nice 植為 -5 ,用於執行 vi
renice    调整已存在优先权
runlevel  显示目前的 runlevel
depmod    分析可载入模块的相依性
lsmod     显示已载入系统的模块
modinfo   显示 kernel 模块的信息
insmod    载入模块
modprobe   自动处理可载入模块
rmmod     删除模块
chkconfig   检查,设置系统的各种服务      chkconfig --list -----> 列出各项服务状态
ntsysv     设置系统的各种服务
cpio      备份文件
 

压缩命令:
 *.Z      compress 程式壓縮的檔案;
 *.bz2    bzip2 程式壓縮的檔案;
 *.gz     gzip 程式壓縮的檔案;
 *.tar    tar 程式打包的資料,並沒有壓縮過;
 *.tar.gz tar 程式打包的檔案,其中並且經過 gzip 的壓縮
compress filename  压缩文件   [-d] 解压   uncompress
gzip filename   压缩   [-d] 解压   zcat 123.gz 查看压缩文件内容
bzip2 -z filename  压缩   [-d] 解压    bzcat filename.bz2  查看压缩文件内容
tar -cvf /home/123.tar /etc  打包,不压缩
tar -xvf 123.tar   解开包
tar -zxvf /home/123.tar.gz  gzip 解压
tar -jxvf /home/123.tar.bz2  bzip2 解压
tar -ztvf /tmp/etc.tar.gz   查看 tar 内容
cpio -covB  > [file|device]   份份
cpio -icduv < [file|device]   还原
 
vi 一般用法
一般模式               编辑模式                   指令模式
h                a,i,r,o,A,I,R,O             :w 保存
j                 进入编辑模式                 :w! 强制保存
k                 dd 删除光标当前行            :q! 不保存离开
l                 ndd 删除 n                  :wq! 保存后离开
0 移动到行首         yy 复制当前行                 :e! 还原原始档
$ 移动到行尾         nyy 复制 n                   :w filename 另存为
H 屏幕最上           p,P 粘贴                      :set nu 设置行号
M 屏幕中央           u  撤消                       :set nonu 取消行号
L 屏幕最下           [Ctrl]+r 重做上一个动作        ZZ 保存离开
G 档案最后一行       [ctrl]+z 暂停退出             :set nohlsearch   永久地关闭高亮显示
/work 向下搜索                                    :sp 同时打开两个文档
?work 向上搜索                                    [Ctrl]+w 两个文档设换
gg 移动到档案第一行                               :nohlsearch    暂时关闭高亮显示
 
认识 SHELL
alias    显示当前所有的命令别名       alias lm="ls -al"   命令别名     unalias lm 取消命令别名
type      类似 which
exprot    设置或显示环境变量
exprot PATH="$PATH":/sbin  添加 /sbin PATH 路径
echo $PATH    显示 PATH 路径
bash      进入子程序
name=yang     设定变量
unset name    取消变量
echo $name    显示变量的内容
myname="$name its me"   &   myname='$name its me'     单引号时 $name 失去变量内容
ciw=/etc/sysconfig/network-scripts/     设置路径
env      列出所有环境变量
echo $RANDOM    显示随意产生的数
set      设置 SHELL
PS1='[/u@/h /w /A #/#]/$ '     提示字元的設定
   [root@linux ~]# read [-pt] variable     ----------- 读取键盘输入的变量
   參數:
   -p  :後面可以接提示字元!
   -t  :後面可以接等待的『秒數!』
declare    声明 shell 变量
ulimit -a   显示所有限制资料
 ls /tmp/yang && echo "exist" || echo "not exist"
  意思是說,當 ls /tmp/yang 執行後,若正確,就執行 echo "exist" , 若有問題,就執行 echo "not exist"
 echo $PATH | cut -d ':' -f 5       : 为分隔符 , 读取第 5 段内容
 export | cut -c 10-20      读取第 10 20 个字节的内容
 last | grep 'root'    搜索有 root 的一行 , [-v] 反向搜索
 cat /etc/passwd | sort    排序显示
 cat /etc/passwd | wc      显示『行、字数、字节数』
正规表示法
[root@test root]# grep [-acinv] ' 搜尋字串 ' filename
       參數說明:
       -a :將 binary 檔案以 text 檔案的方式搜尋資料
       -c :計算找到 ' 搜尋字串 ' 的次數
       -i :忽略大小寫的不同,所以大小寫視為相同
       -n :順便輸出行號
       -v :反向選擇,亦即顯示出沒有 ' 搜尋字串 ' 內容的那一行!
 grep -n 'the' 123.txt     搜索 the 字符 ----------- 搜尋特定字串       
 grep -n 't[ea]st' 123.txt    搜索 test taste 两个字符 --------- 利用 [] 來搜尋集合字元
 grep -n '[^g]oo' 123.txt     搜索前面不为 g oo----------- 向選擇 [^]
 grep -n '[0-9]' 123.txt  搜索有 0-9 的数字
 grep -n '^the' 123.txt 搜索以 the 为行首 ----------- 行首搜索 ^
 grep -n '^[^a-zA-Z]' 123.txt  搜索不以英文字母开头
 grep -n '[a-z]$' 123.txt    搜索以 a-z 结尾的行 ---------- 行尾搜索 $
 grep -n 'g..d' 123.txt     搜索开头 g 结尾 d 字符 ---------- 任意一個字元 .
 grep -n 'ooo*' 123.txt     搜索至少有两个 oo 的字符 --------- 重複字元 *
sed    文本流编辑器     利用脚本命令来处理文本文件
awd    模式扫描和处理语言
 nl 123.txt | sed '2,5d'   删除第二到第五行的内容
diff     比较文件的差异
cmp      比较两个文件是否有差异
patch    修补文件
pr       要打印的文件格式化
 

帐号管理
/etc/passwd    系统帐号信息
/etc/shadow    帐号密码信息     MD5 32 位加密
     在密码栏前面加『 * 』『 ! 』禁止使用某帐号
/etc/group     系统群组信息
/etc/gshadow
newgrp    改变登陆组
useradd  &  adduser    建立新用户   ---------> useradd -m test  自动建立用户的登入目录
          useradd -m -g pgroup test ---------> 指定所属级
/etc/default/useradd   相关设定
/etc/login.defs       UID/GID 有關的設定
passwd    更改密码 -----------> passwd test
usermod   修改用户帐号
userdel   删除帐号 ----------->userdel -r test
chsh      更换登陆系统时使用的 SHELL   [-l] 显示可用的 SHELL;[-s] 修改自己的 SHELL
chfn      改变 finger 指令显示的信息
finger    查找并显示用户信息
id        显示用户的 ID ----------->  id test
groupadd   添加组
groupmod   usermod 类似
groupdel   删除组
su test    更改用户    su -    进入 root, 且使用 root 的环境变量
sudo       以其他身份来执行指令
visudo     编辑 /etc/sudoers      加入一行『 test ALL=(ALL) ALL
           %wheel ALL = (ALL) ALL               系统里所有 wheel 群组的用户都可用 sudo
           %wheel ALL = (ALL) NOPASSWD: ALL     wheel 群组所有用户都不用密码 NOPASSWD
       User_Alias ADMPW = vbird, dmtsai, vbird1, vbird3         加入 ADMPW
       ADMPW ALL = NOPASSWD: !/usr/bin/passwd, /usr/bin/passwd [A-Za-z]*, /
       !/usr/bin/passwd root      可以更改使用者密码 , 但不能更改 root 密码 ( 在指令前面加入 ! 代表不可 )
PAM (Pluggable Authentication Modules, 嵌入式模組 )
who & w     看谁在线                     
last        最近登陆主机的信息
lastlog     最近登入的時間     读取 /var/log/lastlog
talk        与其他用户交谈
write       发送信息     write test   [ctrl]+d 发送
mesg        设置终端机的写入权限     mesg n 禁止接收      mesg y
wall        向所有用户发送信息     wall this is q test
mail        mail  
/etc/default/useradd    家目录默认设置
quota      显示磁盘已使用的空间与限制      quota -guvs -----> 秀出目前 root 自己的 quota 限制值
           quota -vu   查询
quotacheck   检查磁盘的使用空间与限制      quotacheck -avug  -----> 將所有的在 /etc/mtab 內,含有 quota 支援的 partition 進行掃瞄
             [-m] 强制扫描  
     quota 一定要是独立的分区 , 要有 quota.user quota.group 两件文件 , /etc/fstab 添加一句 :
     /dev/hda3 /home ext3 defaults,usrquota,grpquota 1 2
     chmod 600 quota*         设置完成 , 重启生效
edquota    编辑用户或群组的 quota  [u] 用户 ,[g] 群组 ,[p] 复制 ,[t] 设置宽限期限
           edquota -a yang       edquota -p yang -u young -----> 复制    
quotaon    开启磁盘空间限制      quotaon -auvg --------> 啟動所有的具有 quota filesystem
quotaoff   关闭磁盘空间限制      quotaoff -a  --------> 關閉了 quota 的限制
repquota -av     查閱系統內所有的具有 quota filesystem 的限值狀態
Quota 從開始準備 filesystem 的支援到整個設定結束的主要的步驟大概是:
1 、設定 partition filesystem 支援 quota 參數:
由於 quota 必須要讓 partition 上面的 filesystem 支援才行,一般來說, 支援度最好的是 ext2/ext3
其他的 filesystem 類型鳥哥我是沒有試過啦! 啟動 filesystem 支援 quota 最簡單就是編輯 /etc/fstab
使得準備要開放的 quota 磁碟可以支援 quota 囉;
2 、建立 quota 記錄檔:
剛剛前面講過,整個 quota 進行磁碟限制值記錄的檔案是 aquota.user/aquota.group
要建立這兩個檔案就必須要先利用 quotacheck 掃瞄才行喔!
3 、編輯 quota 限制值資料:
再來就是使用 edquota 來編輯每個使用者或群組的可使用空間囉;
4 、重新掃瞄與啟動 quota
設定好 quota 之後,建議可以再進行一次 quotacheck ,然後再以 quotaon 來啟動吧!

开机流程简介
1 、載入 BIOS 的硬體資訊,並取得第一個開機裝置的代號;
2 、讀取第一個開機裝置的 MBR boot Loader ( 亦即是 lilo, grub, spfdisk 等等 ) 的開機資訊;
3 、載入 Kernel 作業系統核心資訊, Kernel 開始解壓縮,並且嘗試驅動所有硬體裝置;
4 Kernel 執行 init 程式並取得 run-level 資訊;
5 init 執行 /etc/rc.d/rc.sysinit 檔案;
6 、啟動核心的外掛模組 (/etc/modprobe.conf)
7 init 執行 run-level 的各個批次檔 ( Scripts )
8 init 執行 /etc/rc.d/rc.local 檔案;
9 、執行 /bin/login 程式,並等待使用者登入;
10 、登入之後開始以 Shell 控管主機。
/etc/rc.d/rc3.d , S 开头的为开机启动 , K 开头的为关闭 , 接着的数字代表执行顺序
GRUB vga 设定
彩度 / 解析度   640x480  800x600  1024x768  1280x1024   bit
    256        769      771      773       775      8 bit
   32768       784      787      790       793     15 bit
   65536       785      788      791       794     16 bit
   16.8M       786      789      792       795     32 bit

./configure    检查系统信息        ./configure --help | more  帮助信息
make clean     清除之前留下的文件
make           编译
make install   安装
rpm -q  -----> 查询是否安装              rpm -ql ------> 查询该套件所有的目录
rpm -qi -----> 查询套件的说明资料        rpm -qc[d] -----> 设定档与说明档
rpm -ivh  ----> 安装                     rpm -V  --------> 查看套件有否更动过
rpm -e  ------> 删除                     rpm -Uvh -------> 升级安装  
--nodeps -----> 强行安装                 --test -----> 测试安装
==========================================================================================
这是一个linux常见命令的列表。
那些有• 标记的条目,你可以直接拷贝到终端上而不需要任何修改,因此你最好开一个终端边读边 剪切&拷贝。
所有的命令已在Fedora和Ubuntu下做了测试

命令 描述
apropos whatis 显示和word相关的命令。 参见线程安全
man -t man | ps2pdf - > man.pdf 生成一个PDF格式的帮助文件
  which command 显示命令的完整路径名
  time command 计算命令运行的时间
time cat 开始计时. Ctrl-d停止。参见sw
nice info 运行一个低优先级命令(这里是info)
renice 19 -p $$ 使脚本运行于低优先级。用于非交互任务。
目录操作
cd - 回到前一目录
cd 回到用户目录
  (cd dir && command) 进入目录dir,执行命令command然后回到当前目录
pushd . 将当前目录压入栈,以后你可以使用popd回到此目录
alias l='ls -l --color=auto' 单字符文件列表命令
ls -lrt 按日期显示文件. 参见newest
ls /usr/bin | pr -T9 -W$COLUMNS 在当前终端宽度上打印9列输出
  find -name '*.[ch]' | xargs grep -E 'expr' 在当前目录及其子目录下所有.c和.h文件中寻找'expr'. 参见findrepo
  find -type f -print0 | xargs -r0 grep -F 'example' 在当前目录及其子目录中的常规文件中查找字符串'example'
  find -maxdepth 1 -type f | xargs grep -F 'example' 在当前目录下查找字符串'example'
  find -maxdepth 1 -type d | while read dir; do echo $dir; echo cmd2; done 对每一个找到的文件执行多个命令(使用while循环)
find -type f ! -perm -444 寻找所有不可读的文件(对网站有用)
find -type d ! -perm -111 寻找不可访问的目录(对网站有用)
locate -r 'file[^/]*/.txt' 使用locate 查找所有符合*file*.txt的文件
look reference 在(有序)字典中快速查找
grep --color reference /usr/share/dict/words 使字典中匹配的正则表达式高亮
归档 and compression
  gpg -c file 文件加密
  gpg file.gpg 文件解密
  tar -c dir/ | bzip2 > dir.tar.bz2 将目录dir/压缩打包
  bzip2 -dc dir.tar.bz2 | tar -x 展开压缩包 (对tar.gz文件使用gzip而不是bzip2)
  tar -c dir/ | gzip | gpg -c | ssh user@remote 'dd of=dir.tar.gz.gpg' 目录dir/压缩打包并放到远程机器上
  find dir/ -name '*.txt' | tar -c --files-from=- | bzip2 > dir_txt.tar.bz2 将目录dir/及其子目录下所有.txt文件打包
  find dir/ -name '*.txt' | xargs cp -a --target-directory=dir_txt/ --parents 将目录dir/及其子目录下所有.txt按照目录结构拷贝到dir_txt/
  ( tar -c /dir/to/copy ) | ( cd /where/to/ && tar -x -p ) 拷贝目录copy/到目录/where/to/并保持文件属性
  ( cd /dir/to/copy && tar -c . ) | ( cd /where/to/ && tar -x -p ) 拷贝目录copy/下的所有文件到目录/where/to/并保持文件属性
  ( tar -c /dir/to/copy ) | ssh -C user@remote 'cd /where/to/ && tar -x -p' 拷贝目录copy/到远程目录/where/to/并保持文件属性
  dd bs=1M if=/dev/sda | gzip | ssh user@remote 'dd of=sda.gz' 将整个硬盘备份到远程机器上
rsync (使用 --dry-run选项进行测试)
  rsync -P rsync://rsync.server.com/path/to/file file 只获取diffs.当下载有问题时可以作多次
  rsync --bwlimit=1000 fromfile tofile 有速度限制的本地拷贝,对I/O有利
  rsync -az -e ssh --delete ~/public_html/ remote.com:'~/public_html' 镜像网站(使用压缩和加密)
  rsync -auz -e ssh remote:/dir/ . && rsync -auz -e ssh . remote:/dir/ 同步当前目录和远程目录
ssh (安全 Shell)
  ssh $USER@$HOST command 在$Host主机上以$User用户运行命令(默认命令为Shell)
ssh -f -Y $USER@$HOSTNAME xeyes 在名为$HOSTNAME的主机上以$USER用户运行GUI命令
  scp -p -r $USER@$HOST: file dir/ 拷贝到$HOST主机$USER'用户的目录下
  ssh -g -L 8080:localhost:80 root@$HOST 由本地主机的8080端口转发到$HOST主机的80端口
  ssh -R 1434:imap:143 root@$HOST 由主机的1434端口转发到imap的143端口
wget (多用途下载工具)
(cd cmdline && wget -nd -pHEKk http://www.pixelbeat.org/cmdline.html) 在当前目录中下载指定网页及其相关的文件使其可完全浏览
  wget -c http://www.example.com/large.file 继续上次未完的下载
  wget -r -nd -np -l1 -A '*.jpg' http://www.example.com/ 批量下载文件到当前目录中
  wget ftp://remote/file[1-9].iso/ 下载FTP站上的整个目录
wget -q -O- http://www.pixelbeat.org/timeline.html | grep 'a href' | head 直接处理输出
  echo 'wget url' | at 01:00 在下午一点钟下载指定文件到当前目录
  wget --limit-rate=20k url 限制下载速度(这里限制到20KB/s)
  wget -nv --spider --force-html -i bookmarks.html 检查文件中的链接是否存在
  wget --mirror http://www.example.com/ 更新网站的本地拷贝(可以方便地用于cron)
网络(ifconfig, route, mii-tool, nslookup 命令皆已过时)
  ethtool eth0 显示网卡eth0的状态
  ethtool --change eth0 autoneg off speed 100 duplex full 手动设制网卡速度
  iwconfig eth1 显示无线网卡eth1的状态
  iwconfig eth1 rate 1Mb/s fixed 手动设制无线网卡速度
iwlist scan 显示无线网络列表
ip link show 显示interface列表
  ip link set dev eth0 name wan 重命名eth0为wan
  ip link set dev eth0 up 启动interface eth0(或关闭)
ip addr show 显示网卡的IP地址
  ip addr add 1.2.3.4/24 brd + dev eth0 添加ip和掩码(255.255.255.0)
ip route show 显示路由列表
  ip route add default via 1.2.3.254 设置默认网关1.2.3.254
tc qdisc add dev lo root handle 1:0 netem delay 20msec 增加20ms传输时间到loopback设备(调试用)
tc qdisc del dev lo root 移除上面添加的传输时间
host pixelbeat.org 查寻主机的DNS IP地址
hostname -i 查寻本地主机的IP地址(同等于host `hostname`)
whois pixelbeat.org 查寻某主机或莫IP地址的whois信息
netstat -tupl 列出系统中的internet服务
netstat -tup 列出活跃的连接
windows networking (samba提供所有windows相关的网络支持)
smbtree 寻找一个windows主机. 参见findsmb
  nmblookup -A 1.2.3.4 寻找一个指定ip的windows (netbios)名
  smbclient -L windows_box 显示在windows主机或samba服务器上的所有共享
  mount -t smbfs -o fmask=666,guest //windows_box/share /mnt/share 挂载一个windows共享
  echo 'message' | smbclient -M windows_box 发送一个弹出信息到windows主机(XP sp2默认关闭此功能)
文本操作 (sed使用标准输入和标准输出,如果想要编辑文件,则需添加<oldfile >newfile)
  sed 's/string1/string2/g' 使用string2替换string1
  sed 's//(.*/)1//12/g' 将任何以1结尾的字符串替换为以2结尾的字符串
  sed '/ *#/d; /^ *$/d' 删除注释和空白行
  sed ':a; ///$/N; s////n//; ta' 连接结尾有/的行和其下一行
  sed 's/[ /t]*$//' 删除每行后的空白
  sed 's//([//`//"$////]/)////1/g' 将所有转义字符之前加上/
seq 10 | sed "s/^/      /; s/ */(./{7,/}/)//1/" 向右排N(任意数)列
  sed -n '1000p;1000q' 输出第一千行
  sed -n '10,20p;20q' 输出第10-20行
  sed -n 's/.*<title>/(.*/)<//title>.*//1/ip;T;q' 输出HTML文件的<title></title>字段中的 内容
  sort -t. -k1,1n -k2,2n -k3,3n -k4,4n 排序IPV4地址
echo 'Test' | tr '[:lower:]' '[:upper:]' 转换成大写
tr -dc '[:print:]' < /dev/urandom 过滤掉不能打印的字符
history | wc -l 计算指定单词出现的次数
集合操作 (如果是英文文本的话export LANG=C可以提高速度)
  sort file1 file2 | uniq 两个未排序文件的并集
  sort file1 file2 | uniq -d 两个未排序文件的交集
  sort file1 file1 file2 | uniq -u 两个未排序文件的差 集
  sort file1 file2 | uniq -u 两个未排序文件的对称差集
  join -t'/0' -a1 -a2 file1 file2 两个有序文件的并集
  join -t'/0' file1 file2 两个有序文件的交集
  join -t'/0' -v2 file1 file2 两个有序文件的差集
  join -t'/0' -v1 -v2 file1 file2 两个有序文件的对称差集
数学
echo '(1 + sqrt(5))/2' | bc -l 方便的计算器(计算 φ)
echo 'pad=20; min=64; (100*10^6)/((pad+min)*8)' | bc 更复杂地计算,这里计算了最大的FastE包率
echo 'pad=20; min=64; print (100E6)/((pad+min)*8)' | python Python处理数值的科学表示法
echo 'pad=20; plot [64:1518] (100*10**6)/((pad+x)*8)' | gnuplot -persist 显示FastE包率相对于包大小的图形
echo 'obase=16; ibase=10; 64206' | bc 进制转换(十进制到十六进制)
echo $((0x2dec)) 进制转换(十六进制到十进制)((shell数学扩展))
units -t '100m/9.58s' 'miles/hour' 单位转换(公尺到英尺)
units -t '500GB' 'GiB' 单位转换(SI 到IEC 前缀)
units -t '1 googol' 定义查找
seq 100 | (tr '/n' +; echo 0) | bc 加N(任意数)列. 参见 add and funcpy
日历
cal -3 显示一日历
cal 9 1752 显示指定月,年的日历
date -d fri 这个星期五是几号. 参见day
date --date='25 Dec' +%A 今年的圣诞节是星期几
date --date '1970-01-01 UTC 2147483647 seconds' 将一相对于1970-01-01 00:00的秒数转换成时间
TZ=':America/Los_Angeles' date 显示当前的美国西岸时间(使用tzselect寻找时区)
  echo "mail -s 'get the train' [email protected] < /dev/null" | at 17:45 在指定的时间发送邮件
echo "DISPLAY=$DISPLAY xmessage cooker" | at "NOW + 30 minutes" 在给定的时间弹出对话框
locales
printf "%'d/n" 1234 根据locale输出正确的数字分隔
BLOCK_SIZE=/'1 ls -l 用ls命令作类适于locale()文件分组
echo "I live in `locale territory`" 从locale数据库中展开信息
LANG=en_IE.utf8 locale int_prefix 查找指定地区的locale信息。参见ccodes
locale | cut -d= -f1 | xargs locale -kc | less 显示在locale数据库中的所有字段
recode (iconv, dos2unix, unix2dos 已经过时了)
recode -l | less 显示所有有效的字符集及其别名
  recode windows-1252.. file_to_change.txt 转换Windows下的ansi文件到当前的字符集(自动进行回车换行符的转换)
  recode utf-8/CRLF.. file_to_change.txt 转换Windows下的ansi文件到当前的字符集
  recode iso-8859-15..utf8 file_to_change.txt 转换Latin9(西欧)字符集文件到utf8
  recode ../b64 < file.txt > file.b64 Base64编码
  recode /qp.. < file.txt > file.qp Quoted-printable格式解码
  recode ..HTML < file.txt > file.html 将文本文件转换成HTML
recode -lf windows-1252 | grep euro 在字符表中查找欧元符号
echo -n 0x80 | recode latin-9/x1..dump 显示字符在latin-9中的字符映射
echo -n 0x20AC | recode ucs-2/x2..latin-9/x 显示latin-9编码
echo -n 0x20AC | recode ucs-2/x2..utf-8/x 显示utf-8编码
光盘
  gzip < /dev/cdrom > cdrom.iso.gz 保存光盘拷贝
  mkisofs -V LABEL -r dir | gzip > cdrom.iso.gz 建立目录dir的光盘镜像
  mount -o loop cdrom.iso /mnt/dir 将光盘镜像挂载到 /mnt/dir (只读)
  cdrecord -v dev=/dev/cdrom blank=fast 清空一张CDRW
  gzip -dc cdrom.iso.gz | cdrecord -v dev=/dev/cdrom - 烧录光盘镜像 (使用 dev=ATAPI -scanbus 来确认该使用的 dev)
  cdparanoia -B 在当前目录下将光盘音轨转录成wav文件
  cdrecord -v dev=/dev/cdrom -audio *.wav 将当前目录下的wav文件烧成音乐光盘 (参见cdrdao)
  oggenc --tracknum='track' track.cdda.wav -o 'track.ogg' 将wav文件转换成ogg格式
磁盘空间 (参见FSlint)
ls -lSr 按文件大小降序显示文件
du -s * | sort -k1,1rn | head 显示当前目录下占用空间最大的一批文件. 参见dutop
df -h 显示空余的磁盘空间
df -i 显示空余的inode
fdisk -l 显示磁盘分区大小和类型(在root下执行)
rpm -q -a --qf '%10{SIZE}/t%{NAME}/n' | sort -k1,1n 显示所有在rpm发布版上安装的包,并以包字节大小为序
dpkg-query -W -f='${Installed-Size;10}/t${Package}/n' | sort -k1,1n 显示所有在deb发布版上安装的包,并以KB包大小为序
dd bs=1 seek=2TB if=/dev/null of=ext3.test 建立一个大的测试文件(不占用空间). 参见truncate
监视/调试
tail -f /var/log/messages 监视Messages日志文件
strace -c ls >/dev/null 总结/剖析命令进行的系统调用
strace -f -e open ls >/dev/null 显示命令进行的系统调用
ltrace -f -e getenv ls >/dev/null 显示命令调用的库函数
lsof -p $$ 显示当前进程打开的文件
lsof ~ 显示打开用户目录的进程
tcpdump not port 22 显示除了ssh外的网络交通. 参见tcpdump_not_me
ps -e -o pid,args --forest 以树状结构显示进程
ps -e -o pcpu,cpu,nice,state,cputime,args --sort pcpu | sed '/^ 0.0 /d' 以CPU占用率为序显示进程
ps -e -orss=,args= | sort -b -k1,1n | pr -TW$COLUMNS 以内存使用量为序显示进程. 参见ps_mem.py
ps -C firefox-bin -L -o pid,tid,pcpu,state 显示指定进程的所有线程信息
ps -p 1,2 显示指定进程ID的进程信息
last reboot 显示系统重启记录
free -m 显示(剩余的)内存总量(-m以MB为单位显示)
watch -n.1 'cat /proc/interrupts' 监测文件/proc/interrupts的变化
系统信息 (参见sysinfo)
uname -a 查看内核/操作系统/CPU信息
head -n1 /etc/issue 查看操作系统版本
cat /proc/partitions 显示所有在系统中注册的分区
grep MemTotal /proc/meminfo 显示系统可见的内存总量
grep "model name" /proc/cpuinfo 显示CPU信息
lspci -tv 显示PCI信息
lsusb -tv 显示USB信息
mount | column -t 显示所有挂载的文件系统并对齐输出
# dmidecode -q | less 显示SMBIOS/DMI 信息
# smartctl -A /dev/sda | grep Power_On_Hours 系统开机的总体时间
# hdparm -i /dev/sda 显示关于磁盘sda的信息
# hdparm -tT /dev/sda 检测磁盘sda的读取速度
# badblocks -s /dev/sda 检测磁盘sda上所有的坏扇区
交互 (参见linux keyboard shortcut database)
readline Line editor used by bash, python, bc, gnuplot, ...
screen 多窗口的虚拟终端, ...
mc 强大的文件管理器,可以浏览rpm, tar, ftp, ssh, ...
gnuplot 交互式并可进行脚本编程的画图工具
links 网页浏览器
miscellaneous
alias hd='od -Ax -tx1z -v' 方便的十六进制输出。 (用法举例: • hd /proc/self/cmdline | less)
alias realpath='readlink -f' 显示符号链接指向的真实路径((用法举例: • realpath ~/../$USER)
set | grep $USER 在当前环境中查找
  touch -c -t 0304050607 file 改变文件的时间标签 (YYMMDDhhmm)
python -m SimpleHTTPServer Serve current directory tree at http://$HOSTNAME:8000/

你可能感兴趣的:(写得蛮好的linux学习笔记)