Linux 实用命令汇总

1 查找文件:
(1) 模糊查找文件
# find /usr -name *squid.conf*  -ls
(2) 无错误查找法
# find / -name '*squid.conf*'  2>/dev/null
Ps: inliux:  0 =stdin   1 =stdout   2 =stderr
(3)查找多个文件
find /bin/sbin/usr/bin/usr/sbin-namesquid


2 chmod
(1) 字符:chmod u+rtest.txt就是对test.tex操作,是拥有者有读的权限:u(user),g(group),o(other),a(all)分别代表文件拥有者,所在群组,
其他用户,所有用户
(2) 数字::r=4,w=2,x=1
若要rwx属性则4+2+1=7;若要rw-属性则4+2=6;若要r-x属性则4+1=5。     
如:chmod 765text.txt
产生的作用是 拥有者有权限(rwx),所在群组有权限(rw),其他用户权限(rx).
(3) –Rf: 选项对子目录生效


3 tail
(1) tail -f -10squirm.match 实时显示文件最后10行内容;
(2) tail -n+2 file 从开始数第二行的位置, -nNumber 从首行或末行位置来读取指定文件,位置由Number 变量的符号(+ 或 - 或无)表示,并通过行号Number 进行位移。
(3) tail -f proxy.log >1 显示1即可cat1


