常用指令

ls   显示文件或目录

-l           列出文件详细信息l(list)

-a          列出当前目录下所有文件及目录,包括隐藏的a(all)

mkdir 创建目录

-p           创建目录,若无父目录,则创建p(parent)

cd 切换目录

touch 创建空文件

echo 创建带有内容的文件。

cat 查看文件内容

cp 拷贝

mv 移动或重命名

rm 删除文件

-r            递归删除,可删除子目录及文件

-f            强制删除

find 在文件系统中搜索某文件

wc 统计文本中行数、字数、字符数

grep 在文本文件中查找某个字符串

rmdir 删除空目录

tree 树形结构显示目录,需要安装tree包

pwd 显示当前目录

ln 创建链接文件

more、less 分页显示文本文件内容

head、tail 显示文件头、尾内容

ctrl+alt+F1 命令行全屏模式

系统管理命令

stat 显示指定文件的详细信息,比ls更详细

who 显示在线登陆用户

whoami 显示当前操作用户

hostname 显示主机名

uname 显示系统信息

top 动态显示当前耗费资源最多进程信息

ps 显示瞬间进程状态 ps -aux

du 查看目录大小 du -h /home带有单位显示目录信息

df 查看磁盘大小 df -h 带有单位显示磁盘信息

ifconfig 查看网络情况

ping 测试网络连通

netstat 显示网络状态信息

man 命令不会用了,找男人 如:man ls

clear 清屏

alias 对命令重命名 如:alias showmeit=”ps -aux” ,另外解除使用unaliax showmeit

kill 杀死进程,可以先用ps 或 top命令查看进程的id,然后再用kill命令杀死进程。

打包压缩相关命令

gzip:

bzip2:

tar: 打包压缩

-c              归档文件

-x              压缩文件

-z              gzip压缩文件

-j              bzip2压缩文件

-v              显示压缩或解压缩过程 v(view)

-f              使用档名

例:

tar -cvf /home/abc.tar /home/abc 只打包,不压缩

tar -zcvf /home/abc.tar.gz /home/abc 打包,并用gzip压缩

tar -jcvf /home/abc.tar.bz2 /home/abc 打包,并用bzip2压缩

当然,如果想解压缩,就直接替换上面的命令 tar -cvf / tar -zcvf / tar -jcvf 中的“c” 换成“x” 就可以了。

关机/重启机器

shutdown

-r             关机重启

-h             关机不重启

now          立刻关机

halt 关机

reboot 重启

Linux管道

将一个命令的标准输出作为另一个命令的标准输入。也就是把几个命令组合起来使用,后一个命令除以前一个命令的结果。

