打包压缩

压缩包工具

	.zip		#zip压缩工具	
	.bz2		#bzip2压缩工具,只能压缩文件,会删除源文件
	.gz			#gzip压缩工具,只能压缩文件,会删除源文件
	tar.gz		#gzip压缩,使用tar打包
	tar.bz2		#使用bzip2压缩,使用tar打包

zip

zip		#打包压缩
选项:
	-r		#递归压缩
	-q		#静默输出
	-T		#检查压缩包是完整
	
unzip	#解压zip格式的压缩包
选项:
	-d		#指定解压的目录
	-l		#查看压缩包的内容
	-t		#检查压缩包里面的内容是否完整
	-q		#静默输出
	
#下载安装
[root@qls ~]# yum  install -y  zip  unzip

[root@qls ~]# cp  /etc/services   ./
[root@qls ~]# ll
total 656
-rw-r--r--. 1 root root 670293 Aug 20 08:46 services
[root@qls ~]# zip  ser.zip   services 
  adding: services (deflated 80%)
[root@qls ~]# ll
total 792
-rw-r--r--. 1 root root 670293 Aug 20 08:46 services
-rw-r--r--. 1 root root 136227 Aug 20 08:46 ser.zip
[root@qls ~]# ll -h
total 792K
-rw-r--r--. 1 root root 655K Aug 20 08:46 services
-rw-r--r--. 1 root root 134K Aug 20 08:46 ser.zip
[root@qls ~]# zip -T ser
services  ser.zip   
[root@qls ~]# zip -T ser.zip 
test of ser.zip OK
[root@qls ~]# unzip  services 
Archive:  services
  End-of-central-directory signature not found.  Either this file is not
  a zipfile, or it constitutes one disk of a multi-part archive.  In the
  latter case the central directory and zipfile comment will be found on
  the last disk(s) of this archive.
unzip:  cannot find zipfile directory in one of services or
        services.zip, and cannot find services.ZIP, period.
[root@qls ~]# ll
total 792
-rw-r--r--. 1 root root 670293 Aug 20 08:46 services
-rw-r--r--. 1 root root 136227 Aug 20 08:46 ser.zip
[root@qls ~]# unzip ser.zip   -d  /opt/
Archive:  ser.zip
  inflating: /opt/services           
[root@qls ~]# ll /opt/
total 656
-rw-r--r--. 1 root setgid      0 Aug 19 01:03 file9
-rw-r--r--. 1 root setgid 670293 Aug 20 08:46 services

gz格式,gzip

gzip	#只能压缩文件,会删除源文件
选项:
	-d		#解压
	-r		#压缩目录下的所有文件
	
zcat	#查看gzip格式压缩包

[root@qls ~]# gzip  services
[root@qls ~]# zcat  services.gz
[root@qls ~]# gzip  -d  services.gz

bzip2

#只能压缩文件,会删除源文件

[root@qls ~]# bzip2  services		#压缩
[root@qls ~]# bzcat  services.bz2	#查看压缩包的内容
[root@qls ~]# bzip2 -d services.bz2	#解压

tar

tar		#打包工具
选项
	z	#使用gzip格式压缩
	j	#使用bzip2格式压缩
	J	#使用xz格式压缩
	c	#创建压缩包
	f	#指定压缩包名
	v	#显示打包过程
	zcf
	t	#查看压缩包里面的内容
	tf
	x	#解压,根据压缩自动解压
	xf
	-C	#指定解压路径
	P	#使用绝对路径打包
	h	#打包软连接
	X	#指定排除列表
	--exclude	#排除
	--exclude-from=xxx  #排除列表
	
	
[root@qls ~]# tar  zcvf  services.tar.gz  services 
services

[root@qls ~]# tar  zcf  etc.tar.gz  /etc

[root@qls ~]# tar  xf  etc.tar.gz

[root@qls ~]# tar xf  etc.tar.gz   -C  /opt/

#解除压缩时,删根的操作
[root@qls ~]# cd  /  
[root@qls /]# tar  zcf  root/etc.tar.gz  etc/

[root@qls ~]# tar  zcPf  etc1.tar.gz  /etc

[root@qls ~]# tar  jcf  etc.bz2  /etc			#使用bz2格式打包
tar: Removing leading `/' from member names

[root@qls ~]# tar  Jcf  etc.xz   /etc

[root@qls ~]# tar zchf  rc1.tzr.gz  /etc/rc.local 

[root@qls ~]# tar  czf  etc.tar.gz  --exclude=/etc/hosts  /etc
tar: Removing leading `/' from member names
[root@qls ~]# ll
total 9980
-rw-r--r--. 1 root root 10216073 Aug 20 09:52 etc.tar.gz
[root@qls ~]# tar  tf etc.tar.gz  |  grep  hosts
etc/selinux/targeted/active/modules/100/denyhosts/
etc/selinux/targeted/active/modules/100/denyhosts/cil
etc/selinux/targeted/active/modules/100/denyhosts/hll
etc/selinux/targeted/active/modules/100/denyhosts/lang_ext
etc/hosts.allow
etc/hosts.deny

