查看Linux系统信息
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 arch uname -m uname -r dmidecode -q hdparm -i /dev/hda hdparm -tT /dev/sda cat /proc/cpuinfo cat /proc/interrupts cat /proc/meminfo cat /proc/swaps cat /proc/version cat /proc/net/dev cat /proc/mounts lspci -tv lsusb -tv 1、查看服务器型号:dmidecode | grep 'Product Name' 2、查看主板的序列号:dmidecode |grep 'Serial Number' 3、查看系统序列号:dmidecode -s system-serial-number 4、查看内存型号信息:dmidecode -t memory | egrep 'Manufacturer|Serial Number' 5、查看OEM信息:dmidecode -t 11 6、查看现有内存数量和内存大小:dmidecode | grep -A16 "Memory Device" | grep "Size" |sed 's/^[ \t]*//' // 7、查看最大支持内存容量:dmidecode | grep "Maximum Capacity" |sed "s/^[ \t]*//"
date 显示系统日期
1 2 3 cal 2007 #显示2007 年的日历表date 041217002007 .00 #设置日期和时间 - 月日时分年.秒clock -w #将时间修改保存到 BIOS
关机(关机、重启、登出 )
1 2 3 4 5 6 7 8 shutdown -h now #关闭系统(1) init 0 #关闭系统(2) telinit 0 #关闭系统(3) shutdown -h hours:minutes & #按预定时间关闭系统 shutdown -c #取消按预定时间关闭系统 shutdown -r now #重启(1) reboot #重启(2) logout #注销
文件和目录
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 cd /home cd .. cd ../.. cd cd ~user1 cd - pwd ls ls -F ls -l ls -a ls *[0-9]* tree lstree mkdir dir1 mkdir dir1 dir2 mkdir -p /tmp/dir1/dir2 rm -f file1 rmdir dir1 rm -rf dir1 rm -rf dir1 dir2 mv dir1 new_dir cp file1 file2 cp dir /* . cp -a /tmp/dir1 . cp -a dir1 dir2 ln -s file1 lnk1 ln file1 lnk1 touch -t 0712250000 file1 file file1 outputs the mime type of the file as text iconv -l iconv -f fromEncoding -t toEncoding inputFile > outputFile creates a new from the given input file by assuming it is encoded in fromEncoding and converting it to toEncoding. find . -maxdepth 1 -name *.jpg -print -exec convert "{}" -resize 80x60 "thumbs/{}" \; batch resize files in the current directory and send them to a thumbnails directory (requires convert from Imagemagick)
文件搜索
1 2 3 4 5 6 7 8 9 10 find / -name file1 #从 '/' 开始进入根文件系统搜索文件和目录find / -user user1 #搜索属于用户 'user1' 的文件和目录find /home/user1 -name \*.bin #在目录 '/ home/user1' 中搜索带有'.bin' 结尾的文件find /usr/bin -type f -atime +100 #搜索在过去100 天内未被使用过的执行文件find /usr/bin -type f -mtime -10 #搜索在10 天内被创建或者修改过的文件find / -name \*.rpm -exec chmod 755 '{}' \; #搜索以 '.rpm' 结尾的文件并定义其权限find / -xdev -name \*.rpm #搜索以 '.rpm' 结尾的文件,忽略光驱、捷盘等可移动设备locate \*.ps #寻找以 '.ps' 结尾的文件 - 先运行 'updatedb' 命令 whereis halt #显示一个二进制文件、源码或man的位置 which halt #显示一个二进制文件或可执行文件的完整路径
挂载文件系统
1 2 3 4 5 6 7 8 9 10 11 12 mount /dev/ hda2 /mnt/ hda2 umount /dev/ hda2 fuser -km /mnt/ hda2 umount -n /mnt/ hda2 mount /dev/ fd0 /mnt/ floppy mount /dev/ cdrom /mnt/ cdrom mount /dev/ hdc /mnt/ cdrecorder mount /dev/ hdb /mnt/ cdrecorder mount -o loop file.iso /mnt/ cdrom mount -t vfat /dev/ hda5 /mnt/ hda5 mount /dev/ sda1 /mnt/u sbdisk mount -t smbfs -o username=user,password=pass // WinClient/share /m nt/share
磁盘空间相关
1 2 3 4 5 6 7 8 df -h ls -lSr |more du -sh dir1 du -sk * | sort -rn rpm -q -a --qf '%10{SIZE}t%{NAME}n' | sort -k1,1n dpkg-query -W -f='${Installed-Size;10}t${Package}n' | sort -k1,1n
用户和群组
1 2 3 4 5 6 7 8 9 10 11 12 13 14 groupadd group_name #创建一个新用户组 groupdel group_name #删除一个用户组 groupmod -n new_group_name old_group_name #重命名一个用户组 useradd -c "Name Surname " -g admin -d /home/user1 -s /bin/bash user1 #创建一个属于 "admin" 用户组的用户 useradd user1 #创建一个新用户 userdel -r user1 #删除一个用户 ( '-r' 排除主目录) usermod -c "User FTP" -g system -d /ftp/user1 -s /bin/nologin user1 #修改用户属性 passwd #修改口令 passwd user1 #修改一个用户的口令 (只允许root执行) chage -E 2005 -12 -31 user1 #设置用户口令的失效期限 pwck #检查 '/etc/passwd' 的文件格式和语法修正以及存在的用户 grpck #检查 '/etc/passwd' 的文件格式和语法修正以及存在的群组 newgrp group_name #登陆进一个新的群组以改变新创建文件的预设群组
文件权限
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 使用 "+" 设置权限,使用 "-" 用于取消 ls -lh ls /tmp | pr -T5 -W$COLUMNS chmod ugo+rwx directory1 chmod go-rwx directory1 chown user1 file1 chown -R user1 directory1 chgrp group1 file1 chown user1:group1 file1 find / -perm -u+s chmod u+s /bin/file1 chmod u-s /bin/file1 chmod g+s /home/public chmod g-s /home/public chmod o+t /home/public chmod o-t /home/public
文件的特殊属性
1 2 3 4 5 6 7 8 9 10 - 使用 "+" 设置权限,使用 "-" 用于取消 chattr +a file1 chattr +c file1 chattr +d file1 chattr +i file1 chattr +s file1 chattr +S file1 chattr +u file1 lsattr
打包和压缩文件
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 bunzip2 file1.bz2 #解压一个叫做 'file1.bz2' 的文件 bzip2 file1 #压缩一个叫做 'file1' 的文件 gunzip file1.gz #解压一个叫做 'file1.gz' 的文件 gzip file1 #压缩一个叫做 'file1' 的文件 gzip -9 file1 #最大程度压缩 rar a file1.rar test_file #创建一个叫做 'file1.rar' 的包 rar a file1.rar file1 file2 dir1 #同时压缩 'file1' , 'file2' 以及目录 'dir1' rar x file1.rar #解压rar包 unrar x file1.rar #解压rar包 tar -cvf archive.tar file1 #创建一个非压缩的 tarball tar -cvf archive.tar file1 file2 dir1 #创建一个包含了 'file1' , 'file2' 以及 'dir1' 的档案文件 tar -tf archive.tar #显示一个包中的内容 tar -xvf archive.tar #释放一个包 tar -xvf archive.tar -C /tmp #将压缩包释放到 /tmp目录下 tar -cvfj archive.tar .bz2 dir1 #创建一个bzip2格式的压缩包 tar -jxvf archive.tar .bz2 #解压一个bzip2格式的压缩包 tar -cvfz archive.tar .gz dir1 #创建一个gzip格式的压缩包 tar -zxvf archive.tar .gz #解压一个gzip格式的压缩包 zip file1.zip file1 #创建一个zip格式的压缩包 zip -r file1.zip file1 file2 dir1 #将几个文件和目录同时压缩成一个zip格式的压缩包 unzip file1.zip #解压一个zip格式压缩包
RPM包(Fedora, Redhat及类似系统)
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 rpm -ivh package.rpm rpm -ivh --nodeeps package.rpm rpm -U package.rpm rpm -F package.rpm rpm -e package_name.rpm rpm -qa rpm -qa | grep httpd rpm -qi package_name rpm -qg "System Environment/Daemons" rpm -ql package_name rpm -qc package_name rpm -q package_name --whatrequires rpm -q package_name --whatprovides rpm -q package_name --scripts rpm -q package_name --changelog rpm -qf /etc/httpd/conf/httpd.conf rpm -qp package.rpm -l rpm --import /media/cdrom/RPM-GPG-KEY rpm --checksig package.rpm rpm -qa gpg-pubkey rpm -V package_name rpm -Va rpm -Vp package.rpm rpm2cpio package.rpm | cpio --extract --make-directories *bin* rpm -ivh /usr/src/redhat/RPMS/ `arch`/package.rpm rpmbuild --rebuild package_name.src.rpm
YUM(Fedora, RedHat及类似系统)
1 2 3 4 5 6 7 8 9 10 yum install package_name yum localinstall package_name.rpm yum update package_name.rpm yum update package_name yum remove package_name yum list yum search package_name yum clean packages yum clean headers yum clean all
DEB包 (Debian, Ubuntu及类似系统)
1 2 3 4 5 6 7 8 dpkg -i package.deb #安装/更新一个 deb 包 dpkg -r package_name #从系统删除一个 deb 包 dpkg -l #显示系统中所有已经安装的 deb 包 dpkg -l | grep httpd #显示所有名称中包含 "httpd" 字样的deb包 dpkg -s package_name #获得已经安装在系统中一个特殊包的信息 dpkg -L package_name #显示系统中已经安装的一个deb包所提供的文件列表 dpkg --contents package.deb #显示尚未安装的一个包所提供的文件列表 dpkg -S /bin/ping #确认所给的文件由哪个deb包提供
APT软件工具 (Debian, Ubuntu及类似系统)
1 2 3 4 5 6 7 8 apt-get install package_name #安装/更新一个 deb 包 apt-cdrom install package_name #从光盘安装/更新一个 deb 包 apt-get update #升级列表中的软件包 apt-get upgrade #升级所有已安装的软件 apt-get remove package_name #从系统删除一个deb包 apt-get check #确认依赖的软件仓库正确 apt-get clean #从下载的软件包中清理缓存 apt-cache search searched-package #返回包含所要搜索字符串的软件包名称
文本处理
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 cat file1 file2 ... | command <> file1_in.txt_or_file1_out.txt general syntax for text manipulation using PIPE, STDIN and STDOUTcat file1 | command ( sed, grep, awk, grep, etc...) > result.txt cat file1 | command ( sed, grep, awk, grep, etc...) >> result.txt grep Aug /var/log/messages grep ^Aug /var/log/messages grep [0-9] /var/log/messages grep Aug -R /var/log/* sed 's/stringa1/stringa2/g' example.txt sed '/^$/d' example.txt sed '/ *#/d; /^$/d' example.txt echo 'esempio' | tr '[:lower:]' '[:upper:]' sed -e '1d' result.txt sed -n '/stringa1/p' sed -e 's/ *$//' example.txt sed -e 's/stringa1//g' example.txt sed -n '1,5p;5q' example.txt sed -n '5p;5q' example.txt sed -e 's/00*/0/g' example.txt cat -n file1 cat example.txt | awk 'NR%2==1' echo a b c | awk '{print $1}' echo a b c | awk '{print $1,$3}' paste file1 file2 paste -d '+' file1 file2 sort file1 file2 sort file1 file2 | uniq sort file1 file2 | uniq -u sort file1 file2 | uniq -d comm -1 file1 file2 comm -2 file1 file2 comm -3 file1 file2
字符设置和文件格式转换 1 2 3 4 dos2unix filedos.txt fileunix.txt #将一个文本文件的格式从MSDOS转换成UNIX unix2dos fileunix.txt filedos.txt #将一个文本文件的格式从UNIX转换成MSDOS recode ..HTML < page.txt > page.html #将一个文本文件转换成html recode -l | more #显示所有允许的转换格式
文件系统分析 1 2 3 4 5 6 7 8 9 badblocks -v /dev/ hda1 fsck /dev/ hda1 fsck.ext2 /dev/ hda1 e2fsck /dev/ hda1 e2fsck -j /dev/ hda1 fsck.ext3 /dev/ hda1 fsck.vfat /dev/ hda1 fsck.msdos /dev/ hda1 dosfsck /dev/ hda1
初始化一个文件系统 1 2 3 4 5 6 mkfs /dev/ hda1 mke2fs /dev/ hda1 mke2fs -j /dev/ hda1 mkfs -t vfat 32 -F /dev/ hda1 fdformat -n /dev/ fd0 mkswap /dev/ hda3
SWAP文件系统 1 2 3 mkswap /dev/ hda3 swapon /dev/ hda3 swapon /dev/ hda2 /dev/ hdb3
备份 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 dump -0aj -f /tmp/home0.bak /home dump -1aj -f /tmp/home0.bak /home restore -if /tmp/home0.bak rsync -rogpav --delete /home /tmp rsync -rogpav -e ssh --delete /home ip_address:/tmp rsync -az -e ssh --delete ip_addr:/home/public /home/local rsync -az -e ssh --delete /home/local ip_addr:/home/public dd bs=1M if =/dev/hda | gzip | ssh user@ip_addr 'dd of=hda.gz' dd if =/dev/sda of=/tmp/file1 tar -Puf backup.tar /home/user 执行一次对 '/home/user' ( cd /tmp/local/ && tar c . ) | ssh -C user@ip_addr 'cd /home/share/ && tar x -p' ( tar c /home ) | ssh -C user@ip_addr 'cd /home/backup-home && tar x -p' tar cf - . | (cd /tmp/backup ; tar xf - ) find /home/user1 -name '*.txt' | xargs cp -av --target-directory=/home/backup/ --parents find /var/log -name '*.log' | tar cv --files-from=- | bzip2 > log.tar.bz2 dd if =/dev/hda of=/dev/fd0 bs=512 count=1 dd if =/dev/fd0 of=/dev/hda bs=512 count=1
光盘 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 cdrecord -v gracetime=2 dev=/dev/cdrom -eject blank=fast -force mkisofs /dev/cdrom > cd .iso mkisofs /dev/cdrom | gzip > cd _iso.gz mkisofs -J -allow-leading-dots -R -V "Label CD" -iso-level 4 -o ./cd.iso data_cd cdrecord -v dev=/dev/cdrom cd .iso gzip -dc cd _iso.gz | cdrecord dev=/dev/cdrom - mount -o loop cd .iso /mnt/iso cd-paranoia -B cd-paranoia -- "-3" cdrecord --scanbus dd if =/dev/hdc | md5sum
网络 - (以太网和WIFI无线) 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 ifconfig eth0 ifup eth0 ifdown eth0 ifconfig eth0 192.168.1.1 netmask 255.255.255.0 ifconfig eth0 promisc dhclient eth0 route -n route add -net 0 /0 gw IP_Gateway route add -net 192.168.0.0 netmask 255.255.0.0 gw 192.168.1.1 route del 0 /0 gw IP_gateway hostname host www.example.com nslookup www.example.com ip link show mii-tool ethtool netstat -tupl tcpdump tcp port 80
watch
这个命令是动态查看命令执行的结果。比如如果需要每隔一秒高亮显示网络连接数的变化情况。则 watch -n 1 -d netstat -ant
1 2 3 4 5 6 7 例子:每隔一秒高亮显示http连接数的变化情况 watch -n 1 -d 'pstree | grep http' 例子:十秒一次输出系统的平均负载 watch -n 10 'cat /proc/loadavg'