linux 常用基本命令

七 常用基本命令
7.1 帮助命令
7.1.1 man 获得帮助信息
1)基本语法:
man manual[命令或配置文件] 获得帮助信息
(1)显示说明

NAME 命令的名称和单行描述
SYNOPSIS 怎样使用命令
DESCRIPTION 命令功能的深入讨论
EXAMPLES 怎样使用命令的例子
SEE ALSO 相关主题(通常是手册页)

内容比较多,回车键或j或向下键(一行行的往下翻)、向上键或k(一行行的往上翻)、

(2)数字说明q
1.用户在shell环境中可以操作的命令或是可执行的文件
2.系统内核(kernel)可以调用的函数
3.常用的函数or函数库
4.设备配置文件
5.配置文件的格式
6.游戏相关
7.linux网络协议和文件系统
8.系统管理员可以用的命令
9.跟内核有关系的文件

2)案例
[root@hadoop106 home]# man ls
退出:q
7.1.2 help 获得shell内置命令的帮助信息
1)基本语法:
命令 --help 获得shell内置命令的帮助信息

2)案例:
[root@node01 bin]# help cd

7.1.3 常用快捷键
ctrl + c 停止进程
ctrl+l 清屏(等同于clear)
ctrl + q 退出
善于用tab键
上下键 查找执行过的history命令
ctrl +alt linux和Windows之间切换
7.2 文件目录类
7.2.1 pwd 显示当前工作目录的绝对路径
1)基本语法:
pwd 显示当前工作目录的绝对路径
Print work directory

2)案例
[root@node01 home]# pwd
/home
7.2.2 ls 列出目录的内容
1)基本语法:
ls [选项] [目录或是文件]
-a 全部的文件,连同隐藏档( 开头为 . 和 … 的文件) 一起列出来(常用)
-l (ll) 长数据串列出,包含文件的属性与权限等等数据;(常用)
每行列出的信息依次是: 文件类型与权限 链接数 用户 用户组 文件大小用byte来表示 修改时间 文件名

2)案例
[root@node01 ~]# ls -l
total 96
-rw-------. 1 root root 3330 Jun 23 02:13 anaconda-ks.cfg
drwxr-xr-x. 3 root root 4096 Jun 23 04:51 Desktop
drwxr-xr-x. 2 root root 4096 Jun 23 02:20 Documents
drwxr-xr-x. 2 root root 4096 Jun 23 02:20 Downloads
-rw-r–r--. 1 root root 41364 Jun 23 02:12 install.log
-rw-r–r--. 1 root root 9154 Jun 23 02:10 install.log.syslog
drwxr-xr-x. 2 root root 4096 Jun 23 02:20 Music
drwxr-xr-x. 2 root root 4096 Jun 23 02:20 Pictures
drwxr-xr-x. 2 root root 4096 Jun 23 02:20 Public
drwxr-xr-x. 2 root root 4096 Jun 23 02:20 Templates
drwxr-xr-x. 2 root root 4096 Jun 23 02:20 Videos

7.2.3 mkdir 创建一个新的目录
1)基本语法:
mkdir [-p] 要创建的目录
-p 创建多层目录 (递归)

2)案例
[root@node01 opt]# mkdir test
[root@node01 opt]# mkdir -p /opt/test1/word
7.2.4 rmdir 删除一个空的目录
1)基本语法:
rmdir 要删除的空目录
2)案例
[root@node01 opt]# mkdir test
[root@node01 opt]# rmdir test
7.2.5 touch 创建空文件
1)基本语法:
touch 文件名称
2)案例
[root@node01 opt]# touch test.java
7.2.6 cd 切换目录
1)基本语法:
cd 绝对路径
cd 相对路径
cd ~ 飘 回到自己的家目录
cd - 回到上一次所在目录
cd … 回到当前目录的上一级目录
cd -P 跳转到实际物理路径,而非快捷方式路径,软连接中讲解

2)案例
(1)使用 mkdir 命令创建java目录
[root@node01 ~]# mkdir java
(2)使用绝对路径切换到java目录
[root@node01 ~]# cd /root/java/
(3)使用相对路径切换到java目录
[root@node01 ~]# cd ./java/
或者
[root@node01 ~]# cd java/ 最后的/可以有 也可以没有 但是tab键补出来是有的
(4)表示回到自己的家目录,亦即是 /root 这个目录
[root@node01 java]# cd ~
(5)cd- 回到上一次所在目录
[root@node01 hello]# cd -
(6)表示回到当前目录的上一级目录,亦即是 /root 的上一级目录的意思;
[root@node01 ~]# cd …
7.2.7 cp 复制文件或目录
1)基本语法:
cp source dest 复制source文件到dest
cp -r sourceFolder targetFolder 递归复制整个文件夹

2)案例
(1)复制文件
[root@node01 opt]# cp test.java test
(2)递归复制整个文件夹
[root@node01 opt]# cp -r test test1
7.2.8 rm 移除文件或目录
1)基本语法:
rmdir deleteEmptyFolder 删除空目录
rm -f deleteFile 删除文件
rm -rf deleteFolderAndFile 递归删除目录及目录中所有内容

2)案例
1)删除空目录
[root@node01 opt]# rmdir test
2)递归删除目录及目录中所有内容
[root@node01 opt]# rm -rf test1
7.2.9 mv 移动文件与目录或重命名
1)基本语法:
mv oldNameFile newNameFile 重命名
mv /temp/movefile /targetFolder 递归移动文件

