Linux从入门到精通的总结

一、Linux的基本操作命令

1、查看ls命令的帮助信息

[root@localhost ~]# man ls


LS(1)                                                                        User Commands                                                                       LS(1)

NAME
       ls - list directory contents

SYNOPSIS
       ls [OPTION]... [FILE]...

DESCRIPTION
       List information about the FILEs (the current directory by default).  Sort entries alphabetically if none of -cftuvSUX nor --sort is specified.

       Mandatory arguments to long options are mandatory for short options too.

       -a, --all
              do not ignore entries starting with .

       -A, --almost-all
              do not list implied . and ..

       --author
              with -l, print the author of each file

       -b, --escape
              print C-style escapes for nongraphic characters

       --block-size=SIZE
              scale sizes by SIZE before printing them; e.g., '--block-size=M' prints sizes in units of 1,048,576 bytes; see SIZE format below

       -B, --ignore-backups
              do not list implied entries ending with ~

 Manual page ls(1) line 1 (press h for help or q to quit)

2、查看cd命令的帮助信息

[root@localhost ~]# help cd
cd: cd [-L|[-P [-e]]] [dir]
    Change the shell working directory.
    
    Change the current directory to DIR.  The default DIR is the value of the
    HOME shell variable.
    
    The variable CDPATH defines the search path for the directory containing
    DIR.  Alternative directory names in CDPATH are separated by a colon (:).
    A null directory name is the same as the current directory.  If DIR begins
    with a slash (/), then CDPATH is not used.
    
    If the directory is not found, and the shell option `cdable_vars' is set,
    the word is assumed to be  a variable name.  If that variable has a value,
    its value is used for DIR.
    
    Options:
        -L	force symbolic links to be followed
        -P	use the physical directory structure without following symbolic
    	links
        -e	if the -P option is supplied, and the current working directory
    	cannot be determined successfully, exit with a non-zero status
    
    The default is to follow symbolic links, as if `-L' were specified.
    
    Exit Status:
    Returns 0 if the directory is changed, and if $PWD is set successfully when
    -P is used; non-zero otherwise.
[root@localhost ~]# 

3、常用快捷键

ctrl + c 停止进程
ctrl+l 清屏;彻底清屏是:
reset ctrl + q 退出
善于用tab键 提示(更重要的是可以防止敲错) 上下键 查找执行过的命令 ctrl +alt linux和Windows之间切换

二、文件目录类

1、pwd 显示当前工作目录的绝对路径

pwd:print working directory 打印工作目录

2、基本语法

pwd (功能描述:显示当前工作目录的绝对路径)

案例实操
显示当前工作目录的绝对路径

[root@localhost ~]# pwd
/root
[root@localhost ~]# 

3、ls 列出目录的内容

ls:list 列出目录内容

-a 全部的文件,连同隐藏档( 开头为 . 的文件) 一起列出来(常用)
-l 长数据串列出,包含文件的属性与权限等等数据;(常用)

4、显示说明

每行列出的信息依次是: 文件类型与权限 链接数 文件属主 文件属组 文件大小用byte来表示 建立或最近修改的时间 名字

案例实操
查看当前目录的所有内容信息

[root@localhost ~]# ls -al
total 60
dr-xr-x---.  2 root root   198 Oct 31 05:19 .
dr-xr-xr-x. 17 root root  4096 Oct 31 05:19 ..
-rw-------.  1 root root  1264 Oct 19 23:01 anaconda-ks.cfg
-rw-------.  1 root root 13876 Oct 31 04:16 .bash_history
-rw-r--r--.  1 root root    18 Dec 29  2013 .bash_logout
-rw-r--r--.  1 root root   176 Dec 29  2013 .bash_profile
-rw-r--r--.  1 root root   176 Dec 29  2013 .bashrc
-rw-r--r--.  1 root root   100 Dec 29  2013 .cshrc
-rw-------.  1 root root    32 Oct 24 14:20 .mysql_history
-rw-------.  1 root root  1193 Oct 30 18:14 .rediscli_history
-rw-r--r--.  1 root root   129 Dec 29  2013 .tcshrc
-rw-------.  1 root root  7355 Oct 31 05:19 .viminfo
[root@localhost ~]# 

5、cd 切换目录

cd:Change Directory切换路径

基本语法

cd  [参数]

参数说明

cd 绝对路径 切换路径
cd相对路径 切换路径
cd ~或者cd 回到自己的家目录
cd - 回到上一次所在目录 cd
… 回到当前目录的上一级目录
cd -P 跳转到实际物理路径,而非快捷方式路径

案例实操
5.1、使用绝对路径切换到root目录

[root@localhost ~]# cd /root/
[root@localhost ~]# 

5.2、表示回到自己的家目录,亦即是 /root 这个目录

[root@localhost ~]#  cd ~
[root@localhost ~]# 

5.3、cd- 回到上一次所在目录

[root@localhost ~]# cd -
/root
[root@localhost ~]# 

5.4、表示回到当前目录的上一级目录,亦即是 “/root/公共的”的上一级目录的意思;

cd ..

6、 mkdir 创建一个新的目录

mkdir:Make directory 建立目录
6.1基本语法

mkdir [选项] 要创建的目录

选项说明

-p: 创建多层目录

案例实操
6.2 创建一个目录

[root@localhost ~]# mkdir xiyou
[root@localhost ~]#  mkdir xiyou/mingjie
[root@localhost ~]# 

6.2.1 创建一个多级目录

[root@localhost ~]# mkdir -p xiyou/dssz/meihouwang
[root@localhost ~]# 

6.3 rmdir 删除一个空的目录

rmdir:Remove directory 移动目录

6.3.1 基本语法:

rmdir 要删除的空目录

[root@localhost ~]# rmdir xiyou/dssz/meihouwang
[root@localhost ~]# 

7、touch 创建空文件

7.1 基本语法

touch 文件名称

7.2 案例实操

[root@localhost ~]# touch xiyou/dssz/sunwukong.txt
[root@localhost ~]# 

8、cp 复制文件或目录

8.1 基本语法

cp [选项] source dest (功能描述:复制source文件到dest)

8.2.选项说明

-r :递归复制整个文件夹
source: 源文件
dest: 目标文件

经验技巧
强制覆盖不提示的方法:\cp

9、案例实操

9.1 复制文件

[root@localhost ~]# cp xiyou/dssz/sunwukong.txt xiyou/mingjie/
[root@localhost ~]# 

9.2递归复制整个文件夹

[root@localhost ~]# cp -r xiyou/dssz/ ./
[root@localhost ~]# 

10、rm 移除文件或目录

10.1 基本语法

rm [选项] deleteFile (功能描述:递归删除目录中所有内容)

10.2 选项说明

-r 递归删除目录中所有内容
-f 强制执行删除操作,而不提示用于进行确认。
-v 显示指令的详细执行过程

10.3 案例实操
10.3.1 删除目录中的内容

[root@localhost ~]# rm xiyou/mingjie/sunwukong.txt
rm: remove regular empty file ‘xiyou/mingjie/sunwukong.txt’? y
[root@localhost ~]# 

10.3.2 递归删除目录中所有内容

[root@localhost ~]# rm -rf dssz/
[root@localhost ~]# 

11、mv 移动文件与目录或重命名

基本语法

(1)mv oldNameFile newNameFile (功能描述:重命名) (2)mv /temp/movefile /targetFolder (功能描述:移动文
件)

11.1 案例实操
11.1.1 移动文件

[root@localhost ~]# cp xiyou/dssz/sunwukong.txt  ./
[root@localhost ~]# ls
anaconda-ks.cfg  sunwukong.txt  xiyou
[root@localhost ~]# 

12、cat 查看文件内容

cat: 查看文件内容,从第一行开始显示。

12.1.基本语法

cat [选项] 要查看的文件

12.2 选项说明

-n: 显示所有行的行号,包括空行。

12.3 经验技巧
一般查看比较小的文件,一屏幕能显示全的。

12.4 案例实操
12.4.1 查看文件内容并显示行号

[root@localhost ~]# cat -n houge.txt 
     1	ghjk
     2	ggjj
     3	hfghj
[root@localhost ~]# 

13、more 文件内容分屏查看器

more指令是一个基于VI编辑器的文本过滤器,它以全屏幕的方式按页显示文本文件的内容。more指令中内置了若干快捷键,详见操作说明。

13.1 基本语法
more 要查看的文件

13.2 操作说明

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

13.3 案例实操
采用more查看文件

[root@localhost ~]# touch smartd.conf
[root@localhost ~]# vim smartd.conf 


fghjklmnvn
fkdkgnk
zjkkmvkg
~                                                                                                                                                                          
~    

[root@localhost ~]# more smartd.conf
fghjklmnvn
fkdkgnk
zjkkmvkg
    
[root@localhost ~]# 

14、 less 分屏显示文件内容

less指令用来分屏查看文件内容,它的功能与more指令类似,但是比more指令更加强大,支持各种显示终端。less指令在显示文件内容时,并不是一次将整个文件加载之后才显示,而是根据显示需要加载内容,对于显示大型文件具有较高的效率。

14.1基本语法

less: 要查看的文件

14.2.操作说明

空白键: 向下翻动一页;
[pagedown]: 向下翻动一页
[pageup]: 向上翻动一页;
/字串: 向下搜寻『字串』的功能;
n:向下查找;
N:向上查找;
?字串 向上搜寻『字串』的功能;
n:向上查找;N:向下查找;
q : 离开 less 这个程序;

14.3 案例实操
(1)采用less查看文件

[root@localhost ~]# less smartd.conf









fghjklmnvn
fkdkgnk
zjkkmvkg
smartd.conf (END)

15、echo

echo:输出内容到控制台

15.1 基本语法

echo [选项] [输出内容] 选项:
-e: 支持反斜线控制的字符转换 控制字符

15.2 控制字符和作用

\ : 输出\本身
\n: 换行符
\t : 制表符,也就是Tab键

15.3 案例实操

[root@localhost ~]# echo "hello\tworld"
hello\tworld
[root@localhost ~]# echo -e "hello\tworld"
hello	world
[root@localhost ~]# 

16、head 显示文件头部内容

head:用于显示文件的开头部分内容,默认情况下head指令显示文件的前10行内容。

16.1 基本语法

head 文件 (功能描述:查看文件头10行内容)
head -n 5 文件 (功能描述:查看文件头5行内容,5可以是任意行数)

16.2 选项说明

-n <行数> 指定显示头部内容的行数

16.3 案例实操
(1)查看文件的头2行

[root@localhost ~]# head -n 2 smartd.conf
fghjklmnvn
fkdkgnk
[root@localhost ~]# 

17、tail 输出文件尾部内容

tail:用于输出文件中尾部的内容,默认情况下tail指令显示文件的后10行内容。

17.1基本语法

