第六章 Linux软件安装

6.1 软件包管理简介

软件包分类

  • 源码包

    脚本安装包

  • 二进制包(RPM包、系统默认包)

源码包
源码包的优点是:

  • 开源,如果有足够的能力,可以修改源代码
  • 可以自由选择所需的功能
  • 软件是编译安装,所以更加适合自己的系统,更加稳定也效率更高
  • 卸载方便

源码包的缺点

  • 安装过程步骤较多,尤其安装较大的软件集合时(如LAMP环境搭建),容易出现拼写错误
  • 编译过程时间较长,安装比二进制安装时间长
  • 因为是编译安装,安装过程中一旦报错新手很难解决

RPM包
二进制包的优点

  • 包管理系统简单,只通过几个命令就可以实现包的安装、升级、查询和卸载
  • 安装速度比源码包安装快的多

二进制包缺点:

  • 经过编译,不再可以看到源代码
  • 功能选择不如源码包灵活
  • 依赖性

rpm是由红帽公司开发的软件包管理方式,使用rpm我们可以方便的进行软件的安装、查询、卸载、升级等工作。但是rpm软件包之间的依赖性问题往往会很繁琐,尤其是软件由多个rpm包组成时。
yum(全称为 Yellow dog Updater, Modified)是一个在Fedora和RedHat以及SUSE中的Shell前端软件包管理器。基於RPM包管理,能够从指定的服务器自动下载RPM包并且安装,可以自动处理依赖性关系,并且一次安装所有依赖的软体包,无须繁琐地一次次下载、安装。

6.2 RPM包管理-rpm命令管理

6.2.1 软件包管理-rpm命令管理-包命名与依赖性

RPM包命名原则
httpd-2.2.15-15.el6.centos.1.i686.rpm
httpd 软件包名
2.2.15 软件版本
15 软件发布的次数
el6.centos 适合的Linux平台
i686 适合的硬件平台
rpm rpm包扩展名

RPM包依赖性

  • 树形依赖: a→b→c
  • 环形依赖: a→b→c→a
  • 模块依赖: 模块依赖查询网站:www.rpmfind.net

    6.2.2 软件包管理-rpm命令管理-安装升级与卸载

    包全名与包名

  • 包全名:操作的包是没有安装的软件包时, 使用包全名。而且要注意路径

  • 包名:操作已经安装的软件包时,使用包名。

是搜索/var/lib/rpm/中的数据库

RPM安装
rpm –ivh 包全名
选项:
-i(install) 安装
-v(verbose) 显示详细信息
-h(hash) 显示进度
—nodeps 不检测依赖性

RPM包升级
rpm -Uvh 包全名
选项:
-U(upgrade) 升级

卸载
rpm -e 包名
选项:
-e(erase) 卸载
—nodeps 不检查依赖性

6.2.3 软件包管理-rpm命令管理-查询

查询是否安装
[root@localhost ~]# rpm -q 包名
#查询包是否安装
选项:
-q 查询(query)
[root@localhost ~]# rpm –qa
#查询所有已经安装的RPM包
选项:
-a 所有(all)

查询软件包详细信息
[root@localhost ~]# rpm –qi 包名
选项:
-i 查询软件信息(information)
-p 查询未安装包信息(package)

查询包中文件安装位置
[root@localhost ~]# rpm –ql 包名
选项:
-l 列表(list)
-p 查询未安装包信息(package)

查询系统文件属于哪个RPM包
[root@localhost ~]# rpm –qf 系统文件名
选项:
-f 查询系统文件属于哪个软件包(file)

查询软件包的依赖性
[root@localhost ~]# rpm –qR 包名
选项:
-R 查询软件包的依赖性(requires)
-p 查询未安装包信息(package)

6.2.4 软件包管理-rpm命令管理-校验和文件提取

RPM包校验
[root@localhost ~]# rpm –V 已安装的包名
选项:
-V 校验指定RPM包中的文件(verify)

验证内容中的8个信息的具体内容如下:

  • S 文件大小是否改变
  • M 文件的类型或文件的权限(rwx)是否被改变
  • 5 文件MD5校验和是否改变(可以看成文件内容是否改变)
  • D 设备的中,从代码是否改变
  • L 文件路径是否改变
  • U 文件的属主(所有者)是否改变
  • G 文件的属组是否改变
  • T 文件的修改时间是否改变

文件类型

  • c 配置文件(config file)
  • d 普通文档(documentation)
  • g “鬼”文件(ghost file),很少见,就是该文件不应该被这个RPM包包含
  • l 授权文件(license file)
  • r 描述文件(read me)

RPM包中文件提取
[root@localhost ~]# rpm2cpio 包全名 | \
cpio -idv .文件绝对路径
rpm2cpio
#将rpm包转换为cpio格式的命令
cpio
#是一个标准工具,它用于创建软件档案文件和从档案文件中提取文件