4 grep
(1)grep Polo /usr/local/squirm/logs/* 查找此目录内容中所有文件含有Polo关键字的行内容
(2)tail -f /opt/log/squirm.log |grep -A30 -B1 UEF62P201OQZSWYN
-A30 -B15 前15行后30行

 

5 more -3 显示3行


5 bin
(1)chmod 755 *.bin------把bin文件改成可执行文件
              ./*.bin---------直接执行bin文件,然后按提示操作
(2)chmod +x a.bin
              ./a.bin

6 查看共享内存
使用ipcs命令,不加任何参数时,会把共享内存/信号量/消息队列的信息都打印出来。如果只想显示共享内存信息,则使用ipcs–m


7 ssh
cat/etc/ssh/sshd_config ssh的默认端口22,FTP端口21


8 fedora默认不允许root登录,
(1)vi /etc/pam.d/gdm注释掉:auth required pam_succed_if.so user != rootquiet 
(2)vi /etc/pam.d/gdm-password注释掉:auth required pam_succed_if.so user != rootquiet
Ps: 修改密码:passwd root 


9 ifconfig
ifconfig (指定接口:ifconfig eth0)


10 硬件
查看版本和内核,CPU,主板,内存
> cat/etc/issue
CentOSrelease 4.4 (Final)
Kernel \r onan\m
> cat/proc/version
Linux version2.6.17.14.WBXsmp (
[email protected]) (gcc version3.4.6 20060404 (Red Hat3.4.6-3)) #1SMP MonAug 13 22:50:31 EDT2007
>cat/proc/cpuinfo 查看cpu信息,processor 0 为一个CPU, 1为两个,flags超线程。
>lspci 查看主板信息
>free 查内存


11 SCP
#scp -r -P22 wbxtf-1.5.0-1.x86_64.centos44.rpm
[email protected]:/home/build/
本地19,复制到20去:
或者scp -P333 -r print.py
[email protected]:/mnt/
本地20执行,从19复制来:
#scp -P 333 –r
[email protected]:/home/test/tcpdump-3.8.2-12.el4_6.1.x86_64.rpm/home/\


12 添加环境变量
> exportWEBEX_DMC_HOME=/opt/webex/idmap
> echo %WEBEX_DMC_HOME


13 linuxstaf
"/STAFProc: error while loadingshared libraries: libSTAF.so: cannotopenshared objectfile:Nosuch file or directory"
source /etc/profile
"./STAFProc: error while loadingshared libraries: libcrypto.so.0.9.8: cannotenable executablestack asshared objectrequires: Permissiondenied"
execstack --clear-execstack /usr/local/staf/lib/libcrypto.so.0.9.8


14 远程mount安装staf
/mnt/staf为目标
/home/fujian/wbxtf-1.5.0-1.x86_64.centos44.rpm:67.44
服务器端(67.44):
(1)修改权限 chmod 777 /home/fujian
(2)修改vi /etc/exports
增加/home/fujian10.224.*.*(rw,sync)
(3)确认mount内容
showmount-e 10.224.67.44
或者showmount-e / showmount查看本地可以被MOUNT的内容tail /var/log/messages
(4)重启服务servicenfsrestart
(5)关闭防火墙service iptablesstop
Client端:
mount-tnfs10.224.39.182:/home/build/ /mnt/staf
rpm -ivh wbxtf-1.5.0-1.x86_64.centos44.rpm
卸载挂载umount/mnt/staf
删除目录rmdirstaf


15 VNC
(1)启动
# vncserver :1
client
测试 10.224.67.44:1
重新启动VNC服务命令  [root@testdb ~]# /etc/init.d/vncserver restart
修改密码
root@testdb~]# vncpasswd

(2)KDE or GNOME
# cat/root/.vnc/xstartup
#!/bin/sh
......
xterm -geometry 80x24+10+10 -ls-title "$VNCDESKTOP Desktop" &
twm &
最后一行修改为“startkde &”,重新启动vncserver服务后就可以登陆到KDE桌面环境
后一行修改为“gnome-session&”,再重新启动vncserver服务后就可以登陆GNOME桌面环境
(4) 设置自动启动  
# chkconfig vncserver on
# chkconfig --listvncserver
chkconfig --level 235 apmd off
httpd           0:关闭  1:关闭  2:关闭  3:关闭  4:关闭  5:启用  6:关
bluetooth       0:关闭  1:关闭  2:关闭  3:关闭  4:关闭  5:关闭  6:关
这是linux下的6种状态,说明HTTPD这个服务在0.1.2.3.4.6下是关闭的,在5下是开启的,0代表的是关机状态,6代表的是重启状态,1代表的是单用户模式,2是没有网络功能的多用户模式,3是有网络功能的多用户模式,4还没有定义,5是桌面模式,123都是用的命令行


16 squid 安全关闭
最安全的停止squid的方法是使用squid -kshutdown命令:
%squid -kshutdown
该命令发送TERM信号到运行中的squid进程。在接受到TERM信号后,squid关闭进来的套接字以拒收新请求。然后它等待一段时间,用以完成外出请求。默认时间是30秒,你可以在shutdown_lifetime指令里更改它。
假如因为某些理由,squid.pid文件丢失或不可读,squid -k命令会失败。在此情形下,你可以用ps找到squid的进程ID,然后手工杀死squid。例如:
%psax |grepsquid
假如你看到不止一个squid进程,请杀死以(squid)显示的那个。例如:
% psax | grepsquid
 
  294  ??  Is     0:00.01squid -sD
 
  296  ?? S      0:00.27 (squid) -sD (squid)

% kill -TERM 296

/etc/init.d/squidstart
CentOS4.4-64:wsz1dmc001:root>servicesquid
Usage: /etc/init.d/squid {start|stop}

17 tcpdump
/sbin/tcpdump -i eth0 port80 -X -s1000
 
18 -v
> ps-ef|grep idmap |grep -v grep | grep -vtail
nobody   18500     1  0 Apr22 ?        00:00:04 (idmap)

19 delete与copy
rmdir 只能删除空目录
-r 对目录操作
rm -rtest递归删除目录test
-f 强行删除
复制cp总有提示:可用\cp 1.txt1.txt
在终端执行alias就可以看出来了。[root@devdb ~]# aliasaliascp='cp -i'也可以这样解决[root@devdb ~]# vi ~/.bashrc
[root@linuxtmp]# cp /etc/ /tmp
cp: omitting directory `/etc’ <== 如果是目录,不能直接复制,要加上 -r 的参数
[root@linuxtmp]# cp -r /etc/ /tmp

20 sed
sed -n  '$=' /opt/webex/idmap/log/result.log
显示最后一行行数

wc -l result.log也可以


cd /usr/local/idmap/etc;
sed -e '43c\MaxShardStoreNum=3' idmap.conf >1.conf;
cp -f 1.conf idmap.conf;
 
21squid因为空间满了,启动不起来解决
Rm –rf /var/cache/squid   这个目录是squid.conf设置的
 
Mkdir /var/cache/squid
 
Chmod 777 /var/cache/squid 授劝
 
/usr/local/squid/sbin/squid –z 创建交换空间
 
Killall idmap 如果异常存在,也启动不来,所以再killall
 
/usr/local/squid/sbin/squid –D 安全启动
 
22 查看磁盘空间
 
cat/proc/swaps仅查看swaps
 
fdisk是查看硬件分区的大小的,一般是这样使用的fdisk -l,如果挂载了多块硬盘,每个硬盘有多个分区,就是用fdisk

du用于查看文件或者目录大小,通常的用法有du -sm,du -sh
du:查询档案或目录的磁盘使用空间
a:显示全部目录和其次目录下的每个档案所占的磁盘空间
b:大小用bytes来表示 (默认值为k bytes)
c:最后再加上总计 (默认值)
s:只显示各档案大小的总合 (summarize)
x:只计算同属同一个档案系统的档案
L:计算所有的档案大小
常用命令:du -a

df用于查看挂载的逻辑分区的剩余空间。通常使用df -a
a:显示全部的档案系统和各分割区的磁盘使用情形
i:显示i -nodes的使用量
k:大小用k来表示 (默认值)
t:显示某一个档案系统的所有分割区磁盘使用量
x:显示不是某一个档案系统的所有分割区磁盘使用量
T:显示每个分割区所属的档案系统名称
常用命令:df -hi
 
df -m 以M为单位显示空间大小
 
23 secure crt
 
sz update_dms1.3 下载
rz               上传
 
24 rpm
[root@wsz1dmc003soft]# rpm -qa wbxtf
wbxtf-1.4.5-1
[root@wsz1dmc003soft]# rpm -e wbxtf-1.4.5-1
 
25tasklist/s10.224.56.39 /u leon/p leon
26 iptables
/sbin/iptables-tfilter -A OUTPUT-d 10.224.225.10  -mstring --string 'WBXSM' --algo kmp -j DROP
 
27 进程中止
$ pgrepsquid   查找
28439
28441
$ pkill -9squid;killall  idmap; /usr/local/squid/sbin/squid -D  立即结束
 
28 chown
[root@wsz1dmc001tmp]# chown-vnobody:fujiansoft

[root@wsz1dmc001tmp]# chown-vnobodysoft
-v详细nobody 用户,fujian组
 
chown-Rfnobody:fujiansoft  对子目录有效果
 
29 vi
 
(1)查找命令
/string、?string——从光标所在处向后或向前查找相应的字符串的命令。
n继续查找,N反向查找
(2)/u 在VI中撤销
(3)!wq 强行保存
 
30 yum
yum remove vsftp
 
31ftp
 
>ftp10.224.67.44
> ls
> cdsoft
250 Directorysuccessfully changed.
> ls
> lcd
Local directorynow C:\DocumentsandSettings\fu.jian.
> lcd c:\
Local directorynow C:\.
>!dir
查看本地文件列表
> get1.pem
> put1.pem
> bye

get "1 2.txt"双引号才能下载空格的

ftp> binary
200 Switching to Binary mode.


# getsebool -a | grepftp
allow_ftpd_anon_write --> off
allow_ftpd_full_access--> off
allow_ftpd_use_cifs--> off
allow_ftpd_use_nfs--> off
ftp_home_dir --> off
httpd_enable_ftp_server --> off
tftp_anon_write –> off
将红色字体部分的值改成on就可以了,设置的方法如下:
#setsebool -Pftp_home_dir 1
-P 永久性变化,不是临时更改
32 sudo
sudo时提示"xxx isnotinthesudoersfile.Thisincidentwill be reported.其中XXX是你的用户名,也就是你的用户名没有权限使用sudo,我们只要修改一下/etc/sudoers文件就行了。下面是修改方法:

1)进入超级用户模式。也就是输入"su -",系统会让你输入超级用户密码,输入密码后就进入了超级用户模式。(当然,你也可以直接用root用)
2)添加文件的写权限。也就是输入命令"chmod u+w /etc/sudoers"。
3)编辑/etc/sudoers文件。也就是输入命令"vim /etc/sudoers",输入"i"进入编辑模式,找到这一行:"rootALL=(ALL) ALL"在起下面添加"xxx ALL=(ALL) ALL"(这里的xxx是你的用户名),然后保存(就是先按一下Esc键,然后输入":wq")退出。
4)撤销文件的写权限。也就是输入命令"chmod u-w /etc/sudoers"。
5)如果需要sudosu - 不用输入密码则
##Samething withouta password
# %wheel        ALL=(ALL)      NOPASSWD: ALL
wbxftp          ALL=(ALL)      NOPASSWD: ALL
33 更改系统语音


      修改/etc/sysconfig/i18n文件

      中文:

      LANG="zh_CN.UTF-8"

     SUPPORTED="zh_CN.UTF-8:zh_CN:zh:en_US.UTF-8:en_US:en"

     SYSFONT="latarcyrheb-sun16"

      英文:

      LANG="en_US.UTF-8"

    SUPPORTED="en_US.UTF-8:en_US:en:zh_CN.UTF-8:zh_CN:zh:fr_FR.UTF-8:fr_FR:fr:

                             de_DE.UTF-8:de_DE:de:ja_JP.UTF-8:ja_JP:ja:es_ES.UTF-8:es_ES:es"

     SYSFONT="latarcyrheb-sun16"
34 修改SSH欢迎信息:cat/etc/motd
35 history 查看过去命令
(1)history 10查看倒数10条
(2)history -c 清除过去记录
(3)!ps执行最近一条的带PS开头的命令
(4)!编号ID,执行history中ID的命令
(5)!! 重复执行上条命令
(6)Ctrl+R 对命令历史进行搜索,。当找到命令后,通常再按回车键就可以执行该命令。如果想对找到的命令进行调整后再执行,则可以按一下左
或右方向键。
(7)# exportHISTTIMEFORMAT='%F %T'  带时间的查找history

36  wc
wc 字数计算
wc [-clw][--help][--version][文件...]
wc -c统计字符
wc -l统计行数
wc -w统计字数
若不指定文件名称、或是所给予的文件名为“-”,则wc指令会从标准输入设备读取数据。
 
37 系统
系统
# uname -a               # 查看内核/操作系统/CPU信息
# cat/etc/issue   # 查看
操作系统版本
# cat/proc/cpuinfo      # 查看CPU信息
# hostname               # 查看计算机名
# lspci -tv              # 列出所有PCI设备
# lsusb -tv              # 列出所有USB设备
# lsmod                  # 列出加载的内核模块
# env                    # 查看环境变量
资源
# free -m                # 查看内存使用量和交换区使用量
# df -h                  # 查看各分区使用情况
# du -sh<目录名>        # 查看指定目录的大小
# grep MemTotal /proc/meminfo   # 查看内存总量
# grep MemFree /proc/meminfo    # 查看空闲内存量
# uptime                 # 查看系统运行时间、用户数、负载
# cat/proc/loadavg      # 查看系统负载磁盘和分区
# mount| column-t      # 查看挂接的分区状态
# fdisk -l               # 查看所有分区
#swapon-s              # 查看所有交换分区
# hdparm -i /dev/hda     # 查看磁盘参数(仅适用于IDE设备)
# dmesg | grep IDE       # 查看启动时IDE设备检测状况
网络
# ifconfig               # 查看所有网络接口的属性
# iptables-L            # 查看防火墙设置
# route -n               # 查看路由表
#netstat-lntp          # 查看所有监听端口
#netstat-antp          # 查看所有已经建立的连接
#netstat-s             # 查看网络统计信息
进程
# ps-ef                 # 查看所有进程
#top                    # 实时显示进程状态用户
# w                      # 查看活动用户 /ps:查看活动用户及最后命令
# id <用户名>            # 查看指定用户信息
# last                   # 查看用户登录
日志
# cut-d: -f1 /etc/passwd   # 查看系统所有用户
# cut-d: -f1 /etc/group    # 查看系统所有组
# crontab -l             # 查看当前用户的计划任务
服务
# chkconfig --list       # 列出所有系统服务
# chkconfig --list| grep on    # 列出所有启动的系统服务程序# rpm -qa                # 查看所有安装的软件包
 
38 tar -xzvf file.tar
39 ntpdate asia.pool.ntp.org
上面此命令就是去同步授时中心的时间
如果要让系统每天23:00去同步,这样可以使用上面所将的crontab设置计划同步
如下命令
#crontab -e
进入crontab编辑模式,使用方法同vi
输入 0 23 * * *ntpdate asia.pool.ntp.org >> /var/log/ntpdate.log 配置文件,cat/etc/ntp.conf


40 多页分屏显示  history|more


41 mount
(1)mount10.224.39.62:/netapp/dc1/ardms/ardms/
umount/ardms
umount10.224.39.62:/netapp/pri/ardms/ardms
(2)mountntfs
mkdir ipod

wgethttp://superb-east.dl.sourceforge.net/sourceforge/fuse/fuse-2.6.0.tar.gz

mount-ntfs-3g  /dev/sdb1 /mnt/ipod
42 分区
/boot100M
/SWAP mem*2
/usr>/opt软件安装地
/data 自定义存数据地方,最大剩余空间
/var>/tmp 服务器要求较高
/    系统文件存放地,保持一定大小
/home 用户目录,一般大小  


43  查看文件大小
du –shdirname
如果查看某个目录下所有文件及文件的大小:
du –sh*
按照文件大小排序
du –sh* |sort–n
44 查看文件个数
|wc -l
45 linux有六种运行级别,默认3,5,其中5为图形模式,3为字符模式。etc/inittab 
        # 0 - 停机(千万不要把initdefault设置为0 )
    # 1 - 单用户模式
    # 2 - 多用户,但是没有NFS
    # 3 - 完全多用户模式
    # 4 - 没有用到
    # 5 - X11
    # 6 - 重新启动(千万不要把initdefault设置为6 )
    # 对各个运行级的详细解释:
    0 为停机,机器关闭。 /sbin/poweroff
    1 为单用户模式,就像Win9x下的安全模式类似。
    2 为多用户模式,但是没有NFS支持。
    3 为完整的多用户模式,是标准的运行级。
    4 一般不用,在一些特殊情况下可以用它来做一些事情。例如在笔记本电脑的电池用尽时,可以切换到这个模式来做一些设置。
    5 就是X11,进到X Window系统了。
    6 为重启,运行init6机器就会重启。 

 

46 添加tomcat进service

(1) touch /etc/init.d/tomcat
(2) chmod 777 /etc/init.d/tomcat

(3) vi /etc/init.d/tomcat

#!/bin/sh
#chkconfig: 5 80 05
#description:service

case $1 in

start)
/usr/local/apache-tomcat-6.0.26/bin/startup.sh
;;

stop)
/usr/local/apache-tomcat-6.0.26/bin/shutdown.sh
;;

*)
echo 'usage:start|stop'
;;

esac

(4)chkconfig --addtomcat

#chkconfig: 2345 98 98 表示在执行命令 # chkconfig –add httpd 时会在目录 /etc/rc2.d/ 、/etc/rc3.d/ /etc/rc5.d 分别生成文件S98httpd和 K98httpd

47 启动菜单 按E,再按E,然后添加数字1,按B启动,passwd root修改密码

48 查看运行级别 runlevel
 

49  getIndexlog('10.224.95.150', '37fb4f22-4a29-47ce-84ed-5df79e53146f', '/usr/local/apache-tomcat/logs/wbxdms.2010-07-27.log')

方法的好处是当完成一个操作,取最新的以保证不是后面相同UUID的操作,同时后面即使有相同UUID的操作也没有关系,因为从当前行找最近的。

 

 

j2eeweb:ahf6dmi002:logs # sed -n '/37fb4f22-4a29-47ce-84ed-5df79e53146f/=' wbxdms.2010-07-27.log   //获取这个UUID的行的集合

358428      //取最后一行,即是最新的一行,定为起始行,

 

 tail -n +358428 wbxdms.2010-07-27.log |grep -n '</objects>'    //从上面的起始行开始检索,查找</objects>,也会返回一系列集,此时取最接近起始行的行,用字符串分割,取出第一个数字,加上起始行,定位结束行

27:     </objects>

108:    </objects>

  

358428-3

358428+27

sed -n '358425,358455p'  wbxdms.2010-07-27.log     //将起始行-3,将起始行与结束行之间的行数给取出来。

 

50 tcpdump -i eth0 port 8070 -s 0 -w b.pkt

 

51 link 目标在前,同时不需要多建文件,否则多层目录

j2eeweb:ahf6dms001:conf # cd /var
j2eeweb:ahf6dms001:var # ln -s /usr/local/apache-tomcat/webapps/wbxdms/WEB-INF/classes/conf tomcat
 

52 mkdir -p 自动创建多级目录 

53 pkill -9 squid; /usr/local/squid/sbin/squid -D

54 vi命令 <shift>+G 最后一行

55 逆序显示log: tac error.log |grep error|more

 

56  grep '123'  wbxdms.log | less 分页

57  ll -h 查看文件大小

58 touch 创建文件

 

59  split -b 2m qd.2011-11-08.log   qdlog 用2M划分文件。

 

-l n:将输入文件每n行拆分为一个文件,默认值为1 000。

-b n[bkm]:以字节为单位进行拆分,并设定每个拆分后的文件的大小。b代表512KB,k代表1KB,m代表1MB。

 

60 默认下载到当前执行wget的目录里,
-O   可以指定下载的路径

 

61  more +4 -10 schedulerJob.xml

从第四行开始显示10行

 

62 

配对1:

root@linux ~]# tar -zcvf   /tmp/etc.tar.gz      /etc <==打包后,以 gzip 压缩

tar -zxvf /tmp/etc.tar.gz

 

配对2:

root@linux ~]# tar -cvf   /tmp/etc.tar     /etc <==打包后,以 gzip 压缩

tar -xvf /tmp/etc.tar.gz


63 sysctl -a|grep dirty


64  sed -i 's/%M:%L/%m:%l/g'  log4j.xml


65

vi /etc/ssh/sshd_config


/etc/init.d/sshd restart


------------------------


66  一直选y安装

yum -y install samba


67  有时用yum升级一些文件时,会出现以下情况:
another app is currently holding the yum lock;waiting for it to exit...
可以通过强制关掉yum进程:
#rm -f /var/run/yum.pid
然后就可以使用yum了。



68  ls -t 按时间顺序


69  删除文件之外的 rm `ls | grep -v "aa"`



yum install yum-downloadonly -y

 

yum install samba -y --downloadonly --downloaddir=/var/rpm

 

 

mount -t cifs -o username=jiafu,password=ssss //10.224.18.223/vscm-share/jiafu  /var/rpm


删除递归子目录

find . -name "*.o"  | xargs rm -f



文件颜色的含义:蓝色为文件夹;绿色是可执行文件;浅蓝色是链接文件;红框文件是加了SUID位,任意限权;
红色为压缩文件;褐色为设备文件。


`ls -t /logs/*sip*|head -1`

`ls -rt /logs/*sip*|head -1`



scp 不输入密码:


sshpass-p password123 scp -o StrictHostKeyChecking=no  /root/abc.sh 192.168.1.15:/root


有时候:

sshpass-p password123 scp    /root/abc.sh 192.168.1.15:/root




你可能感兴趣的:(linux,网络,防火墙,磁盘,桌面环境)