2)案例:
1)重命名
[root@node01 opt]# mv test.java test1.java
2)移动文件
[root@node01 opt]# mv test1.java test1
7.2.10 cat 查看文件内容
查看文件内容,从第一行开始显示。
1)基本语法
cat [选项] 要查看的文件
-A 相当于 -vET 的整合选项,可列出一些特殊字符而不是空白而已;
-b 列出行号,仅针对非空白行做行号显示,空白行不标行号!
-E 将结尾的断行字节 $ 显示出来;
-n 列出行号,连同空白行也会有行号,与 -b 的选项不同;
-T 将 [tab] 按键以 ^I 显示出来;
-v 列出一些看不出来的特殊字符

2)案例:
[hello@node01 ~]$ cat -A test.txt
hellda $
dasadf ^I$
daII^I$
das$

3)面试题:查看CentOS版本命令
[root@node01 桌面]$ cat /etc/redhat-release
CentOS release 6.5 (Final)
7.2.11 tac查看文件内容
查看文件内容,从最后一行开始显示,可以看出 tac 是 cat 的倒著写。
1)基本语法:
tac [选项参数] 要查看的文件
2)案例
[root@node01 test1]# cat test1.java
hello
you
He

[root@node01 test1]# tac test1.java
heloo1
hello2
hello3
7.2.12 more 查看文件内容
查看文件内容,一页一页的显示文件内容。
1)基本语法:
more 要查看的文件

2)功能使用说明:
空白键 (space) 代表向下翻一页
Enter 代表向下翻『一行』
:q 代表立刻离开 more ,不再显示该文件内容。
Ctrl+F 向下滚动一屏 F(follow 后面的)
Ctrl+B 返回上一屏 B(back 返回)
:= 输出当前行的行号
:f 输出文件名和当前行的行号

3)案例
[root@node01 test1]# more test1.java
7.2.13 less 查看文件内容
less 的作用与 more 十分相似,都可以用来浏览文字档案的内容,不同的是 less 允许使用[pageup] [pagedown]往回滚动。
1)基本语法:
less 要查看的文件
2)功能使用说明
空白键 向下翻动一页
Ctrl+F 向下滚动一屏 F(follow 后面的)
Ctrl+B 返回上一屏 B(back 返回)
:[pagedown] 向下翻动一行;
:[pageup] 向上翻动一行;
:/字串 向下搜寻『字串』的功能;n:向下查找;N:向上查找;
:?字串 向上搜寻『字串』的功能;n:向上查找;N:向下查找;
:q 离开 less 这个程序

3)案例
[root@node01 test1]# less test1.java
7.2.14 head查看文件内容
查看文件内容,只看头几行。
1)基本语法
head -n 10 文件 查看文件头10行内容,10可以是任意行数
head -10 文件 查看文件头10行内容,10可以是任意行数

2)案例
[root@node01 test1]# head -n 2 test1.java
hello
you
7.2.15 tail 查看文件内容
查看文件内容,只看尾巴几行。
1)基本语法
tail -n 10 文件 查看文件最后10行内容,10可以是任意行数
tail -f 文件 实时追踪该文档的所有更新,当文件改名或被删除,追踪停止,等同于–follow=descriptor,默认是打印最后10行
tail -F 文件 实时追踪该文档的所有更新,该文件被删除或改名后,如果再次创建相同的文件名,会继续追踪,等同于–follow=name --retry,默认是打印最后10行

2)案例
(1)查看文件尾巴1行内容
[root@node01 test1]# tail -n 1 test1.java
haha
(2)实时追踪该档的所有更新
[root@node01 test1]# tail -F test1.java
hello
you
he
7.2.16 重定向命令
1)基本语法:
ls -l > 文件 列表的内容写入文件a.txt中(覆盖写)
ls -al >> 文件 列表的内容追加到文件aa.txt的末尾
FileInputStream 也可以指定追加和覆盖模式
RandomAccessFile 随机访问文件,而是任意访问文件,可读可写可追加
DataInputStream 读写有数据类型。。。

2)案例
[root@node01 opt]# ls -l>t.txt
[root@node01 opt]# ls -l>>t.txt
[root@node01 test1]# echo hello>>test1.java
7.2.17 echo 回写命令
1)基本语法:
echo 要显示的内容 >> 存储内容的的文件 将要显示的内容,存储到文件中
echo 变量 显示变量的值

2)案例
[root@node01 test1]# echo $JAVA_HOME
/opt/module/jdk1.8.0_144
7.2.18 ln软链接
可以当成是windos下的“快捷方式”,将软件安装目录中的启动脚本在桌面创建快捷方式同样可以启动软件。
1)基本语法:
注意:创建软链接的时候原文件和目标文件最好使用绝对路径

ln -s [原文件] [目标文件] 给原文件创建一个软链接,软链接存放在目标文件目录,-s是soft的意思
ln –s [原目录] [目标目录] 给原目录创建一个软链接,软链接存放在目标目录,-s是soft的意思
rm -f aaa.txt 删除文件软链接
rm -rf aa,而不是rm -rf aa/ 删除目录软链接

2)案例:
①创建一个文件软链接
[root@node01 test1]# ln -s /opt/test1/test1.txt /opt/
[root@node01 opt]# ll
lrwxrwxrwx 1 root root 20 Jun 26 11:10 test1.txt -> /opt/test1/test1.txt
[root@node01 opt]# cat test1.txt
Hello

②创建一个目录软链接
[root@node01 test2]# ln -s /opt/test2/test3/ /opt/test1/
[root@node01 test1]# ll
lrwxrwxrwx 1 root root 17 Jun 26 11:14 test3 -> /opt/test2/test3/

cd不加参数进入是软链接的地址
[root@node01 test1]# cd test3
[root@node01 test3]# pwd
/opt/test1/test3