[root@localhost ~]# cpio 选项 < [文件|设备]
选项:
-i:copy-in模式,还原
-d:还原时自动新建目录
-v:显示还原过程

[root@localhost ~]# rpm -qf /bin/ls
#查询ls命令属于哪个软件包
[root@localhost ~]# mv /bin/ls /tmp/
#造成ls命令误删除假象
[root@localhost ~]# rpm2cpio /mnt/cdrom/Packages/coreutils- 8.4-19.el6.i686.rpm | cpio -idv ./bin/ls
#提取RPM包中ls命令到当前目录的/bin/ls下
[root@localhost ~]# cp /root/bin/ls /bin/
#把ls命令复制会/bin/目录,修复文件丢失

6.3 RPM包管理-yum在线管理

6.3.1 IP地址配置和网络yum源

1、IP地址配置
[root@localhost ~]# setup
#使用setup工具
tips:CentOS7中是nmtui命令

[root@localhost ~]# vi /etc/sysconfig/network-scripts/ifcfg-eth0
ONBOOT=“no” 改为
ONBOOT=“yes“
#启动网卡

[root@localhost ~]# service network restart
#重启网络服务

2、网络yum源
[root@localhost yum.repos.d]# vi /etc/yum.repos.d/CentOS-Base.repo

  • [base] 容器名称,一定要放在[]中
  • name 容器说明,可以自己随便写
  • mirrorlist 镜像站点,这个可以注释掉
  • baseurl 我们的yum源服务器的地址。默认是CentOS官方的yum源服务 器,是可以使用的,如果你觉得慢可以改成你喜欢的yum源地址
  • enabled 此容器是否生效,如果不写或写成enable=1都是生效,写成 enable=0就是不生效
  • gpgcheck 如果是1是指RPM的数字证书生效,如果是0则不生效
  • gpgkey 数字证书的公钥文件保存位置。不用修改

Linux软件安装 - 图1

6.3.2 yum命令

1.常用yum命令
1)查询
[root@localhost yum.repos.d]# yum list
#查询所有可用软件包列表
[root@localhost yum.repos.d]# yum search 关键字
#搜索服务器上所有和关键字相关的包

2)安装
[root@localhost yum.repos.d]# yum –y install 包名
选项: install 安装
-y 自动回答yes

3)升级
[root@localhost yum.repos.d]# yum -y update 包名
选项: update 升级
-y 自动回答yes

4)卸载
[root@localhost yum.repos.d]# yum -y remove 包名
选项: remove 卸载
-y 自动回答y e s

tips:update 不加包名全部升级(包括Linux内核,会导致服务器挂掉)
卸载同理(尽量不要卸载)

2、YUM软件组管理命令
[root@localhost~]# yum grouplist
#列出所有可用的软件组列表

[root@localhost~]# yum groupinstall 软件组名
#安装指定软件组,组名可以由grouplist查询出来

[root@localhost~]# yum groupremove 软件组名
#卸载指定软件组

tips:安装软件包组 有空格 用””括起来

6.3.2 光盘yum源搭建

光盘yum源搭建步骤
1)挂载光盘
[root@localhost ~]# mount /dev/cdrom /mnt/cdrom/
2)让网络yum源文件失效 (视频内改名处理)
[root@localhost ~]# cd /etc/yum.repos.d/

[root@localhost yum.repos.d]# mv CentOS-Base.repo \ CentOS-Base.repo.bak

[root@localhost yum.repos.d]# mv CentOS-Debuginfo.repo \ CentOS-Debuginfo.repo.bak

[root@localhost yum.repos.d]# mv CentOS-Vault.repo \ CentOS-Vault.repo.bak

3)修改光盘yum源文件
[root@localhost yum.repos.d]# vim CentOS-Media.repo
[c6-media]
name=CentOS-$releasever - Media
baseurl=file:///mnt/cdrom
#地址为你自己的光盘挂载地址

file:///media/cdrom/
# file:///media/cdrecorder/
#注释这两个不存在的地址 ( 不注释也没事,但是会显示报错)

gpgcheck=1
enabled=1
#把enabled=0改为enabled=1,让这个yum源配置文件生效 gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-CentOS-6