[root@qls ~]# tar  czf  etc.tar.gz  --exclude=/etc/{hosts,hostname}  /etc
tar: Removing leading `/' from member names
[root@qls ~]# ll
total 9980
-rw-r--r--. 1 root root 10215980 Aug 20 09:54 etc.tar.gz
[root@qls ~]# tar  tf etc.tar.gz  |  grep  -E 'hosts|hostname'
etc/selinux/targeted/active/modules/100/denyhosts/
etc/selinux/targeted/active/modules/100/denyhosts/cil
etc/selinux/targeted/active/modules/100/denyhosts/hll
etc/selinux/targeted/active/modules/100/denyhosts/lang_ext
etc/selinux/targeted/active/modules/100/hostname/
etc/selinux/targeted/active/modules/100/hostname/cil
etc/selinux/targeted/active/modules/100/hostname/hll
etc/selinux/targeted/active/modules/100/hostname/lang_ext
etc/hosts.allow
etc/hosts.deny
etc/dbus-1/system.d/org.freedesktop.hostname1.conf

[root@qls ~]# tar  czf  etc.tar.gz  --exclude=/etc/hosts --exclude=/etc/passwd  /etc
tar: Removing leading `/' from member names
[root@qls ~]# tar  tf etc.tar.gz  |  grep  -E 'hosts|passwd'
etc/selinux/targeted/active/modules/100/denyhosts/
etc/selinux/targeted/active/modules/100/denyhosts/cil
etc/selinux/targeted/active/modules/100/denyhosts/hll
etc/selinux/targeted/active/modules/100/denyhosts/lang_ext
etc/hosts.allow
etc/hosts.deny
etc/passwd-
etc/security/opasswd
etc/pam.d/passwd

[root@qls ~]# cat paichu.list
/etc/hosts
/etc/hostname
/etc/passwd
/etc/fstab
/etc/services
[root@qls ~]# ll
total 9984
-rw-r--r--. 1 root root 10215966 Aug 20 09:55 etc.tar.gz
-rw-r--r--. 1 root root       62 Aug 20 09:56 paichu.list
[root@qls ~]# tar  czf  etc1.tar.gz  -X paichu.list  /etc
tar: Removing leading `/' from member names
[root@qls ~]# ll
total 19828
-rw-r--r--. 1 root root 10079106 Aug 20 09:58 etc1.tar.gz
-rw-r--r--. 1 root root 10215966 Aug 20 09:55 etc.tar.gz
-rw-r--r--. 1 root root       62 Aug 20 09:56 paichu.list
[root@qls ~]# tar tf  etc1.tar.gz   |grep -E  'hosts|hostname|passwd|fstab|services'
etc/selinux/targeted/active/modules/100/denyhosts/
etc/selinux/targeted/active/modules/100/denyhosts/cil
etc/selinux/targeted/active/modules/100/denyhosts/hll
etc/selinux/targeted/active/modules/100/denyhosts/lang_ext
etc/selinux/targeted/active/modules/100/hostname/
etc/selinux/targeted/active/modules/100/hostname/cil
etc/selinux/targeted/active/modules/100/hostname/hll
etc/selinux/targeted/active/modules/100/hostname/lang_ext
etc/selinux/targeted/active/modules/100/updfstab/
etc/selinux/targeted/active/modules/100/updfstab/cil
etc/selinux/targeted/active/modules/100/updfstab/hll
etc/selinux/targeted/active/modules/100/updfstab/lang_ext
etc/hosts.allow
etc/hosts.deny
etc/passwd-
etc/dbus-1/system.d/org.freedesktop.hostname1.conf
etc/security/opasswd
etc/pam.d/passwd
etc/firewalld/services/

[root@qls ~]# tar  czf  etc2.tar.gz   --exclude-from=paichu.list  /etc
tar: Removing leading `/' from member names
[root@qls ~]# ll
total 29672
-rw-r--r--. 1 root root 10079106 Aug 20 09:58 etc1.tar.gz
-rw-r--r--. 1 root root 10079106 Aug 20 10:00 etc2.tar.gz
-rw-r--r--. 1 root root 10215966 Aug 20 09:55 etc.tar.gz
-rw-r--r--. 1 root root       62 Aug 20 09:56 paichu.list

tar与find的结合

[root@qls ~]# find /var/log/  -name '*.log'  | xargs  tar  log.tar.gz 

#错误的打包方式,不可取
[root@qls ~]# find /var/log/  -name '*.log'  -exec  tar czf  log1.tar.gz  {} \;

find跟du结合

[root@qls ~]# find  /etc  -type d  -maxdepth  1   | sed  -r  's#(.*)# du -sh \1#g'  |bash

[root@qls ~]# ls  -d  /* |xargs  du -sh

练习题

1.列出linux常用打包工具并写相应的压缩、解压缩参数

2.如何用gzip命令对文件进行压缩、解压缩,给出实践步骤。

	gzip  filename   #压缩
	gzip -d   filename.gz  #解压
	zcat	filename.tar	#查看压缩包内容

3.如何用zip命令对文件以及目录进行压缩、解压缩,给出实践步骤。

	zip	 filename.zip   filename   #压缩
	zip -r dir.zip  dir  #压缩目录
	unzip	filename.zip	#解压
	-d	#解压到指定的路径
	
4.创建一个自己名字的文件至/opt目录,给出实践步骤。
     
     touch   /opt/frank
     
5.打包opt/整个目录,并命名为opt_2019_08_19.tar.gz,给出实践步骤。

	tar  czf  opt_2019_08_19.tar.gz  /opt
	
	