cd加参数(-P)进入是实际的物理地址
[root@node01 test1]# cd -P test3
[root@node01 test3]# pwd
/opt/test2/test3

7.2.19 ln 硬链接
1)基本语法:
注意:创建硬链接的时候原文件和目标文件都使用绝对路径;
ln [原文件] [目标文件] 给原文件创建一个硬链接,软链接存放在目标文件目录
rm -rf aa,而不是rm -rf aa/ 删除硬链接;硬链接相当于对原文件内容进行了复制,当删除原文件的时候,硬链接文件。

7.2.20 history查看所有命令历史
1)基本语法:
history
2)案例
[root@node01 test1]# history
7.3 时间日期类
1)基本语法
date [OPTION]… [+FORMAT]
7.3.1 date显示当前时间
1)基本语法:
date 显示系统当前时间
date +%Y 显示当前年份
date +%m 显示当前月份
date +%d 显示当前是哪一天
date +%Y%m%d 显示当前年月日各种格式
date "+%Y-%m-%d %H:%M:%S 显示年月日时分秒 ,必须要加双引号(在命令行中,如果一个参数中间包含有空格,那么必须加双引号,否则系统会当做两个参数进行处理)

2)案例
[root@node01 /]# date
2017年 06月 19日 星期一 20:53:30 CST
[root@node01 /]# date +%Y%m%d
20170619
[root@node01 /]# date “+%Y-%m-%d %H:%M:%S”
2017-06-19 20:54:58
7.3.2 date显示非当前时间
1)基本语法:
date -d ‘1 days ago’
date -d ‘n days ago’ 显示前一天日期
date -d yesterday +%Y%m%d
date -d next-day +%Y%m%d
date -d tomorrow +%Y%m%d 显示明天日期
date -d ‘next monday’ 显示下周一时间

2)案例:
[root@node01 /]# date -d ‘1 days ago’
2017年 06月 18日 星期日 21:07:22 CST
[root@node01 /]# date -d next-day +%Y%m%d
20170620
[root@node01 /]# date -d ‘next monday’
2017年 06月 26日 星期一 00:00:00 CST
7.3.3 date设置系统时间
1)基本语法:
date -s 字符串时间
2)案例
[root@hadoop106 /]# date -s “2017-06-19 20:52:18”
[root@uek ~]# date -s “2018-08-07”
2018年 08月 07日 星期二 00:00:00 CST
[root@uek ~]# date -s “2018-08-07 09:44:00”
2018年 08月 07日 星期二 09:44:00 CST
7.3.4 cal查看日历
1)基本语法:
cal [选项] 不加选项,显示本月日历
-3 显示系统前一个月,当前月,下一个月的日历,以当前月为中心具体某一年,显示这一年的日历。
2)案例:
[root@node01 /]# cal
[root@node01 /]# cal -3
[root@node01 /]# cal 2016
7.4 用户管理命令
运维人员必掌握;

当linux系统安装时,系统自带一个默认的linux超级管理员用户:root. 当登录进入linxu系统之后,命令行界面显示:
[root@node1 ~]#
Root : 用户名;
Node1 : 主机名;
~ : 当前所在目录名称;也代表用户主目录;([root@node5 ~]# pwd /root)

:当前用户属于root用户(什么时候使用root用户?在对系统进行配置管理时,需要使用root用户);如果此处是$ ,代表普通用户,普通用户是没有root的超级管理员权限的;

7.4.1 useradd 或adduser 添加新用户
1)基本语法:
useradd 用户名 添加新用户

2)案例:
[root@node01 opt]# adduser rwd

7.4.2 passwd 设置用户密码
1)基本语法:
passwd 用户名 设置用户密码

2)案例
[root@node01 opt]# passwd rwd
7.4.3 id 判断用户是否存在
1)基本语法:
id 用户名
2)案例:
[root@node01 opt]#id rwd
7.4.4 su 切换用户
1)基本语法:
su 用户名称 切换用户,只能获得用户的执行权限,不能获得环境变量
su - 用户名称 切换到用户并获得该用户的环境变量及执行权限
2)案例
[root@node01 opt]#su rwd
[root@node01 opt]#su - rwd
7.4.5 userdel 删除用户
1)基本语法:
userdel 用户名 删除用户但保存用户主目录(home目录下)
userdel -r 用户名 用户和用户主目录,都删除
注意:如果删除的用户正在被占用则,则会提示:
userdel: user rwd is logged in
解决方法:退出该用户,使用exit命令退出

2)案例:
(1)删除用户但保存用户主目录
[root@node01 opt]#userdel rwd
(2)删除用户和用户主目录,都删除
[root@node01 opt]#userdel -r rwd
7.4.6 who 查看登录用户信息
1)基本语法
whoami 显示自身用户名称
who am i 显示登录用户的用户名
who 看当前有哪些用户登录到了本台机器上
因为linux是多用户 操作系统

2)案例
[root@node01 opt]# whoami
[root@node01 opt]# who am i
[root@node01 opt]# who
7.4.7 给普通用户设置root权限
1)修改配置文件(使用root用户修改)
修改 /etc/sudoers 文件,找到下面一行,在root下面添加一行,如下所示:

Allow root to run any commands anywhere

root ALL=(ALL) ALL
rwd ALL=(ALL) ALL
保存退出的时候:wq
提示:E45: ‘readonly’ option is set (add ! to override)
解决办法:强制保存退出:wq!
或者配置成采用sudo命令时,不需要输入密码

Allow root to run any commands anywhere