(1)tail 文件 (功能描述:查看文件后10行内容
(2)tail -n 5 文件(功能描述:查看文件后5行内容,5可以是任意行数)
(3)tail -f 文件 (功能描述:实时追踪该文档的所有更新)

17.2 选项说明

-n<行数> 输出文件尾部n行内容
-f 显示文件最新追加的内容,监视文件变化

17.3 案例实操
(1)查看文件头1行内容

[root@localhost ~]# tail -n 1 smartd.conf 
zjkkmvkg
[root@localhost ~]# 

(2)实时追踪该档的所有更新

[root@localhost ~]# tail -f houge.txt
ghjk
ggjj
hfghj

18、> 覆盖 和 >> 追加

基本语法

(1)ll >文件 (功能描述:列表的内容写入文件a.txt中(覆盖写))
(2)ll文件 (功能描述:列表的内容追加到文件aa.txt的末尾) (3)cat 文件1 > 文件2 (功能描述:将文件1的内容覆盖到文件2)
(4)echo “内容” >> 文件

18.2 案例实操
(1)将ls查看信息写入到文件中

[root@localhost ~]# ls -l>houge.txt
[root@localhost ~]# 

(2)将ls查看信息追加到文件中

[root@localhost ~]# ls -l>>houge.txt
[root@localhost ~]# 

(3)采用echo将hello单词追加到文件中

[root@localhost ~]# echo hello>>houge.txt
[root@localhost ~]# 

19、ln 软链接

软链接也成为符号链接,类似于windows里的快捷方式,有自己的数据块,主要存放了链接其他文件的路径。

19.1 基本语法

ln -s [原文件或目录] [软链接名] (功能描述:给原文件创建一个软链接)

19.2 经验技巧

删除软链接: rm -rf 软链接名,而不是rm -rf 软链接名/
查询:通过ll就可以查看,列表属性第1位是l,尾部会有位置指向。

19.3 案例实操
(1)创建软连接

[root@localhost ~]# mv houge.txt xiyou/dssz/
[root@localhost ~]#  ln -s xiyou/dssz/houge.txt ./houz
[root@localhost ~]# ll
total 8
-rw-------. 1 root root 1264 Oct 19 23:01 anaconda-ks.cfg
lrwxrwxrwx. 1 root root   20 Oct 31 08:51 houz -> xiyou/dssz/houge.txt
-rw-r--r--. 1 root root   28 Oct 31 08:22 smartd.conf
-rw-r--r--. 1 root root    0 Oct 31 08:06 sunwukong.txt
drwxr-xr-x. 4 root root   33 Oct 31 08:15 xiyou
[root@localhost ~]# 

(2)删除软连接

[root@localhost ~]# rm -rf houzi
[root@localhost ~]# 

(3)进入软连接实际物理路径

[root@localhost ~]# ln -s xiyou/dssz/ ./dssz
[root@localhost ~]# cd -P dssz/
[root@localhost dssz]# ll
total 4
-rw-r--r--. 1 root root 559 Oct 31 08:47 houge.txt
-rw-r--r--. 1 root root   0 Oct 31 08:09 hustrooy.txt
-rw-r--r--. 1 root root   0 Oct 31 06:49 sunwukong.txt
[root@localhost dssz]# 

20、history 查看已经执行过历史命令
20.1 基本语法

history (功能描述:查看已经执行过历史命令)

20.2 案例实操
(1)查看已经执行过的历史命令

[root@localhost dssz]# history
    1  ll
    2  cd /
    3  ll
    4  cd root
    5  ll
    6  ip addr
    7  ping 192.168.219.5
    8  ping www,baidu.com
    9  vi /etc/sysconfig/network-scripts/ifcfg-ens33 
   10  service network restart
   11  ping www,baidu.com
   12  ip addr
   13  ping www.baidu.com
   14  ping 192.168.219.5
   15  vi /etc/resolv.conf
   16  service network restart
   17  ping 192.168.219.5
   18  ping www.baidu.com
   19  service network restart
   20  ping 192.168.219.5
   21  ping www.baidu.com
   22  ping 192.168.219.5
   23  java
   24  javac
   25  java -version
   26  cd /usr/local/java/tomcat/
   27  ls
   28  tar -zxvf apache-tomcat-8.5.47.tar.gz 
   29  ls
   30  cd apache-tomcat-8.5.47
   31  ls
   32  cd bin/
   33  ls
   34  ./startup.sh
   35  firewall-cmd --zone=public --add-port=8080/tcp --permanent
   36  ./startup.sh
   37  firewall-cmd --reload
   38  ./startup.sh
   39  ping 192.168.219.5
   40  ping www.baidu.com
   41  ping 192.168.219.5
   42  vi /etc/sysconfig/network-scripts/ifcfg-ens33 
   43  ping 192.168.219.5
   44  ll
   45  ping www.baidu.com
   46  ping 192.168.219.5
   47  ping www.baidu.com
   48  cd /usr/local/java/zookeeper/
   49  ls
   50  tar -zxvf zookeeper-3.4.5.tar.gz 
   51  mv zookeeper-3.4.5 zookeeper
   52  ls
   53  cd zookeeper
   54  ls
   55  cd conf/
   56  ls
   57  cd ..
   58  cd zookeeper/
   59  ls
   60  mv zookeeper zookeeper3.4.5 
   61  ls
   62  mkdir -p zkData
   63  cd ..
   64  cd zookeeper/
   65  ls
   66  cd zkData/
   67  touch myid
   68  vim myid
   69  cd ..
   70  cd zookeeper3.4.5/
   71  ls
   72  cd conf/
   73  ls
   74  mv zoo_sample.cfg zoo.cfg
   75  vim zoo.cfg
   76  cd ..
   77  cd bin/
   78  ls
   79  ./zkServer.sh 
   80  ./zkServer.sh start
   81  ./zkCli.sh 
   82  exit
   83  cd /usr/local/java/zookeeper/zookeeper3.4.5/
   84  ls
   85   mkdir -p zkData
   86  ls
   87  cd zkData/
   88  pwd
   89  exit
   90  cd /usr/local/java/tomcat/apache-tomcat-8.5.47
   91  ls
   92  vi catalina.sh
   93  vi /etc/profile
   94  cd bin/
   95  ls
   96  vi catalina.sh 
   97  ./startup.sh
   98  cd /usr/local/java/redis/
   99  l
  100  ls
  101  tar -zxvf redis-3.2.5.tar.gz 
  102  ls
  103  cd redis-3.2.5
  104  ls
  105  yum install gcc
  106  make MALLOC=libc
  107   cd src && make install
  108  ./redis-server
  109  cd ..
  110  cd src/
  111  ./redis-server
  112  quit
  113  exit
  114  cd /usr/local/java/redis/redis-3.2.5
  115  ls
  116  vi redis.conf 
  117  cd src/
  118  ./redis-server /usr/local/redis-4.0.6/redis.conf 
  119  ps -aux | grep redis
  120  kill 8491
  121  cd /etc/
  122  mkdir redis
  123  cd redis/
  124  cp /usr/local/java/redis/redis-3.2.5/utils/redis_init_script /etc/init.d/redisd
  125  cd /etc/init.d/
  126   chkconfig redisd on
  127  vi redisd 
  128  chkconfig redisd on
  129  service redisd start
  130  service redisd stop
  131  service redisd start
  132  cd /usr/local/java/redis/redis-3.2.5
  133  ls
  134  cd b
  135  ls
  136  cd src/
  137  ls
  138   ./redis-cli    
  139  ./redis-cli start   
  140   ./redis-cli    
  141  cd /usr/local/java/
  142  ls
  143  cd mysql/
  144   wget http://dev.mysql.com/get/mysql-5.7.26-1.el7.x86_64.rpm-bundle.tar
  145  yum -y install wget
  146  yum -y install vim
  147   wget http://dev.mysql.com/get/mysql-5.7.26-1.el7.x86_64.rpm-bundle.tar
  148  cd /usr/local/java/
  149  ls
  150  cd nginx/
  151  yum install -y gcc gcc-c++
  152  yum install gcc-c++
  153  yum install -y pcre pcre-devel
  154   yum install -y zlib zlib-devel
  155  yum install -y openssl openssl-devel
  156   wget http://nginx.org/download/nginx-1.14.0.tar.gz
  157  ls
  158  tar -zxvf nginx-1.14.0.tar.gz
  159  ls
  160  cd nginx-1.14.0
  161  ./configure --prefix=/usr --sbin-path=/usr/sbin/nginx --conf-path=/etc/nginx/nginx.conf --error-log-path=/var/log/nginx/error.log --pid-path=/var/run/nginx/nginx.pid --lock-path=/var/lock/nginx.lock --user=nginx --group=nginx --with-http_ssl_module --with-http_flv_module --with-http_gzip_static_module --http-log-path=/var/log/nginx/access.log --http-client-body-temp-path=/var/tem/nginx/client --http-proxy-temp-path=/var/tem/nginx/proxy --http-fastcgi-temp-path=/var/tem/nginx/fcgi --with-http_stub_status_module
  162   make && make install
  163  nginx -c /etc/nginx/nginx.conf
  164  ls
  165  cd src/
  166  ls
  167  cd ..
  168  ls
  169  cd..
  170  cd ..
  171  ls
  172  cd nginx-1.14.0
  173  ls
  174  cd conf/
  175  ls
  176  cd ..
  177  nginx -c /etc/nginx/nginx.conf
  178  cd /etc/nginx/nginx.conf
  179  ls
  180  useradd -s /sbin/nologin -M nginx
  181  id nginx
  182  sudo mkdir -p /var/tem/nginx/client
  183  ls
  184  sudo firewall-cmd --permanent --zone=public --add-service=http 
  185  sudo firewall-cmd --permanent --zone=public --add-service=https
  186  sudo firewall-cmd --reload
  187  cd /usr/local/java/nginx/
  188  ls
  189  cd nginx-1.14.0
  190  ls
  191  cd /etc/
  192  ls
  193  useradd -s /sbin/nologin -M nginx
  194  id nginx
  195  cd /usr/local/java/nginx/nginx-1.14.0
  196  ls
  197  cd src/
  198  ls
  199  ps -ef|grep nginx
  200  nginx -t -c /etc/nginx/nginx.conf
  201  cd ..
  202  cd conf/
  203  ls
  204  vim nginx.conf 
  205  cd ..
  206  cd sbin
  207  ls
  208  cd configure 
  209  ls
  210  cd src/
  211  ls
  212  cd core/
  213  ls
  214  cd ..
  215  cd event/
  216  ls
  217  cd ..
  218  cd http/
  219  ls
  220  cd ../..
  221  nginx -c ./logs/nginx.conf
  222  cd ..
  223  cd nginx/
  224  ls
  225  rm -f nginx-1.14.0
  226  ls
  227  cd nginx-1.14.0
  228  cd ..
  229  rm -f nginx-1.14.0
  230  ls
  231  rm nginx-1.14.0
  232  cd ..
  233  rm nginx/
  234  cd nginx/
  235  ls
  236  rm -rf nginx-1.14.0
  237  ls
  238  yum install gcc-c++
  239  yum install -y zlib zlib-devel
  240  yum install -y openssl openssl-devel
  241  tar -zxvf nginx-1.14.0.tar.gz 
  242  cd nginx-1.14.0
  243  ./configure --prefix=/usr/local/nginx --pid-path=/var/run/nginx/nginx.pid --lock-path=/var/lock/nginx.lock --error-log-path=/var/log/nginx/error.log --http-log-path=/var/log/nginx/access.log --with-http_gzip_static_module --http-client-body-temp-path=/var/temp/nginx/client --http-proxy-temp-path=/var/temp/nginx/proxy --http-fastcgi-temp-path=/var/temp/nginx/fastcgi --http-uwsgi-temp-path=/var/temp/nginx/uwsgi --http-scgi-temp-path=/var/temp/nginx/scgi
  244  make
  245  make install
  246  make
  247  make install
  248  ls
  249  cd ..
  250  ls
  251  rm -rf nginx-1.14.0
  252  rm -rf nginx-1.14.0.tar.gz 
  253  ls
  254  yum install gcc-c++
  255  yum install -y pcre pcre-devel
  256  yum install -y zlib zlib-devel
  257  yum install -y openssl openssl-devel
  258  wget http://nginx.org/download/nginx-1.15.9.tar.gz
  259  tar -zxvf nginx-1.15.9.tar.gz
  260  ls
  261  ll
  262  cd nginx-1.15.9
  263  ls
  264  ll
  265  ./configure --prefix=/usr/local/nginx/ --with-http_ssl_module --with-http_stub_status_module 
  266  ll
  267  make && make install
  268  ll
  269  cd ..
  270  ll
  271  cd ..
  272  ll
  273  cd nginx/
  274  ls
  275  cd sbin/
  276  ll
  277  ./nginx
  278  systemctl stop firewalld
  279  cd ..
  280  cd java/nginx/nginx-1.15.9
  281  ls
  282  cd conf
  283  ls
  284  vim nginx.conf 
  285  cd /usr/local/java/mysql/
  286  ls
  287  tar -zxvf mysql-5.7.26-1.el7.x86_64.rpm-bundle.tar 
  288  tar -xvf mysql-5.7.26-1.el7.x86_64.rpm-bundle.tar 
  289  ls
  290  rpm -e --nodeps mariadb-libs
  291  rpm -ivh mysql-community-common-5.7.26-1.el7.x86_64.rpm
  292  ll
  293  tar -xvf mysql-5.7.26-1.el7.x86_64.rpm-bundle.tar 
  294  rm -rf mysql-5.7.26-1.el7.x86_64.rpm-bundle.tar 
  295  rm -rf mysql-community-embedded-5.7.26-1.el7.x86_64.rpm 
  296  rm -rf mysql-community-embedded-devel-5.7.26-1.el7.x86_64.rpm 
  297  rm -rf mysql-community-libs-5.7.26-1.el7.x86_64.rpm 
  298  rm -rf mysql-community-test-5.7.26-1.el7.x86_64.rpm 
  299  ll
  300  clear
  301  ll
  302  ls
  303  wget http://dev.mysql.com/get/mysql-5.7.26-1.el7.x86_64.rpm-bundle.tar
  304  ll
  305  ls
  306  cd /usr/local/java/mysql/
  307  ls
  308  tar -xvf mysql-5.7.26-1.el7.x86_64.rpm-bundle.tar
  309  rpm -qa|grep mari
  310  rpm -ivh mysql-community-common-5.7.26-1.el7.x86_64.rpm
  311  rpm -ivh mysql-community-libs-5.7.26-1.el7.x86_64.rpm
  312  rpm -ivh mysql-community-client-5.7.26-1.el7.x86_64.rpm
  313  rpm -ivh mysql-community-server-5.7.26-1.el7.x86_64.rpm
  314  systemctl start mysqld.service
  315  grep "password" /var/log/mysqld.log
  316  mysql -u root -p
  317  systemctl start mysqld.service
  318  ls
  319  systemctl start mysqld.service
  320  services start mysqld.service
  321  grep "password" /var/log/mysqld.log
  322  systemctl start mysqld.service
  323  yum install -y mariadb-server
  324   systemctl start mariadb.service
  325  systemctl enable mariadb.service
  326  systemctl start mysqld.service
  327  mysql_sceure_installation
  328  systemctl start mariadb.service
  329  yum install -y mariadb-server
  330  systemctl start mariadb.service
  331  yum install -y mariadb-server
  332  systemctl start mariadb.service
  333  systemctl enable mariadb.service
  334  mysql -u root -p
  335  ps -A|grep mysql
  336  mysql -u root -p
  337  chown -R mysql:mysql /var/lib/mysql
  338  mysql -u root -p
  339  clear
  340  rpm -ivh mysql-community-server-5.7.26-1.el7.x86_64.rpm
  341  rpm -ivh mysql-community-server-5.7.26-1.el7.x86_64.rpm --force --nodeps
  342  systemctl start mysqld.service
  343  grep "password" /var/log/mysqld.log
  344  mysql -u root -p
  345  systemctl start mysqld.service
  346  mysql -u root -p
  347  vim /etc/my.cnf
  348  /etc/init.d/mysql restart
  349  mysql
  350  mysql -u root -p
  351  systemctl start mysqld.service
  352  /etc/init.d/mysql restart
  353  mysql -u root -p
  354  vim /etc/my.cnf
  355  systemctl start mysqld.service
  356  mysql -u root -p
  357  use mysql
  358  mysql -u root -p
  359  grep 'temporary pass' /var/log/mysqld.log 
  360  $ mysql -uroot -pl#\(\)FqWfy9ih
  361  mysql -uroot -pl#\(\)FqWfy9ih
  362  mysql -u root -p
  363  systemctl stop mysqld.service
  364  vi /etc/my.cnf
  365  systemctl start mysqld.service
  366  mysql -u root
  367  vi /etc/my.cnf
  368  mysql -u root
  369  exit
  370  exit
  371  ping 192.168.219.5
  372  ping www.baidu.com
  373  ping 192.168.219.5
  374  ping www.baidu.com
  375  service network restart
  376  ping 192.168.219.5
  377  ping www.baidu.com
  378  ping 192.168.219.5
  379  ping www.baidu.com
  380  cd /usr/local/java/redis/
  381  ls
  382  cd redis-3.2.5
  383  ls
  384  cd src/
  385  ls
  386  cd ..
  387  ll
  388  cd /usr/local/java/
  389  ll
  390  cd ..
  391  ll
  392  cd bin/
  393  ls
  394  redis-cli 
  395  service iptables status
  396  yum install iptables-services
  397  service iptables status
  398  service iptables stop
  399  systemctl iotables stop
  400  systemctl stop firewalld.service  
  401  systemctl status firewalld.service  
  402  chkconfig iptables --list
  403  ll
  404  pwd
  405  cd ..
  406  cd java/redis/redis-3.2.5
  407  ll
  408  vim redis.conf 
  409  cd ..
  410  ll
  411  cd bin/
  412  ll
  413  redis-server 
  414  clear
  415  cd /usr/local/java/redis/redis-3.2.5
  416  ll
  417  ps -ef|grep redis
  418  redis-cli 
  419  redis-cli start
  420  redis-server /etc/redis.conf
  421  cd /
  422  redis-server /etc/redis.conf
  423   redis-cli
  424  cd /usr/local/java/redis/
  425  ll
  426  cd ..
  427  ll
  428  cd ..
  429  ll
  430  cd sbin/
  431  ll
  432  ls
  433  ll
  434  cd ..
  435  cd bin/
  436  ll
  437  redis-cli 
  438  redis-server 
  439  cd ..
  440  cd java/redis/redis-3.2.5
  441  ll
  442  vim redis.conf 
  443  cd ../..
  444  cd ..
  445  cd bin/
  446  redis-service
  447  redis-server
  448  ll
  449  ./redis-server
  450  systemctl stop firewalld.service  
  451  ./redis-server
  452  cd /usr/local/bin/redis-cli
  453  cd /usr/local/bin
  454  redis-cli
  455  cd /usr/local/bin/
  456  ./redis-cli
  457  systemctl stop firewalld.service  
  458  ./redis-server
  459  cd /usr/local/
  460  ll
  461  cd bin/
  462  ll
  463  ./redis-server
  464  cd /usr/local/java/redis/redis-3.2.5
  465  ll
  466  vim redis.conf 
  467  ping 192.168.219.5
  468  service iptables stop
  469  vim redis.conf 
  470  ip addr
  471  vim redis.conf 
  472  vim /etc/sysconfig/iptables
  473  service iptables restart
  474  service iptables stop
  475  systemctl stop firewalld.service  
  476  vim redis.conf 
  477  cd ../../..
  478  ll
  479  cd bin/
  480  ll
  481  ./redis-server
  482  cd ../..
  483  cd /usr/local/java/redis/redis-3.2.5
  484  vim redis.conf 
  485  vim /etc/sysconfig/iptables
  486  cd /usr/local/
  487  cd bin/
  488  ll
  489  ./redis-cli 
  490  cd /usr/local/bin/
  491  ./redis-cli 
  492  cd /usr/local/bin/
  493  ll
  494  ./redis-server 
  495  ll
  496  cd ~
  497  ll
  498  cd root
  499  cd /root/
  500  ll
  501  cd /usr/local/bin/
  502  ll
  503  ls/
  504  cd /usr/local/java/redis/redis-3.2.5
  505  ls
  506  vim redis.conf 
  507  cd /usr/local/bin/
  508  ./redis-cli
  509  cd /usr/local/java/redis/
  510  ll
  511  vim redis6379.conf 
  512  pwd
  513  vim redis6379.conf 
  514  ./redis-cli -p 6379
  515  ll
  516  redis-cli -p 6380
  517  redis-service redis6379.conf 
  518  clear
  519  redis-service redis6379.conf 
  520   redis-cli -p 6380
  521   redis-cli -p 6379
  522  redis-server redis6379.conf
  523   redis-cli -p 6379
  524  vim redis.conf 
  525  ll
  526  vim redis6381.conf
  527  redis-server redis6381.conf
  528   redis-cli -p 6381
  529  cd ..
  530  cd bin/
  531  ll
  532  cd ..
  533  cd java/redis/
  534  ll
  535  redis-sentinel sentinel.conf
  536  cd /usr/local/java/redis/redis
  537  cd /usr/local/java/redis/
  538  ll
  539  cd redis-3.2.5
  540  pwd
  541  cd ..
  542  clear
  543  redis-server redis6379.conf
  544  redis-server redis6380.conf
  545  redis-cli -p 6380
  546  ps -ef|grep redis
  547  redis-cli -p 6380
  548  syscemctl list -unit-files|grep firewalld
  549  systemctl list -unit-files|grep firewalld
  550  systemctl list-unit-files|grep firewalld
  551  cd /usr/local/java/redis/redis-3.2.5
  552  vim redis.conf 
  553  rm -rf dump.*
  554  ll
  555  vim redis.conf 
  556  cp redis.conf /usr/local/java/redis/
  557  cd ..
  558  ll
  559  vim redis.conf 
  560  ll
  561  vim redis.conf 
  562  redis-server redis6379.conf
  563  redis-cli -p 6379
  564  vim redis.conf 
  565  vim sentinel.conf
  566  ll
  567  cd /usr/local/
  568  ll
  569  cd bin/
  570  ll
  571  cd ..
  572  cd java/redis/
  573  ll
  574  redis-server redis6379.conf
  575  redis-cli -p 6379
  576  cd /usr/local/java/redis/
  577  redis-server redis6380.conf 
  578  shutdown
  579  redis-server redis6380.conf 
  580  redis-cli -p 6380
  581  clear
  582  cd /usr/local/java/redis/
  583  redis-server redis6379.conf 
  584  redis-cli -p 6379
  585  ps -ef|grep redis
  586  cd /usr/local/java/r
  587  cd /usr/local/java/redis/
  588  vim /redis6379.conf
  589  ll
  590  cd ..
  591  ll
  592  cd /
  593  ll
  594  cp redis6379.conf /usr/local/java/redis/
  595  ll
  596  cd /usr/local/java/redis/
  597  ll
  598  vim redis6379.conf 
  599  cp redis6379.conf redis6380.conf 
  600  ll
  601  cp redis6379.conf redis6381.conf 
  602  vim redis6380.conf 
  603  vim redis6381.conf 
  604  vim redis6379.conf 
  605  vim redis6380.conf 
  606  vim redis6381.conf 
  607  clear
  608  redis-server redis6381.conf
  609  redis-cli -p 6380
  610  redis-cli -p 6381
  611  redis-server redis6381.conf
  612  redis-cli -p 6381
  613  redis-server redis6381.conf
  614  redis-cli -p 6381
  615  cd /usr/local/java/redis/
  616  redis-service redis6379.conf 
  617  ll
  618  clear
  619  ll
  620  clear
  621  redis-server redis6380.conf
  622  redis-cli -p 6380
  623  cd /usr/local/java/redis/
  624  redis-service redis6381.conf 
  625  redis-servce redis6381.conf 
  626  redis-server redis6381.conf 
  627  redis-cli -p 6381
  628  clear
  629  cd /usr/local/java/redis/
  630  ll
  631  redis-service redis6379.conf
  632  vim redis6380.conf 
  633  vim redis6381.conf 
  634  vim redis6380.conf 
  635  redis-server redis6379.conf
  636  redis-cli -p 6379
  637  ll
  638  rm -rf dump*
  639  ll
  640  yum install ruby
  641  yum install rubygems
  642  ll
  643  vim redis6379.conf 
  644  cp redis6379.conf redis6380.conf 
  645  cp redis6379.conf redis6381.conf 
  646  cp redis6379.conf redis6389.conf 
  647  cp redis6379.conf redis6390.conf 
  648  cp redis6379.conf redis6391.conf 
  649  ll
  650  vim redis6380.conf 
  651  vim redis6381.conf 
  652  vim redis6380.conf 
  653  vim redis6379.conf 
  654  vim redis6380.conf 
  655  vim redis6381.conf 
  656  vim redis6389.conf 
  657  vim redis6390.conf 
  658  vim redis6391.conf 
  659  vim redis6379.conf 
  660  vim redis6391.conf 
  661  clear
  662  redis-server redis6379.conf
  663  redis-server redis6380.conf
  664  redis-server redis6381.conf
  665  redis-server redis6389.conf
  666  redis-server redis6390.conf
  667  redis-server redis6391.conf
  668  ll
  669  ps -ef|grep redis
  670  pwd
  671  ll
  672  redis-3.2.5/
  673  cd redis-3.2.5
  674  ll
  675  cd src/
  676  ./redis-trib.rb create --replicas 1 192.168.1.100:6379 192.168.1.100:6380 192.168.1.100:6381 192.168.1.100:6389 192.168.1.100:6390 192.168.1.100:6391
  677  ./redis-trib.rb create --replicas 1 192.168.219.5:6379 192.168.219.5:6380 192.168.219.5:6381 192.168.219.5:6389 192.168.219.5:6390 192.168.219.5:6391
  678  cd
  679  redis-cli -p 6379
  680  redis-cli  -p 6379
  681  redis-cli -c -p 6379
  682  cd /usr/local/java/redis/
  683  ll
  684  vim nodes-6379.conf 
  685  clear
  686  cat /etc/shells 
  687  ll | grep bash
  688  cd b
  689  echo $SHELL
  690  echo $bin
  691  pwd
  692  cd /bin/
  693  ll | grep bash
  694  cd ..
  695  touch helloworld.sh
  696  pwd
  697  ll
  698   vi helloworld.sh
  699  sh helloworld.sh 
  700   vi helloworld.sh
  701  sh /home/ll
  702  cd /home/
  703  ll
  704  ls
  705  cd /
  706  chmod 777 helloworld.sh
  707  ./helloworld.sh 
  708  cd /opt/
  709  mkdir datas
  710  cd datas/
  711  touch batch.sh
  712  vim batch.sh
  713  ./batch.sh
  714  sh batch.sh
  715  sh batch.sh 
  716  ls
  717  ll
  718  echo $HOME
  719  set
  720  clear
  721  A=5
  722  echo $A
  723  A=8
  724  echo $A
  725  unset A
  726  echo $A
  727  readonly B=2
  728  echo $B
  729  B=9
  730  C=1+2
  731  echo $C
  732  D=I love banzhang
  733  D="I love banzhang"
  734  echo $A
  735  echo $D
  736  clear
  737  D=I love banzhang
  738  D="I love banzhang"
  739  echo $D
  740  vim helloworld.sh 
  741  ./helloworld.sh 
  742  vim helloworld.sh 
  743  ./helloworld.sh 
  744  ll
  745  vim helloworld.sh 
  746  ll
  747  ls
  748  vim helloworld.sh 
  749  cd /
  750  ll
  751  vim helloworld.sh 
  752  ./helloworld.sh 
  753  export B
  754  ./helloworld.sh 
  755  touch parameter.sh
  756  vim parameter.sh
  757  chmod 777 parameter.sh
  758  ./parameter.sh cls  xz
  759  cd /opt/
  760  ll
  761   gem install --local redis-3.2.0.gem
  762  cat /etc/shells 
  763  cd ~
  764  [root@localhost opt]# cat /etc/shells 
  765  /bin/sh
  766  /usr/bin/bash
  767  /bin/bash
  768  /usr/bin/sh
  769  cp xiyou/dssz/suwukong.txt xiyou/mingjie/
  770  cp xiyou/dssz/sunwukong.txt xiyou/mingjie/
  771  cp -r xiyou/dssz/ ./
  772  rm xiyou/mingjie/sunwukong.txt
  773  ll
  774  cd xiyou/mingjie/
  775  ll
  776  ls
  777  cd ~
  778  rm -rf dssz/
  779  mv xiyou/dssz/suwukong.txt xiyou/dssz/houge.txt
  780  cd xiyou/dssz/
  781  ll
  782  ls
  783  mv xiyou/dssz/sunwukong.txt xiyou/dssz/houge.txt
  784  mv xiyou/dssz/sunwukong.txt xiyou/dssz/
  785  mv xiyou/dssz/sunwukong.txt ./
  786  cd ·
  787  cd ~
  788  ll
  789  cd xiyou/
  790  ls
  791  cd dssz/
  792  ls
  793  cd ~
  794  cd xiyou/dssz/sunwukong.txt 
  795  cp xiyou/dssz/sunwukong.txt  ./
  796  ls
  797  cd xiyou/
  798  ls
  799  cd mingjie/
  800  ls
  801  touch hustrooy.txt
  802  cd ·
  803  cd ~
  804  mv xiyou/mingjie/hustrooy.txt ./xiyou/dssz/
  805  cd xiyou/dssz/
  806  ls
  807  cd ~
  808  ll
  809  cd xiyou/
  810  touch houge.txt
  811  cd ~
  812  cat -n houge.txt 
  813  mv xiyou/houge.txt  ./
  814  ll
  815  cat -n houge.txt 
  816  vim houge.txt 
  817  cat -n houge.txt 
  818  more smartd.conf
  819  touch smartd.conf
  820  more smartd.conf
  821  vim smartd.conf 
  822  more smartd.conf
  823  vim smartd.conf 
  824  less smartd.conf
  825  echo "hello\tworld"
  826  echo -e "hello\tworld"
  827  head -n 2 smartd.conf
  828  tail -n 1 smartd.conf 
  829  tail -f houge.txt
  830  ls -l>houge.txt
  831  ls -l>>houge.txt
  832  echo hello>>houge.txt
  833  clear
  834  mv houge.txt xiyou/dssz/
  835   ln -s xiyou/dssz/houge.txt ./houz
  836  ll
  837  rm -rf houzi
  838  ln -s xiyou/dssz/ ./dssz
  839  cd -P dssz/
  840  ll
  841  history
[root@localhost dssz]# 

21、时间日期类

21.1 基本语法

date [OPTION]… [+FORMAT]

21.2 选项说明

-d<时间字符串> 显示指定的“时间字符串”表示的时间,而非当前时间
-s<日期时间> 设置系统日期时间

21.3 参数说明

<+日期时间格式>: 指定显示时使用的日期时间格式

21.4 date 显示当前时间
基本语法

1)date (功能描述:显示当前时间)
(2)date +%Y (功能描述:显示当前年份)
(3)date +%m (功能描述:显示当前月份)
(4)date +%d (功能描述:显示当前是哪一天)
(5)date “+%Y-%m-%d %H:%M:%S” (功能描述:显示年月日时分秒)