[root@qls ~]# tar  czf  opt_$(date  +%Y_%m_%d).tar.gz  /opt
tar: Removing leading `/' from member names
[root@qls ~]# ll
total 40356
-rw-r--r--. 1 root root 10079106 Aug 20 09:58 etc1.tar.gz
-rw-r--r--. 1 root root 10079106 Aug 20 10:00 etc2.tar.gz
-rw-r--r--. 1 root root 10215966 Aug 20 09:55 etc.tar.gz
-rw-r--r--. 1 root root      353 Aug 20 10:05 log1.tar.gz
-rw-r--r--. 1 root root   288985 Aug 20 10:07 log2.tar.gz
-rw-r--r--. 1 root root   288985 Aug 20 10:03 log.tar.gz
-rw-r--r--. 1 root root 10352576 Aug 20 10:37 opt_2019_08_20.tar.gz

6.查看打包好的opt_2019_08_19.tar.gz里的文件,给出实践步骤。

tar  tf   opt_2019_08_19.tar.gz

7.将打包好的opt_2019_08_19.tar.gz内容指定解压至/tmp目录,并给出实践步骤。

tar  xf  opt_2019_08_19.tar.gz  -C  /tmp

8.打包以当前主机名+ip的命名方式的压缩包: 比如: www.oldboyedu.com_2019-08-19_10.0.0.99.tar.gz ,压缩/opt目录即可

主机名
时间
ip

[root@qls ~]# tar czf  opt_$(hostname)_$(date  +%F)_$(ifconfig  eth0 |awk 'NR==2{print $2}').tar.gz   /opt
tar: Removing leading `/' from member names
[root@qls ~]# ll
total 50468
-rw-r--r--. 1 root root 10079106 Aug 20 09:58 etc1.tar.gz
-rw-r--r--. 1 root root 10079106 Aug 20 10:00 etc2.tar.gz
-rw-r--r--. 1 root root 10215966 Aug 20 09:55 etc.tar.gz
-rw-r--r--. 1 root root      353 Aug 20 10:05 log1.tar.gz
-rw-r--r--. 1 root root   288985 Aug 20 10:07 log2.tar.gz
-rw-r--r--. 1 root root   288985 Aug 20 10:03 log.tar.gz
-rw-r--r--. 1 root root 10352576 Aug 20 10:37 opt_2019_08_20.tar.gz
-rw-r--r--. 1 root root 10352576 Aug 20 10:41 opt_qls_2019-08-20_10.0.0.100.tar.gz
-rw-r--r--. 1 root root       62 Aug 20 09:56 paichu.list

date

[root@qls ~]# date
Tue Aug 20 10:42:19 CST 2019
[root@qls ~]# date +%F
2019-08-20
[root@qls ~]# date +%Y-%m-%d
2019-08-20
[root@qls ~]# date  +%T
10:43:01
[root@qls ~]# date  +%H:%M:%S
10:43:27
[root@qls ~]# date +%w
2
[root@qls ~]# date +%W
33
[root@qls ~]# date +%d
20
[root@qls ~]# date +%s
1566269040
[root@qls ~]# date +%y-%m-%d
19-08-20
[root@qls ~]# date -d  '-1day'
Mon Aug 19 10:46:06 CST 2019
[root@qls ~]# date -d  '-1day' +%F
2019-08-19
[root@qls ~]# date -d  '+1day' +%F
2019-08-21
[root@qls ~]# date -d  '+1year' +%F
2020-08-20
[root@qls ~]# date -d  '-1year' +%F
2018-08-20
[root@qls ~]# date -s  '2019/08/30'
Fri Aug 30 00:00:00 CST 2019
[root@qls ~]# date +%F
2019-08-30
[root@qls ~]# date -s  '10:48:00'
Fri Aug 30 10:48:00 CST 2019
[root@qls ~]# date +%T
10:48:04
[root@qls ~]# yum install -y  ntpdate
[root@qls ~]# ntpdate  ntp.aliyun.com
20 Aug 10:49:27 ntpdate[10174]: step time server 203.107.6.88 offset -863992.416377 sec
[root@qls ~]# date 
Tue Aug 20 10:49:34 CST 2019

rpm包

tree-1.6.0-10.el7.x86_64.rpm
trang-20091111-14.el7.noarch.rpm 

依赖性太强

#挂载镜像
[root@qls ~]# mount  /dev/cdrom   /mnt

[root@qls ~]# rpm  -ivh /mnt/Packages/tree-1.6.0-10.el7.x86_64.rpm
Preparing...                          ################################# [100%]
Updating / installing...
   1:tree-1.6.0-10.el7                ################################# [100%]

[root@qls ~]# yum install -y samba


选项
	-e		#卸载软件包
	-i		#安装
	-v		#显示安装的过程
	-h		#查看安装的进度
	-qa		#查看软件包是否安装
	-qi		#显示软件包详细信息
	-qc		#查询软件包的配置文件
	-qf		#搜索命令属于哪个软件包,本地要有这个命令
	-U		#升级
	

[root@qls ~]# rpm -qf  /usr/sbin/ifconfig
net-tools-2.0-0.24.20131004git.el7.x86_64


[root@qls ~]# rpm -ivh https://mirrors.aliyun.com/centos/7.6.1810/os/x86_64/Packages/tree-1.6.0-10.el7.x86_64.rpm
Retrieving https://mirrors.aliyun.com/centos/7.6.1810/os/x86_64/Packages/tree-1.6.0-10.el7.x86_64.rpm
Preparing...                          ################################# [100%]
Updating / installing...
   1:tree-1.6.0-10.el7                ################################# [100%]

安装低版本
[root@qls ~]# rpm -ivh https://mirrors.aliyun.com/zabbix/zabbix/3.0/rhel/7/x86_64/zabbix-agent-3.0.0-1.el7.x86_64.rpm
Retrieving https://mirrors.aliyun.com/zabbix/zabbix/3.0/rhel/7/x86_64/zabbix-agent-3.0.0-1.el7.x86_64.rpm
warning: /var/tmp/rpm-tmp.t6JBzJ: Header V4 DSA/SHA1 Signature, key ID 79ea5ed4: NOKEY
Preparing...                          ################################# [100%]
Updating / installing...
   1:zabbix-agent-3.0.0-1.el7         ################################# [100%]

