[实验] Linux rpm 软件包的制作 (通过 rpm-build 实现) (Nginx 版)

注意:文中的很多信息例如软件的名称等是站主在本次操作中随意取的名称,读者可以根据自己的喜好换成任意别的名称

软件准备:

在 Nginx 官网上下载搭建集群所需软件 Nginx:

http://nginx.org/en/download.html

正文:

步骤目录:

步骤一:系统环境要求

步骤二:准备 rpm-build 软件
2.1 安装 rpm-build
2.2 生成 rpm-build 目录
2.3 查看生成的 rpm-build 目录

步骤三:制作 Nginx 软件的 rpm 包
3.1 将 Nginx 的源码安装包放在固定的位置
3.2 制作 Nginx 的 nginx.spec 文件
3.3 SPEC 配置文件里的内容说明
3.4 安装 Nginx 软件的依赖包
3.6 查看新生成的 Nginx rpm 软件包

步骤四:使用新生成的 Nginx rpm 软件包
4.1 安装刚刚新生成的 Nginx rpm 软件包
4.2 启动 Nginx 服务
4.3 查看 Nginx 服务的启动状态
4.3.1 查看 Nginx 网页是否可以访问
4.3.2 查看 Nginx 的端口有没有启动

具体的操作步骤:

步骤一:系统环境要求

1) 服务器的系统是 CentOS 7 版本
2) 服务器系统要配置好 yum 源

步骤二:准备 rpm-build 软件
2.1 安装 rpm-build

# yum -y install rpm-build

2.2 生成 rpm-build 目录

# rpmbuild -ba nginx.spec
error: failed to stat /root/nginx.spec: No such file or directory

2.3 查看生成的 rpm-build 目录

# ls /root/rpmbuild/
BUILD  BUILDROOT  RPMS	SOURCES  SPECS	SRPMS

步骤三:制作 Nginx 软件的 rpm 包
3.1 将 Nginx 的源码安装包放在固定的位置

# cp nginx-1.16.1.tar.gz /root/rpmbuild/SOURCES/

(补充:这里要安装的 Nginx 版本是 1.16.1)

3.2 制作 Nginx 的 nginx.spec 文件

# vi /root/rpmbuild/SPECS/nginx.spec

将部分内容修改如下:

