Linux学习-常用命令

唯愿会及时拥抱入眠,留住这世上最暖一面,茫茫人海取暖渡过 最冷一天。

张国荣-<最冷一天>

一、Linux的目录结构

Linux系统是文件系统.根目录是”/“,以树型结构来管理.

~ 代表root目录.root为超级管理员.

二、Linux常用命令
1、切换目录命令 cd
1
2
3
4
5
cd app 切换到app目录
cd .. 切换到上一层目录
cd / 切换到系统根目录
cd ~ 切换到用户主目录
cd - 切换到上一个所在目录
2、列出文件列表 ls ll (dir)

ls(list)用来显示当前目录下的内容。配合参数的使用,能以不同的方式显示目录内容。

1
2
3
4
ls --help  查看帮助信息
ls -a 显示所有文件或目录(包含隐藏的文件)
ls -l 缩写成ll,显示详情信息
//在linux中以 . 开头的文件都是隐藏的文件
3、创建与删除目录
1
2
3
4
5
6
7
//创建
mkdir(make directory)命令可用来创建子目录。
mkdir app 在当前目录下创建app目录
mkdir –p app2/test 级联创建aap2以及test目录
//删除
rmdir(remove directory)命令可用来删除“空”的子目录;
rmdir app 删除app目录
4、浏览文件
1
2
3
4
5
6
7
8
9
10
11
12
13
14
cat //用于显示文件的内容
//格式:
cat[参数]<文件名>
cat install.log
more //一般用于要显示的内容会超过一个画面长度的情况。
按空格键显示下一个画面,回车显示下一行内容。
按q键退出查看
more install.log
less //和more用法类似,不同的是可以PgUP和PgDn键来进行上下翻页
less install.log
tail //用于展示文件的后几行内容
tail -10 install.log 查看后10行数据
tail -f catalina.log 动态查看日志
ctrl+c 结束查看
5、文件操作
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
//cp是copy操作
//mv它是move相当于剪切
cp(copy)命令可以将文件从一处复制到另一处。一般在使用cp命令时将一个文件复制成另一个文件或复制到某目录时,需要指定源文件名与目标文件名或目录。
cp a.txt b.txt 将a.txt复制为b.txt文件
cp a.txt ../ 将a.txt文件复制到上一层目录中
cp install.log /a/myinstall.log
将install.log复制到a目录下并重命名为myinstall.log

//mv 移动或者重命名
mv a.txt ../ 将a.txt文件移动到上一层目录中
mv a.txt b.txt 将a.txt文件重命名为b.txt
mv install.log /b/my.log
将install.log移动到b目录下并重命名为my.log