升级
[root@qls ~]# rpm -Uvh  https://mirrors.aliyun.com/zabbix/zabbix/4.0/rhel/7/x86_64/zabbix-agent-4.0.0-2.el7.x86_64.rpm
Retrieving https://mirrors.aliyun.com/zabbix/zabbix/4.0/rhel/7/x86_64/zabbix-agent-4.0.0-2.el7.x86_64.rpm
warning: /var/tmp/rpm-tmp.0nJhRu: Header V4 RSA/SHA512 Signature, key ID a14fe591: NOKEY
Preparing...                          ################################# [100%]
Updating / installing...
   1:zabbix-agent-4.0.0-2.el7         ################################# [ 50%]
Cleaning up / removing...
   2:zabbix-agent-3.0.0-1.el7         ################################# [100%]

yum

-y		#免交互

#本地安装
[root@qls ~]# yum  localinstall  /mnt/Packages/tree-1.6.0-10.el7.x86_64.rpm 

install			#安装
provides		#查询命令属于哪个软件包
search			#搜寻软件包
update			#更新
check-update	#检查系统可更新的包
repolist		#查看yum源镜像仓库
list			 #查看可安装的包
list installed	 #查看系统中已经安装的包
clean			#清空缓存
		all		#清空所有
		packages	#清空软件包
info			#查看软件包的详细信息
history			#yum命令的历史事物
remove			#卸载软件
reinstall		#遇到配置被删除,可以重新安装

[root@qls ~]# head  /etc/yum.conf 
[main]
cachedir=/var/cache/yum/$basearch/$releasever	#缓存生成路径
keepcache=1		#开启缓存

源码编译:以nginx为例

预编译
make
make  install

#下载源码包
[root@qls ~]# wget http://nginx.org/download/nginx-1.16.1.tar.gz

#解压
[root@qls ~]# tar  xf nginx-1.16.1.tar.gz

[root@qls ~]# cd nginx-1.16.1

#安装依赖
[root@qls nginx-1.16.1]# yum  install  gcc-devel  gcc pcre  pcre-devel openssl  openssl-devel -y

[root@qls nginx-1.16.1]# ./configure   --prefix=/app/nginx-1.16.1  --with-http_ssl_module

checking for OS
 + Linux 3.10.0-957.el7.x86_64 x86_64
checking for C compiler ... not found

./configure: error: C compiler cc is not found		#报错

解决:
[root@qls nginx-1.16.1]# yum  install  gcc-devel  gcc  -y

报错
./configure: error: the HTTP rewrite module requires the PCRE library.
You can either disable the module by using --without-http_rewrite_module
option, or install the PCRE library into the system, or build the PCRE library
statically from the source with nginx by using --with-pcre=<path> option.

解决
[root@qls nginx-1.16.1]# yum install  -y pcre  pcre-devel

报错
./configure: error: SSL modules require the OpenSSL library.
You can either do not enable the modules, or install the OpenSSL library
into the system, or build the OpenSSL library statically from the source
with nginx by using --with-openssl=<path> option.

解决
[root@qls nginx-1.16.1]# yum install openssl  openssl-devel  -y 

[root@qls nginx-1.16.1]# echo  $?
0

[root@qls nginx-1.16.1]#  make

[root@qls nginx-1.16.1]# echo  $?
0

[root@qls nginx-1.16.1]# make install

[root@qls nginx-1.16.1]# echo  $?
0

[root@qls nginx-1.16.1]# ll /app/nginx-1.16.1/
total 4
drwxr-xr-x. 2 root root 4096 Aug 20 12:36 conf
drwxr-xr-x. 2 root root   40 Aug 20 12:36 html
drwxr-xr-x. 2 root root    6 Aug 20 12:36 logs
drwxr-xr-x. 2 root root   19 Aug 20 12:36 sbin
[root@qls nginx-1.16.1]# ln  -s  /app/nginx-1.16.1/  /app/nginx
[root@qls nginx-1.16.1]# ll /app/
total 0
lrwxrwxrwx. 1 root root 18 Aug 20 12:37 nginx -> /app/nginx-1.16.1/
drwxr-xr-x. 6 root root 54 Aug 20 12:36 nginx-1.16.1
[root@qls nginx-1.16.1]# /app/nginx/sbin/nginx 
[root@qls nginx-1.16.1]# ss -lntp|grep 80
LISTEN     0      128          *:80                       *:*                   users:(("nginx",pid=12928,fd=6),("nginx",pid=12927,fd=6))

[root@qls nginx-1.16.1]# systemctl  status firewalld
● firewalld.service - firewalld - dynamic firewall daemon
   Loaded: loaded (/usr/lib/systemd/system/firewalld.service; enabled; vendor preset: enabled)
   Active: active (running) since Tue 2019-08-20 12:31:46 CST; 7min ago
     Docs: man:firewalld(1)
 Main PID: 6927 (firewalld)
   CGroup: /system.slice/firewalld.service
           └─6927 /usr/bin/python -Es /usr/sbin/firewalld --nofork --nopid

Aug 20 12:31:44 qls systemd[1]: Starting firewalld - dynamic firewall daemon...
Aug 20 12:31:46 qls systemd[1]: Started firewalld - dynamic firewall daemon.
[root@qls nginx-1.16.1]# systemctl  stop  firewalld
[root@qls nginx-1.16.1]# systemctl  disable   firewalld
Removed symlink /etc/systemd/system/multi-user.target.wants/firewalld.service.
Removed symlink /etc/systemd/system/dbus-org.fedoraproject.FirewallD1.service.

磁盘管理

#使用fdisk进行分区,支持2TB下的分区,使用MBR分区表
1. 添加磁盘

2.进行分区
[root@qls ~]# fdisk   /dev/sdb
Welcome to fdisk (util-linux 2.23.2).

Changes will remain in memory only, until you decide to write them.
Be careful before using the write command.