Name:nginx
Version:1.16.1
Release:1.0
Summary:Nginx is a web server software.
......
License:GPL
URL:www.nginx.org
Source0:%{name}-%{version}.tar
......
%description
nginx is an HTTP and reverse proxy server ......
......
%post
useradd nginx
......
%prep
%setup -q
......
%build
./configure --user=nginx --group=nginx --with-http_ssl_module
make %{?_smp_mflags}
%install
make install DESTDIR=%{buildroot}
......
%files
......
%doc
/usr/local/nginx/*
......
%changelog


补充:
1) 这里的 Name:nginx 是指软件名称是 nginx
2) 这里的 Version:1.16.1 是指软件的版本是 1.16.1
3) 这里的 Release:1.0 是指发布的版本是 1。0
4) 这里的 Summary: Nginx is a web server software. 是指软件的描述是 Summary: Nginx is a web server software.
5) 这里的 License:GPL 是指软件使用的协议是 GPL
6) 这里的 URL:www.nginx.org 是指软件的官网是 www.nginx.org
7) 这里的 Source0:%{name}-%{version}.tar 是指软件源码文件的名称
8) 这里的 #BuildRequires: 是指软件编译安装时需要的依赖包,这里没有内容
9) 这里的 #Requires: 是指软件安装时所需要的依赖包,这里没有内容
10) 这里的 %description 是指软件的详细描述,这里没有内容
11) 这里的

%post
useradd nginx

是指软件安装后创建 nginx 用户

12) 这里的 %prep 是指软件安装前的准备,这里没有内容
13) 这里的 %setup –q 是指自动解压软件的源码包,并 cd 进入刚刚解压出来的目录
14) 这里的

%build
./configure
make %{?_smp_mflags}

是指对源码安装包进行配置
15) 这里的

%install
make install DESTDIR=%{buildroot}

是指对源码安装包进行编译安装
16) 这里的

%files
%doc
/usr/local/nginx/*

是指将源码安装包安装到 /usr/local/nginx/ 目录里

3.4 安装 Nginx 软件的依赖包

# yum -y install gcc pcre-devel openssl-devel

3.5 生成 Nginx rpm 软件包

# rpmbuild -ba /root/rpmbuild/SPECS/nginx.spec

3.6 查看新生成的 Nginx rpm 软件包

# rpm -qpi /root/rpmbuild/RPMS/x86_64/nginx-1.16.1-1.0.x86_64.rpm

步骤四:使用新生成的 Nginx rpm 软件包
4.1 安装刚刚新生成的 Nginx rpm 软件包

# rpm -ivh /root/rpmbuild/RPMS/x86_64/nginx-1.16.1-1.0.x86_64.rpm

4.2 启动 Nginx 服务

# /usr/local/nginx/sbin/nginx

4.3 查看 Nginx 服务的启动状态
4.3.1 查看 Nginx 网页是否可以访问

# curl http://127.0.0.1/

4.3.2 查看 Nginx 的端口有没有启动

# ss -ntulap | grep 80

[命令] Linux 命令组 lvm (逻辑卷管理)

内容目录:

内容一:LVM 的原理
1.1 LVM 的目的
1.2 LVM 的结构
1.2.1 LVM 的第一层
1.2.2 LVM 的第二层
1.2.3 LVM 的第三层

内容二:LVM 管理的命令集

内容三:快速部署 LVM 的思路

内容四:创建 LVM 逻辑卷的案例
4.1 创建卷组的格式
4.2 创建卷组的案例
4.3 创建逻辑卷的方案案例选择
4.3.1 案例一:创建指定大小的逻辑卷
4.3.2 案例二:创建大小是卷组剩余空间百分比的逻辑卷
4.3.3 案例三:创建大小是卷组全部空间百分比的逻辑据
4.4 查看已创建的逻辑卷 /dev/vg/vo
4.5 将新创建的逻辑卷格式化、挂载并使用

内容五:扩展 LVM 逻辑卷大小的案例
5.1 检查现有逻辑卷大小
5.2 检查逻辑卷所在卷组的剩余空间,看是否够逻辑卷扩展
5.3 当卷组的剩余空间不足时,要先扩展卷组(如果卷组的空间足够大,则可以跳过次步骤)
5.3.1 扩展卷组的格式
5.3.2 扩展卷组的案例
5.3.2.1 扩展卷组
5.3.2.2 查看扩展后的卷组
5.3.2.3 之后就可以扩展逻辑卷了
5.4 当卷组的剩余空间充足时,可直接扩展逻辑卷
5.4.1 扩展逻辑卷的格式
5.4.1.1 第一种格式:将逻辑卷扩展到指定大小
5.4.1.2 第二种格式:给逻辑卷添加指定大小的空间
5.4.1.3 第三种格式:将剩余空间的百分比添加给逻辑卷
5.4.1.4 补充:使用 -r 参数的格式
5.4.2 扩展逻辑卷的案例
5.4.2.1 扩展逻辑卷
5.4.2.1.1 案例一:将逻辑卷扩展到某个值
5.4.2.1.2 案例二:给逻辑卷添加某个值
5.4.2.1.3 案例三:将所有剩余空间添加给逻辑卷,并强制刷新文件系统容量
5.4.2.2 查看扩展后的逻辑卷
5.5 更新文件系统大小
5.5.1 更新文件系统大小的目的
5.5.2 查看文件系统的格式
5.5.3 刷新文件系统容量的格式
5.5.4 刷新文件系统的案例

内容六:创建 LVM 卷组时固定 PE 的大小的案例
6.1 创建卷组的时候固定 PE 大小
6.1.1 创建卷组时固定 PE 大小的格式
6.1.2 创建卷组时设置 PE 大小的案例
6.2 创建逻辑卷的时候指定 PE 个数
6.2.1 创建逻辑卷的时候指定 PE 个数的格式
6.2.2 创建逻辑卷的时候指定 PE 个数的案例
6.2.3 查看刚刚创建的制定了 PE 大小和个数的逻辑卷

具体的内容:

内容一:LVM 的原理
1.1 LVM 的目的

将零散的空闲存储整合成虚拟磁盘,再将虚拟的磁盘整合成虚拟的分区

1.2 LVM 的结构
1.2.1 LVM 的第一层

物理卷
Physical Volume

1.2.2 LVM 的第二层

卷组
Volume Group

1.2.3 LVM 的第三层

逻辑卷
Logical Volume

内容二:LVM 管理的命令集

function physical volume volume group logical volume
Scan     pvscan          vgscan       lvscan
Create   pvcreate        vgcreate     lvcreate
Display  pvdisplay       vgdisplay    lvdisplay
Remove   pvremove        vgremove     lvremove
Extend   / 

内容三:快速部署 LVM 的思路

(1)准备至少一个空闲分区

(2)创建卷组:

# vgcreate <volume group name> <free partition>

(3)创建逻辑卷:

# lvcreate -L <logical volume size> -n <logical volume name> <volume group name>

内容四:创建 LVM 逻辑卷的案例
4.1 创建卷组的格式

# vgcreate <volume group name> <free partition>......

4.2 创建卷组的案例

# vgcreate vg /dev/vdb2
......

(补充:这里以使用硬盘 /dev/vdb2 创建名为 vg 的卷组为例)

4.3 创建逻辑卷的方案案例选择

(注意:以下方案三选一即可,且只能三选一)

4.3.1 案例一:创建指定大小的逻辑卷

# lvcreate -L 200M -n vo vg
 Logical volume "vo" created

(补充:这里以使用 vg 卷组创建名为 vo 大小为 200M 的逻辑卷为例)

4.3.2 案例二:创建大小是卷组剩余空间百分比的逻辑卷

# lvcreate -l 80%Free -n vo vg
 Logical volume "vo" created

(补充:这里以使用 vg 卷组创建名为 vo 大小为卷组 vg 剩余空间 80% 的逻辑卷为例)

4.3.3 案例三:创建大小是卷组全部空间百分比的逻辑据

# lvcreate -l 80%VG -n vo vg
 Logical volume "vo" created

(补充:这里以使用 vg 卷组创建名为 vo 大小为卷组 vg 全部空间 80% 的逻辑卷为例)

4.4 查看已创建的逻辑卷 /dev/vg/vo

# lvscan
ACTIVE '/dev/vg/vo' [200.00 MiB] inherit

(补充:这里以查看 /dev/vg/vo 逻辑卷的大小为例)

4.5 将新创建的逻辑卷格式化、挂载并使用

(步骤略)

内容五:扩展 LVM 逻辑卷大小的案例
5.1 检查现有逻辑卷大小

# lvscan | grep vo
ACIVE '/dev/vg/vo' [200.00 MiB] inherit
......

(补充:这里以查看 /dev/vg/vo 逻辑卷的大小为例)

5.2 检查逻辑卷所在卷组的剩余空间,看是否够逻辑卷扩展

# vgdisplay vg | grep Free
 Free PE/Size 4/300.00 MiB

(补充:这里以查看 vg 卷组的大小为例)

5.3 当卷组的剩余空间不足时,要先扩展卷组(如果卷组的空间足够大,则可以跳过次步骤)
5.3.1 扩展卷组的格式

# vgextend <volume group name> <free partition>......

5.3.2 扩展卷组的案例
5.3.2.1 扩展卷组

# vgextend vg /dev/vdb3
 Physical volume "/dev/vdb3" successfully created
 Volume group "vg" successfully extended

(补充:这里以将 /dev/vdb 硬盘添加到 vg 卷组为例)

5.3.2.2 查看扩展后的卷组

# vgdisplay vg | grep 'Free'
 Free PE/Size 128/512.00 MiB

(补充:这里以查看 vg 卷组的剩余大小为例)

5.3.2.3 之后就可以扩展逻辑卷了

5.4 当卷组的剩余空间充足时,可直接扩展逻辑卷
5.4.1 扩展逻辑卷的格式
5.4.1.1 第一种格式:将逻辑卷扩展到指定大小

# lvextend -L <new size of logical volume> /dev/<volume group name>/<logical volume name>

5.4.1.2 第二种格式:给逻辑卷添加指定大小的空间

# lvextend -L +<the size of the logical volume added> /dev/<volume group name>/<logical volume name>

5.4.1.3 第三种格式:将剩余空间的百分比添加给逻辑卷

# lvextend -l +<percentage of remaining size>FREE /dev/<volume group name>/<logical volume name>

5.4.1.4 补充:使用 -r 参数的格式

# lvextend -r -l +<percentage of remaining size>FREE /dev/<volume group name>/<logical volume name>

(补充:如果使用 -r 参数就不需要再执行 5.5.3 刷新文件系统容量的格式)

5.4.2 扩展逻辑卷的案例
5.4.2.1 扩展逻辑卷
5.4.2.1.1 案例一:将逻辑卷扩展到某个值

# lvextend -L 300MiB /dev/vg/vo
 Extending logical volume vo to 300.00 MiB
 Logical volume vo successfully resized

(补充:这里以将 /dev/vg/vo 逻辑卷扩展到 300M 为例)

5.4.2.1.2 案例二:给逻辑卷添加某个值

# lvextend -L +100MiB /dev/vg/vo
 Extending logical volume vo to 300.00 MiB
 Logical volume vo successfully resized

(补充:这里以给 /dev/vg/vo 逻辑卷添加 100M 为例)

5.4.2.1.3 案例三:将所有剩余空间添加给逻辑卷,并强制刷新文件系统容量

# lvextend -r -l +100%FREE /dev/vg/vo
 Extending logical volume vo to 500.00 MiB
 Logical volume vo successfully resized

(补充:这里以将卷组所有剩余空间都添加给 /dev/vg/vo 逻辑卷为例)

5.4.2.2 查看扩展后的逻辑卷

# lvscan
......
ACTIVE '/dev/vg/vo' [300.00 MiB] inherit

5.5 更新文件系统大小
5.5.1 更新文件系统大小的目的

对于格式化过的逻辑卷,扩展后应该通知 Linux 内核,否则使用 df 等工具时看到的仍是扩展前的大小

5.5.2 查看文件系统的格式

# df -hT

5.5.3 刷新文件系统容量的格式

(1)EXT3/4 文件系统刷新的方法

# resize2fs /dev/<volume group name>/<logical volume name>

或者:

# resize2fs <logical volume mount point>

(2)XFS 文件系统刷新的方法

# xfs_growfs <logical volume mount point>

(3)btrfs 文件系统刷新的方法

# btrfs filesystem resize max <logical volume mount point>

5.5.4 刷新文件系统的案例

# resize2fs /dev/vg/vo
......

(补充:这里以刷新 /dev/vg/vo 逻辑卷为例)

内容六:创建 LVM 卷组时固定 PE 的大小的案例
6.1 创建卷组的时候固定 PE 大小
6.1.1 创建卷组时固定 PE 大小的格式

# vgcreate -s <PE size> <volume group name> <free partition>

6.1.2 创建卷组时设置 PE 大小的案例

# vgcreate -s 20MiB pevg /dev/vdb6 Physical volume "/dev/vdb4" 
successfully created Volume group "pevg" successfully created 

(补充:这里以使用 /dev/vdb6 硬盘创建名为 pevg PE 大小为 20M 的卷组为例)

6.2 创建逻辑卷的时候指定 PE 个数
6.2.1 创建逻辑卷的时候指定 PE 个数的格式

# lvcreate -l <number of PE> -n <logical volume name> <volume group name>

6.2.2 创建逻辑卷的时候指定 PE 个数的案例

# lvcreate -l 50 -n pelo pevg 
 Logical volume "pelo" created

(补充:这里以使用 pevg 卷组创建包含 50 个 PE 个数的逻辑卷为例)

6.2.3 查看刚刚创建的制定了 PE 大小和个数的逻辑卷

# lvscan
 ACTIVE '/dev/pevg/pelo' [1000.00 MiB] inherit

(补充:会发现它的大小是精确的)

[命令] Linux 命令 chattr (文件锁)

内容一: chattr 格式
1.1 锁定文件的格式(文件将无法被修改、追加和删除)

# chattr +i <file>

1.2 解锁文件的格式(文件将可以被修改、追加和删除)

# chattr -i <file>

1.3 锁定文件后仅可追加内容的格式(文件将无法被修改和删除,但是可以被追加新内容)

# chattr +a <文file> 

1.4 解锁文件只可被追加内容的格式(文件将取消无法被修改和删除,但红四可以被追加新内容的状态)

# chattr -a <file> 

1.5 查看文件特殊属性

# lsattr <file> 

内容二: chattr 的使用案例
2.1 案例一:锁定文件并查看文件的锁定状态
2.1.1 锁定文件

# chattr +i /etc/resolv.conf

(补充:这里以锁定 /etc/resolv.conf 文件为例)

2.1.2 查看文件的锁定状态

# lsattr /etc/resolv.conf
----i----------- /etc/resolv.conf

(补充:这里以查看 /etc/resolv.conf 文件为例)

2.1.3 解锁文件

# chattr -i /etc/resolv.conf

(补充:这里以解锁 /etc/resolv.conf 文件为例)

2.2 案例二:锁定文件后仅可追加内容并查看文件的锁定状态
2.2.1 锁定文件后仅可追加内容

# chattr +a /etc/hosts

(补充:这里以锁定 /etc/hosts 文件为例)

2.2.2 查看文件的锁定状态

# lsattr /etc/hosts
----a---------- /etc/hosts

(补充:这里以查看 /etc/hosts 文件为例)

2.2.3 解锁仅可追加内容的文件

# chattr -a /etc/hosts

(补充:这里以解锁 /etc/hosts 文件为例)

[内容] Linux 硬件信息的查看 (CPU、内存、硬盘和其他硬件信息)

内容目录:

内容一:查看 CPU 信息
1.1 查看 CPU 个数(也就是处理的 socket 数)
1.2 查看 CPU 核心数
1.3 查看 CPU 的详细信息

内容二:查看内存大小
2.1 查看内存大小
2.2 查看内存详细信息

内容三:查看硬盘信息

内容四:查看其他硬件的方法
4.1 查看其他所有硬件的方法
4.2 查看某一个硬件的方法

具体的内容:

内容一:查看 CPU 信息
1.1 查看 CPU 个数(也就是处理的 socket 数)

# cat /proc/cpuinfo | grep "physical id" | sort | uniq | wc -l

1.2 查看 CPU 核心数

# cat /proc/cpuinfo | egrep "core id|physical id" | tr -d "\n" | sed s/physical/\\nphysical/g | grep -v ^$ | sort | uniq | wc -l

1.3 查看 CPU 的详细信息

# lscpu

内容二:查看内存大小
2.1 查看内存大小

# free -m

2.2 查看内存详细信息

# cat /proc/meminfo 

内容三:查看硬盘信息

# lsblk

内容四:查看其他硬件的信息
4.1 查看其他所有硬件的信息

# dmesg

4.2 查看某一个硬件的信息

# dmesg | grep -i mouse

(补充:这里以查看鼠标信息的方法为例)

[工具] Shell 检测性能指标 (例如:剩余硬盘空间、内存空间等)

介绍:

#名称: 检测性能指标(例如:剩余硬盘空间、内存空间等)
#作用: 检测性能指标(例如:剩余硬盘空间、内存空间等)

#使用方法:
#1. 给此脚本添加执行权限
#2. 执行此脚本

脚本:

#!/bin/bash

ip=`ip a s | awk '/noprefixroute ens33/{print $2}'`
host=`hostname`
disk=`df -h | awk '/\/$/{print $5}'`
mem=`free -m | awk '/Mem/{print $4}'`
cpu=`top -bn 1 | awk -F',' '/^%Cpu/{print $4 }' | awk '{print $1}'`
soft=`rpm -qa | wc -l`
port=`ss -ntulap | wc -l`

echo "$ip $host disk $disk"
echo "$ip $host mem $mem"
echo "$ip $host cpu $cpu"
echo "$ip $host soft $soft"
echo "$ip $host port $port"
echo