root ALL=(ALL) ALL
rwd ALL=(ALL) NOPASSWD:ALL
修改完毕,现在可以用rwd帐号登录,然后用命令 sudo ,即可获得root权限进行操作。
Sudo 命令 : 普通用户操作root用户权限的命令;

2)案例
[rwd@node01 opt]$ sudo mkdir module
[root@node01 opt]# chown hello:hello module/
7.4.8 cat /etc/passwd 查看创建了哪些用户
cat /etc/passwd
7.4.9 usermod(modify ddl dml dql)修改用户
一个用户组下,可以包含有多个用户;
讲完“用户组管理命令”部分讲解
1)基本语法:
usermod -g 用户组 用户名
2)案例:
将用户rwd加入bigdata用户组
[root@node01 opt]#usermod -g bigdata rwd
7.5 用户组管理命令
每个用户都有一个用户组,系统可以对一个用户组中的所有用户进行集中管理。不同Linux 系统对用户组的规定有所不同,
如Linux下的用户属于与它同名的用户组,这个用户组在创建用户时同时创建。
用户组的管理涉及用户组的添加、删除和修改。组的增加、删除和修改实际上就是对/etc/group文件的更新。
7.5.1 groupadd 新增组
1)基本语法
groupadd 组名
2)案例:
添加一个javaweb组
[root@node01 opt]#groupadd javaweb
7.5.2 groupdel删除组
1)基本语法:
groupdel 组名
2)案例
[root@node01 opt]# groupdel rwd
[root@node01 opt]# userdel rwd
[root@node01 opt]# groupdel rwd

[root@node01 ~]# groupdel rwd
提示:groupdel: cannot remove the primary group of user ‘rwd’
解决办法:先删除用户rwd再删除用户组rwd
7.5.3 groupmod修改组
1)基本语法:
groupmod -n 新组名 老组名
2)案例
修改javaweb组名称为bigdata
[root@node01 hello]# groupmod -n bigdata javaweb
7.5.4 cat /etc/group 查看创建了哪些组
cat /etc/group
7.5.5 综合案例
[root@node01 opt]# groupadd javaweb
[root@node01 opt]# groupmod -n bigdata javaweb
[root@node01 opt]# usermod -g bigdata rwd
[root@node01 opt]# su rwd
[rwd@node01 ~]$ mkdir hello
[rwd@node01 ~]$ ls -l
[root@node01 hello]# usermod -g rwd rwd
7.6 文件权限类
2.5 文件
举例:
-rw-r–r--. 1(文件硬连接的次数) root(文件的拥有者) root(拥有者所属的用户组) 23732(文件内容大小) Feb 2 23:06(文件创建的时间) install.log (文件名)
文件类型:
在Linux系统中,文件类型(常见三种类型):
1)文件

2)目录(类似windows下的文件夹)
d
3)连接(类似windows下的快捷方式)
l

案例:
drwxr-xr-x :d(文件类型:目录)
-rw-r–r-- : -(文件类型:文件)
lrw-r–r-- : l(文件类型:链接文件)

文件权限:
1)可读 r read
2)可写 w write
3)可执行(脚本,shell脚本)x execute
4)特殊字符 - 表示没有任何权限;
权限的数字表示方式:以二进制数字之和的方式表示;
R W X
2^2=4 2^1=2 2^0=1
举例:rw-(拥有者的权限) rw-(同组下其他用户的权限) r–(不同组下其他用户权限)
4+2 4+2 4 以数字的方式表示:777
文件的归属:
1)拥有者 owner u
2)属于组 group g
3)其他用户 other o

-rw-r–r--. 1 root root 5890 Feb 2 23:04 install.log.syslog
drwxr-xr-x. 3 root root 4096 Feb 4 09:35 workerSpace

第一部分:-rw-r–r--
十个字符,代表不同含义:- rw- r-- r–
第一个字符:表示文件的类型;
后面九个字符,分为三组,表示此文件针对的不同用户的权限关系;
为什么是三组?
一个文件对于用户,包含三个部分;
1)user拥有者 rwx
2)group拥有者所属的组 rwx
3)Other group其他用户 r-- (只用读的权限)

第二部分: root root
第一个字符串表示文件的拥有者;
第二个字符串表示文件的所属组;

第三部分:文件的内容大小;
第四部分:文件的创建时间;

案例:
d r-x r-- --x : 目录 ,
r-x :当前用户对于该文件有读和执行的权限,没有写的权限;
r-- :和当前用户在一个组内的其他用户,对于该文件有读的权限,没有写和执行权限;
–x :和当前用户不在一个组内的其他用户,对于该文件只有执行的权限,没有读和写的权限;
–w-r-xr-- : 文件
lr-x—r-- : 硬链接
–wxrw–w-: 文件

2.6 文件权限操作:
Chmod
需要使用root用户设置文件对不同用户的权限:
举例:
对于同组用户来说,仅仅可读;对于其他用户来说,即不可读也不可写。
U
G
o
#chmod g-w xxx.txt
#chmod o+r xxx.txt

数字形式:
#chmod 664 xxx.txt
#chmod 777 xxx.txt (全部权限)

改变文件的拥有者:

chown 拥有者 文件名

改变文件的所属组:

chgrp 所属组 文件名

当对于目录设置权限,并且目录下有很多文件,也需要同样的文件权限:
-R (recursive) 递归
#chmod -R rwx(664) 目录名

案例:
将xxx.txt 文件的拥有者和所属组设置为shi用户和shi组(没有成功)
#chmod shi:shi xxx.txt

7.6.1 文件属性
Linux系统是一种典型的多用户系统,不同的用户处于不同的地位,拥有不同的权限。为了保护系统的安全性,Linux系统对不同的用户访问同一文件(包括目录文件)的权限做了不同的规定。在Linux中我们可以使用ll或者ls –l命令来显示一个文件的属性以及文件所属的用户和组。