Device does not contain a recognized partition table
Building a new DOS disklabel with disk identifier 0xe23878a4.

Command (m for help): m
Command action
   a   toggle a bootable flag
   b   edit bsd disklabel
   c   toggle the dos compatibility flag
   d   delete a partition
   g   create a new empty GPT partition table
   G   create an IRIX (SGI) partition table
   l   list known partition types
   m   print this menu
   n   add a new partition
   o   create a new empty DOS partition table
   p   print the partition table
   q   quit without saving changes
   s   create a new empty Sun disklabel
   t   change a partition's system id
   u   change display/entry units
   v   verify the partition table
   w   write table to disk and exit
   x   extra functionality (experts only)

Command (m for help): p

Disk /dev/sdb: 21.5 GB, 21474836480 bytes, 41943040 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: 0xe23878a4

   Device Boot      Start         End      Blocks   Id  System

Command (m for help): n
Partition type:
   p   primary (0 primary, 0 extended, 4 free)
   e   extended
Select (default p): p
Partition number (1-4, default 1): 
First sector (2048-41943039, default 2048): 
Using default value 2048
Last sector, +sectors or +size{K,M,G} (2048-41943039, default 41943039): +5G
Partition 1 of type Linux and of size 5 GiB is set

Command (m for help): p

Disk /dev/sdb: 21.5 GB, 21474836480 bytes, 41943040 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: 0xe23878a4

   Device Boot      Start         End      Blocks   Id  System
/dev/sdb1            2048    10487807     5242880   83  Linux

Command (m for help): w
The partition table has been altered!

Calling ioctl() to re-read partition table.

3.格式化,创建文件系统
[root@qls ~]# mkfs.xfs     /dev/sdb1
meta-data=/dev/sdb1              isize=512    agcount=4, agsize=327680 blks
         =                       sectsz=512   attr=2, projid32bit=1
         =                       crc=1        finobt=0, sparse=0
data     =                       bsize=4096   blocks=1310720, imaxpct=25
         =                       sunit=0      swidth=0 blks
naming   =version 2              bsize=4096   ascii-ci=0 ftype=1
log      =internal log           bsize=4096   blocks=2560, version=2
         =                       sectsz=512   sunit=0 blks, lazy-count=1
realtime =none                   extsz=4096   blocks=0, rtextents=0

4.创建挂载点,并进行挂载
[root@qls ~]# mkdir   /test_f
[root@qls ~]# 
[root@qls ~]# 
[root@qls ~]# mount  /dev/sdb1  /test_f
[root@qls ~]# df -h
Filesystem      Size  Used Avail Use% Mounted on
/dev/sda3        48G  1.8G   46G   4% /
devtmpfs        980M     0  980M   0% /dev
tmpfs           991M     0  991M   0% /dev/shm
tmpfs           991M  9.6M  981M   1% /run
tmpfs           991M     0  991M   0% /sys/fs/cgroup
/dev/sda1       497M  120M  378M  25% /boot
tmpfs           199M     0  199M   0% /run/user/0
/dev/sdb1       5.0G   33M  5.0G   1% /test_f
[root@qls ~]# cp  /etc/services  /test_f/
[root@qls ~]# ll /test_f/
total 656
-rw-r--r--. 1 root root 670293 Aug 20 15:58 services

[root@qls ~]# umount  /dev/sdb1
[root@qls ~]# ll /test_f/
total 0
[root@qls ~]# mkdir   /test_1
[root@qls ~]# 
[root@qls ~]# mount  /dev/sdb1  /test_1
[root@qls ~]# ll /test_1
total 656
-rw-r--r--. 1 root root 670293 Aug 20 15:58 services


5.永久挂载
[root@qls ~]# tail -1  /etc/fstab
/dev/sdb1                                 /test_1                 xfs     defaults        0 0

gdisk

GPT分区表,支持128分区

#安装gdisk
[root@qls ~]# yum  install  gdisk  -y

[root@qls ~]# gdisk  /dev/sdc
GPT fdisk (gdisk) version 0.8.10

Partition table scan:
  MBR: not present
  BSD: not present
  APM: not present
  GPT: not present

Creating new GPT entries.

Command (? for help): ?
b	back up GPT data to a file
c	change a partition's name
d	delete a partition
i	show detailed information on a partition
l	list known partition types
n	add a new partition
o	create a new empty GUID partition table (GPT)
p	print the partition table
q	quit without saving changes
r	recovery and transformation options (experts only)
s	sort partitions
t	change a partition's type code
v	verify disk
w	write table to disk and exit
x	extra functionality (experts only)
?	print this menu