21.5 案例实操
(1)显示当前时间信息

[root@localhost ~]# date
Thu Oct 31 09:02:40 GMT 2019
[root@localhost ~]# 

(2)显示当前时间年月日

[root@localhost ~]#  date +%Y%m%d
20191031
[root@localhost ~]# 

(3)显示当前时间年月日时分秒

[root@localhost ~]# date "+%Y-%m-%d %H:%M:%S"
2019-10-31 09:04:06
[root@localhost ~]# 

22、date 显示非当前时间

22.1 基本语法

(1)date -d ‘1 days ago’ (功能描述:显示前一天时间)
(2)date -d ‘-1 days ago’ (功能描述:显示明天时间)

22.1 案例实操
(1)显示前一天

[root@localhost ~]# date -d '1 days ago'
Wed Oct 30 09:06:51 GMT 2019
[root@localhost ~]# 

(2)显示明天时间

[root@localhost ~]# date -d '-1 days ago'
Fri Nov  1 09:07:37 GMT 2019
[root@localhost ~]# 

23、date 设置系统时间

23.1 基本语法

date -s 字符串时间

23.2 案例实操
(1)设置系统当前时间

[root@localhost ~]# date -s "2019-11-6 20:52:18"
Wed Nov  6 20:52:18 GMT 2019
[root@localhost ~]# date
Wed Nov  6 20:53:01 GMT 2019
[root@localhost ~]# 