例:grep -r “close” /home/* | more 在home目录下所有文件中查找,包括close的文件,并分页输出。

Linux软件包管理

dpkg (Debian Package)管理工具,软件包名以.deb后缀。这种方法适合系统不能联网的情况下。

比如安装tree命令的安装包,先将tree.deb传到Linux系统中。再使用如下命令安装。

sudo dpkg -i tree_1.5.3-1_i386.deb 安装软件

sudo dpkg -r tree 卸载软件

注:将tree.deb传到Linux系统中,有多种方式。VMwareTool,使用挂载方式;使用winSCP工具等;

APT(Advanced Packaging Tool)高级软件工具。这种方法适合系统能够连接互联网的情况。

依然以tree为例

sudo apt-get install tree 安装tree

sudo apt-get remove tree 卸载tree

sudo apt-get update 更新软件

sudo apt-get upgrade

将.rpm文件转为.deb文件

.rpm为RedHat使用的软件格式。在Ubuntu下不能直接使用,所以需要转换一下。

sudo alien abc.rpm

vim使用

vim三种模式:命令模式、插入模式、编辑模式。使用ESC或i或:来切换模式。

命令模式下:

:q 退出

:q! 强制退出

:wq 保存并退出

:set number 显示行号

:set nonumber 隐藏行号

/apache 在文档中查找apache 按n跳到下一个,shift+n上一个

yyp 复制光标所在行,并粘贴

h(左移一个字符←)、j(下一行↓)、k(上一行↑)、l(右移一个字符→)

帮助命令
man eg: man ls
help eg: help cd
info eg: info ls
–help eg: ls –help
查看环境变量的命令
export,printenv,env,set
查看时间的命令
date,hwclock,cal
date :显示或者设置系统的时钟
-s 设置时间
-d 显示字符串所指的时间或日期
显示时间

            # date -d "$date"
            # date "+%y" 显示年
            # date '+%y-%m-%d-%k-%M-%S' 显示年月日时分秒
            # date "+%y" 显示年
            # date '+%y-%m-%d-%k-%M-%S' 显示年月日时分秒
  设置时间 # date -s 2013-07-14
            # date -s 19:22:22
            # date -s "2013-07-14 19:22:22" 
hwclock : 显示硬件时钟
            # hwclock
          设置硬件时间
            # hwclock --set --date="13/07/14 12:05:22"
cal: 显示公里日历(阳历日历)
          # cal 

which 查找文件

# which COMMAND

type 显示命令的类型(内部命令/外部命令)

# type COMMAND

file 显示文件类型

# file filename 

echo 显示字符串

# echo $PATH

hash 用来显示,添加,清除哈希表
简单的说就是一种将任意长度的消息压缩到某一固定长度的消息摘要的函数 。

# hash -l 显示为
builtin(内部命令) hash -p /usr/bin/file file
builtin hash -p /bin/chmod chmod
builtin hash -p /bin/date date
builtin hash -p /usr/bin/stat stat
builtin hash -p /usr/bin/man man
builtin hash -p /usr/bin/info info
builtin hash -p /bin/ls ls
builtin hash -p /usr/bin/clear clear

目录命令
cd
cd ~ 回家目录
cd 回家目录
cd - dirname 进入指定目录
cd - 在上一个目录和当前目录来回切换
dirname 指定路径目录
mkdir 创建目录
rmdir 删除目录
pwd 显示当前目录
文本文件相关命令
查看
cat,tac

    # cat /etc/passwd 用户的属性信息
    # cat /etc/shadow 影子口令  把密码放到另外一个文件中去  只能让管理员访问
    # cat /etc/group 组的属性信息
    # cat /etc/gshadow 组的密码
more/less
    more  向后翻  在翻至文件尾部之前允许向前翻
    less  向前翻
head/tail
    head 文件前n(默认前10)行
    tail ~    后      后
      -n #  -n 20
      -#    -20

创建
nano
ctrl+o 保存
ctrl+x 退出
touch
修改文件时间戳
access 访问时间 -a
modify 修改时间 -m
-t 指定时间格式 [cc]yymmddhhmm.ss
stat file
显示文件的属性信息
访问时间
修改
改变
编辑
nano
vim
复制
cp src(源) 。。。DEST(目标目录)
-r 递归复制
-a 比-r全面,归档
-v 过程
-i 交互式复制
移动
mv
删除
rm
-r 逐级删除
-i 提醒
-f 强行删除
命令别名
alias command=command

# alias  cls=clear

通配符
bash支持文件通配,globbing

* 任意长度的任意字符
?任意单个字符
[]  指定范围内的任意单个字符[a-z]
[^] 脱字符,取反,指定范围外的单个字符[^0-9]

添加用户
useradd,adduser

# useradd USERNAME  创建用户时为其创建同名组,家目录,用户的私有组
    -u UID,有效范围0-65535
    -g GID,有效范围已有的GID
    -c 注释
    -d /path/to/somewhere
    -s /path/to/shell_command 切换到shell的命令上
    -r 创建系统用户,ID号1-499之间的用户(系统用户的家目录虽然有路径,却并没有真正给他创建目录)
    -M 不为用户创建家目录
    -m 必须为用户创建家目录

转换用户
su(switch user)
su USERNAME
su -l USERNAME=su - USERNAME

查看用户的id
id USERNAME
-u
-g
-n(名字)
-un
-gn

创建组:
groupadd USERNAME
/etc/group
组名:密码占位符,GID,以此组为额外组的用户列表,用户间用逗号分隔
-g GID 创建组的时候为其制定GID
-r 创建系统组
修改用户属性
usermod
-u
-g 改基本组
-G 额外组与-a一块使用 -a(append追加)保留原来的额外组,新增额外组
-s shell
-l 修改用户的登录名称
-m -d /path/to/sommewhere 给用户修改新的家目录,并将原有家目录中的用户一并挪过去
groupmod 修改组属性
-g GID
-n NEW_NAME
密码管理
passwd 修改自己的密码
passwd
-l 锁定用户帐号
-u 解锁
密钥属性的修改
passwd
-e 设定过期期限
-n 设定密码最短使用天数
-x 设定最长使用天数
-w 警告天数
-i 非活动时长
chage
-d 修改密码的最近一次修改时间
-m –mindays MIN_DAYS 最短使用期限
-M –maxdays MAX_DAYS 最长使用期限
-W –warndays WARN_DAYS 警告天数
-I –inactive 非活动天数
-E –expiredate 过期时间
usermod
-e 指定账户过期时间
-i 跟上天数:表示非活动天数
gpasswd 为组设定密码
newgrp GROUP 临时设定指定的组为自己的基本组

改变文件的权限
chmod change mode
chmod [选项]权限文件
权限定义方式
1.同事修改三类用户的权限;8进制数字方式
2.修改某一些或某些类用户的权限:u,g,o
u=rw
u=,g=
ug=
3.只操作某类用户的某位或者某些位权限:u,g,o,a
+/-
u+w
+x
-x
g-rw(把属主的读写权限删除)
选项
-R :递归修改权限
–reference=/path/to/somefile FILE
修改文件的属主和属组
chown[选项] 用户 文件
chgrp[选项] 组 文件
选项
-R :递归修改权限
–reference=/path/to/somefile FILE
删除用户:
userdel
userdel [options] USERNAME
-r
删除组
groupdel
groupdel GRPNAME
bash的快捷键
Ctrl+a 跳至命令行首
Ctrl+e 尾
Ctrl+u 删除命令行首到光标所在地点内容
Ctrl+k 删除当前光标所有出至命令行的内容
Ctrl+l 清屏,相当于clear命令
Ctrl+c 取消或终止
Ctrl+z 将当前命令送至后台
cut:文本切割
最常用的功能是能够使用制定的符号作为行中内容的分隔符,将每一行切片,而只取出某些片
cut [options] FILE
-d:默认分隔符为空白,一般在后边加:号,-d:
-f 1-5(第一段-第五段) 1,5(第一段和第五段)
join: 将两个文件中,指定栏位内容相同的行连接起来
参  数:
-a<1或2> 除了显示原来的输出内容之外,还显示指令文件中没有相同栏位的行。
-e<字符串> 若[文件1]与[文件2]中找不到指定的栏位,则在输出中填入选项中的字符串。
-i或–igore-case 比较栏位内容时,忽略大小写的差异。
-o<格式> 按照指定的格式来显示结果。
-t<字符> 使用栏位的分隔字符。
-v<1或2> 跟-a相同,但是只显示文件中没有相同栏位的行。
-1<栏位> 连接[文件1]指定的栏位。
-2<栏位> 连接[文件2]指定的栏位。
–help 显示帮助。
–version 显示版本信息。
grep
global serach regular exmpression and printing 以正则表达式来描述选择条件
正则表达式是一类字符所书写的模式(pattern)
元字符:(、?)不表示字符本身的意义,而用于额外功能性的描述
grep [options] ‘pattern’ file
正则表达式:基本正则表达式,扩展正则表达式
基本正则表达式:贪婪模式(尽可能长de去匹配符合模式的内容)
^: 锚定行首的符合条件的内容,用法格式:”^pattern”
$:锚定行尾的符合条件的内容,用法格式:”pattern$”
^pattern$ 自成一行
^$ 空白行
.:匹配任意单个字符
:前边的字符距最近才能匹配
ab:ab,aab,b 匹配
acb 不匹配
.
:匹配任意长度的任意字符
[]:匹配指定范围内的任意字符

          [^]:匹配指定范围外的任意字符
              [0-9]: 所有的数字
              [a-z]:所有的小写字母
              [A-Z]:所有的大写字母
              [a-zA-Z]:所有的字母
              [0-9a-zA-Z]:所有的数字和字母
grep的选项
    --color=auto
    -v:反向选取,只显示不符合模式的行
    -o:只显示被模式匹配到的字串,而不显示整个行
    -A #行号:显示匹配的行时,顺带显示后边的#行
    -B # :前面的#行
    -C # :前后的#

sort : 排序
-f 忽略字符大小写
-n 以数值大小进行排序
-r 降序
-u 移除重复的行,具有相同内容的行,只保留一个
-R 随机排序
uniq :排序完成后不重复的行
-c:统计每行重复的次数
-u;只显示没有重复的行
-d: 只显示重复过的行

WingsAngle

Welcome to WingsAngle!

WA twoday

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
日志文件说明 
/var/log/message 系统启动后的信息和错误日志,是Red Hat Linux中最常用的日志之一
/var/log/secure 与安全相关的日志信息
/var/log/maillog 与邮件相关的日志信息
/var/log/cron 与定时任务相关的日志信息
/var/log/spooler 与UUCP和news设备相关的日志信息
/var/log/boot.log 守护进程启动和停止相关的日志消息

系统:
# uname -a # 查看内核/操作系统/CPU信息
# cat /etc/issue
# cat /etc/redhat-release # 查看操作系统版本
# 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 # 查看活动用户
# id <用户名> # 查看指定用户信息
# last # 查看用户登录日志
# cut -d: -f1 /etc/passwd # 查看系统所有用户
# cut -d: -f1 /etc/group # 查看系统所有组
# crontab -l # 查看当前用户的计划任务
服务:
# chkconfig –list # 列出所有系统服务
# chkconfig –list | grep on # 列出所有启动的系统服务
程序:
# rpm -qa # 查看所有安装的软件包

WingsAngle

Welcome to WingsAngle!

WA onecday

1
2
3
4
5
6
7
8
linux 基础命令
Linux提供了大量的命令,利用它可以有效地完成大量的工作,如磁盘操作、文件存取、目录操作、进程管理、文件权限设定等。所以,在Linux系统上工作离不开使用系统提供的命令。要想真正理解Linux系统,就必须从Linux命令学起,通过基础的命令学习可以进一步理解Linux系统。不同Linux发行版的命令数量不一样,但Linux发行版本最少的命令也有200多个。这里里把比较重要和使用频率最多的命令,按照它们在系统中的作用分成下面六个部分一一介绍。
安装和登录命令:login、shutdown、halt、reboot、install、mount、umount、chsh、exit、last;
文件处理命令:file、mkdir、grep、dd、find、mv、ls、diff、cat、ln;
系统管理相关命令:df、top、free、quota、at、lp、adduser、groupadd、kill、crontab;
网络操作命令:ifconfig、ip、ping、netstat、telnet、ftp、route、rlogin、rcp、finger、mail、 nslookup
系统安全相关命令:passwd、su、umask、chgrp、chmod、chown、chattr、sudo ps、who;
其它命令:tar、unzip、gunzip、unarj、mtools、man、unendcode、uudecode。