Command (? for help): n
Partition number (1-128, default 1): 
First sector (34-6442450910, default = 2048) or {+-}size{KMGTP}: 
Last sector (2048-6442450910, default = 6442450910) or {+-}size{KMGTP}: 
Current type is 'Linux filesystem'
Hex code or GUID (L to show codes, Enter = 8300): L
0700 Microsoft basic data  0c01 Microsoft reserved    2700 Windows RE          
3000 ONIE boot             3001 ONIE config           4100 PowerPC PReP boot   
4200 Windows LDM data      4201 Windows LDM metadata  7501 IBM GPFS            
7f00 ChromeOS kernel       7f01 ChromeOS root         7f02 ChromeOS reserved   
8200 Linux swap            8300 Linux filesystem      8301 Linux reserved      
8302 Linux /home           8400 Intel Rapid Start     8e00 Linux LVM           
a500 FreeBSD disklabel     a501 FreeBSD boot          a502 FreeBSD swap        
a503 FreeBSD UFS           a504 FreeBSD ZFS           a505 FreeBSD Vinum/RAID  
a580 Midnight BSD data     a581 Midnight BSD boot     a582 Midnight BSD swap   
a583 Midnight BSD UFS      a584 Midnight BSD ZFS      a585 Midnight BSD Vinum  
a800 Apple UFS             a901 NetBSD swap           a902 NetBSD FFS          
a903 NetBSD LFS            a904 NetBSD concatenated   a905 NetBSD encrypted    
a906 NetBSD RAID           ab00 Apple boot            af00 Apple HFS/HFS+      
af01 Apple RAID            af02 Apple RAID offline    af03 Apple label         
af04 AppleTV recovery      af05 Apple Core Storage    be00 Solaris boot        
bf00 Solaris root          bf01 Solaris /usr & Mac Z  bf02 Solaris swap        
bf03 Solaris backup        bf04 Solaris /var          bf05 Solaris /home       
bf06 Solaris alternate se  bf07 Solaris Reserved 1    bf08 Solaris Reserved 2  
bf09 Solaris Reserved 3    bf0a Solaris Reserved 4    bf0b Solaris Reserved 5  
c001 HP-UX data            c002 HP-UX service         ea00 Freedesktop $BOOT   
eb00 Haiku BFS             ed00 Sony system partitio  ed01 Lenovo system partit
Press the <Enter> key to see more codes: 
ef00 EFI System            ef01 MBR partition scheme  ef02 BIOS boot partition 
fb00 VMWare VMFS           fb01 VMWare reserved       fc00 VMWare kcore crash p
fd00 Linux RAID            
Hex code or GUID (L to show codes, Enter = 8300): 
Changed type of partition to 'Linux filesystem'

Command (? for help): p
Disk /dev/sdc: 6442450944 sectors, 3.0 TiB
Logical sector size: 512 bytes
Disk identifier (GUID): E2A6B39D-0ACA-4E24-AFEE-10AC07DFB9C9
Partition table holds up to 128 entries
First usable sector is 34, last usable sector is 6442450910
Partitions will be aligned on 2048-sector boundaries
Total free space is 2014 sectors (1007.0 KiB)

Number  Start (sector)    End (sector)  Size       Code  Name
   1            2048      6442450910   3.0 TiB     8300  Linux filesystem

Command (? for help): p
Disk /dev/sdc: 6442450944 sectors, 3.0 TiB
Logical sector size: 512 bytes
Disk identifier (GUID): E2A6B39D-0ACA-4E24-AFEE-10AC07DFB9C9
Partition table holds up to 128 entries
First usable sector is 34, last usable sector is 6442450910
Partitions will be aligned on 2048-sector boundaries
Total free space is 2014 sectors (1007.0 KiB)

Number  Start (sector)    End (sector)  Size       Code  Name
   1            2048      6442450910   3.0 TiB     8300  Linux filesystem

Command (? for help): w

Final checks complete. About to write GPT data. THIS WILL OVERWRITE EXISTING
PARTITIONS!!

Do you want to proceed? (Y/N): y
OK; writing new GUID partition table (GPT) to /dev/sdc.
The operation has completed successfully.
[root@qls ~]# lsblk
NAME   MAJ:MIN RM  SIZE RO TYPE MOUNTPOINT
sda      8:0    0   50G  0 disk 
├─sda1   8:1    0  500M  0 part /boot
├─sda2   8:2    0    2G  0 part [SWAP]
└─sda3   8:3    0 47.5G  0 part /
sdb      8:16   0   20G  0 disk 
└─sdb1   8:17   0    5G  0 part /test_1
sdc      8:32   0    3T  0 disk 
└─sdc1   8:33   0    3T  0 part 
sr0     11:0    1  4.3G  0 rom  
[root@qls ~]# mkfs.xfs   /dev/sdc1  
meta-data=/dev/sdc1              isize=512    agcount=4, agsize=201326527 blks
         =                       sectsz=512   attr=2, projid32bit=1
         =                       crc=1        finobt=0, sparse=0
data     =                       bsize=4096   blocks=805306107, imaxpct=5
         =                       sunit=0      swidth=0 blks
naming   =version 2              bsize=4096   ascii-ci=0 ftype=1
log      =internal log           bsize=4096   blocks=393215, version=2
         =                       sectsz=512   sunit=0 blks, lazy-count=1
realtime =none                   extsz=4096   blocks=0, rtextents=0

[root@qls ~]# mkdir  /gpt
[root@qls ~]# 
[root@qls ~]# 
[root@qls ~]# mount  /dev/sdc1  /gpt
[root@qls ~]# 
[root@qls ~]# 
[root@qls ~]# cp /etc/services  /gpt
[root@qls ~]# 
[root@qls ~]# 
[root@qls ~]# ll /gpt
total 656
-rw-r--r--. 1 root root 670293 Aug 20 16:42 services
[root@qls ~]# umount  /gpt
[root@qls ~]# 
[root@qls ~]# ll /gpt
total 0
[root@qls ~]# ll /opt/
total 0
[root@qls ~]# mount   /dev/sdc1  /opt/
[root@qls ~]# ll /opt/
total 656
-rw-r--r--. 1 root root 670293 Aug 20 16:42 services
[root@qls ~]# umount /opt/
[root@qls ~]# 
[root@qls ~]# 
[root@qls ~]# cp /etc/hosts  /opt
[root@qls ~]# 
[root@qls ~]# 
[root@qls ~]# ll /opt
total 4
-rw-r--r--. 1 root root 158 Aug 20 16:43 hosts
[root@qls ~]# 
[root@qls ~]# 
[root@qls ~]# mount   /dev/sdc1  /opt/
[root@qls ~]# ll /opt/
total 656
-rw-r--r--. 1 root root 670293 Aug 20 16:42 services
[root@qls ~]# umount  /opt
[root@qls ~]# 
[root@qls ~]# 
[root@qls ~]# ll /opt
total 4
-rw-r--r--. 1 root root 158 Aug 20 16:43 hosts