1)从左到右的10个字符表示:
如果没有权限,就会出现减号[ - ]而已。从左至右用0-9这些数字来表示:

(1)0首位表示类型
在Linux中第一个字符代表这个文件是目录、文件或链接文件等等

  • 代表文件
    d 代表目录
    c 字符流,装置文件里面的串行端口设备,例如键盘、鼠标(一次性读取装置)
    s socket
    p 管道
    l 链接文档(link file);
    b 设备文件,装置文件里面的可供储存的接口设备(可随机存取装置)

(2)第1-3位确定属主(该文件的所有者)拥有该文件的权限。—User

(3)第4-6位确定属组(所有者的同组用户)拥有该文件的权限,—Group

(4)第7-9位确定其他用户拥有该文件的权限 —Other

文件类型 属主权限 属组权限 其他用户权限
0 1 2 3 4 5 6 7 8 9
d r w x r - x r - x
目录文件 读 写 执行 读 写 执行 读 写 执行

2)rxw作用文件和目录的不同解释
(1)作用到文件:
[ r ]代表可读(read) 可以读取,查看
[ w ]代表可写(write) 可以修改,但是不代表可以删除该文件,删除一个文件的前提条件是对该文件所在的目录有写权限,才能删除该文件
[ x ]代表可执行(execute) 可以被系统执行

(2)作用到目录:
[ r ]代表可读(read) 可以读取,ls查看目录内容
[ w ]代表可写(write) 可以修改,目录内创建+删除+重命名目录
[ x ]代表可执行(execute) 可以进入该目录

[hello@node01 ~]$ ls -l
总用量 8
drwxrwxr-x. 2 root root 4096 5月 27 14:14 hello
-rw-rw-r–. 1 root root 34 5月 27 14:20 test.txt

(1)如果查看到是文件:链接数指的是硬链接个数。创建硬链接方法
ln [原文件] [目标文件]
硬链接使用的比较少,因为相当于对数据做了备份,而在一台机器上做备份如果这台机器宕掉,做备份是没有效果的。
[root@node01 opt]# ln sunhouzi/shz.txt ./shz.txt
(2)如果查看的是目录:链接数指的是子目录个数(包括该目录下的隐藏目录)。
[root@node01 opt]# ls -al hello/
总用量 8
drwxr-xr-x. 2 root root 4096 9月 3 19:02 .
drwxr-xr-x. 5 root root 4096 9月 3 21:21 …
注释:. 关联的是当前目录的个数;…关联的是上一级目录的个数
3)案例
7.6.2 chmod改变权限
1)基本语法:
chmod [{ugoa}{±=}{rwx}] [文件或目录] [mode=421 ] [文件或目录]

2)功能描述
改变文件或者目录权限
文件: r-查看;w-修改;x-执行文件
目录: r-列出目录内容;w-在目录中创建和删除;x-进入目录
删除一个文件的前提条件:该文件所在的目录有写权限,你才能删除该文件。

3)案例
[root@node01 test1]# chmod u+x test1.java
[root@node01 test1]# chmod g+x test1.java
[root@node01 test1]# chmod o+x test1.java
[root@node01 test1]# chmod 777 test1.java
[root@node01 test1]# chmod -R 777 testdir
7.6.3 chown改变所有者
1)基本语法:
chown [-R][最终用户] [文件或目录] 修改文件或者目录的所有者,-R递归修改
chown 文件所属用户:文件所属用户组 修改的文件
chown -R 文件所属用户:文件所属用户组 修改的目录
2)案例
[root@node01 opt]# chown rwd:rwd aaa.txt
[root@node01 opt]# chown -R rwd:rwd haha
[root@node01 opt]# chown rwd:rwd aaa.txt
[root@node01 opt]# ll
-rw-r–r-- 2 rwd rwd 9 Jun 25 09:53 aaa.txt
修改前:
[root@node01 opt]# ll
drwxr-xr-x 2 root root 4096 Jun 25 09:54 test
修改后
[root@node01 opt]# chown -R rwd:rwd test/
[root@node01 opt]# ll -r
drwxr-xr-x 2 rwd rwd 4096 Jun 25 09:54 test
-rw-r–r-- 2 rwd rwd 9 Jun 25 09:53 aaa.txt
7.6.4 chgrp改变所属组
1)基本语法:
chgrp [最终用户组] [文件或目录] 改变文件或者目录的所属组

2)案例:
[root@node01 opt]# chgrp root test/
[root@node01 opt]# ll
drwxr-xr-x 2 rwd root 4096 Jun 25 09:54 test
7.6.5 su 切换用户
1)基本语法:
su username 切换用户

2)案例
[root@node01 opt]# su rwd
[rwd@node01 ~]$
[rwd@node01 ~]$ su root
密码:
[root@node01 opt]#
7.7 磁盘分区类
7.7.1 fdisk查看分区
1)基本语法:
注意:在root用户下才能使用
fdisk -l 查看磁盘分区详情
2)功能说明(了解):
(1)Linux分区
这个硬盘是42.9G的,有255个磁面;63个扇区;5221个磁柱;每个 cylinder(磁柱)的容量是 8225280 bytes=8225.280 K(约为)=8.225280M(约为);
Device Boot Start End Blocks Id System
分区序列 引导 从X磁柱开始 到Y磁柱结束 容量 分区类型ID 分区类型
(2)Win7分区