24、cal 查看日历

24.1 基本语法

cal [选项] (功能描述:不加选项,显示本月日历)

24.2 选项说明

具体某一年 显示这一年的日历

24.3 案例实操
(1)查看当前月的日历

[root@localhost ~]# cal
    November 2019   
Su Mo Tu We Th Fr Sa
                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

[root@localhost ~]# 

(2)查看2017年的日历

[root@localhost ~]# cal 2017
                               2017                               

       January               February                 March       
Su Mo Tu We Th Fr Sa   Su Mo Tu We Th Fr Sa   Su Mo Tu We Th Fr Sa
 1  2  3  4  5  6  7             1  2  3  4             1  2  3  4
 8  9 10 11 12 13 14    5  6  7  8  9 10 11    5  6  7  8  9 10 11
15 16 17 18 19 20 21   12 13 14 15 16 17 18   12 13 14 15 16 17 18
22 23 24 25 26 27 28   19 20 21 22 23 24 25   19 20 21 22 23 24 25
29 30 31               26 27 28               26 27 28 29 30 31

        April                   May                   June        
Su Mo Tu We Th Fr Sa   Su Mo Tu We Th Fr Sa   Su Mo Tu We Th Fr Sa
                   1       1  2  3  4  5  6                1  2  3
 2  3  4  5  6  7  8    7  8  9 10 11 12 13    4  5  6  7  8  9 10
 9 10 11 12 13 14 15   14 15 16 17 18 19 20   11 12 13 14 15 16 17
16 17 18 19 20 21 22   21 22 23 24 25 26 27   18 19 20 21 22 23 24
23 24 25 26 27 28 29   28 29 30 31            25 26 27 28 29 30
30
        July                  August                September     
Su Mo Tu We Th Fr Sa   Su Mo Tu We Th Fr Sa   Su Mo Tu We Th Fr Sa
                   1          1  2  3  4  5                   1  2
 2  3  4  5  6  7  8    6  7  8  9 10 11 12    3  4  5  6  7  8  9
 9 10 11 12 13 14 15   13 14 15 16 17 18 19   10 11 12 13 14 15 16
16 17 18 19 20 21 22   20 21 22 23 24 25 26   17 18 19 20 21 22 23
23 24 25 26 27 28 29   27 28 29 30 31         24 25 26 27 28 29 30
30 31
       October               November               December      
Su Mo Tu We Th Fr Sa   Su Mo Tu We Th Fr Sa   Su Mo Tu We Th Fr Sa
 1  2  3  4  5  6  7             1  2  3  4                   1  2
 8  9 10 11 12 13 14    5  6  7  8  9 10 11    3  4  5  6  7  8  9
15 16 17 18 19 20 21   12 13 14 15 16 17 18   10 11 12 13 14 15 16
22 23 24 25 26 27 28   19 20 21 22 23 24 25   17 18 19 20 21 22 23
29 30 31               26 27 28 29 30         24 25 26 27 28 29 30
                                              31

[root@localhost ~]# 

25、用户管理命令

useradd: 添加新用户

25.1 基本语法

useradd 用户名 (功能描述:添加新用户)
useradd -g 组名 用户名 (功能描述:添加新用户到某个组)

25.2 案例实操
(1)添加一个用户

[root@localhost ~]# useradd tangseng
[root@localhost ~]# ll /home/
total 0
drwx------. 2 tangseng tangseng 62 Nov  6 20:59 tangseng
[root@localhost ~]# 

26、passwd 设置用户密码

26.1 基本语法

passwd: 用户名 (功能描述:设置用户密码)

26.2 案例实操
(1)设置用户的密码

[root@localhost ~]# passwd tangseng
Changing password for user tangseng.
New password: 
BAD PASSWORD: The password contains the user name in some form
Retype new password: 
passwd: all authentication tokens updated successfully.
[root@localhost ~]# 

27、id 查看用户是否存在

27.1 基本语法

id :用户名

27.2 案例实操
(1)查看用户是否存在

[root@localhost ~]# id tangseng
uid=1001(tangseng) gid=1001(tangseng) groups=1001(tangseng)
[root@localhost ~]# 

28、 cat /etc/passwd 查看创建了哪些用户

28.1 基本语法

[root@localhost ~]# cat  /etc/passwd
root:x:0:0:root:/root:/bin/bash
bin:x:1:1:bin:/bin:/sbin/nologin
daemon:x:2:2:daemon:/sbin:/sbin/nologin
adm:x:3:4:adm:/var/adm:/sbin/nologin
lp:x:4:7:lp:/var/spool/lpd:/sbin/nologin
sync:x:5:0:sync:/sbin:/bin/sync
shutdown:x:6:0:shutdown:/sbin:/sbin/shutdown
halt:x:7:0:halt:/sbin:/sbin/halt
mail:x:8:12:mail:/var/spool/mail:/sbin/nologin
operator:x:11:0:operator:/root:/sbin/nologin
games:x:12:100:games:/usr/games:/sbin/nologin
ftp:x:14:50:FTP User:/var/ftp:/sbin/nologin
nobody:x:99:99:Nobody:/:/sbin/nologin
systemd-network:x:192:192:systemd Network Management:/:/sbin/nologin
dbus:x:81:81:System message bus:/:/sbin/nologin
polkitd:x:999:998:User for polkitd:/:/sbin/nologin
sshd:x:74:74:Privilege-separated SSH:/var/empty/sshd:/sbin/nologin
postfix:x:89:89::/var/spool/postfix:/sbin/nologin
nginx:x:1000:1000::/home/nginx:/sbin/nologin
mysql:x:27:27:MySQL Server:/var/lib/mysql:/bin/false
tangseng:x:1001:1001::/home/tangseng:/bin/bash
[root@localhost ~]# 

28.2 su 切换用户

su: swith user 切换用户

28.2.1基本语法

su 用户名称 (功能描述:切换用户,只能获得用户的执行权限,不能获得环境变量)
su -用户名称 (功能描述:切换到用户并获得该用户的环境变量及执行权限)

28.2.2 案例实操
(1)切换用户

[root@localhost ~]# su tangseng
[tangseng@localhost root]$ echo $PATH
/usr/local/java/jdk/jdk1.8.0_221/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/root/bin
[tangseng@localhost root]$ exit
exit
[root@localhost ~]# su - tangseng
Last login: Wed Nov  6 21:10:49 GMT 2019 on pts/5
[tangseng@localhost ~]$ echo $PATH
/usr/local/java/jdk/jdk1.8.0_221/bin:/usr/local/bin:/bin:/usr/bin:/usr/local/sbin:/usr/sbin:/home/tangseng/.local/bin:/home/tangseng/bin
[tangseng@localhost ~]$ 

28.3 userdel 删除用户
28.3.1 基本语法

(1)userdel 用户名 (功能描述:删除用户但保存用户主目录) (2)userdel -r 用户名 (功能描述:用户和用户主目录,都删除)

28.3.2 选项说明

-r 删除用户的同时,删除与用户相关的所有文件。

28.3.3 案例实操
(1)删除用户但保存用户主目录

[root@localhost tangseng]# userdel tangseng
userdel: user tangseng is currently used by process 8699
[root@localhost tangseng]# ll /home/
total 0
drwx------. 2 tangseng tangseng 83 Nov  6 21:11 tangseng
[root@localhost tangseng]# 

(2)删除用户和用户主目录,都删除

[root@localhost ~]# useradd zhubajie
[root@localhost ~]# ll /home/
total 0
drwx------. 2 tangseng tangseng 83 Nov  6 21:11 tangseng
drwx------. 2 zhubajie zhubajie 62 Nov  6 21:17 zhubajie
[root@localhost ~]# userdel -r zhubajie
[root@localhost ~]# ll /home/
total 0
drwx------. 2 tangseng tangseng 83 Nov  6 21:11 tangseng
[root@localhost ~]# 

29、who 查看登录用户信息

29.1 基本语法

(1)whoami (功能描述:显示自身用户名称)
(2)who am i (功能描述:显示登录用户的用户名)

29.2 案例实操
(1)显示自身用户名称

[root@localhost ~]# whoami
root
[root@localhost ~]# 

(2)显示登录用户的用户名

[root@localhost ~]# who am i
root     pts/5        2019-10-31 07:53 (192.168.219.1)
[root@localhost ~]# 

30、 sudo 设置普通用户具有root权限

1.添加MrZhou用户,并对其设置密码。

[root@localhost ~]# useradd MrZhou
[root@localhost ~]# passwd MrZhou
Changing password for user MrZhou.
New password: 
BAD PASSWORD: The password contains the user name in some form
Retype new password: 
Sorry, passwords do not match.
New password: 
BAD PASSWORD: The password is shorter than 8 characters
Retype new password: 
passwd: all authentication tokens updated successfully.
[root@localhost ~]# 

2.修改配置文件

[root@localhost ~]# vi /etc/sudoers

修改 /etc/sudoers 文件,找到下面一行(91行),在root下面添加一行,如下所示:

## Allow root to run any commands anywhere
root    ALL=(ALL)       ALL
root    ALL=(ALL)     ALL
MrZhou   ALL=(ALL)     ALL

或者配置成采用sudo命令时,不需要输入密码

## Allow root to run any commands anywhere
 root      ALL=(ALL)     ALL
 MrZhou    ALL=(ALL)     NOPASSWD:ALL

修改完毕,现在可以用atguigu帐号登录,然后用命令 sudo ,即可获得root权限进行操作。

3、案例实操
(1)用普通用户在/opt目录下创建一个文件夹

[root@localhost opt]#  sudo mkdir module
[root@localhost opt]#  chown MrZhou:MrZhou module/
[root@localhost opt]# 

31、usermod 修改用户

31.1 基本语法

usermod -g 用户组 用户名

31.2 选项说明

-g 修改用户的初始登录组,给定的组必须存在

31.3 案例实操
(1)将用户加入到用户组

[root@localhost mingjie]# usermod -g root tangseng
[root@localhost mingjie]# 

32、用户组管理命令

每个用户都有一个用户组,系统可以对一个用户组中的所有用户进行集中管理。不同Linux 系统对用户组的规定有所不同,
如Linux下的用户属于与它同名的用户组,这个用户组在创建用户时同时创建。
用户组的管理涉及用户组的添加、删除和修改。组的增加、删除和修改实际上就是对/etc/group文件的更新。