磁盘的挂载方式

mount		#挂载磁盘
选项
	-o		#指定挂载的参数
	-a		#重新挂载/etc/fstab中的挂载列表
	-t		#指定挂载文件系统,xfs	是7系统默认的, ext4 6系统默认

[root@qls ~]# blkid
/dev/sr0: UUID="2018-11-25-23-54-16-00" LABEL="CentOS 7 x86_64" TYPE="iso9660" PTTYPE="dos" 
/dev/sda1: UUID="ffc53ebe-1964-4fe9-b761-01b1e0a0e2af" TYPE="xfs" 
  ev/sda2: UUID="e2ed12e8-15c2-4061-806e-a02f7847c0d0" TYPE="swap" 
▽dev/sda3: UUID="400a5819-809d-43b4-a323-30f4c3ac7bf0" TYPE="xfs" 
/dev/sdb1: UUID="905bb897-c545-4ee6-b8e9-53436eadaf18" TYPE="xfs" 
/dev/sdc1: UUID="9d441e76-17a1-48f9-a49b-28e3e9ea8d20" TYPE="xfs" PARTLABEL="Linux filesystem" PARTUUID="0bd340a4-52c0-46a0-9cb7-75e771d9be1b" 
[root@qls ~]# df -h
Filesystem      Size  Used Avail Use% Mounted on
/dev/sda3        48G  1.9G   46G   4% /
devtmpfs        980M     0  980M   0% /dev
tmpfs           991M     0  991M   0% /dev/shm
tmpfs           991M  9.7M  981M   1% /run
tmpfs           991M     0  991M   0% /sys/fs/cgroup
/dev/sdb1       5.0G   33M  5.0G   1% /test_1
/dev/sda1       497M  120M  378M  25% /boot
tmpfs           199M     0  199M   0% /run/user/0
[root@qls ~]# mount  UUID="9d441e76-17a1-48f9-a49b-28e3e9ea8d20"  /gpt

umount  	#卸载磁盘
选项
	-l		#强制卸载
	
出现卸载不掉的情况下

	1. 使用强制卸载
	2. 切换到其他目录进行卸载

/etc/fstab配置文件

[root@qls ~]# tail  -1  /etc/fstab 
UUID=9d441eb-28e3e9ea8d20 /gpt                    xfs     defaults        0 0

第一列:挂载的设备名,可以使用UUID,还可以网络地址

第二列:挂载点,挂载的入口

第三列:文件系统的类型

第四列:挂载的参数。defaults

参数

含义

async/sync

是否同步方式运行,默认async(异步)。

user/nouser

是否允许普通用户使用mount命令挂载,默认nouser。

exec/noexec

是否允许可执行文件执行,默认exec。

suid/nosuid

是否允许存在suid属性的文件,默认suid。

auto/noauto

执行mount -a时,此文件系统是否被主动挂载,默认auto。

rw/ro

是否只读或者读写模式进行挂载。默认rw。

defaults

具有rw,suid,exec,auto,nouser,async等默认参数的设定。

第五列:是否通过dump进行备份,0 不备份  ,1 每天备份  2 不定期的备份

第六列:是否检查磁盘,0 不检查  ,1 检查,按照顺序检查,1只能给/

swap

oom  

临时添加虚拟内存

#1. 生成一个1G的大文件
[root@qls ~]# dd  </dev/zero  >/root/swap.txt  bs=100M  count=10
10+0 records in
10+0 records out
1048576000 bytes (1.0 GB) copied, 29.8756 s, 35.1 MB/s

#修改权限
[root@qls ~]# chmod  600  swap.txt 

#2.让这个成为swap文件
[root@qls ~]# mkswap   -f  swap.txt 
Setting up swapspace version 1, size = 1023996 KiB
no label, UUID=d849c5bf-b582-46f6-816e-301ab190bb3a
[root@qls ~]# file  swap.txt 
swap.txt: Linux/i386 swap file (new style), version 1 (4K pages), size 255999 pages, no label, UUID=d849c5bf-b582-46f6-816e-301ab190bb3a
[root@qls ~]# free -m
              total        used        free      shared  buff/cache   available
Mem:           1980         106         561           9        1313        1677
Swap:          2047           0        2047

#3.添加swap大小
[root@qls ~]# swapon  swap.txt 
swapon: /root/swap.txt: insecure permissions 0644, 0600 suggested.
[root@qls ~]# free -m
              total        used        free      shared  buff/cache   available
Mem:           1980         106         560           9        1313        1676
Swap:          3047           0        3047

[root@qls ~]# swapoff  swap.txt 	#缩减swap空间
[root@qls ~]# free -m
              total        used        free      shared  buff/cache   available
Mem:           1980         106         560           9        1313        1677
Swap:          2047           0        2047

[root@qls ~]# swapon -s		#检查当前swap使用那些分区
Filename				Type		Size	Used	Priority
/dev/sda2                              	partition	2097148	0	-2
/root/swap.txt                         	file	1023996	0	-3

#禁用swap

[root@qls ~]# swapoff -a
[root@qls ~]# free -m
              total        used        free      shared  buff/cache   available
Mem:           1980         106         562           9        1312        1677
Swap:             0           0           0

#开启swap
[root@qls ~]# swapon -a
[root@qls ~]# free -m
              total        used        free      shared  buff/cache   available
Mem:           1980         106         562           9        1312        1677
Swap:          2047           0        2047

磁盘故障

block 慢
[root@qls ~]# cp Desktop.zip  /data/
cp: error writing ‘/data/Desktop.zip’: No space left on device
cp: failed to extend ‘/data/Desktop.zip’: No space left on device

