王杰,大黄,红焖羊肉-有爱俱乐部,让爱心充满这个世界

admin 3周前 ( 10-28 09:24 ) 0条评论
摘要: 一.RPM基本概述1.什么是rpm?RPM全称 RPM Package Manager 缩写,由红帽开发用于软件包的安装升级卸载与查询2.rpm包名组成部分?RPM包命名以-将软件...

一.RPM根本概述

1.什么是rpm?

RPM全称 RPM Package Manager 缩写,由红帽开发用于软件包的装置晋级卸载与查询

2.rpm包名组成部分?

RPM包命名以-将软件分成了若干部分bash-4.2.46-28.el7.x86_64.rpm

3.怎么获取rpm包?

在咱们刚开端学习rpm包,主张先运用本地CentOS7的镜像,但实践出产环境中都是经过联网的办法获取rpm包。(先学会,你懂的?)

咱们先经过虚拟机加载镜像,然后在linux中履行 mount /dev/cdrom /mnt,此刻你会在/mnt/Packages目录下看到许多rpm的包文件。那么就能够开端rpm包办理之旅。

4败气症.扩展: Linux中除了rpm装置软件,是否还有装置软件办法?

分类

装置

版别

rpm包

预先编译打包,装置简略

软件版别偏低

源码包

手动编译打包,装置繁琐

软件版别随意

二进制包

解压即可运用,装置简略

不能修正源码

二.RPM运用示例

1.rpm包怎么装置?

以下列出了rpm指令进行装置软件的常用参数

选项

描绘

-i

装置rpm

-v

显现装置详细信息

-h

显现装置rpm进展

--force

强制从头装置

--nodeps

疏忽依靠联系

#装置软件包, 需求指定软件包绝对途径
[root@xuliangwei ~]# rpm -ivh /mnt/Packages/tree-1.6.0-10.el7.x86_64.rpm
[root@xuliangwei ~]# rpm -ivh /mnt/Packages/vsftpd-3.0.2-22.el7.x86_64.rpm
#在软件包地点目录下能够不指定绝对途径
[root@xuliangwei ~]# cd /mnt/Packages/
[root@xuliangwei Packages]# rpm -ivh zsh-5.0.2-28.el7.x86_64.rpm
#假如软件包存在, 强制再次装置
[root@xuliangwei ~]# rpm -ivh --force /mnt/Packages/tree-1.5.3-3.el6.x86_64.rpm
#装置samba服务需求依靠其他组件, 运用--nodeps可从头强制装置
[root@xuliangwei ~]# rpm -ivh --nodeps /mnt/Packages/tree-1.6.0-10.el7.x86_64.rpm

2.怎么查询已装置好的rpm包?

选项

描绘

rpm -q

检查指定软件包是否装置

rpm -qa

检查体系中已装置的一切RPM软件包列表

rpm -qi

检查指定软件的详细信息

rpm -ql

查询指定软件包所装置的目录、文件列表

rpm -qc

查询指定软件包的装备文件

rpm -qf

查询文件或目录归于哪个RPM软件

rpm -qip

查询未装置的rpm包详细信息

rpm -qlp

查询未装置的软件包会发生哪些文件

#查询vsftpd这个rpm包是否装置
[root@xuliangwei ~]# 我的逼rpm -q vsftpd
#含糊查找体系已装置的rpm包
[root@xuliangwei ~]# rpm -qa |grep ftp
#查询vsftpd软件包的相关信息
[root@xuliangwei ~]# rpm -qi vsftpd
#查询rpm包所装置的文件
[root@xuliangwei ~]# rpm -ql vsftpd
#查询rpm包相关的装备文件
[root@xuliangwei ~]# rpm -qc vsftpd
#查询装备文件或指令来自于哪个rpm包
[root@xuliangwei ~]# rpm -qf /etc/vsftpd/vsftpd.conf
[root@xuliangwei ~]# rpm -qf /usr/sbin/vsftpd
#查询未装置的软件包会发生哪些文件
[六合天地芯root@xuliangwei ~]# rpm -qlp /mnt/Packages/samba-3.6.23-41.el6.x86_64.rpm
#查询未装置的软件包会发生哪些文件
[root@xuliangwei ~]# rpm -qip /mnt/Packages/samba-3.6.23-41.el6.x86_64.rpm

3.RPM包晋级

选项

描绘

rpm -U

假如老版别不存在则全新装置,假如存在有新版即晋级

# 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
#1.先装置低版别
[root@www.xuliangwei.com ~]# rpm -ivh zabbix-agent-3.0.9-1.el7.x蔚为壮观造句86_64.rpm
#2.测验装置高版别(会呈现过错)
[root@www.xuliangwei.com ~]# rpm -ivh zabbix-agent-4.2.0-1.el7.x86冰原狼白灵_64.rpm
#3.运用晋级的办法,完美处理替换
[root@www.xuliangwei.com ~]# rpm -Uvh zabbix-agent-4.2.0-1.el7.x86_64.rpm

4.RPM包卸载

卸载包时需求先把依靠的包卸载掉,假如依靠的包是体系一切必要的,那就不能卸载这个包,否则会形成体系溃散。