33、groupadd 新增组

33.1 基本语法

groupadd :组名

33.2 案例实操
(1)添加一个xitianqujing组

[root@localhost opt]# groupadd xitianqujing
[root@localhost opt]# 

34、groupdel 删除组

34.1基本语法

groupdel :组名

34.2 案例实操
(1)删除xitianqujing组

[root@localhost opt]#  groupdel xitianqujing
[root@localhost opt]# 

35、groupmod 修改组

35.1 基本语法

groupmod -n 新组名 老组名

35.2 选项说明

-n<新组名> 指定工作组的新组名

35.3 案例实操
(1)修改atguigu组名称为atguigu1

[root@localhost opt]# groupadd xitianqujing
[root@localhost opt]# groupmod -n xitian xitianqujing
[root@localhost opt]# 

36、cat /etc/group 查看创建了哪些组

36.1 基本操作

[root@localhost opt]# cat  /etc/group
root:x:0:
bin:x:1:
daemon:x:2:
sys:x:3:
adm:x:4:
tty:x:5:
disk:x:6:
lp:x:7:
mem:x:8:
kmem:x:9:
wheel:x:10:
cdrom:x:11:
mail:x:12:postfix
man:x:15:
dialout:x:18:
floppy:x:19:
games:x:20:
tape:x:33:
video:x:39:
ftp:x:50:
lock:x:54:
audio:x:63:
nobody:x:99:
users:x:100:
utmp:x:22:
utempter:x:35:
input:x:999:
systemd-journal:x:190:
systemd-network:x:192:
dbus:x:81:
polkitd:x:998:
ssh_keys:x:997:
sshd:x:74:
postdrop:x:90:
postfix:x:89:
nginx:x:1000:
mysql:x:27:
tangseng:x:1001:
MrZhou:x:1002:
xitian:x:1003:
[root@localhost opt]# 

37、文件权限类

37.1 文件属性

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

37.2 从左到右的10个字符表示,如图1-154所示:
在这里插入图片描述
如果没有权限,就会出现减号[ - ]而已。从左至右用0-9这些数字来表示:

(1)0首位表示类型
在Linux中第一个字符代表这个文件是目录、文件或链接文件等等
– :代表文件
d: 代表目录
l: 链接文档(link file);

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

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

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

37.3 rxw作用文件和目录的不同解释

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

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

37.4 案例实操

[root@localhost ~]# ll
total 8
-rw-------. 1 root root 1264 Oct 19 23:01 anaconda-ks.cfg
lrwxrwxrwx. 1 root root   11 Oct 31 08:52 dssz -> xiyou/dssz/
lrwxrwxrwx. 1 root root   20 Oct 31 08:51 houz -> xiyou/dssz/houge.txt
-rw-r--r--. 1 root root   28 Oct 31 08:22 smartd.conf
-rw-r--r--. 1 root root    0 Oct 31 08:06 sunwukong.txt
drwxr-xr-x. 4 root root   33 Oct 31 08:15 xiyou
[root@localhost ~]# 

在这里插入图片描述

(1)如果查看到是文件:链接数指的是硬链接个数。创建硬链接方法

ln [原文件] [目标文件]

[root@localhost ~]# ln xiyou/dssz/houge.txt ./hg.txt
[root@localhost ~]# 

(2)如果查看的是文件夹:链接数指的是子文件夹个数。

[root@localhost ~]# ls -al xiyou/
total 4
drwxr-xr-x. 4 root root   33 Oct 31 08:15 .
dr-xr-x---. 3 root root 4096 Nov  6 22:36 ..
drwxr-xr-x. 2 root root   64 Oct 31 08:50 dssz
drwxr-xr-x. 2 root root    6 Oct 31 08:10 mingjie
[root@localhost ~]# 

38、chmod 改变权限

38.1 基本语法
如图所示:
在这里插入图片描述
第一种方式变更权限

chmod [{ugoa}{±=}{rwx}] 文件或目录

第二种方式变更权限

chmod [mode=421 ] [文件或目录]

38.2 经验技巧

u:所有者 g:所有组 o:其他人 a:所有人(u、g、o的总和)
r=4 w=2 x=1 rwx=4+2+1=7

38.3 案例实操
(1)修改文件使其所属主用户具有执行权限

[root@localhost ~]# cp xiyou/dssz/houge.txt ./
[root@localhost ~]# chmod u+x houge.txt
[root@localhost ~]# 

(2)修改文件使其所属组用户具有执行权限

[root@localhost ~]# chmod g+x houge.txt
[root@localhost ~]# 

(3)修改文件所属主用户执行权限,并使其他用户具有执行权限

[root@localhost ~]# chmod u-x,o+x houge.txt
[root@localhost ~]# 

(4)采用数字的方式,设置文件所有者、所属组、其他用户都具有可读可写可执行权限。

[root@localhost ~]# chmod 777 houge.txt
[root@localhost ~]# 

(5)修改整个文件夹里面的所有文件的所有者、所属组、其他用户都具有可读可写可执行权限。

[root@localhost ~]# chmod -R 777 xiyou/
[root@localhost ~]# 

39、chown 改变所有者

39.1 基本语法

chown [选项] [最终用户] [文件或目录] (功能描述:改变文件或者目录的所有者)

39.2 选项说明

-R 递归操作

39.3 案例实操
(1)修改文件所有者

[root@localhost ~]# chown MrZhou  houge.txt
[root@localhost ~]# ls -al
total 76
dr-xr-x---.  3 root   root  4096 Nov  6 22:41 .
dr-xr-xr-x. 17 root   root  4096 Oct 31 05:19 ..
-rw-------.  1 root   root  1264 Oct 19 23:01 anaconda-ks.cfg
-rw-------.  1 root   root 17639 Nov  6 21:47 .bash_history
-rw-r--r--.  1 root   root    18 Dec 29  2013 .bash_logout
-rw-r--r--.  1 root   root   176 Dec 29  2013 .bash_profile
-rw-r--r--.  1 root   root   176 Dec 29  2013 .bashrc
-rw-r--r--.  1 root   root   100 Dec 29  2013 .cshrc
lrwxrwxrwx.  1 root   root    11 Oct 31 08:52 dssz -> xiyou/dssz/
-rwxrwxrwx.  2 root   root   559 Oct 31 08:47 hg.txt
-rwxrwxrwx.  1 MrZhou root     0 Nov  6 23:28 houge.txt
lrwxrwxrwx.  1 root   root    20 Oct 31 08:51 houz -> xiyou/dssz/houge.txt
-rw-------.  1 root   root    32 Oct 24 14:20 .mysql_history
-rw-------.  1 root   root  1193 Oct 30 18:14 .rediscli_history
-rw-r--r--.  1 root   root    28 Oct 31 08:22 smartd.conf
-rw-r--r--.  1 root   root     0 Oct 31 08:06 sunwukong.txt
-rw-r--r--.  1 root   root   129 Dec 29  2013 .tcshrc
-rw-------.  1 root   root  7113 Oct 31 08:22 .viminfo
drwxrwxrwx.  4 root   root    50 Nov  6 23:26 xiyou
[root@localhost ~]# 

(2)递归改变文件所有者和所有组

[root@localhost xiyou]# ll
total 0
drwxrwxrwx. 2 root root 64 Oct 31 08:50 dssz
-rw-r--r--. 1 root root  0 Nov  6 23:26 houge.txt
drwxrwxrwx. 2 root root  6 Oct 31 08:10 mingjie
[root@localhost xiyou]# chown -R MrZhou:MrZhou xiyou/
chown: cannot access ‘xiyou/: No such file or directory
[root@localhost xiyou]# chown -R MrZhou:MrZhou xiyou/
chown: cannot access ‘xiyou/: No such file or directory
[root@localhost xiyou]# cd ~
[root@localhost ~]# chown -R MrZhou:MrZhou xiyou/
[root@localhost ~]# 
[root@localhost ~]# ll
total 12
-rw-------. 1 root   root   1264 Oct 19 23:01 anaconda-ks.cfg
lrwxrwxrwx. 1 root   root     11 Oct 31 08:52 dssz -> xiyou/dssz/
-rwxrwxrwx. 2 MrZhou MrZhou  559 Oct 31 08:47 hg.txt
-rwxrwxrwx. 1 MrZhou root      0 Nov  6 23:28 houge.txt
lrwxrwxrwx. 1 root   root     20 Oct 31 08:51 houz -> xiyou/dssz/houge.txt
-rw-r--r--. 1 root   root     28 Oct 31 08:22 smartd.conf
-rw-r--r--. 1 root   root      0 Oct 31 08:06 sunwukong.txt
drwxrwxrwx. 4 MrZhou MrZhou   50 Nov  6 23:26 xiyou
[root@localhost ~]# 

40、chgrp 改变所属组

40.1 基本语法

chgrp [最终用户组] [文件或目录] (功能描述:改变文件或者目录的所属组)

40.2 案例实操
(1)修改文件的所属组

[root@localhost ~]# chgrp root houge.txt
[root@localhost ~]# ls -al
total 76
dr-xr-x---.  3 root   root    4096 Nov  6 22:41 .
dr-xr-xr-x. 17 root   root    4096 Oct 31 05:19 ..
-rw-------.  1 root   root    1264 Oct 19 23:01 anaconda-ks.cfg
-rw-------.  1 root   root   17639 Nov  6 21:47 .bash_history
-rw-r--r--.  1 root   root      18 Dec 29  2013 .bash_logout
-rw-r--r--.  1 root   root     176 Dec 29  2013 .bash_profile
-rw-r--r--.  1 root   root     176 Dec 29  2013 .bashrc
-rw-r--r--.  1 root   root     100 Dec 29  2013 .cshrc
lrwxrwxrwx.  1 root   root      11 Oct 31 08:52 dssz -> xiyou/dssz/
-rwxrwxrwx.  2 MrZhou MrZhou   559 Oct 31 08:47 hg.txt
-rwxrwxrwx.  1 MrZhou root       0 Nov  6 23:28 houge.txt
lrwxrwxrwx.  1 root   root      20 Oct 31 08:51 houz -> xiyou/dssz/houge.txt
-rw-------.  1 root   root      32 Oct 24 14:20 .mysql_history
-rw-------.  1 root   root    1193 Oct 30 18:14 .rediscli_history
-rw-r--r--.  1 root   root      28 Oct 31 08:22 smartd.conf
-rw-r--r--.  1 root   root       0 Oct 31 08:06 sunwukong.txt
-rw-r--r--.  1 root   root     129 Dec 29  2013 .tcshrc
-rw-------.  1 root   root    7113 Oct 31 08:22 .viminfo
drwxrwxrwx.  4 MrZhou MrZhou    50 Nov  6 23:26 xiyou
[root@localhost ~]# 

41、搜索查找类

41.1 find 查找文件或者目录

find指令将从指定目录向下递归地遍历其各个子目录,将满足条件的文件显示在终端。

41.2 基本语法

find [搜索范围] [选项]

41.3 选项说明

-name<查询方式> 按照指定的文件名查找模式查找文件
-user<用户名> 查找属于指定用户名所有文件
-size<文件大小> 按照指定的文件大小查找文件。

41.4 案例实操
(1)按文件名:根据名称查找/目录下的filename.txt文件。

[root@localhost ~]# find xiyou/ -name “*.txt”
[root@localhost ~]# 

(2)按拥有者:查找/opt目录下,用户名称为-user的文件

[root@localhost ~]# find xiyou/ -user MrZhou
xiyou/
xiyou/mingjie
xiyou/dssz
xiyou/dssz/sunwukong.txt
xiyou/dssz/hustrooy.txt
xiyou/dssz/houge.txt
xiyou/houge.txt
[root@localhost ~]# 

(3)按文件大小:在/home目录下查找大于200m的文件(+n 大于 -n小于 n等于)

[root@localhost ~]# find /home -size +204800
[root@localhost ~]# 

42、grep 过滤查找及“|”管道符

管道符,“|”,表示将前一个命令的处理结果输出传递给后面的命令处理

42.1基本语法

grep 选项 查找内容 源文件

42.2 选项说明

-n 显示匹配行及行号。

42.3 案例实操
(1)查找某文件在第几行

[root@localhost ~]#  ls | grep -n test
[root@localhost ~]# 

43、which 查找命令

查找命令在那个目录下

43.1 基本语法

which 命令

43.2 案例实操

which ll

44、压缩和解压类

gzip/gunzip 压缩

44.1 基本语法

gzip 文件 (功能描述:压缩文件,只能将文件压缩为.gz文件) gunzip 文件.gz (功能描述:解压缩文件命令)*

44.2 经验技巧

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

44.3 案例实操
(1)gzip压缩

[root@localhost ~]# ls
anaconda-ks.cfg  dssz  hg.txt  houge.txt  houz  smartd.conf  sunwukong.txt  test.java  xiyou
[root@localhost ~]# gzip houge.txt
[root@localhost ~]# ls
anaconda-ks.cfg  dssz  hg.txt  houge.txt.gz  houz  smartd.conf  sunwukong.txt  test.java  xiyou
[root@localhost ~]# 

(2)gunzip解压缩文件

[root@localhost ~]# gunzip houge.txt.gz 
[root@localhost ~]# ls
anaconda-ks.cfg  dssz  hg.txt  houge.txt  houz  smartd.conf  sunwukong.txt  test.java.gz  xiyou
[root@localhost ~]# 

45、zip/unzip 压缩

45.1 基本语法