//rm它可以帮助我们删除文件与目录
//rm 删除文件并询问
用法:rm [选项]... 文件...
rm a.txt 删除a.txt文件
删除需要用户确认,y/n
//rm -f 直接删除不询问
rm -f a.txt 不询问,直接删除
//rm 删除目录
rm -r a 递归删除
//不询问递归删除(慎用!!!)
rm -rf a 不询问递归删除
rm -rf * 删除所有文件
rm -rf /* 自杀
6、打包压缩与解压

tar命令位于/bin目录下,它能够将用户所指定的文件或目录打包成一个文件,但不做压缩。一般Linux上常用的压缩方式是选用tar将许多文件打包成一个文件,再以gzip压缩命令压缩成xxx.tar.gz(或称为xxx.tgz)的文件。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
//常用参数: tar --help
-c:创建一个新tar文件
-v:显示运行过程的信息
-f:指定文件名
-z:调用gzip压缩命令进行压缩
-t:查看压缩文件的内容
-x:解开tar文件

//打包:
tar -cvf ab.tar a.log b.log 将a,b两个文件打包成ab.tar
tar –cvf xxx.tar ./*
//打包并且压缩:
tar -zcvf ab.tar.gz a.log b.log 将a,b两个文件打包并压缩成ab.tar
tar –zcvf xxx.tar.gz ./*

//解压
tar –xvf xxx.tar
tar -xvf xxx.tar.gz -C /usr/aaa
tar -xvf ab.tar.gz -C /b 将ab.tar.gz解压到b目录下
7、文件查找

查找符合条件的文件find

查找文件中符合条件的字符串grep

1
2
3
4
5
6
7
8
9
10
11
12
13
14
//find指令用于查找符合条件的文件
示例:
find / -name “ins*” 查找文件名称是以ins开头的文件
find / -name “ins*” –ls 显示文件的详情信息
find / –user itcast –ls 查找用户itcast的文件
find / –user itcast –type d –ls 查找用户itcast的目录
find /-perm -777 –type d-ls 查找权限是777的文件
//grep查找文件里符合条件的字符串
用法: grep [选项]... PATTERN [FILE]...
示例:
grep lang anaconda-ks.cfg 在anaconda-ks.cfg文件中查找lang
grep lang anaconda-ks.cfg –color 高亮显示(加粗)
grep lang anaconda-ks.cfg –color -A5 -B5
在anaconda-ks.cfg文件中查找lang并加粗,显示前后5行.
8.其他常用命令
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
pwd 显示当前所在目录

touch创建一个空文件
touch a.txt

ll -h 友好显示文件大小

wget 下载资料(有网络)
wget http://nginx.org/download/nginx-1.9.12.tar.gz

//命令之间使用 && 连接,实现逻辑与的功能。
只有在 && 左边的命令返回真(命令返回值 $? == 0),&& 右边的命令才会被执行。
只要有一个命令返回假(命令返回值 $? == 1),后面的命令就不会被执行。

mkdir test && cd test 创建test文件夹并进入test目录
三、VIM编辑器
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
在Linux下一般使用vi编辑器来编辑文件。 vi既可以查看文件也可以编辑文件。 三种模式:命令行、插入、底行模式。
切换到命令行模式:按Esc键;
切换到插入模式:按 i 、o、a键;
i 在当前位置前插入
I 在当前行首插入
a 在当前位置后插入
A 在当前行尾插入
o 在当前行之后插入一行
O 在当前行之前插入一行
切换到底行模式:按:(冒号)

打开文件:vim file
退出:esc -> :q
修改文件:输入i进入插入模式
保存并退出:esc->:wq
不保存退出:esc->:q!

快捷键:
dd – 快速删除一行
yy - 复制当前行
nyy - 从当前行向后复制几行
p - 粘贴
R – 替换
四、重定向
1
2
3
4
5
6
7
8
9
10
11
12
13
> 重定向输出,覆盖原有内容;
>> 重定向输出,又追加功能;
示例:
cat /etc/passwd > a.txt 将输出定向到a.txt中
cat /etc/passwd >> a.txt 输出并且追加
//例如:
echo "helloworld" 将helloworld打印到控制台
echo "helloworld" > a.txt 将helloworld输出到a.txt文件中
cat a.txt > b.txt 将查看的a.txt的内容输出到b.txt中
echo "good java" >> b.txt 将good java输出并追加到b.txt文件中

//Linux查看ip地址信息
ifconfig > ifconfig.txt 将查看的ip地址信息输出到ifconfig.txt文件中
五、管道

管道是Linux命令中重要的一个概念,其作用是将一个命令的输出用作另一个命令的输入.

笔试题ps –ef | grep java 查询名称中包含java的进程

1
2
3
4
5
6
7
//示例:
ls --help | more 分页查询帮助信息
ps –ef | grep java 查询名称中包含java的进程

ifconfig | more
cat index.html | more
ps –ef | grep aio
六、系统常用命令
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
date  显示或设置系统时间
date 显示当前系统时间
date -s “2014-01-01 10:10:10“ 设置系统时间 df 显示磁盘信息
df –h 友好显示大小 free 显示内存状态
free –m 以mb单位显示内存组昂头 top 显示,管理执行中的程序

clear 清屏幕
ps 正在运行的某个进程的状态
ps –ef 查看所有进程
ps –ef | grep ssh 查找某一进程 kill 杀掉某一进程
kill 2868 杀掉2868编号的进程
kill -9 2868 强制杀死进程

du 显示目录或文件的大小。
du –h 显示当前目录的大小
who 显示目前登入系统的用户信息。
uname 显示系统信息。
uname -a 显示本机详细信息。
依次为:内核名称(类别),主机名,内核版本号,内核版本,内核编译日期,硬件名,处理器类型,硬件平台类型,操作系统名称
七、Linux下用户和组的管理
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
57
58
59
60
//用户管理:
useradd 添加一个用户
useradd test 添加test用户
useradd test -d /home/t1 为指定用户home目录
passwd 设置、修改密码
passwd test 为test用户设置密码

切换登录:
ssh -l test -p 22 192.168.19.128 端口22

userdel 删除一个用户
userdel test 删除test用户(不会删除home目录)
userdel –r test 删除用户以及home目录

//组管理
当在创建一个新用户user时,若没有指定他所属于的组,
就建立一个和该用户同名的私有组.
//创建用户时也可以指定所在组
groupadd 创建组
groupadd public 创建一个名为public的组
useradd u1 –g public 创建用户指定组 groupdel 删除组,如果该组有用户成员,必须先删除用户才能删除组。
groupdel public

//id命令:查看一个用户的UID和GID
直接使用 id
直接使用 id 用户名
//su命令:切换用户
su test 切换到test用户
su - test 切换到test用户,并且将环境也切换到test用户的环境(推荐使用)

【账户文件】
/etc/passwd 用户文件
/etc/shadow 密码文件
/etc/group 组信息文件
【用户文件】
root:x:0:0:root:/root:/bin/bash
账号名称: 在系统中是唯一的
用户密码: 此字段存放加密口令
用户标识码(User ID): 系统内部用它来标示用户
组标识码(Group ID): 系统内部用它来标识用户属性
用户相关信息: 例如用户全名等
用户目录: 用户登录系统后所进入的目录
用户环境: 用户工作的环境
【密码文件】
shadow文件中每条记录用冒号间隔的9个字段组成.
用户名:用户登录到系统时使用的名字,而且是惟一的
口令: 存放加密的口令
最后一次修改时间: 标识从某一时刻起到用户最后一次修改时间
最大时间间隔: 口令保持有效的最大天数,即多少天后必须修改口令
最小时间间隔: 再次修改口令之间的最小天数
警告时间:从系统开始警告到口令正式失效的天数
不活动时间:口令过期少天后,该账号被禁用
失效时间:指示口令失效的绝对天数(从197011日开始计算)
标志:未使用
【组文件】
root:x:0:
组名:用户所属组
组口令:一般不用
GID:组ID
用户列表:属于该组的所有用户
八、Linux文件权限管理

1
2
3
4
5
6
7
8
9
10
11
12
13
//Linux三种文件类型:
普通文件:包括文本文件、数据文件、可执行的二进制程序文件等。
目录文件:Linux系统把目录看成是一种特殊的文件,利用它构成文件系统的树型结构。
设备文件:Linux系统把每一个设备都看成是一个文件。
//文件类型标识:
//普通文件(-)
//目录(d)
//符号链接(l)
* 进入etc可以查看,相当于快捷方式
字符设备文件(c)
块设备文件(s)
套接字(s)
命名管道(p)
1、权限设置:
1
2
3
4
5
6
7
chmod 变更文件或目录的权限。
chmod 755 a.txt
chmod u=rwx,g=rx,o=rx a.txt
chmod 000 a.txt / chmod 777 a.txt chown
变更文件或目录改文件所属用户和组
chown u1:public a.txt :变更当前的目录或文件的所属用户和组
chown -R u1:public dir :变更目录中的所有的子目录及文件的所属用户和组
九、常用网络操作
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
//主机名配置
hostname 查看主机名
hostname xxx 修改主机名 重启后无效
如果想要永久生效,可以修改/etc/sysconfig/network文件

//IP地址配置
Setup 设置ip地址
ifconfig 查看(修改)ip地址(重启后无效)
ifconfig eth0 192.168.12.22 修改ip地址
如果想要永久生效
修改 /etc/sysconfig/network-scripts/ifcfg-eth0文件

//域名映射
/etc/hosts文件用于在通过主机名进行访问时做ip地址解析之用

//网络服务管理
service network status 查看指定服务的状态
service network stop 停止指定服务
service network start 启动指定服务
service network restart 重启指定服务
service ---status–all 查看系统中所有后台服务
netstat –nltp 查看系统中网络进程的端口监听情况

//防火墙设置
防火墙根据配置文件/etc/sysconfig/iptables来控制本机的”出”、”入”网络访问行为。
service iptables status 查看防火墙状态
service iptables stop 关闭防火墙
service iptables start 启动防火墙
chkconfig iptables off 禁止防火墙自启
-------------本文结束感谢您的阅读-------------