Linux系统中挂载和使用光盘的基本步骤
参考:https://www.cnblogs.com/fengfangbing/p/6889757.html
1. 创建挂载点
mkdir /mnt/cdrom
在 /mnt 目录下创建一个空文件夹cdrom作为光盘的挂载点(任何一个空目录都可以作为挂载点)。
2. 打开光驱,放入光盘
如果用的是VMware中的虚拟机,进入虚拟机设置,选择“CD/DVD”硬件,勾选“已连接”和“启动时连接”,在连接处,选择“使用ISO映像文件”,浏览选择本地电脑中下载好的ISO光盘镜像文件,确定即可。
3. 执行挂载命令
mount -t iso9660 /dev/sr0 /mnt/cdrom 或者 mount /dev/sr0 /mnt/cdrom
iso9660 是光盘的默认文件系统。
由于linux系统可以自动识别光盘的文件系统,故“-t iso9660”也可以省略不写。
光盘的设备文件名是固定的,一般为/dev/cdrom或/dev/sr0。
挂载成功后,就可以通过挂载点读取光盘里面的数据。
4. 查看光盘中的数据
cd /mnt/cdrom ls -l
注意:操作完成之后,如果要取出光盘,必须解除挂载。
5. 解除挂载
不能在挂载点目录下解除挂载,必须先切换到其他目录(如用户家目录)。

cd 切换到用户家目录 umount /dev/sr0 或者 umount /mnt/cdrom

6.4 源码包管理

6.4.1 源码包和RPM包的区别
  1. 区别
  • 安装之前的区别:概念上的区别
  • 安装之后的区别:安装位置不同
  1. RPM包安装位置
  • 是安装在默认位置中 | RPM包默认安装路径 | | | —- | —- | | /etc/ | 配置文件安装目录 | | /usr/bin/ | 可执行的命令安装目录 | | /usr/lib/ | 程序所使用的函数库保存位置 | | /usr/share/doc/ | 基本的软件使用手册保存位置 | | /usr/share/man/ | 帮助文件保存位置 |
  1. 源码包安装位置
  • 安装在指定位置当中,一般是

/usr/local/软件名/

  1. 安装位置不同带来的影响
  • RPM包安装的服务可以使用系统服务管理命令(service)来管理,例如RPM包安装的apache的启动方法是:
    • /etc/rc.d/init.d/httpd start
    • service httpd start
  • 而源码包安装的服务则不能被服务管理命令管理,因为没有安装到默认路径中。所以只能用绝对路径进行服务的管理,如:
  • /usr/local/apache2/bin/apachectl start
    6.4.2 源码包安装过程
  1. 安装准备
  1. 安装注意事项
  • 源代码保存位置:/usr/local/src/
  • 软件安装位置:/usr/local/
  • 如何确定安装过程报错:
    • 安装过程停止
    • 并出现error、warning或no的提示
  1. 源码包安装过程
  • 下载源码包
  • 解压缩下载的源码包
  • 进入解压缩目录
  • ./configure 软件配置与检查
    • 定义需要的功能选项。
    • 检测系统环境是否符合安装要求。
    • 把定义好的功能选项和检测系统环境的信息都写入Makefile文件,用于后续的编辑
  • make 编译
  • make clean
  • make install 编译安装
  1. 源码包的卸载
  • 不需要卸载命令,直接删除安装目录即可。

不会遗留任何垃圾文件。

6.5 脚本安装包

  1. 脚本安装包
  • 脚本安装包并不是独立的软件包类型,常见安装的是源码包。
  • 是人为把安装过程写成了自动安装的脚本,只要执行脚本,定义简单的参数,就可以完成安装。
  • 非常类似于Windows下软件的安装方式。
  1. Webmin的作用
  • Webmin 是一个基于 Web 的 Linux 系统管理界面。您就可以通过图形化的方式设置用户帐号、Apache、DNS、文件共享等服务。
  1. Webmin安装过程

没有安装perl的需要先安装perl
安装步骤:

(https://pan.baidu.com/s/1tenkC16krTUv1dwMzJQl2Q 密码:hh1x)

  • 下载适用于 Unix/Linux 的源码包。
  • 下载 perl-5.x.y.tar.gz 文件后执行以下操作。

$ tar -xzf perl-5.x.y.tar.gz $ cd perl-5.x.y $ ./Configure -de $ make $ make test $ make install
接下来我们如果 perl -v 命令查看是否安装成功。
安装成功后,Perl 的安装路径为 /usr/local/bin ,库安装在 /usr/local/lib/perlXX, XX 为版本号。

1.941版本(202-01-05发布)
下载地址:
https://pan.baidu.com/s/1tenkC16krTUv1dwMzJQl2Q
密码:hh1x

ip:10000 访问
Linux软件安装 - 图2
出现上面情况可能是

未关闭:

$ systemctl stop firewalld

参考:
1.启动防火墙
systemctl start firewalld
2.禁用防火墙
systemctl stop firewalld
3.查看状态
systemctl status firewalld或者 firewall-cmd —state
(https://blog.csdn.net/root_miss/article/details/83000159)
(https://blog.csdn.net/baidu_36124158/article/details/90603496)