zip [选项] XXX.zip 将要压缩的内容 (功能描述:压缩文件和目录的命令)
unzip [选项] XXX.zip (功能描述:解压缩文件)

45.2 选项说明

-r 压缩目录 unzip选项 功能
-d<目录> 指定解压后文件的存放目录

45.3 经验技巧

zip 压缩命令在window/linux都通用,可以压缩目录且保留源文件。

45.4 案例实操
(1)压缩 1.txt 和2.txt,压缩后的名称为mypackage.zip

[root@localhost opt]# touch bailongma.txt
[root@localhost ~]# zip houma.zip houge.txt bailongma.txt 
updating: houge.txt (stored 0%)
updating: bailongma.txt (stored 0%)
[root@localhost ~]# 
[root@localhost ~]# ls
anaconda-ks.cfg  bailongma.txt  dssz  gfd.txt  gf.txt  hg.txt  houge.txt  houma.zip  houz  opt  smartd.conf  sunwukong.txt  test.java.gz  xiyou
[root@localhost ~]# 

(2)解压 mypackage.zip

[root@localhost ~]# unzip houma.zip 
Archive:  houma.zip
replace houge.txt? [y]es, [n]o, [A]ll, [N]one, [r]ename: y
 extracting: houge.txt               
replace bailongma.txt? [y]es, [n]o, [A]ll, [N]one, [r]ename: y
 extracting: bailongma.txt           
[root@localhost ~]# ls
anaconda-ks.cfg  bailongma.txt  dssz  gfd.txt  gf.txt  hg.txt  houge.txt  houma.zip  houz  opt  smartd.conf  sunwukong.txt  test.java.gz  xiyou
[root@localhost ~]# 

(3)解压mypackage.zip到指定目录-d

[root@localhost ~]#  unzip houma.zip -d /opt
Archive:  houma.zip
 extracting: /opt/houge.txt          
replace /opt/bailongma.txt? [y]es, [n]o, [A]ll, [N]one, [r]ename: y
 extracting: /opt/bailongma.txt      
[root@localhost ~]# 

46、tar 打包

46.1基本语法

tar [选项] XXX.tar.gz 将要打包进去的内容 (功能描述:打包目录,压缩后的文件格式.tar.gz)

46.1 选项说明

-z 打包同时压缩
-c 产生.tar打包文件
-v 显示详细信息
-f 指定压缩后的文件名
-x 解包.tar文件

46.2 案例实操
(1)压缩多个文件

[root@localhost ~]# tar -zcvf houma.tar.gz houge.txt bailongma.txt 
houge.txt
bailongma.txt
[root@localhost ~]# ls
anaconda-ks.cfg  bailongma.txt  dssz  gfd.txt  gf.txt  hg.txt  houge.txt  houma.tar.gz  houma.zip  houz  opt  smartd.conf  sunwukong.txt  test.java.gz  xiyou
[root@localhost ~]# 

(2)压缩目录

[root@localhost ~]# tar -zcvf xiyou.tar.gz xiyou/
xiyou/
xiyou/mingjie/
xiyou/dssz/
xiyou/dssz/sunwukong.txt
xiyou/dssz/hustrooy.txt
xiyou/dssz/houge.txt
xiyou/houge.txt
[root@localhost ~]# 

(3)解压到当前目录

[root@localhost ~]# tar -zxvf houma.tar.gz
houge.txt
bailongma.txt
[root@localhost ~]# 

(4)解压到指定目录

[root@localhost ~]# tar -zxvf xiyou.tar.gz -C /opt
xiyou/
xiyou/mingjie/
xiyou/dssz/
xiyou/dssz/sunwukong.txt
xiyou/dssz/hustrooy.txt
xiyou/dssz/houge.txt
xiyou/houge.txt
[root@localhost ~]# ll /opt/
total 72
-rw-r--r--. 1 root   root       0 Nov  6 23:58 bailongma.txt
drwxr-xr-x. 2 root   root      58 Oct 31 00:26 datas
-rwxrwxrwx. 1 root   root       0 Nov  6 23:28 houge.txt
drwxr-xr-x. 2 MrZhou MrZhou     6 Nov  6 22:07 module
-rw-r--r--. 1 root   root   71168 Oct 30 16:43 redis-3.2.0.gem
drwxrwxrwx. 4 MrZhou MrZhou    50 Nov  6 23:26 xiyou
[root@localhost ~]# 

47、磁盘分区类

df 查看磁盘空间使用情况

df: disk free 空余硬盘

47.1 基本语法

df 选项 (功能描述:列出文件系统的整体磁盘使用量,检查文件系统的磁盘空间占用情况)

47.2 选项说明

-h 以人们较易阅读的 GBytes, MBytes, KBytes 等格式自行显示;

47.3 案例实操
(1)查看磁盘使用情况

[root@localhost ~]# df -h
Filesystem               Size  Used Avail Use% Mounted on
/dev/mapper/centos-root   37G  4.1G   33G  11% /
devtmpfs                 475M     0  475M   0% /dev
tmpfs                    487M     0  487M   0% /dev/shm
tmpfs                    487M  7.9M  479M   2% /run
tmpfs                    487M     0  487M   0% /sys/fs/cgroup
/dev/sda1               1014M  133M  882M  14% /boot
tmpfs                     98M     0   98M   0% /run/user/0
[root@localhost ~]# 

47.4 fdisk 查看分区

47.4.1 基本语法

fdisk -l (功能描述:查看磁盘分区详情)

47.4.2 选项说明

-l: 显示所有硬盘的分区列表

47.4.3 经验技巧

该命令必须在root用户下才能使用

47.4.4 功能说明

(1)Linux分区

Device:分区序列
Boot:引导
Start:从X磁柱开始
End:到Y磁柱结束
Blocks:容量
Id:分区类型ID
System:分区类型

(2)Win7分区,如图所示:
在这里插入图片描述
47.4.5 案例实操
(1)查看系统分区情况

[root@localhost ~]# fdisk -l

Disk /dev/sda: 42.9 GB, 42949672960 bytes, 83886080 sectors
Units = sectors of 1 * 512 = 512 bytes
Sector size (logical/physical): 512 bytes / 512 bytes
I/O size (minimum/optimal): 512 bytes / 512 bytes
Disk label type: dos
Disk identifier: 0x000d3f5f

   Device Boot      Start         End      Blocks   Id  System
/dev/sda1   *        2048     2099199     1048576   83  Linux
/dev/sda2         2099200    83886079    40893440   8e  Linux LVM

Disk /dev/mapper/centos-root: 39.7 GB, 39720058880 bytes, 77578240 sectors
Units = sectors of 1 * 512 = 512 bytes
Sector size (logical/physical): 512 bytes / 512 bytes
I/O size (minimum/optimal): 512 bytes / 512 bytes


Disk /dev/mapper/centos-swap: 2147 MB, 2147483648 bytes, 4194304 sectors
Units = sectors of 1 * 512 = 512 bytes
Sector size (logical/physical): 512 bytes / 512 bytes
I/O size (minimum/optimal): 512 bytes / 512 bytes

[root@localhost ~]# 

48、mount/umount 挂载/卸载

对于Linux用户来讲,不论有几个分区,分别分给哪一个目录使用,它总归就是一个根目录、一个独立且唯一的文件结构。 Linux中每个分区都是用来组成整个文件系统的一部分,它在用一种叫做“挂载”的处理方法,它整个文件系统中包含了一整套的文件和目录,并将一个分区和一个目录联系起来,要载入的那个分区将使它的存储空间在这个目录下获得。

48.1 挂载前准备(必须要有光盘或者已经连接镜像文件),如图
在这里插入图片描述
在这里插入图片描述
48.2 基本语法

mount [-t vfstype] [-o options] device dir (功能描述:挂载设备) umount
设备文件名或挂载点 (功能描述:卸载设备)

48.3 参数说明

-t vfstype 指定文件系统的类型,通常不必指定。mount 会自动选择正确的类型。常用类型有: 光盘或光盘镜像:iso9660

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

参数:-o options
功能:
主要用来描述设备或档案的挂接方式。常用的参数有:
loop:用来把一个文件当成硬盘分区挂接上系统
ro:采用只读方式挂接设备

rw:采用读写方式挂接设备  
iocharset:指定访问文件系统所用字符集

参数:device
**功能:要挂接(mount)的设备 **

参数:dir
功能:设备在系统上的挂接点(mount point)

48.4 案例实操
(1)挂载光盘镜像文件

[root@hadoop101 ~]# mkdir /mnt/cdrom/						建立挂载点
[root@hadoop101 ~]# mount -t iso9660 /dev/cdrom /mnt/cdrom/	设备/dev/cdrom挂载到 挂载点 :  /mnt/cdrom中
[root@hadoop101 ~]# ll /mnt/cdrom/

(2)卸载光盘镜像文件

[root@hadoop101 ~]# umount /mnt/cdrom

(3)设置开机自动挂载

[root@hadoop101 ~]# vi /etc/fstab

添加红框中内容,保存退出。
效果图:
在这里插入图片描述

49、进程线程类

进程是正在执行的一个程序或命令,每一个进程都是一个运行的实体,都有自己的地址空间,并占用一定的系统资源。

ps 查看当前系统进程状态
ps:process status 进程状态

49.1 基本语法

ps aux | grep xxx (功能描述:查看系统中所有进程)
ps -ef | grep xxx (功能描述:可以查看子父进程之间的关系)

49.2 选项说明

-a: 选择所有进程
-u: 显示所有用户的所有进程
-x: 显示没有终端的进程

49.3 功能说明

(1)ps aux显示信息说明

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:产生此进程的命令名

(2)ps -ef显示信息说明

UID:用户ID
PID:进程ID
PPID:父进程ID
C:CPU用于计算执行优先级的因子。数值越大,表明进程是CPU密集型运算,执行优先级会降低;数值越小,表明进程是I/O密集型运算,执行优先级会提高
STIME:进程启动的时间 TTY:完整的终端名称 TIME:CPU时间 CMD:启动进程所用的命令和参数

49.4 经验技巧

如果想查看进程的CPU占用率和内存占用率,可以使用aux;
如果想查看进程的父进程ID可以使用ef;

49.5 案例实操
(1)查看进程的CPU占用率和内存占用率