#先查询, 然后卸载 
[象人族root@www.xul德寿宝文明iangwei.com ~]# rpm -qa |grep sh
[root@www.xuliangwei.com ~]# rpm -e zsh

5.RPM包校验(扩展了解)

软件相关的数据库存放于/var/lib/rpm目录

参数

描绘

S

文件的容量巨细是否被改动

M

文件的类型或许文件的特点是否被修正

5

MD5 这一种指纹加密的内容现已不同

L

途径现已被改动

U

文件的所属主已被修正

G

文件的所属组已被修正

T

文件的创立时刻已被改动

[root@www.xuliangwei.com ~]# rpm -V vsftpd
S.5....T. c /etc/pam.d/vsftpd
.......T. c /etc/vsftpd/ftpusers
S.5....T. c /etc/vsftpd/vsftpd.conf
.M....... /var/ftp/pub

6.RPM包小结

怎么查询 util-linux 软件包装置了哪些文件?

怎么查询 mkdir 指令是由哪个 RPM 软件包装置的?

装置 .rpm 软件包时,-i、-U、选项有何差异?

三.YUM根本介绍

1.什么是YUM?

Yum是RedHat以及CentOS中的软件包办理器。能够经过互联网下载 .rpm 包而且装置,并能够主动处理依靠性联系,无须繁琐地一次次下载、装置。(PS: YUM是出产最佳实践)

2.YUM源是什么?

要成功的运用 YUM 东西装置更新软件或体系,就需求有一个包含各种 rpm 软件包的repository(软件库房),这个软件库房咱们习气称为 yum 源。(可所以本地源、网络源)

3.YUM源装备实例

1)阿里yum源

#默许体系是国外源,需求替换为国内的源
[root@www.xuliangwei.com ~]# wget -O /etc/yum.repos.d/CentOS-Base.repo \
http://mirrors.aliyun.com/repo/Centos-7.repo
#扩展源,有许多软件在根根源中没有
[root@www.xuliangwei.com ~]# wget -O /etc/yum.repos.d/epel.repo \
http://mirrors.aliyun.com/repo/epel-7.repo

2)Nginx官方源,比方在学习Nginx时需求运用官方的yum源来装置

[root@www.xuliangwei.com ~]# vim /etc/yum.repos.d/nginx.repo
[nginx]
name=nginx repo
baseurl=http://nginx.org/packages/centos/7/$basearch/
gpgcheck=0
enabled=1

PS:源超找办法根本共同,zabbix,Docker、Nginx、saltstack、openstack

四.YUM实践事例

1.运用yum查询软件包的办法

[root@www.xuliangwei.com ~]# yum list
[root@www.xuliangwei.com ~]# yum list|grep ftp
[root@www.xuliangwei.com ~]# yum info ftp

2.运用yum装置软件包的办法

[root@www.xuliangwei.com ~]# yum install tree
[root@www.x阿里布达时代纪uliangwei.com ~]# yum install tree -y #非交互
#装置本地的rpm包, 假如有依靠联系, 会主动从软件库房中下载所需依靠
[root@www.xuliangwei.com ~]# yum localinstall /mnt/Packages/bind-9.9.4-50.el7.x86_64.rpm
#直接装置网络上的rpm包
[root@www.xuliangwei.com ~]# yum instal王杰,大黄,红焖羊肉-有爱沙龙,让爱心充溢这个国际l http://repo.zabbix.com/zabbix/3.4/rhel/7/x86_64/zabbix-release-3.4-2.el7.noarch.rpm

3.运用yum从头装置软件包的办法

#1.假如不小心删去vsftpd装备文件
[root@www.xuliangwei.com ~]# rm -f /etc/vsftpd/vsftpd.conf
#2.能够对软件进行从头装置
[root@www.xu天武玄奇liangwei.com ~]# yum reinstall vsftpd
#3.检查软件的装备文件
[root@www.xuliangwei.com ~]# rp王杰,大黄,红焖羊肉-有爱沙龙,让爱心充溢这个国际m -qc vsftpd
/etc/logrotate.d/vsftpd王杰,大黄,红焖羊肉-有爱沙龙,让爱心充溢这个国际
/etc/pam.d/vsftpd
/etc/vsftpd/f王杰,大黄,红焖羊肉-有爱沙龙,让爱心充溢这个国际tpusers
/etc/vsftpd/user_list
/etc/vsftpd/vsftpd.conf

4.运用yum更新软件包

#比照Linux已装置的软件和yum库房中的软件, 有哪些需求晋级
[root@www.xuliangwei.com ~]# yum check-update
#更新acl软件
[root@www.xuliangwei.com ~]# yum update acl -y
#如下的履行很风险,这代表更新整个体系一切的软件,包含内核
[root@www.xuliangwei.com ~]# yum update -y

5.运用yum删去软件包金诺瑞

[root@www.xuliangwei.com ~]# yum install samba -y
[root@www.xuliangwei.com ~]# yum erase 王杰,大黄,红焖羊肉-有爱沙龙,让爱心充溢这个国际samba -y
[root@www.xuliangwei.com ~]# yum remove samba -y

