Día 06-Gestión de software

Día 06-Gestión de software

1. Descripción básica de PRM

1. ¿Qué son las rpm?

RPM es la abreviatura de RedHat Package Manager, desarrollado por Red Hat para la instalación, actualización, desinstalación y consulta de paquetes de software.

2. ¿Cuál es la parte del nombre del paquete rpm?

El paquete RPM lleva el nombre: el software se divide en varias partesbash-4.2.46-28.el7.x86_64.rpm

[Error en la transferencia de la imagen del enlace externo. El sitio de origen puede tener un mecanismo de enlace anti-sanguijuelas. Se recomienda guardar la imagen y subirla directamente (img-S1jp41qn-1606388881508) (https://i.loli.net/2020/ 11/26 / qGja91yzESudv3H.jpg)]

3. Cómo obtener el paquete rpm

Cuando comenzamos a aprender el paquete rpm, se recomienda utilizar primero la imagen local de CentOS7, pero en el entorno de producción real, el paquete rpm se obtiene a través de Internet. (Aprenda primero, ¿sabe?)
Primero cargamos la imagen a través de una máquina virtual y luego la ejecutamos en Linux mount /dev/cdrom /mnt. En este momento, /mnt/Packagesverá muchos archivos de paquetes rpm en el directorio. Entonces puede comenzar el viaje de la gestión de paquetes rpm.

4. Extensión: además del software de instalación de rpm, ¿hay alguna forma de instalar software en Linux?

clasificación instalación versión
paquete rpm Precompilado y empaquetado, fácil de instalar La versión del software es baja
Paquete fuente Recopilación y empaquetado manual, instalación engorrosa Cualquier versión de software
Paquete binario (paquete verde) Descomprima y use, fácil de instalar No se puede modificar el código fuente

Dos, uso del paquete RPM

1. Cómo instalar el paquete rpm

Parámetros comunes

  • -i Instalar rpm
  • -v Mostrar detalles de instalación
  • -h Muestra el progreso de las rpm de la instalación
  • -force Es una instalación obligatoria, por ejemplo, si ha instalado la versión 1 de este rpm, si desea instalar la versión 2 de este rpm, debe usar -force para forzar la instalación.
  • -nodepsIgnore las dependencias , es decir, no verifique las dependencias durante la instalación. Por ejemplo, su rpm requiere A, pero no instala A, por lo que su paquete no se puede instalar. Puede instalarlo con -nodeps.
# 安装软件包, 需要指定软件包绝对路径
rpm -ivh /mnt/Packages/tree-1.6.0-10.el7.x86_64.rpm
rpm -ivh /mnt/Packages/vsftpd-3.0.2-22.el7.x86_64.rpm
-------------------------由于文件下没有安装包,所以安装不了

#在软件包所在目录下可以不指定绝对路径
cd /mnt/Packages/
rpm -ivh zsh-5.0.2-28.el7.x86_64.rpm
--------------------------------------------

#如果软件包存在, 强制再次安装
rpm -ivh --force /mnt/Packages/tree-1.5.3-3.el6.x86_64.rpm
--------------------------------------------

#安装samba服务需要依赖其他组件, 使用--nodeps可重新强制安装
--------------------------------------------

2. Cómo consultar el paquete rpm instalado

Opciones descripción
rpm -q consulta Preguntar si el paquete especificado está instalado (énfasis)
rpm -qa consultar todo Ver la lista de todos los paquetes RPM instalados en el sistema
rpm -qi información de consulta Ver información detallada sobre el software especificado
rpm -ql lista de consultas consulta la lista de directorios y archivos instalados por el paquete de software especificado (énfasis)
rpm -qc query config consulta el archivo de configuración del paquete de software especificado (solo el archivo de configuración, en etc)
rpm -qf consulta desde Consulta a qué software RPM pertenece el archivo o directorio
rpm -qip información de consulta consulta de paquete información detallada sobre paquetes rpm desinstalados
rpm -qlp Consultar qué archivos se generarán mediante paquetes desinstalados
#查询tree这个rpm包是否安装
rpm -q tree
--------------------------------------------
tree-1.6.0-10.el7.x86_64

#模糊查找系统已安装的rpm包
rpm -qa|grep tree
--------------------------------------------
tree-1.6.0-10.el7.x86_64

#查询tree软件包的相关信息
rpm -qi tree
--------------------------------------------
Name        : tree
Version     : 1.6.0
Release     : 10.el7
...
Description :
The tree utility recursively displays the contents of directories in a
tree-like format.  Tree is basically a UNIX port of the DOS tree
utility.

#查询rpm包所安装的文件
rpm -ql tree
--------------------------------------------
/usr/bin/tree
/usr/share/doc/tree-1.6.0
/usr/share/doc/tree-1.6.0/LICENSE
/usr/share/doc/tree-1.6.0/README
/usr/share/man/man1/tree.1.gz

#查询rpm包相关的配置文件
rpm -qc -tree
--------------------------------------------
啥都没

#查询配置文件或命令来自于哪个rpm包(只能查已经安装过的
rpm -qf /usr/bin/tree  # 文件路径从 ql 中获得
--------------------------------------------
tree-1.6.0-10.el7.x86_64

rpm -qf /usr/share/doc/tree-1.6.0  # 文件路径从 ql 中获得
--------------------------------------------
tree-1.6.0-10.el7.x86_64

# 想看未安装的
yum provides vim

#查询未安装的软件包会产生哪些文件
[root@lqz ~]# rpm -qlp /mnt/Packages/samba-3.6.23-41.el6.x86_64.rpm

#查询未安装的软件包会产生哪些文件
[root@lqz ~]# rpm -qip /mnt/Packages/samba-3.6.23-41.el6.x86_64.rpm

3. Actualización del paquete RPM

Opciones descripción
rpm -U Si la versión anterior no existe, instale una nueva, si hay una nueva versión, actualice
cd /mnt/Packages/  # 切换到自创的Package目录
wget  https://mirrors.aliyun.com/zabbix/zabbix/3.0/rhel/7/x86_64/zabbix-agent-3.0.9-1.el7.x86_64.rpm
wget  https://mirrors.aliyun.com/zabbix/zabbix/4.2/rhel/7/x86_64/zabbix-agent-4.2.0-1.el7.x86_64.rpm  # 下载两个不同版本的安装包

# 先安装低版本
rpm -ivh zabbix-agent-3.0.9-1.el7.x86_64.rpm
--------------------------------------------
warning: zabbix-agent-3.0.9-1.el7.x86_64.rpm: Header V4 DSA/SHA1 Signature, key ID 79ea5ed4: NOKEY
Preparing...                          ################################# [100%]
Updating / installing...
   1:zabbix-agent-3.0.9-1.el7         ################################# [100%]

# 尝试安装高版本(会出现错误)
rpm -ivh zabbix-agent-4.2.0-1.el7.x86_64.rpm
--------------------------------------------
warning: zabbix-agent-4.2.0-1.el7.x86_64.rpm: Header V4 RSA/SHA512 Signature, key ID a14fe591: NOKEY
Preparing...                          ################################# [100%]
	file /etc/zabbix/zabbix_agentd.conf from install of zabbix-agent-4.2.0-1.el7.x86_64 conflicts with file from package zabbix-agent-3.0.9-1.el7.x86_64
	file /usr/sbin/zabbix_agentd from install of zabbix-agent-4.2.0-1.el7.x86_64 conflicts with file from package zabbix-agent-3.0.9-1.el7.x86_64   # conflicts 冲突
	file /usr/share/man/man8/zabbix_agentd.8.gz from install of zabbix-agent-4.2.0-1.el7.x86_64 conflicts with file from package zabbix-agent-3.0.9-1.el7.x86_64
	
rpm -q zabbix-agent  # 查看信息是没有更新的
--------------------------------------------
zabbix-agent-3.0.9-1.el7.x86_64

# 使用升级的方式,完美解决替换
rpm -Uvh zabbix-agent-4.2.0-1.el7.x86_64.rpm
--------------------------------------------
warning: zabbix-agent-4.2.0-1.el7.x86_64.rpm: Header V4 RSA/SHA512 Signature, key ID a14fe591: NOKEY
Preparing...                          ################################# [100%]
Updating / installing...
   1:zabbix-agent-4.2.0-1.el7         ################################# [ 50%]
Cleaning up / removing...
   2:zabbix-agent-3.0.9-1.el7         ################################# [100%]
   
rpm -q zabbix-agent
--------------------------------------------
zabbix-agent-4.2.0-1.el7.x86_64

4. Desinstalación del paquete RPM

Al desinstalar un paquete, primero debe desinstalar el paquete dependiente. Si el sistema requiere el paquete dependiente, no podrá desinstalarlo, de lo contrario, el sistema se bloqueará.

#先查询, 然后卸载 
rpm -qa|grep zabbix-agent
--------------------------------------------
zabbix-agent-4.2.0-1.el7.x86_64

# 卸载不存在的
rpm -e zsh
--------------------------------------------
error: package zsh is not installed

# 卸载
rpm -e zabbix-agent
--------------------------------------------
没有提示符

5. Verificación del paquete RPM

Las bases de datos relacionadas con el software se almacenan en el /var/lib/rpmdirectorio

ll /var/lib/rpm
--------------------------------------------
total 163412
-rw-r--r--. 1 root root   3002368 Nov 26 16:09 Basenames
-rw-r--r--. 1 root root     16384 Nov 26 11:47 Conflictname
-rw-r--r--  1 root root    270336 Nov 26 16:09 __db.001
-rw-r--r--  1 root root     81920 Nov 26 16:09 __db.002
-rw-r--r--  1 root root   1318912 Nov 26 16:09 __db.003
-rw-r--r--. 1 root root   2883584 Nov 26 16:09 Dirnames
-rw-r--r--. 1 root root     16384 Nov 26 16:09 Group
-rw-r--r--. 1 root root     20480 Nov 26 16:09 Installtid
-rw-r--r--. 1 root root     28672 Nov 26 16:09 Name
-rw-r--r--. 1 root root     16384 Nov 26 16:09 Obsoletename
-rw-r--r--. 1 root root 157175808 Nov 26 16:09 Packages
-rw-r--r--. 1 root root   2293760 Nov 26 16:09 Providename
-rw-r--r--. 1 root root    192512 Nov 26 16:09 Requirename
-rw-r--r--. 1 root root     73728 Nov 26 16:09 Sha1header
-rw-r--r--. 1 root root     36864 Nov 26 16:09 Sigmd5
-rw-r--r--. 1 root root      8192 Nov 26 10:45 Triggername
parámetro descripción
S Si se ha cambiado el tamaño del archivo
METRO Si se ha modificado el tipo de archivo o el atributo de archivo
5 MD5 este tipo de contenido de cifrado de huellas dactilares es diferente
L La ruta ha sido cambiada
U El propietario del archivo ha sido modificado.
GRAMO El grupo del archivo ha sido modificado.
T La hora de creación del archivo ha sido modificada.
rpm -V vsftpd  # 如果RPM包安装后的文件没有被修改,那么这个命令敲入执行后什么信息都不会出现

如果是被修改了,会显示修改了哪些:
S.5....T.  c /etc/pam.d/vsftpd  # 容量,MD5,创建时间改变 c 表示修改的文件是配置文件

.......T.  c /etc/vsftpd/ftpusers
S.5....T.  c /etc/vsftpd/vsftpd.conf
.M.......    /var/ftp/pub

[Error en la transferencia de la imagen del enlace externo. El sitio de origen puede tener un mecanismo de enlace anti-sanguijuela. Se recomienda guardar la imagen y subirla directamente (img-3W7LDFJ5-1606388881512) (C: \ Users \ S \ Desktop \ 2971086-886732c80de6b261 .webp)]

6. Resumen del paquete RPM

¿Cómo comprobar qué archivos están instalados en el paquete util-linux?
¿Cómo verificar qué paquete RPM instaló el comando mkdir?
Al instalar el paquete .rpm, ¿cuál es la diferencia entre -i, -U y opciones?

3. Introducción básica a YUM

1. ¿Qué es YUM?

Yum es un administrador de paquetes en RedHat y CentOS. Capaz de descargar e instalar el paquete .rpm a través de Internet, yManejo automático de dependencias, No es necesario descargar e instalar una y otra vez. (PD: YUM es producciónóptimopráctica)

2. ¿Cuál es la fuente de YUM?

1 Para utilizar con éxito la herramienta YUM para instalar y actualizar software o sistemas, necesita un repositorio (almacén de software) que contenga varios paquetes de software rpm Este almacén de software se utiliza para denominar yum source. (Puede ser fuente local, fuente de red)

3. Ejemplo de configuración de fuente YUM

3.1. Fuente de Huawei

1. Haga una copia de seguridad de los archivos de configuración:

cp -a /etc/yum.repos.d/CentOS-Base.repo /etc/yum.repos.d/CentOS-Base.repo.bak

2. Dos esquemas, elija usted mismo.

Opcion uno:

Descargue el nuevo archivo CentOS-Base.repo en el directorio ** / etc / yum.repos.d / **, seleccione CentOS版本7:

Ejecute los siguientes comandos:

wget -O /etc/yum.repos.d/CentOS-Base.repo https://repo.huaweicloud.com/repository/conf/CentOS-7-reg.repo

Opción II:

Modifique el archivo CentOS-Base.repo , elimine el comentario de la línea al principio de baseurl y agregue el comentario al principio de mirrorlist . En el archivo http://mirror.centos.org替换成https://repo.huaweicloud.com, puede consultar el siguiente comando:

sed -i "s/#baseurl/baseurl/g" /etc/yum.repos.d/CentOS-Base.repo
sed -i "s/mirrorlist=http/#mirrorlist=http/g" /etc/yum.repos.d/CentOS-Base.repo
sed -i "s@http://mirror.centos.org@https://repo.huaweicloud.com@g" /etc/yum.repos.d/CentOS-Base.repo

3. Ejecute yum clean all para borrar el caché de yum original.

4. Ejecute yum makecache (actualice la caché) o yum repolist all (marque todos los archivos que pueden ser utilizados por la configuración, la caché se actualizará automáticamente).

3.2 Fuente oficial de Nginx, por ejemplo, debe usar la fuente oficial de yum para instalar cuando aprenda Nginx

vim /etc/yum.repos.d/nginx.repo  # 创建并编辑文件  输入以下内容
--------------------------------------------
[nginx]
name=nginx repo 
baseurl=http://nginx.org/packages/centos/7/$basearch/ 
gpgcheck=0
enabled=1

PD: El método de súper búsqueda de origen es básicamente el mismo, zabbix, Docker, Nginx, saltstack, openstack

Caso práctico 4.YUM

1. Use yum para consultar el paquete de software

# 列出所有可安裝的软件清单命令:yum list
yum list|grep docker
--------------------------------------------
....
cockpit-docker.x86_64                     195.12-1.el7.centos            extras 
docker.x86_64                             2:1.13.1-203.git0be3e21.el7.centos
docker-client.x86_64                      2:1.13.1-203.git0be3e21.el7.centos

yum info ftp  # 具体信息
--------------------------------------------
....

2. Use yum para instalar paquetes de software

[[email protected] ~]# yum install tree
[[email protected] ~]# yum install tree -y    #非交互

#安装本地的rpm包, 如果有依赖关系, 会自动从软件仓库中下载所需依赖
[[email protected] ~]# yum localinstall /mnt/Packages/bind-9.9.4-50.el7.x86_64.rpm

#直接安装网络上的rpm包
[[email protected] ~]# yum install http://repo.zabbix.com/zabbix/3.4/rhel/7/x86_64/zabbix-release-3.4-2.el7.noarch.rpm

3. Use yum para reinstalar el paquete

#1.如果不小心删除vsftpd配置文件
[[email protected] ~]# rm -f /etc/vsftpd/vsftpd.conf

#2.可以对软件进行重新安装
[[email protected] ~]# yum reinstall vsftpd

#3.检查软件的配置文件
[[email protected] ~]# rpm -qc vsftpd
/etc/logrotate.d/vsftpd
/etc/pam.d/vsftpd
/etc/vsftpd/ftpusers
/etc/vsftpd/user_list
/etc/vsftpd/vsftpd.conf

4 usa yum para actualizar el paquete

#对比Linux已安装的软件和yum仓库中的软件, 有哪些需要升级
yum check-update
--------------------------------------------
Loaded plugins: fastestmirror
Loading mirror speeds from cached hostfile
 * epel: hkg.mirror.rackspace.com

nginx.x86_64                             1:1.18.0-2.el7.ngx                              nginx

# 升级
yum update nginx -y 无交互

#如下的执行很危险,这代表更新整个系统所有的软件,包括内核
yum update -y

5. Usa yum para quitar el paquete

yum erase tree
--------------------------------------------
.....
Removed:
  tree.x86_64 0:1.6.0-10.el7                                                                  

Complete!

# 2
yum remove tree -y

6. Instrucciones relacionadas con el almacén de yum (comprensión ampliada)

#列出yum源可用的软件仓库
yum repolist
--------------------------------------------
Loaded plugins: fastestmirror
Loading mirror speeds from cached hostfile
 * epel: hkg.mirror.rackspace.com
repo id                      repo name                                                  status
base/7/x86_64                CentOS-7 - Base - repo.huaweicloud.com                     10,072
epel/x86_64                  Extra Packages for Enterprise Linux 7 - x86_64             13,473
extras/7/x86_64              CentOS-7 - Extras - repo.huaweicloud.com                      448
nginx/x86_64                 nginx repo                                                    206
updates/7/x86_64             CentOS-7 - Updates - repo.huaweicloud.com                     773
repolist: 24,972


#列出全部yum源可用和禁用的仓库
yum repolist all

#查找某个命令或文件属于那个软件包(生产常用)
yum provides /etc/my.cnf
yum provides cd

7. Instrucciones relacionadas con yum cache (comprensión ampliada)

#1.缓存rpm包方式一、修改yum全局配置文件
[[email protected] ~]# vim /etc/yum.conf
[main]
cachedir=/var/cache/yum/$basearch/$releasever
keepcache=1     #启动缓存

#2.缓存rpm包方式二,只下载不安装
[[email protected] ~]# yum install -y yum-plugin-downloadonly #插件
[[email protected] ~]# yum install httpd -y --downloadonly --downloaddir=/tmp

#3.清除所有yum缓存的软件包以及元数据
[[email protected] ~]# yum clean all

#4.只清除缓存的软件包
[[email protected] ~]# yum clean packages

8. Instrucciones relacionadas con el paquete (comprensión ampliada)

[[email protected] ~]# yum groups list
#安装一整个组的软件
[root@lqz ~]# yum groups install Development tools 
Compatibility libraries 
Base Debugging Tools

#yum删除包组
[[email protected] ~]# yum groups remove  -y Base

9. Instrucción de registro de historia (comprensión ampliada)

#1.查看历史执行yum命令
[[email protected] ~]# yum history

#2.查询历史执行yum命令ID详细信息
[[email protected] ~]# yum history info N

#3.撤销历史执行过的yum命令
[[email protected] ~]# yum history undo N

PD: YUM también tiene archivos de configuración y verificación de firmas, si necesitamos ampliar nuestra comprensión, haga clic en el portal

5. Construye un almacén local

1. A veces su sistema Linux no puede estar conectado a Internet. Por supuesto, no puede usar fácilmente la fuente yum en red. En este momento, necesita usar el CD del sistema Linux para crear una fuente yum. Los pasos específicos son los siguientes:

#1.挂载镜像
[root@lqz ~]# mount /dev/cdrom /mnt   

#2.备份原有仓库
[root@lqz ~]# gzip /etc/yum.repos.d/

#3.使用yum-config-manager命令添加本地仓库
[root@lqz ~]# yum-config-manager --add-repo="file:///mnt"

#4.或者使用手动添加repo文件
[root@lqz ~]# vim /etc/yum.repos.d/cdrom.repo  
[cdrom]      
name=This is local cdrom
baseurl=file:///mnt
enabled=1
gpgcheck=0

[]          #仓库名称
name        3仓库描述信息
baseurl     #YUM源url地址 ,可以是file:// ftp:// http://
enabled     #是否使用该YUM源(0代表禁用, 1代表激活)
gpgcheck    #是否验证软件签名(0代表禁用, 1代表激活)

#5.生成缓存
[root@lqz ~]# yum makecache

2. Muchas veces, no solo una máquina no puede acceder a Internet, sino que muchas máquinas no pueden acceder a Internet, sino que es necesario descargar software de Internet. En este momento, ¿todas las máquinas están colgadas en el CD? Por supuesto, pero si aparece el software ¿Qué pasa con la actualización?

[Error en la transferencia de la imagen del enlace externo. El sitio de origen puede tener un mecanismo de enlace anti-sanguijuela. Se recomienda guardar la imagen y subirla directamente (img-7QbcyQH7-1606388881515) (https://i.loli.net/2020/ 11/26 / YbWX3ip1vocqyQr.jpg)]

El CD local proporciona paquetes de software básicos: Base
yum cache proporciona paquetes de software comunes: nginx, zabbix, docker

sistema IP Roles
centos7 10.0.0.99 Servidor de almacén de Yum
centos7 10.0.0.98 cliente de almacén de yum

2. El servidor se prepara para la construcción del almacén de yum.

#1.关闭防火墙、与selinux
[root@yum_server ~]# systemctl stop firewalld
[root@yum_server ~]# setenforce 0

#2.安装ftp服务,启动并加入开机启动
[root@yum_server ~]# yum -y install vsftpd 
[root@yum_server ~]# systemctl start vsftpd 
[root@yum_server ~]# systemctl enable vsftpd

#3.开启yum缓存功能
[root@yum_server ~]# vim /etc/yum.conf
[main] cachedir=/var/cache/yum/$basearch/$releasever 
keepcache=1
[root@yum_server ~]# yum clean all

#4.提供基础base软件包
[root@yum_server ~]# mkdir /var/ftp/centos7
[root@yum_server ~]# mount /dev/cdrom /mnt
[root@yum_server ~]# cp -rp  /mnt/Packages/.rpm /var/ftp/centos7/

#5.提供第三方源
[root@yum_server ~]# mkdir /var/ftp/ops
[root@yum_server ~]# yum -y install nginx docker

#6.复制已缓存的 Nginx docker 及依赖包 到自定义 YUM 仓库目录中
[root@yum_server_69_112 ~]# find /var/cache/yum/x86_64/7/ 
-iname ".rpm" -exec cp -rf {} /var/ftp/ops ;

#7.安装createrepo并创建 reopdata仓库
[root@yum_server_ ~]# yum -y install createrepo
[root@yum_server_ ~]# createrepo /var/ftp/ops

#PS: 如果此仓库每次新增软件则需要重新生成一次

3. El cliente configura la fuente yum para que apunte al servidor.

#1.客户端配置并使用 base 基础源
[root@yum_client ~]# gzip /etc/yum.repos.d/
[root@yum_client ~]# vim /etc/yum.repos.d/centos7.repo 
[centos7]
name=centos7_base
baseurl=ftp://10.0.0.99/centos7
gpgcheck=0

#2.客户端配置并使用 ops 源
[root@yum_client ~]# vim /etc/yum.repos.d/ops.repo 
[ops]
name=local ftpserver
baseurl=ftp://10.0.0.99/ops
gpgcheck=0

6. Prácticas de gestión del paquete fuente

1. ¿Qué es el paquete de código fuente?

El paquete de código fuente se refiere al código fuente de un programa que se ha desarrollado y escrito, pero no se ha compilado en una herramienta que se pueda utilizar normalmente.

2. Por qué aprender paquetes de código fuente

1. Algunos sitios web oficiales de software solo proporcionan paquetes de código fuente, que deben compilarse e instalarse por sí mismos.
2. Cuando algún software tiene algunas características en la nueva versión antes de que pueda convertirse en un paquete rpm, puede compilar el software usted mismo y usar sus nuevas características.

3. Ventajas y desventajas de los paquetes de código fuente

1. Puede modificar el código fuente
usted mismo. 2. Puede personalizar las funciones relacionadas que necesita.
3. La nueva versión del software tiene prioridad para actualizar el código fuente
. 4. Las desventajas son: 1) En comparación con yum, instalar software es mucho más complicado. 2) La implementación de la estandarización es difícil y la automatización no se puede implementar.

4. Cómo obtener el paquete de código fuente

Los paquetes de software comunes se pueden obtener del paquete fuente del sitio web oficial, como apache, nginx, mysql, etc.

5 Los pasos para compilar el paquete de código fuente en un archivo ejecutable binario son los siguientes, denominados trilogía de instalación

[Error en la transferencia de la imagen del enlace externo. El sitio de origen puede tener un mecanismo de enlace anti-sanguijuela. Se recomienda guardar la imagen y subirla directamente (img-M2B3yb4o-1606388881517) (https://i.loli.net/2020/ 11/26 / c1g6lkwAzXdySno.jpg)]
PD: Este método no es 100% universal para todos los paquetes de código fuente. Se recomienda que después de descomprimir el paquete de código fuente, vaya al directorio para encontrar el archivo de ayuda README correspondiente.

6. Ejemplo de compilación de código fuente

Compilemos Nginx para comprender en profundidad el proceso de compilación del paquete fuente.

#1.基础环境准备
[root@node1 ~]# yum install -y gcc make wget 

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

#3.解压源码包, 并进入相应目录
[root@node1 ~]# tar xf nginx-1.15.12.tar.gz
[root@node1 ~]# cd nginx-1.15.12

#4.配置相关的选项,并生成Makefile
[root@node1 nginx-1.15.12]# ./configure --help
[root@node1 nginx-1.15.12]# ./configure --prefix=/usr/local/nginx
[root@node1 nginx-1.15.12]# echo $? # 检查上一个命令是否执行成功

#5.将Makefile文件编译可执行二进制程序,此时,/usr/local/nginx可执行文件还不在,需要执行make install 才能copy过去
[root@node1 nginx-1.15.12]# make

#6.将二进制文件拷贝至对应的目录中
[root@node1 nginx-1.15.12]# make install

#7 建立软连接(以后方便升级)
[root@node1 nginx-1.15.12]# ln -s nginx-1.18.0 nginx

#8 目录介绍
conf:配置文件
html:网站文件存放
logs:日志
sbin:可执行文件

# 9 命令
nginx  # 启动
nginx -s reload # 重新加载
nginx -s stop  # 重启
nginx -s stop # 停止

Procesamiento de mensajes de error de compilación de código fuente

checking for C compiler ... not found ./configure: error: C compiler cc is not found 
# yum -y install gcc gcc-c++ make


./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.
# yum install -y pcre-devel


./configure: error: the HTTP gzip module requires the zlib library.
You can either disable the module by using --without-
http_gzip_module option, or install the zlib library into the
system, or build the zlib library statically from the source with
nginx by using --with-zlib=<path> option. 
# yum -y install zlib-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.
# yum -y install openssl-devel

Supongo que te gusta

Origin blog.csdn.net/A1L__/article/details/110200971
Recomendado
Clasificación