3)案例
[root@node01 /]# fdisk -l
Disk /dev/sda: 42.9 GB, 42949672960 bytes
255 heads, 63 sectors/track, 5221 cylinders
Units = cylinders of 16065 * 512 = 8225280 bytes
Sector size (logical/physical): 512 bytes / 512 bytes
I/O size (minimum/optimal): 512 bytes / 512 bytes
Disk identifier: 0x00068807
Device Boot Start End Blocks Id System
/dev/sda1 * 1 39 307200 83 Linux
Partition 1 does not end on cylinder boundary.
/dev/sda2 39 543 4046848 82 Linux swap / Solaris
Partition 2 does not end on cylinder boundary.
/dev/sda3 543 5222 37587968 83 Linux
7.7.2 df查看硬盘
1)基本语法:
df 参数 列出文件系统的整体磁盘使用量,检查文件系统的磁盘空间占用情况
-a 列出所有的文件系统,包括系统特有的 /proc 等文件系统;
-k 以 KBytes 的容量显示各文件系统;
-m 以 MBytes 的容量显示各文件系统;
-h 以人们较易阅读的 GBytes, MBytes, KBytes 等格式自行显示;
-H 以 M=1000K 取代 M=1024K 的进位方式;
-T 显示文件系统类型,连同该 partition 的 filesystem 名称 (例如 ext3) 也列出;
-i 不用硬盘容量,而以 inode 的数量来显示

2)案例
[root@node01 ~]# df -h
Filesystem Size Used Avail Use% Mounted on
/dev/sda2 15G 3.5G 11G 26% /
tmpfs 939M 224K 939M 1% /dev/shm
/dev/sda1 190M 39M 142M 22% /boot
7.7.3 mount/umount挂载/卸载
对于Linux用户来讲,不论有几个分区,分别分给哪一个目录使用,它总归就是一个根目录、一个独立且唯一的文件结构
Linux中每个分区都是用来组成整个文件系统的一部分,它在用一种叫做“挂载”的处理方法,它整个文件系统中包含了一整套的文件和目录,并将一个分区和一个目录联系起来,要载入的那个分区将使它的存储空间在这个目录下获得。
挂载:在光驱上插入一张光盘叫挂载
卸载:拔掉光盘叫卸载

0)挂载前准备(必须要有光盘或者已经连接镜像文件)

1)挂载光盘语法:
mount [-t vfstype] [-o options] device dir

(1)-t vfstype 指定文件系统的类型,通常不必指定。mount 会自动选择正确的类型。
常用类型有:
光盘或光盘镜像:iso9660
DOS fat16文件系统:msdos
Windows 9x fat32文件系统:vfat
Windows NT ntfs文件系统:ntfs
Mount Windows文件网络共享:smbfs
UNIX(LINUX) 文件网络共享:nfs

(2)-o options 主要用来描述设备或档案的挂接方式。常用的参数有:
loop:用来把一个文件当成硬盘分区挂接上系统
  ro:采用只读方式挂接设备
  rw:采用读写方式挂接设备(常用)
iocharset:指定访问文件系统所用字符集

(3)device 要挂接(mount)的设备
(4)dir设备在系统上的挂载点(mount point) (spring 切入点)

2)案例
(1)光盘镜像文件的挂载
[root@node01 ~]# cd /mnt/
[root@node01 ~]# mkdir /mnt/cdrom/ 提前创建挂载点
[root@node01 ~]# mount -t iso9660 /dev/cdrom /mnt/cdrom/ 设备/dev/cdrom挂载到挂载点 : /mnt/cdrom中
显示挂载成功,只读:mount: block device /dev/sr0 is write-protected, mounting read-only
如果还想写的话:‘mount -o remount,rw /dev/cdrom /mnt/cdrom’命令
[root@node01 ~]# ll /mnt/cdrom/

3)卸载光盘语法:
[root@node01 ~]# umount 设备文件名或挂载点
提示:umount: /mnt/cdrom: device is busy.
(In some cases useful info about processes that use
the device is found by lsof(8) or fuser(1))
显示设备正在被使用。
解决办法:cd… 退出挂载的目录

4)案例
[root@node01 ~]# umount /mnt/cdrom
[root@node01 ~]# cd /mnt/cdrom

5)开机自动挂载语法:
[root@node01 ~]# vi /etc/fstab
添加红框中内容,保存退出。

7.8 搜索查找类
7.8.1 find 查找文件或者目录
1)基本语法:
find [搜索范围] [匹配条件]
2)案例
(1)按文件名:根据名称查找/目录下的filename为.txt结尾的文件。
[root@node01 ~]# find /opt/ -name *.txt
(2)按拥有者:查找/opt目录下,用户名称为-user的文件
[root@node01 ~]# find /opt/ -user root
(3)按文件大小:在/home目录下查找大于200m的文件(+n 大于 -n小于 n等于)
[root@node01 ~]find /home -size +204800
7.8.2 grep 过滤查找及“|”管道符
0)管道符,“|”,表示将前一个命令的处理结果输出传递给后面的命令处理
1)基本语法
grep+参数+查找内容+源文件
参数(了解即可):
-c:只输出匹配行的计数。
-I:不区分大小写(只适用于单字符)。
-h:查询多文件时不显示文件名。
-l:查询多文件时只输出包含匹配字符的文件名。
-n:显示匹配行及行号。
-s:不显示不存在或无匹配文本的错误信息。
-v:显示不包含匹配文本的所有行。