[root@localhost ~]# ps aux
USER        PID %CPU %MEM    VSZ   RSS TTY      STAT START   TIME COMMAND
root          1  0.0  0.6 128104  6668 ?        Ss   Nov06   0:02 /usr/lib/systemd/systemd --switched-root --system --deserialize 22
root          2  0.0  0.0      0     0 ?        S    Nov06   0:00 [kthreadd]
root          3  0.0  0.0      0     0 ?        S    Nov06   0:05 [ksoftirqd/0]
root          5  0.0  0.0      0     0 ?        S<   Nov06   0:00 [kworker/0:0H]
root          6  0.0  0.0      0     0 ?        R    Nov06   0:02 [kworker/u256:0]
root          7  0.0  0.0      0     0 ?        S    Nov06   0:00 [migration/0]
root          8  0.0  0.0      0     0 ?        S    Nov06   0:00 [rcu_bh]
root          9  0.1  0.0      0     0 ?        R    Nov06   1:23 [rcu_sched]
root         10  0.0  0.0      0     0 ?        S<   Nov06   0:00 [lru-add-drain]
root         11  0.0  0.0      0     0 ?        S    Nov06   0:00 [watchdog/0]
root         13  0.0  0.0      0     0 ?        S    Nov06   0:00 [kdevtmpfs]
root         14  0.0  0.0      0     0 ?        S<   Nov06   0:00 [netns]
root         15  0.0  0.0      0     0 ?        S    Nov06   0:00 [khungtaskd]
root         16  0.0  0.0      0     0 ?        S<   Nov06   0:00 [writeback]
root         17  0.0  0.0      0     0 ?        S<   Nov06   0:00 [kintegrityd]
root         18  0.0  0.0      0     0 ?        S<   Nov06   0:00 [bioset]
root         19  0.0  0.0      0     0 ?        S<   Nov06   0:00 [bioset]
root         20  0.0  0.0      0     0 ?        S<   Nov06   0:00 [bioset]
root         21  0.0  0.0      0     0 ?        S<   Nov06   0:00 [kblockd]
root         22  0.0  0.0      0     0 ?        S<   Nov06   0:00 [md]
root         23  0.0  0.0      0     0 ?        S<   Nov06   0:00 [edac-poller]
root         24  0.0  0.0      0     0 ?        S<   Nov06   0:00 [watchdogd]
root         30  0.0  0.0      0     0 ?        S    Nov06   0:00 [kswapd0]
root         31  0.0  0.0      0     0 ?        SN   Nov06   0:00 [ksmd]
root         32  0.0  0.0      0     0 ?        SN   Nov06   0:00 [khugepaged]
root         33  0.0  0.0      0     0 ?        S<   Nov06   0:00 [crypto]
root         41  0.0  0.0      0     0 ?        S<   Nov06   0:00 [kthrotld]
root         42  0.0  0.0      0     0 ?        S    Nov06   0:00 [kworker/u256:1]
root         43  0.0  0.0      0     0 ?        S<   Nov06   0:00 [kmpath_rdacd]
root         44  0.0  0.0      0     0 ?        S<   Nov06   0:00 [kaluad]
root         45  0.0  0.0      0     0 ?        S<   Nov06   0:00 [kpsmoused]
root         47  0.0  0.0      0     0 ?        S<   Nov06   0:00 [ipv6_addrconf]
root         60  0.0  0.0      0     0 ?        S<   Nov06   0:00 [deferwq]
root         91  0.0  0.0      0     0 ?        S    Nov06   0:00 [kauditd]
root        722  0.0  0.0      0     0 ?        S<   Nov06   0:00 [ata_sff]
root        741  0.0  0.0      0     0 ?        S    Nov06   0:00 [scsi_eh_0]
root        751  0.0  0.0      0     0 ?        S<   Nov06   0:00 [scsi_tmf_0]
root        752  0.0  0.0      0     0 ?        S    Nov06   0:00 [scsi_eh_1]
root        754  0.0  0.0      0     0 ?        S<   Nov06   0:00 [scsi_tmf_1]
root       1759  0.0  0.0      0     0 ?        S<   Nov06   0:00 [nfit]
root       1764  0.0  0.0      0     0 ?        S<   Nov06   0:00 [mpt_poll_0]
root       1771  0.0  0.0      0     0 ?        S<   Nov06   0:00 [mpt/0]
root       1833  0.0  0.0      0     0 ?        S    Nov06   0:00 [scsi_eh_2]
root       1836  0.0  0.0      0     0 ?        S<   Nov06   0:00 [scsi_tmf_2]
root       1950  0.0  0.0      0     0 ?        S<   Nov06   0:00 [ttm_swap]
root       1957  0.0  0.0      0     0 ?        S    Nov06   0:00 [irq/16-vmwgfx]
root       2996  0.0  0.0      0     0 ?        S<   Nov06   0:00 [kdmflush]
root       2997  0.0  0.0      0     0 ?        S<   Nov06   0:00 [bioset]
root       3011  0.0  0.0      0     0 ?        S<   Nov06   0:00 [kdmflush]
root       3012  0.0  0.0      0     0 ?        S<   Nov06   0:00 [bioset]
root       3030  0.0  0.0      0     0 ?        S<   Nov06   0:00 [bioset]
root       3035  0.0  0.0      0     0 ?        S<   Nov06   0:00 [xfsalloc]
root       3040  0.0  0.0      0     0 ?        S<   Nov06   0:00 [xfs_mru_cache]
root       3044  0.0  0.0      0     0 ?        S<   Nov06   0:00 [xfs-buf/dm-0]
root       3046  0.0  0.0      0     0 ?        S<   Nov06   0:00 [xfs-data/dm-0]
root       3049  0.0  0.0      0     0 ?        S<   Nov06   0:00 [xfs-conv/dm-0]
root       3050  0.0  0.0      0     0 ?        S<   Nov06   0:00 [xfs-cil/dm-0]
root       3051  0.0  0.0      0     0 ?        S<   Nov06   0:00 [xfs-reclaim/dm-]
root       3052  0.0  0.0      0     0 ?        S<   Nov06   0:00 [xfs-log/dm-0]
root       3053  0.0  0.0      0     0 ?        S<   Nov06   0:00 [xfs-eofblocks/d]
root       3054  0.0  0.0      0     0 ?        S    Nov06   0:04 [xfsaild/dm-0]
root       3055  0.0  0.0      0     0 ?        S<   Nov06   0:00 [kworker/0:1H]
root       3122  0.0  0.3  37116  3260 ?        Ss   Nov06   0:00 /usr/lib/systemd/systemd-journald
root       3143  0.0  0.8 127352  8100 ?        Ss   Nov06   0:00 /usr/sbin/lvmetad -f
root       3157  0.0  0.5  48212  5644 ?        Ss   Nov06   0:00 /usr/lib/systemd/systemd-udevd
root       5001  0.0  0.0      0     0 ?        S<   Nov06   0:00 [xfs-buf/sda1]
root       5006  0.0  0.0      0     0 ?        S<   Nov06   0:00 [xfs-data/sda1]
root       5011  0.0  0.0      0     0 ?        S<   Nov06   0:00 [xfs-conv/sda1]
root       5015  0.0  0.0      0     0 ?        S<   Nov06   0:00 [xfs-cil/sda1]
root       5018  0.0  0.0      0     0 ?        S<   Nov06   0:00 [xfs-reclaim/sda]
root       5019  0.0  0.0      0     0 ?        S<   Nov06   0:00 [xfs-log/sda1]
root       5021  0.0  0.0      0     0 ?        S<   Nov06   0:00 [xfs-eofblocks/s]
root       5028  0.0  0.0      0     0 ?        S    Nov06   0:00 [xfsaild/sda1]
root       5057  0.0  0.0      0     0 ?        S<   Nov06   0:00 [kworker/u257:0]
root       5058  0.0  0.0      0     0 ?        S<   Nov06   0:00 [hci0]
root       5060  0.0  0.0      0     0 ?        S<   Nov06   0:00 [hci0]
root       5062  0.0  0.0      0     0 ?        S<   Nov06   0:00 [kworker/u257:2]
root       6054  0.0  0.0  55524   880 ?        S<sl Nov06   0:00 /sbin/auditd
polkitd    6180  0.0  1.5 613000 14968 ?        Ssl  Nov06   0:00 /usr/lib/polkit-1/polkitd --no-debug
root       6183  0.0  0.6  99688  6100 ?        Ss   Nov06   0:00 /usr/bin/VGAuthService -s
root       6194  0.1  0.6 300832  6324 ?        Ssl  Nov06   1:39 /usr/bin/vmtoolsd
dbus       6196  0.0  0.2  66460  2604 ?        Ssl  Nov06   0:00 /usr/bin/dbus-daemon --system --address=systemd: --nofork --nopidfile --systemd-activation
root       6235  0.0  0.2  26644  2056 ?        Ss   Nov06   0:00 /usr/lib/systemd/systemd-logind
root       6254  0.0  0.1 126292  1676 ?        Ss   Nov06   0:00 /usr/sbin/crond -n
root       6303  0.0  0.2  96564  2464 ?        Ss   Nov06   0:00 login -- root
root       6336  0.0  2.9 358304 29100 ?        Ssl  Nov06   0:00 /usr/bin/python -Es /usr/sbin/firewalld --nofork --nopid
root       6637  0.0  1.0 625400 10744 ?        Ssl  Nov06   0:02 /usr/sbin/NetworkManager --no-daemon
root       7087  0.0  1.9 573932 19136 ?        Ssl  Nov06   0:11 /usr/bin/python2 -Es /usr/sbin/tuned -l -P
root       7088  0.0  0.4 112868  4356 ?        Ss   Nov06   0:00 /usr/sbin/sshd -D
root       7090  0.0  0.6 214448  6296 ?        Ssl  Nov06   0:06 /usr/sbin/rsyslogd -n
mysql      7136  0.0 18.0 1119716 179780 ?      Sl   Nov06   0:45 /usr/sbin/mysqld --daemonize --pid-file=/var/run/mysqld/mysqld.pid
root       7377  0.0  0.2 115440  2028 tty1     Ss+  Nov06   0:00 -bash
root       7708  0.1  0.2 135056  2832 ?        Ssl  Nov06   1:42 redis-server *:6379 [cluster]
root       7712  0.1  0.2 135320  2928 ?        Ssl  Nov06   1:42 redis-server *:6380 [cluster]
root       7716  0.1  0.2 135320  2952 ?        Ssl  Nov06   1:40 redis-server *:6381 [cluster]
root       7720  0.1  0.2 134008  2660 ?        Ssl  Nov06   1:41 redis-server *:6389 [cluster]
root       7724  0.1  0.2 134004  2660 ?        Ssl  Nov06   1:42 redis-server *:6390 [cluster]
root       7728  0.1  0.2 134008  2668 ?        Ssl  Nov06   1:43 redis-server *:6391 [cluster]
root       9133  0.0  0.5 158872  5608 ?        Ss   Nov06   0:00 sshd: root@pts/2
root       9135  0.0  0.5 158872  5612 ?        Ss   Nov06   0:00 sshd: root@pts/3
root       9141  0.0  0.2 115448  2080 pts/2    Ss+  Nov06   0:00 -bash
root       9142  0.0  0.2 115576  2196 pts/3    Ss+  Nov06   0:00 -bash
root       9250  0.0  0.5 158872  5612 ?        Ss   00:10   0:00 sshd: root@pts/6
root       9254  0.0  0.2 115576  2192 pts/6    Ss+  00:10   0:00 -bash
root       9375  0.0  0.0      0     0 ?        R    01:07   0:01 [kworker/0:3]
root       9378  0.0  0.5 158872  5604 ?        Ss   01:18   0:00 sshd: root@pts/4
root       9382  0.0  0.2 115580  2080 pts/4    Ss+  01:18   0:00 -bash
root       9399  0.0  0.5 158872  5612 ?        Ss   01:21   0:01 sshd: root@pts/5
root       9403  0.0  0.2 115580  2120 pts/5    Ss   01:21   0:00 -bash
root       9425  0.0  0.0      0     0 ?        S    01:37   0:00 [kworker/0:0]
root       9426  0.0  0.0      0     0 ?        S    01:42   0:00 [kworker/0:1]
root       9427  0.0  0.1 155364  1852 pts/5    R+   01:45   0:00 ps aux
[root@localhost ~]# 

(2)查看进程的父进程ID