[root@qls ~]# du  -sh  /* |grep  G
du: cannot access ‘/proc/7780/task/7780/fd/4’: No such file or directory
du: cannot access ‘/proc/7780/task/7780/fdinfo/4’: No such file or directory
du: cannot access ‘/proc/7780/fd/4’: No such file or directory
du: cannot access ‘/proc/7780/fdinfo/4’: No such file or directory
1.1G	/root
1.5G	/usr
5.1G	/var
[root@qls ~]# du  -sh  /var/* |grep  G
4.9G	/var/log
[root@qls ~]# du  -sh  /var/log/* |grep  G
4.9G	/var/log/test.log

#确认之后再删除

[root@qls ~]# rm -f /var/log/test.log

index慢了

[root@qls ~]# df -i
Filesystem       Inodes  IUsed    IFree IUse% Mounted on
/dev/sda3      24909312 263092 24646220    2% /
devtmpfs         250786    403   250383    1% /dev
tmpfs            253511      1   253510    1% /dev/shm
tmpfs            253511    766   252745    1% /run
tmpfs            253511     16   253495    1% /sys/fs/cgroup
/dev/sdb1       2621440      4  2621436    1% /test_1
/dev/sda1        256000    326   255674    1% /boot
tmpfs            253511      1   253510    1% /run/user/0

[root@qls ~]# find  / -type d  -size +3M   |xargs  ls -lhd
drwxr-xr-x. 2 1001 1001 4.7M Aug 20 17:34 /root/nginx-1.16.1/conf

#确认好在删除
[root@qls ~]# find  /root/nginx-1.16.1/conf  -type f  -name '*txt' |xargs   rm -f
[root@qls ~]# find  /root/nginx-1.16.1/conf  -type f  -name '*sh' |xargs   rm -f
[root@qls ~]# find  /root/nginx-1.16.1/conf  -type f  -name '*py' |xargs   rm -f
[root@qls ~]# find  /root/nginx-1.16.1/conf  -type f  -name '*log' |xargs   rm -f
[root@qls ~]# 
[root@qls ~]# 
[root@qls ~]# ll /root/nginx-1.16.1/conf |wc -l
10

开机启动流程

#简单说明CentOS-7系统启动过程:

01) 按下电源

02) 开机BIOS自检    

03) MBR引导系统   

04) GRUB菜单

05) 加载内核          

06) 启动系统进程(使用systemd进行管理)       

07) 读取运行级别

08) 进行系统初始化

09) 启动开机自动启动服务(并行启动)

10) 运行getty文件,进入登录页面

运行级别
[root@qls ~]# ll /usr/lib/systemd/system/runlevel*.target 
lrwxrwxrwx. 1 root root 15 Aug 14 15:11 /usr/lib/systemd/system/runlevel0.target -> poweroff.target
lrwxrwxrwx. 1 root root 13 Aug 14 15:11 /usr/lib/systemd/system/runlevel1.target -> rescue.target
lrwxrwxrwx. 1 root root 17 Aug 14 15:11 /usr/lib/systemd/system/runlevel2.target -> multi-user.target
lrwxrwxrwx. 1 root root 17 Aug 14 15:11 /usr/lib/systemd/system/runlevel3.target -> multi-user.target
lrwxrwxrwx. 1 root root 17 Aug 14 15:11 /usr/lib/systemd/system/runlevel4.target -> multi-user.target
lrwxrwxrwx. 1 root root 16 Aug 14 15:11 /usr/lib/systemd/system/runlevel5.target -> graphical.target
lrwxrwxrwx. 1 root root 13 Aug 14 15:11 /usr/lib/systemd/system/runlevel6.target -> reboot.target

System 运行级别

Systemd目标名称

作用

0

runlevel0.target,poweroff.target

关机

1

runlevel1.target,rescue.target

单用户模式

2

runlevel2.target,multi.target

多用户模式

3

runlevel3.target,multi.target

多用户模式

4

runlevel4.target,multi.target

多用户模式

5

runlevel5.target,graphical.target

图形界面或桌面模式

6

runlevel6.target,reboot.target

重启

[root@qls ~]# systemctl   get-default	#查看运行级别
multi-user.target
[root@qls ~]# runlevel
N 3
[root@qls ~]# systemctl   set-default  graphical.target	#切换运行级别

[root@qls ~]# init  5

主配置文件

ll /etc/systemd/system/default.target

systemd

#systemctl管理服务的启动、停止、重启、重载、状态等常用命令

[root@qls ~]# systemctl start vsftpd        #启动

[root@qls ~]# systemctl stop vsftpd         #停止

[root@qls ~]# systemctl status vsftpd       #查看运行状态

[root@qls ~]# systemctl restart vsftpd      #重启

[root@qls ~]# systemctl reload  vsftpd      #重载

[root@qls ~]# systemctl mask  vsftpd        #禁止服务运行

[root@qls ~]# systemctl unmask  vsftpd      #取消禁止服务运行

[root@qls ~]# systemctl enable vsftpd 		#开机自启

[root@qls ~]# systemctl disable  vsftpd 	#关闭开机自启

单用户修改root密码

1、重新启动或开启CentOS-7系统,在选择进入系统的Grub菜单界面有提示按e时,按e进入编辑界面
2、找到Linux16这行,将磁盘改为rw读写模式,然后再在后面添加如下:
init=/bin/bash enforcing=0 #(前者作用让系统登录后加载bash解释器,后者是且关闭Selinux)
3、ctrl+x以单用户模式启动
4、在命令行执行:
	mount -o rw,remount /  # 重新挂载根目录,如果前面改了rw,这里可以不执行
	passwd root  # 设置root用户密码
5、执行 exec /sbin/init 命令重启系统