2)案例(查不到)
[root@node01 opt]# ll | grep hadoop
drwxr-xr-x 10 10021 10021 4096 May 19 04:59 hadoop
drwxr-xr-x 6 root root 4096 May 19 09:10 hadoop-repo
[root@node01 opt]# ls | grep -n haoop
drwxr-xr-x 10 10021 10021 4096 May 19 04:59 hadoop
drwxr-xr-x 6 root root 4096 May 19 09:10 hadoop-repo
7.8.3 which 文件搜索命令
1)基本语法:
which 命令 搜索命令所在目录及别名信息
2)案例
[root@node01 opt]# which ls
/bin/ls
7.9 进程线程类
进程是正在执行的一个程序或命令,每一个进程都是一个运行的实体,都有自己的地址空间,并占用一定的系统资源。
7.9.1 ps查看系统中所有进程
1)基本语法:
ps -aux 查看系统中所有进程

2)功能说明:
USER 该进程是由哪个用户产生的
PID 进程的ID号
%CPU 该进程占用CPU资源的百分比,占用越高,进程越耗费资源;

%MEM 该进程占用物理内存的百分比,占用越高,进程越耗费资源;
VSZ 该进程占用虚拟内存的大小,单位KB;---->例如执行函数开辟的虚拟内存

RSS 该进程占用实际物理内存的大小,单位KB;
TTY 该进程是在哪个终端中运行的。其中tty1-tty7代表本地控制台终端,tty1-tty6是本地的字符界面终端,tty7是图形终端。pts/0-255代表虚拟终端。
STAT 进程状态。常见的状态有:R:运行、S:睡眠、T:停止状态、s:包含子进程、+:位于后台
后台线程:精灵线程和守护线程,实际前台线程死掉之后就死掉
START 该进程的启动时间
TIME 该进程占用CPU的运算时间,注意不是系统时间
COMMAND 产生此进程的命令名

3)案例
[root@node01 datas]# ps -aux

7.9.2 top查看(诊断)系统健康状态
1)基本命令
top [选项]
退出top: q
(1)选项:
-d 秒数:指定top命令每隔几秒更新。默认是3秒在top命令的交互模式当中可以执行的命令:
-i:使top不显示任何闲置或者僵死进程。
-p:通过指定监控进程ID来仅仅监控某个进程的状态。

(2)操作选项(在top命令中使用):
P: 以CPU使用率排序,默认就是此项
M: 以内存的使用率排序
N: 以PID排序
q: 退出top

(3)查询结果字段解释
第一行信息为任务队列信息
内容 说明
12:26:46 系统当前时间
up 1 day, 13:32 系统的运行时间,本机已经运行1天
13小时32分钟
2 users 当前登录了两个用户
load average: 0.00, 0.00, 0.00 系统在之前1分钟,5分钟,15分钟的平均负载。一般认为小于1时,负载较小。如果大于1,系统已经超出负荷。
第二行为进程信息
Tasks: 95 total 系统中的进程总数
1 running 正在运行的进程数
94 sleeping 睡眠的进程
0 stopped 正在停止的进程
0 zombie 僵尸进程。如果不是0,需要手工检
查僵尸进程
第三行为CPU信息
Cpu(s): 0.1%us 用户模式占用的CPU百分比
0.1%sy 系统模式占用的CPU百分比
0.0%ni 改变过优先级的用户进程占用的CPU百分比
99.7%id 空闲CPU的CPU百分比
0.1%wa 等待输入/输出的进程的占用CPU百分比
0.0%hi 硬中断请求服务占用的CPU百分比
0.1%si 软中断请求服务占用的CPU百分比
0.0%st st(Steal time)虚拟时间百分比。就是当有虚拟机时,虚拟CPU等待实际CPU的时间百分比。
第四行为物理内存信息
Mem: 625344k total 物理内存的总量,单位KB
571504k used 已经使用的物理内存数量
53840k free 空闲的物理内存数量,我们使用的是虚拟机,总共只分配了628MB内存,所以只有53MB的空闲内存了
65800k buffers 作为缓冲的内存数量
第五行为交换分区(swap)信息
Swap: 524280k total 交换分区(虚拟内存)的总大小
0k used 已经使用的交互分区的大小
524280k free 空闲交换分区的大小
409280k cached 作为缓存的交互分区的大小

2)案例
[root@node01 opt]# top -d 1
[root@node01 opt]# top -i
[root@node01 hello]# top -p 2575
执行上述命令后,可以按P、M、N对查询出的进程结果进行排序。
7.9.3 pstree查看进程树
1)基本语法:
pstree [选项]
选项
-p: 显示进程的PID
-u: 显示进程的所属用户

2)案例:
[root@node01 datas]# pstree -u
[root@node01 datas]# pstree -p
7.9.4 kill终止进程
1)基本语法:
kill -9 pid进程号
选项
-9 表示强迫进程立即停止
2)案例:
①图形化界面打开浏览器,使用top查看,并使用M对进程按照使用内存大小排序,将使用内存最大的进程kill掉(杀死对应进程号),查看到浏览器被强行关闭。
②启动mysql程序
切换到root用户执行
[root@node01 桌面]# kill -9 5102
7.9.5 netstat显示网络统计信息
1)基本语法:
netstat -anp 此命令用来显示整个系统目前的网络情况。例如目前的连接、数据包传递数据、或是路由表内容
-an 按一定顺序排列输出
-p 表示显示哪个进程在调用
-nltp 查看tcp协议进程端口号

2)案例
查看端口50070的使用情况
[root@node01 opt]# netstat -anp | grep 50070
tcp 0 0 0.0.0.0:50070 0.0.0.0:* LISTEN 6816/java
端口号 进程号
7.9.6 前后台进程切换
1)基本语法:
fg %1 (功能描述:把后台进程转换成前台进程)
ctrl+z bg %1 (功能描述:把前台进程发到后台)
7.10 压缩和解压类
7.10.1 gzip/gunzip压缩
1)基本语法:
gzip+文件 压缩文件,只能将文件压缩为*.gz文件
gunzip+文件.gz 解压缩文件命令;