6.与yum库房相关指令(扩展了解)

#列出yum源可用的软件库房
[root@www.xuliangwei.com ~]# yum repolist
#列出悉数yum源可用和禁用的库房
[root@www.xuliangwei.com ~]# yum repolist all
#查找某个指令或文件归于那个软件包(出产常用)
[root@www.xuliangwei.com ~]# yum provides /etc/my.cnf
[root@www.xuliangwei.com ~]# yum provides cd

7.与yum缓存相关指令(扩展了解)

#1.缓存rpm包办法一、修正yum大局装备文件
[root@www.xuliangwei.com ~]# vim /etc/yum.conf
[main]
cachedir=/var/cache/yum/$basearch/$releasever
keepcache=1 #发动缓存
#2.缓存rpm包方李俞英式二,只下载不装置
[root@www.xuliangwei.com ~]# yum install -y yum-plugin-downloa丁晓君老公简历donly #插件
[root@www.xuliangwei.com ~]# yum install httpd -y --downloadonly --downloaddir=/tmp
#3.铲除一切yum缓存的软件包以及元数据
[root@www.xuliangwei.com ~]# yum clean all
#4.只铲除缓存的软件包
[root@www.xuliangwei.com ~]# yum clean packages

8.组包相关指令(扩展了解)

[root@www.xuliangwei.com ~]# yum groups list
#装置一整个组的软件
[root@xuliangwei ~]# yum groups install Development tools \
Compatibility libraries \
Base Debugging Tools
#yum删去包组
[root@www.xuliangwei.com ~]# yum groups remove -y Base

9.前史记录指令(扩展了解)

#1.检查前史履行yum指令
[root@www.xuliangwei.com ~]# yum history
#2.查询前史履行yum指令ID详细信息
[root@www.xuliangwei.com ~]# yum history info N
#3.吊销前史履行过的yum指令
[root@www.xuliangwei.com ~]# yum history undo N

PS: YUM还有装备文件与签名验证需求咱们额定扩展了解的请点击传送门

五.建立本地库房

1.有的时分你的linux体系不能联网,当然就不能很快捷的运用联网的yum源了,这时分就需求你自己会运用linux体系光盘制造一个yum源。具体进程如下:

#1.挂载镜像
[root@xuliangwei ~]# mou李淑显nt /dev/cdrom /mnt
#2.备份原有库房
[root@xuliangwei ~]# gzip /etc/yum.repos.d/*
#3.运用yum-config-manager指令增加本地库房
[root@xuliangwei 中村玉绪~]# yum-config-manager --add-repo="file:///mnt"
#4.或许运用手动增加repo文件
[root@xuliangwei ~]# 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@xuliangwei ~]# yum makecache

2.许多时分不仅仅是一台机器无法上网,而是许多机器都无法上网,但都有联网下载软件的需求,这个时分莫非每台机器都挂在光盘吗? 当然能够,但假如软件呈现了更新怎么办?

本地光盘供给根底软件包: Base

yum缓存供给常用软件包: nginx, zabbix, docker

1.环境预备

体系

IP

人物

centos7

10.0.0一转成双20150321.99

yum库房服务端

centos7

10.0.0.98

yum库房客户端

2.服务端进行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软件包
[rd3073oot@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.客户端装备yum源指向服务端

#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

.源码包办理实践

1.源码包是什么?

源码包指的是开发编写好的程序源代码,但并没有将其编译为一个能正常运用的东西。

2.为什么要学习源码包?

1、部分软件官网仅供给源码包,需求自行编译并装置。

2、部分软件在新版别有一些特性还没来得及制造成rpm包时,能够自行编译软件运用其新特性。

3.源码包的优缺陷

1.能够自行修正源代码

2.能够定制需求的相关功用

3.新版软件优先更新源码

4.缺陷是:

1) 相对yum装置软件会杂乱许多。

2) 标准化施行困难,主动化就无法落地。

4.源码包怎么获取

常见的软件包都能够在官网获取源码包,比方 apache、nginx、mysq终极一家之玩转铁时空l等等

5.将源码包编译为二进制可履行文件进程如下,简称装置三步曲

PS: 此办法不是百分百通用于一切源码包,主张拿到源码包解压后,进入到目录找相关的README协助文档

6.源码编dfe008译示例

下面经过编译Nginx来深化了解下源码包编译的进程。

#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 --prefix=/soft/nginx-1.12.2
#5.将Makefile文件编译可履行二进制程序
[root@node1 nginx-1.15.12]# make
#6.将二进制文件复制至对应的目录中
[root@node1 nginx-1.15.12]# make install

源码编译报错信息处理

checking for C compiler ... not found ./configure: error: C c王杰,大黄,红焖羊肉-有爱沙龙,让爱心充溢这个国际ompiler 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= 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= 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= option.
# yum -y install openssl-devel
文章版权及转载声明:

作者:admin本文地址:http://lovecub50.com/articles/4269.html发布于 3周前 ( 10-28 09:24 )
文章转载或复制请以超链接形式并注明出处有爱俱乐部,让爱心充满这个世界