Linux从入门到精通的总结

mac2024-04-21  43

一、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 系统定时任务

最新回复(0)