[root@localhost ~]# ps -ef
UID         PID   PPID  C STIME TTY          TIME CMD
root          1      0  0 Nov06 ?        00:00:02 /usr/lib/systemd/systemd --switched-root --system --deserialize 22
root          2      0  0 Nov06 ?        00:00:00 [kthreadd]
root          3      2  0 Nov06 ?        00:00:05 [ksoftirqd/0]
root          5      2  0 Nov06 ?        00:00:00 [kworker/0:0H]
root          6      2  0 Nov06 ?        00:00:02 [kworker/u256:0]
root          7      2  0 Nov06 ?        00:00:00 [migration/0]
root          8      2  0 Nov06 ?        00:00:00 [rcu_bh]
root          9      2  0 Nov06 ?        00:01:23 [rcu_sched]
root         10      2  0 Nov06 ?        00:00:00 [lru-add-drain]
root         11      2  0 Nov06 ?        00:00:00 [watchdog/0]
root         13      2  0 Nov06 ?        00:00:00 [kdevtmpfs]
root         14      2  0 Nov06 ?        00:00:00 [netns]
root         15      2  0 Nov06 ?        00:00:00 [khungtaskd]
root         16      2  0 Nov06 ?        00:00:00 [writeback]
root         17      2  0 Nov06 ?        00:00:00 [kintegrityd]
root         18      2  0 Nov06 ?        00:00:00 [bioset]
root         19      2  0 Nov06 ?        00:00:00 [bioset]
root         20      2  0 Nov06 ?        00:00:00 [bioset]
root         21      2  0 Nov06 ?        00:00:00 [kblockd]
root         22      2  0 Nov06 ?        00:00:00 [md]
root         23      2  0 Nov06 ?        00:00:00 [edac-poller]
root         24      2  0 Nov06 ?        00:00:00 [watchdogd]
root         30      2  0 Nov06 ?        00:00:00 [kswapd0]
root         31      2  0 Nov06 ?        00:00:00 [ksmd]
root         32      2  0 Nov06 ?        00:00:00 [khugepaged]
root         33      2  0 Nov06 ?        00:00:00 [crypto]
root         41      2  0 Nov06 ?        00:00:00 [kthrotld]
root         42      2  0 Nov06 ?        00:00:00 [kworker/u256:1]
root         43      2  0 Nov06 ?        00:00:00 [kmpath_rdacd]
root         44      2  0 Nov06 ?        00:00:00 [kaluad]
root         45      2  0 Nov06 ?        00:00:00 [kpsmoused]
root         47      2  0 Nov06 ?        00:00:00 [ipv6_addrconf]
root         60      2  0 Nov06 ?        00:00:00 [deferwq]
root         91      2  0 Nov06 ?        00:00:00 [kauditd]
root        722      2  0 Nov06 ?        00:00:00 [ata_sff]
root        741      2  0 Nov06 ?        00:00:00 [scsi_eh_0]
root        751      2  0 Nov06 ?        00:00:00 [scsi_tmf_0]
root        752      2  0 Nov06 ?        00:00:00 [scsi_eh_1]
root        754      2  0 Nov06 ?        00:00:00 [scsi_tmf_1]
root       1759      2  0 Nov06 ?        00:00:00 [nfit]
root       1764      2  0 Nov06 ?        00:00:00 [mpt_poll_0]
root       1771      2  0 Nov06 ?        00:00:00 [mpt/0]
root       1833      2  0 Nov06 ?        00:00:00 [scsi_eh_2]
root       1836      2  0 Nov06 ?        00:00:00 [scsi_tmf_2]
root       1950      2  0 Nov06 ?        00:00:00 [ttm_swap]
root       1957      2  0 Nov06 ?        00:00:00 [irq/16-vmwgfx]
root       2996      2  0 Nov06 ?        00:00:00 [kdmflush]
root       2997      2  0 Nov06 ?        00:00:00 [bioset]
root       3011      2  0 Nov06 ?        00:00:00 [kdmflush]
root       3012      2  0 Nov06 ?        00:00:00 [bioset]
root       3030      2  0 Nov06 ?        00:00:00 [bioset]
root       3035      2  0 Nov06 ?        00:00:00 [xfsalloc]
root       3040      2  0 Nov06 ?        00:00:00 [xfs_mru_cache]
root       3044      2  0 Nov06 ?        00:00:00 [xfs-buf/dm-0]
root       3046      2  0 Nov06 ?        00:00:00 [xfs-data/dm-0]
root       3049      2  0 Nov06 ?        00:00:00 [xfs-conv/dm-0]
root       3050      2  0 Nov06 ?        00:00:00 [xfs-cil/dm-0]
root       3051      2  0 Nov06 ?        00:00:00 [xfs-reclaim/dm-]
root       3052      2  0 Nov06 ?        00:00:00 [xfs-log/dm-0]
root       3053      2  0 Nov06 ?        00:00:00 [xfs-eofblocks/d]
root       3054      2  0 Nov06 ?        00:00:04 [xfsaild/dm-0]
root       3055      2  0 Nov06 ?        00:00:00 [kworker/0:1H]
root       3122      1  0 Nov06 ?        00:00:00 /usr/lib/systemd/systemd-journald
root       3143      1  0 Nov06 ?        00:00:00 /usr/sbin/lvmetad -f
root       3157      1  0 Nov06 ?        00:00:00 /usr/lib/systemd/systemd-udevd
root       5001      2  0 Nov06 ?        00:00:00 [xfs-buf/sda1]
root       5006      2  0 Nov06 ?        00:00:00 [xfs-data/sda1]
root       5011      2  0 Nov06 ?        00:00:00 [xfs-conv/sda1]
root       5015      2  0 Nov06 ?        00:00:00 [xfs-cil/sda1]
root       5018      2  0 Nov06 ?        00:00:00 [xfs-reclaim/sda]
root       5019      2  0 Nov06 ?        00:00:00 [xfs-log/sda1]
root       5021      2  0 Nov06 ?        00:00:00 [xfs-eofblocks/s]
root       5028      2  0 Nov06 ?        00:00:00 [xfsaild/sda1]
root       5057      2  0 Nov06 ?        00:00:00 [kworker/u257:0]
root       5058      2  0 Nov06 ?        00:00:00 [hci0]
root       5060      2  0 Nov06 ?        00:00:00 [hci0]
root       5062      2  0 Nov06 ?        00:00:00 [kworker/u257:2]
root       6054      1  0 Nov06 ?        00:00:00 /sbin/auditd
polkitd    6180      1  0 Nov06 ?        00:00:00 /usr/lib/polkit-1/polkitd --no-debug
root       6183      1  0 Nov06 ?        00:00:00 /usr/bin/VGAuthService -s
root       6194      1  0 Nov06 ?        00:01:39 /usr/bin/vmtoolsd
dbus       6196      1  0 Nov06 ?        00:00:00 /usr/bin/dbus-daemon --system --address=systemd: --nofork --nopidfile --systemd-activation
root       6235      1  0 Nov06 ?        00:00:00 /usr/lib/systemd/systemd-logind
root       6254      1  0 Nov06 ?        00:00:00 /usr/sbin/crond -n
root       6303      1  0 Nov06 ?        00:00:00 login -- root
root       6336      1  0 Nov06 ?        00:00:00 /usr/bin/python -Es /usr/sbin/firewalld --nofork --nopid
root       6637      1  0 Nov06 ?        00:00:02 /usr/sbin/NetworkManager --no-daemon
root       7087      1  0 Nov06 ?        00:00:11 /usr/bin/python2 -Es /usr/sbin/tuned -l -P
root       7088      1  0 Nov06 ?        00:00:00 /usr/sbin/sshd -D
root       7090      1  0 Nov06 ?        00:00:06 /usr/sbin/rsyslogd -n
mysql      7136      1  0 Nov06 ?        00:00:45 /usr/sbin/mysqld --daemonize --pid-file=/var/run/mysqld/mysqld.pid
root       7377   6303  0 Nov06 tty1     00:00:00 -bash
root       7708      1  0 Nov06 ?        00:01:42 redis-server *:6379 [cluster]
root       7712      1  0 Nov06 ?        00:01:42 redis-server *:6380 [cluster]
root       7716      1  0 Nov06 ?        00:01:40 redis-server *:6381 [cluster]
root       7720      1  0 Nov06 ?        00:01:41 redis-server *:6389 [cluster]
root       7724      1  0 Nov06 ?        00:01:42 redis-server *:6390 [cluster]
root       7728      1  0 Nov06 ?        00:01:43 redis-server *:6391 [cluster]
root       9133   7088  0 Nov06 ?        00:00:00 sshd: root@pts/2
root       9135   7088  0 Nov06 ?        00:00:00 sshd: root@pts/3
root       9141   9133  0 Nov06 pts/2    00:00:00 -bash
root       9142   9135  0 Nov06 pts/3    00:00:00 -bash
root       9250   7088  0 00:10 ?        00:00:00 sshd: root@pts/6
root       9254   9250  0 00:10 pts/6    00:00:00 -bash
root       9375      2  0 01:07 ?        00:00:01 [kworker/0:3]
root       9378   7088  0 01:18 ?        00:00:00 sshd: root@pts/4
root       9382   9378  0 01:18 pts/4    00:00:00 -bash
root       9399   7088  0 01:21 ?        00:00:01 sshd: root@pts/5
root       9403   9399  0 01:21 pts/5    00:00:00 -bash
root       9425      2  0 01:37 ?        00:00:00 [kworker/0:0]
root       9426      2  0 01:42 ?        00:00:00 [kworker/0:1]
root       9428   9403  0 01:47 pts/5    00:00:00 ps -ef
[root@localhost ~]# 

50、kill 终止进程

50.1 基本语法

kill [选项] 进程号 (功能描述:通过进程号杀死进程)
killall 进程名称 (功能描述:通过进程名称杀死进程,也支持通配符,这在系统因负载过大而变得很慢时很有用)

50.2 选项说明

-9: 表示强迫进程立即停止

50.3 案例实操
(1)杀死浏览器进程

[root@hadoop101 桌面]# kill -9 5102

(2)通过进程名称杀死进程

[root@hadoop101 桌面]# killall firefox

51、pstree 查看进程树

51.1 基本语法

pstree [选项]

51.2 选项说明

-p: 显示进程的PID
-u: 显示进程的所属用户

51.3 案例实操
(1)显示进程pid

[root@hadoop101 datas]# pstree -p

(2)显示进程所属用户

[root@hadoop101 datas]# pstree -u

52、top 查看系统健康状态

52.1 基本命令

top [选项]*

52.2 选项功能说明

-d 秒数: 指定top命令每隔几秒更新。默认是3秒在top命令的交互模式当中可以执行的命令:
-i: 使top不显示任何闲置或者僵死进程。
-p: 通过指定监控进程ID来仅仅监控某个进程的状态。

52.3 操作说明

P: 以CPU使用率排序,默认就是此项
M: 以内存的使用率排序
N: 以PID排序
q :退出top

52.4 查询结果字段解释
第一行信息为任务队列信息

52.4.1 内容 说明

12:26:46: 系统当前时间
up 1 day, 13:32: 系统的运行时间,本机已经运行1天 13小时32分钟
2users: 当前登录了两个用户
load average: 0.00, 0.00, 0.00: 系统在之前1分钟,5分钟,15分钟的平均负载。一般认为小于1时,负载较小。如果大于1,系统已经超出负荷。

第二行为进程信息

52.4.2 内容 说明

Tasks: 95 total: 系统中的进程总数
1 running: 正在运行的进程数
94 sleeping: 睡眠的进程
0 stopped: 正在停止的进程
*0 zombie: 僵尸进程。如果不是0,需要手工检查僵尸进 程

第三行为CPU信息

52.4.3 内容 说明

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的时间百分比。

第四行为物理内存信息

52.4.4 内容 说明

Mem: 625344k total 物理内存的总量,单位KB 571504k used 已经使用的物理内存数量 53840k
free: 空闲的物理内存数量,我们使用的是虚拟机,总共只分配了628MB内存,所以只有53MB的空闲内存了 65800k
buffers: 作为缓冲的内存数量 第五行为交换分区(swap)信息

Swap: 524280k total 交换分区(虚拟内存)的总大小 0k used 已经使用的交互分区的大小 524280k
free: 空闲交换分区的大小 409280k cached 作为缓存的交互分区的大小

52.5 案例实操

[root@localhost datas]# top -d 1


 PID USER      PR  NI    VIRT    RES    SHR S %CPU %MEM     TIME+ COMMAND                                                                                               
     9 root      20   0       0      0      0 S  1.0  0.0   1:24.66 rcu_sched                                                                                             
  6194 root      20   0  300832   6324   4972 S  1.0  0.6   1:41.22 vmtoolsd                                                                                              
  7724 root      20   0  134004   2660   1160 S  1.0  0.3   1:43.78 redis-server                                                                                          
  9453 root      20   0  162000   2232   1564 R  1.0  0.2   0:00.13 top                                                                                                   
     1 root      20   0  128104   6668   4160 S  0.0  0.7   0:02.67 systemd                                                                                               
     2 root      20   0       0      0      0 S  0.0  0.0   0:00.01 kthreadd                                                                                              
     3 root      20   0       0      0      0 S  0.0  0.0   0:05.31 ksoftirqd/0                                                                                           
     5 root       0 -20       0      0      0 S  0.0  0.0   0:00.00 kworker/0:0H                                                                                          
     6 root      20   0       0      0      0 S  0.0  0.0   0:02.28 kworker/u256:0                                                                                        
     7 root      rt   0       0      0      0 S  0.0  0.0   0:00.00 migration/0                                                                                           
     8 root      20   0       0      0      0 S  0.0  0.0   0:00.00 rcu_bh                                                                                                
    10 root       0 -20       0      0      0 S  0.0  0.0   0:00.00 lru-add-drain                                                                                         
    11 root      rt   0       0      0      0 S  0.0  0.0   0:00.98 watchdog/0                                                                                            
    13 root      20   0       0      0      0 S  0.0  0.0   0:00.00 kdevtmpfs                                                                                             
    14 root       0 -20       0      0      0 S  0.0  0.0   0:00.00 netns                                                                                                 
    15 root      20   0       0      0      0 S  0.0  0.0   0:00.05 khungtaskd                                                                                            
    16 root       0 -20       0      0      0 S  0.0  0.0   0:00.00 writeback   



[root@localhost datas]# top -i

top - 02:13:58 up 20:11,  6 users,  load average: 0.00, 0.01, 0.05
Tasks: 112 total,   1 running, 111 sleeping,   0 stopped,   0 zombie
top - 02:16:19 up 20:13,  6 users,  load average: 0.00, 0.01, 0.05
Tasks: 112 total,   6 running, 106 sleeping,   0 stopped,   0 zombie
%Cpu(s):  0.3 us,  0.3 sy,  0.0 ni, 99.3 id,  0.0 wa,  0.0 hi,  0.0 si,  0.0 st
KiB Mem :   995896 total,   298720 free,   339852 used,   357324 buff/cache
KiB Swap:  2097148 total,  2097148 free,        0 used.   460364 avail Mem 

   PID USER      PR  NI    VIRT    RES    SHR S %CPU %MEM     TIME+ COMMAND                                                                                               
     9 root      20   0       0      0      0 S  0.3  0.0   1:24.80 rcu_sched                                                                                             
  7716 root      20   0  135320   2952   1184 R  0.3  0.3   1:42.52 redis-server                                                                                          
  7720 root      20   0  134008   2660   1160 R  0.3  0.3   1:43.62 redis-server    


[root@localhost datas]# top -p 2575


top - 02:13:58 up 20:11,  6 users,  load average: 0.00, 0.01, 0.05
Tasks: 112 total,   1 running, 111 sleeping,   0 stopped,   0 zombie
top - 02:16:19 up 20:13,  6 users,  load average: 0.00, 0.01, 0.05
Tasks: 112 total,   6 running, 106 sleeping,   0 stopped,   0 zombie
top - 02:18:22 up 20:15,  6 users,  load average: 0.05, 0.05, 0.05
Tasks:   0 total,   0 running,   0 sleeping,   0 stopped,   0 zombie
%Cpu(s):  0.0 us,  0.3 sy,  0.0 ni, 99.7 id,  0.0 wa,  0.0 hi,  0.0 si,  0.0 st
KiB Mem :   995896 total,   298968 free,   339604 used,   357324 buff/cache
KiB Swap:  2097148 total,  2097148 free,        0 used.   460612 avail Mem 

   PID USER      PR  NI    VIRT    RES    SHR S %CPU %MEM     TIME+ COMMAND                                                                                               

执行上述命令后,可以按P、M、N对查询出的进程结果进行排序。

53、netstat 显示网络统计信息和端口占用情况

53.1 基本语法

netstat -anp |grep 进程号 (功能描述:查看该进程网络信息) netstat -nlp | grep 端口号 (功能描述:查看网络端口号占用情况)

53.2 选项说明

-n: 拒绝显示别名,能显示数字的全部转化成数字
-l: 仅列出有在listen(监听)的服务状态
-p:表示显示哪个进程在调用

53.3 案例实操
(1)通过进程号查看该进程的网络信息

[root@hadoop101 hadoop-2.7.2]# netstat -anp | grep 火狐浏览器进程号
unix  2      [ ACC ]     STREAM     LISTENING     20670  3115/firefox        /tmp/orbit-root/linc-c2b-0-5734667cbe29
unix  3      [ ]         STREAM     CONNECTED     20673  3115/firefox        /tmp/orbit-root/linc-c2b-0-5734667cbe29
unix  3      [ ]         STREAM     CONNECTED     20668  3115/firefox        
unix  3      [ ]         STREAM     CONNECTED     20666  3115/firefox     

(2)查看某端口号是否被占用

netstat -nlp | grep 20670 
unix  2      [ ACC ]     STREAM     LISTENING     20670  3115/firefox        /tmp/orbit-root/linc-c2b-0-5734667cbe29

54、crond 系统定时任务

  • 1
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值