2)特点:
(1)只能压缩文件不能压缩目录
(2)不保留原来的文件

3)案例
(1)gzip压缩
[root@node01 opt]# ls
test.java
[root@node01 opt]# gzip test.java
[root@node01 opt]# ls
test.java.gz
(2)gunzip解压缩文件
[root@node01 opt]# gunzip test.java.gz
[root@node01 opt]# ls
test.java
7.10.2 zip/unzip压缩
1)基本语法:
zip + 参数 + XXX.zip + 将要压缩的内容 压缩文件和目录的命令,window/linux通用且可以压缩目录且保留源文件
-r 压缩目录

2)案例:
(1)压缩 1.txt 和2.txt,压缩后的名称为test.zip
[root@node01 opt]# zip test.zip aaa.txt bbb.txt
adding: aaa.txt (stored 0%)
adding: bbb.txt (stored 0%)
[root@node01 opt]# ls
test1.java test.java test.zip

(2)解压 test.zip
[root@node01 opt]# unzip test.zip
Archive: test.zip
extracting: aaa.java
extracting: bbb.java
[root@node01 opt]# ls
Aaa.txt bbb.txt test.zip

(3)解压test.zip到指定目录-d
[root@node01 opt]# unzip test.zip -d /opt
7.10.3 tar打包
1)基本语法:
tar + 参数 + XXX.tar.gz + 将要打包进去的内容 打包目录,压缩后的文件格式.tar.gz
-c 产生.tar打包文件
-C 解压缩到指定位置
-v 显示详细信息 verbose
-f 指定压缩后的文件名
-z 打包同时压缩
-x 解包.tar文件

2)案例
(1)压缩:tar -zcvf  XXX.tar.gz   n1.txt    n2.txt
压缩多个文件
[root@node01 opt]# tar -zcvf test.tar.gz aaa.txt bbb.txt
aaa.txt
bbb.txt
[root@node01 opt]# ls
aaa.txt bbb.txt test.tar.gz

压缩目录
[root@node01 opt]# tar -zcvf test.java.tar.gz test1
test1/
test1/hello
test1/test1.java
test1/test/
test1/test/test.java
[root@hadoop106 opt]# ls
test1 test.java.tar.gz

(2)解压:tar -zxvf  XXX.tar.gz
解压到当前目录
[root@node01 opt]# tar -zxvf test.tar.gz
解压到/opt目录
[root@node01 opt]# tar -zxvf test.tar.gz -C /opt
7.11 后台服务管理类
7.11.1 service后台服务管理
service network status 查看指定服务的状态
service network stop 停止指定服务
service network start 启动指定服务
service network restart 重启指定服务
service --status-all 查看系统中所有的后台服务
7.11.2 chkconfig设置后台服务的自启配置
chkconfig --list 查看所有服务器自启配置
chkconfig iptables off 关掉指定服务的自动启动
chkconfig iptables on 开启指定服务的自动启动

7.12 crond系统定时任务
7.12.1 crond服务管理
[root@node01 ~]# service crond start (启动服务)

[root@node01 ~]# service crond stop (关闭服务)

[root@node01 ~]# service crond restart (重启服务)

[root@node01 ~]# service crond reload (重新载入配置)

查看crontab服务状态:
[root@node01 ~]# service crond status
7.12.2 crontab定时任务设置
1)基本语法
crontab [选项]
-e 编辑crontab定时任务
-l 查询crontab任务
-r 删除当前用户所有的crontab任务

2)参数说明
[root@node01 ~]# crontab -e

          • 命令
            进入crontab编辑界面。会打开vim编辑你的工作。
            corn从左到右(用空格隔开):分 小时 月份中的日期 月份 星期中的日期
          • 执行的任务
            项目 含义 范围
            第一个“” 一小时当中的第几分钟 0-59
            第二个“
            ” 一天当中的第几小时 0-23
            第三个“” 一个月当中的第几天 1-31
            第四个“
            ” 一年当中的第几月 1-12
            第五个“*” 一周当中的星期几 0-7(0和7都代表星期日)

(2)特殊符号
特殊符号 含义

  • 代表任何时间。比如第一个“*”就代表一小时中每分钟都执行一次的意思。
    , 代表不连续的时间。比如“0 8,12,16 * * * 命令”,就代表在每天的8点0分,12点0分,16点0分都执行一次命令
  • 代表连续的时间范围。比如“0 5 * * 1-6命令”,代表在周一到周六的凌晨5点0分执行命令
    /n 代表每隔多久执行一次。比如“/10 * * * * 命令”,代表每隔10分钟就执行一遍命令

(3)特定时间执行命令
时间 含义
45 22 * * * 命令 在22点45分执行命令
0 17 * * 1 命令 每周1 的17点0分执行命令
0 5 1,15 * * 命令 每月1号和15号的凌晨5点0分执行命令
40 4 * * 1-5 命令 每周一到周五的凌晨4点40分执行命令
*/10 4 * * * 命令 每天的凌晨4点,每隔10分钟执行一次命令
0 0 1,15 * 1 命令 每月1号和15号,每周1的0点0分都会执行命令。注意:星期几和几号最好不要同时出现,因为他们定义的都是天。非常容易让管理员混乱。

3)案例:
[root@node01 ~]#crontab -e
*/1 * * * * echo ”aaa” >> /opt/testLinux/testcrontab.txt
aaaa
aaaa
aaaa
aaaa

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值