Linux安装及管理程序

网友投稿 234 2022-11-04

Linux安装及管理程序

一 Linux应用程序基础

1.1 安装及管理程序的原因

1.2 应用程序与系统命令的关系

1.3 典型应用程序的目录结构

1.4  常见的软件包封装类型

二 RPM软件包管理工具

2.1  RPM 概述

2.2  rpm软件包

2.3 RPM命令的格式

2.4 查询已安装的rpm软件信息

2.5 查询未安装的 RPM 软件包文件中信息

2.6 安装、升级、卸载 RPM 软件包

2.7 维护RPM数据库

2.8 解决软件包依赖关系方法

三 YUM

四 源代码编译安装

一 Linux应用程序基础

1.1 安装及管理程序的原因

当我们主机安装linux操作系统时候,也会同时安装一些软件或网络服务等等,但是随着系统一起安装的软件包毕竟他是少数的,能够实现的功能也是有限的,那么我们想为主机提供更多更丰富的功能的时候, 就需要安装新的程序了,那我们在学习linux操作系统下安装应用程序方法之前先来了解下应用的基础知识。

1.2 应用程序与系统命令的关系

在Linux操作系统中,一直以来系统命令和应用程序并没有特别明确的区别,从长期使用习惯来看,可以通过以下描述来对两者进行区别。

文件位置:

系统命令:系统命令的执行文件大多比较小,通常放置在/bin和/sbin目录中。对于内部命令,常集成在 Bash 程序内,而不是独立地执行文件;

应用程序:应用程序的执行文件通常放在/usr/bin、/usr/sbin 和/usr/local/bin、/usr/local/sbin 等目录中

主要用途:

系统命令:命令文件一般在安装操作系统时一起安装,用于辅助操作系统本身的管理。应用程序:应用程序一般需要在操作系统之外另行安装,提供相对独立于操作系统的功能,有时候等同于“软件”的概念。

适用环境:

系统命令:命令只在字符操作界面中运行。应用程序:应用程序可能会用到图形界面,形式多样。

运行格式:

系统命令:命令行大多适用于“命令字选项参数”形式的一般格式;

应用程序:应用程序一般没有固定的执行格式,运行方式由程序开发者自行定义

1.3 典型应用程序的目录结构

linux操作系统应用程序主要是7个文件组成,他们分别放在对应的目录下,安装完一个软件包以后,可能会向系统中复制大量的数据文件,并进行相关设置。在 Linux 操作系统中,典型的应用程序通常由以下几部分组成。

普通的可执行程序文件:一般保存在/usr/bin 目录中,普通用户即可执行。

服务器执行程序文件和管理程序文件:一般保存在/usr/sbin 目录中,只有管理员能执行。

应用程序配置文件:一般保存在/etc 目录中,配置文件较多时会建立相应的子目录。

日志文件:一般保存在/var/log 目录中。

应用程序的参考文档等数据:一般保存在/usr/share/doc/目录中。(主要存放软件的说明文档)

执行文件及配置文件的 man 手册文件:一般保存在/usr/share/man/目录中。

可说下面以 CentOS 中已经安装的 postfix 软件包(一款邮件服务器程序)为例,展示服务 器应用程序的文件组成。执行“rpm -ql postfix”命令,可以查看 postfix 软件包在系统中安装 的目录和文件清单(关于 rpm 命令的详细用法将在下节详细讲解),具体操作如下:rpm -ql postfix

1.4  常见的软件包封装类型

对于各种应用程序的软件包,在封装时可以采用各种不同的类型,不同类型的软件包其安装方法也各不相同。常见的软件包封装类型如下所述。

RPM 软件包:这种软件包文件的扩展名为“.rpm”,只能在使用 RPM(RPM Package Manager,RPM 软件包管理器)机制的 Linux 操作系统中安装,如 RHEL、Fedora、 CentOS 等。RPM 软件包一般针对特定版本的操作系统量身定制,因此依赖性较强。安装 RPM 软件包需要使用操作系统中的 rpm 命令。

DEB 软件包:这种软件包文件的扩展名为“.deb”,只能在使用 DPKG(Debian Package,Debian包管理器)机制的 Linux 操作系统中进行安装,如 Debian、Ubuntu 等。安装 DEB 软件包需要使用操作系统中的 dpkg 命令

源代码软件包:这种软件包是程序员开发完成的原始代码,一般被制作成“.tar.gz” 或“.tar.bz2”等格式的压缩包文件,因多数使用 tar 命令打包而成,所以经常被称为 “TarBall”。安装源代码软件包需要使用相应的编译工具,如 Linux 中的 C 语言编译器 gcc。因此,在安装操作系统的时候尽量勾选“开发工具”一项来安装基本的编译。源代码的好处可以增加相应的功能。

附带安装程序的软件包(绿色免安装的软件包):这种软件包的扩展名不一,但仍以 TarBall 格式的居多。 软件包中会提供用于安装的可执行程序或脚本文件,如 install.sh、setup 等,有时 候会以“.bin”格式的单个安装文件形式出现。安装时只需运行安装文件就可以根据向导程序的提示完成安装操作。 开放源代码的自由软件绝大多数选择以 TarBall 的形式发布,而 RPM 软件包、DEB 软件包等则使用了二进制的文件格式,代码相对比较封闭。

二 RPM软件包管理工具

2.1  RPM 概述

RPM 软件包管理机制最早由 Red Hat 公司提出,后来随着版本的升级逐渐融入更多的 优 秀 特 性 , 成 为 众 多 Linux 发 行 版 中 公 认 的 软 件 包 管 理 标 准 。 在 其 官 方 站 点 中,可以了解到关于 RPM 包管理机制的详细资料。

RPM 软件包管理器通过建立统一的文件数据库文件,对在 Linux 操作系统中安装、卸载、 升级的各种.rpm 软件包进行详细的记录,并能够自动分析软件包之间的依赖关系,保持各应用程序在一个协调、有序的整体环境中运行。

2.2  rpm软件包

使用 RPM 机制封装的软件包文件拥有约定俗成的命名格式,一般使用“软件名-软件版 本 - 发 布 次 数 . 操 作 系 统 类 型 . 硬 件 架 构 类 型 .rpm” 的 文 件 名 形 式 , 如 “bash-4.2.46-20.el7_2.x86_64.rpm”。

其中硬件平台通常为“i386”或“i686”等,表示适用于 Intel 公司的处理器,“x86_64”表示适用于 64 位的系统,如果是“noarch”表示不区分硬件架 构(支持不同硬件体系的处理器)。

2.3 RPM命令的格式

RPM命令能够实现几乎所有对rpm软件包的管理功能

执行“man rpm”命令可以获得关于rpm命令的详细帮助信息

RPM命令的功能:

查询、验证RPM软件包的相关信息

安装、升级、卸载RPM软件包

维护RPM数据库信息等综合管理操作

CentOS 的 DVD 安装光盘携带的大部分软件包都在 Packages 目录中,通过该目录中 的文件可以熟悉 RPM 软件包的一般命名格式。例如,以下操作用于查看 DVD 光盘设备中 携带的 bash 和 fontconfig-devel 软件包(分别是 Shell 解释器、字体配置和定制库)。一般 情 况 下 , CentOS 启 动 后 安 装 光 盘 会 自 动 挂 载 到 系 统 的 /run/media/root/CentOS\7\x86_64/Packages/目录下。

2.4 查询已安装的rpm软件信息    rpm -q[子选项] [软件名]

rpm -q 软件名 #查询指定软件是否已安装

rpm -q elinks lynx

rpm -qi 软件名   #显示已安装的指定软件的详细信息

rpm -qi samba-client

rpm -ql 软件名   #显示已安装的指定软件的文件列表

rpm -ql wget

rpm -qc 软件名   #列出已安装的指定软件的配置文件

rpm -qc -qd 软件名      #查看一个已经安装软件的文档安装位置:

rpm -qd -qR 软件名   #列出已安装的指定软件的依赖的软件包及文件

rpm -qR wget(下载文件)

rpm -qF 文件或目录   #查询已安装的指定软件属于哪个安装包

rpm -qF yum

rpm -qa #显示当前系统中以 rpm方式安装的所有软件列表

rpm -qa | grep -i postfix #查询软件postfix是否已安装

rpm -qf /usr/bin/passwd   #查看指定的文件或目录是哪个软件包所安装的

2.5 查询未安装的 RPM 软件包文件中信息    rpm -qp[子选项] RPM包文件

rpm -qpi RPM包文件名 #查询指定软件包的详细信息

rpm -qpi /mnt/Packages/ethtool-4.8-10.el7.x86_64.rpm

rpm -qpl RPM包文件名 #查询指定软件包的文件列表

rpm -qpl /mnt/Packages/ethtool-4.8-10.el7.x86_64.rpm

rpm -qpc RPM包文件名 #查询指定软件包的配置文件

rpm -qpc /mnt/Packages/elinks-0.12-0.37.pre6.el7.0.1.x86_64.rpm

rpm -qpd RPM包文件名 #查询指定软件包的软件包文档的位置

rpm -qpd /mnt/Packages/vsftpd-3.0.2-25.el7.x86_64.rpm

示例:

[root@ky17 ~]# df -h  #(查看磁盘文件存储大小)

文件系统        容量  已用  可用 已用% 挂载点

/dev/sda3        56G  5.2G   51G   10% /

devtmpfs        895M     0  895M    0% /dev

tmpfs           910M     0  910M    0% /dev/shm

tmpfs           910M   11M  900M    2% /run

tmpfs           910M     0  910M    0% /sys/fs/cgroup

/dev/sda1       497M  167M  330M   34% /boot

tmpfs           182M     0  182M    0% /run/user/1000

tmpfs           182M   12K  182M    1% /run/user/42

[root@ky17 ~]# ls /mnt/

#先查看要挂载的文件目录里面有没有文件,要保证没有不然后面操作的文件会将前面的隐

[root@ky17 ~]# mount /dev/sr0 /mnt/

#将/dev/下cdrom 挂载到 /mnt/目录下(mount 挂载)

mount: /dev/sr0 写保护,将以只读方式挂载

再次查看,挂载成功

所有的安装包都放在Packages中

2.6 安装、升级、卸载 RPM 软件包

格式:

rpm [选项] RPM包文件

rpm -ivh RPM软件包

常用选项:

-i:安装一个新的 RPM 软件包。

-U:升级某个软件包,若未安装过,则进行安装。

-F:升级某个软件包,若未安装过,则放弃安装。

-h:在安装或升级软件包的过程中,以“#”号显示安装进度。

-v:显示软件安装过程中的详细信息。

--force:强制安装某个软件包,比如要安装版本更旧的软件包

-e:卸载指定名称的软件包。

--nodeps:在安装或升级、卸载一个软件包时,不检查与其他软件包的依赖关系。

常用组合键:-ivh

案列

rpm -ivh /mnt/Packages/lynx-2.8.8-0.3.dev15.el7.x86_64.rpm

curl命令

删除 -e

强制安装与不检查依赖关系

辅助选项

1.--nodeps就是安装时不检查依赖关系,比如你这个rpm需要A,但是你没装A,这样你的包就装不上,用了--nodeps你就能装上了。

2.--force就是强制安装,比如你装过这个rpm的版本1,如果你想装这个rpm的版本2,就需要用--force强制安装

--force、--nodeps、-h、-v

先rpm -ivh  /mnt/Packages/perl-URI-1.60-9.el7.noarch.rpm

rpm -ivh --nodeps /mnt/Packages/perl-URI-1.60-9.el7.noarch.rpm

--nodeps

2.7 维护RPM数据库

1.重建 RPM 数据库

当 RPM 数据库发生损坏,可通过 重建RPM数据库 修复

rpm --rebuilddb 或者 rpm --initdb

rpm --import /mnt/RPM-GPG-KEY-CentOS-7

GPG在Linux上的应用主要是实现官方发布的包的签名机制。

GPG分为公钥及私钥。

公钥:顾名思意,即可共享的密钥,主要用于验证私钥加密的数据及签名要发送给私钥方的数据。

私钥:由本地保留的密钥,用于签名本地数据及验证用公钥签名的数据。

rpm数据库被损坏修复方案

故障报错:

error: db5 error(11) from dbenv->open: Resource temporarily unavailable error: cannot open Packages index using db5 - Resource temporarily unavailable (11) error: cannot open Packages database in /var/lib/rpm

修复过程:

重 建 r p m 数 据 库 , 步 骤 如 下 \color{red}{重建rpm数据库 ,步骤如下}重建rpm数据库,步骤如下:

1. 进入目录, 查看相关rpmdb文件

# cd /var/lib/rpm/

# ls | grep 'db.'

__db.001

__db.002

__db.003

__db.004

2. 删除损坏的rpmdb文件

将原rpmdb文件都更名为结尾带.bak的文件

for i in `ls | grep 'db.'`;do mv $i $i.bak;done或 rm -f __db.* # 清除原rpmdb文件

3. 重建rpm数据库  rpm --rebuilddb

4. 清除所有yum的缓存 # yum clean all

导入验证公钥

如没有公钥可在官网下载:wget /home/目录

安装数字证书

mount /dev/sr0 /mnt/

rpm --import /mnt/RPM-GPG-KEY-CentOS-7

进行验证

rpm -qa|grep gpg-pubkey

2.8 解决软件包依赖关系方法

三 YUM安装

(源的分类:网络源,本地源,FTP源)

3.1 本地yum源

cd /etc/yum.repos.d/      进入yum配置文件

mkdir repos.bak          创建备份文件repos.bak

mv *.repo repos.bak       将yum配置文件都移动到repos.bak

vim local.repo            创建yum源仓库

[local] #仓库类别

name=local #仓库名称

baseurl=file:///mnt     #指定URL 访问路径为光盘挂载目录

enabled=1 #开启此yum源,此为默认项,可省略,不开启是0

gpgcheck=0 #不验证软件包的签名,0代表不查看RPM文件内的数字签名,如果设置为“1”则代表需要查看RPM的数字签名。

mount /dev/cdrom /mnt/ #把光盘挂载到/mnt目录下

挂载    设备      目录或文件夹

注:最好是空的 原来的数据将被隐藏,一个挂载点同一时只能挂载一个设备

yum clean all && yum makecache #删除yum缓存并更新

yum常用的操作命令:

yum -y install 软件名 #安装、升级软件包,“-y”选项表示自动确认

yum -y remove 软件名 #卸载软件包,可自动解决其依赖关系

yum -y update 软件名 #升级软件包

yum list #查询软件包列表

yum list installed #查询系统中已安装的软件包

yum list available #查询仓库中尚未安装的软件包

yum list updates #查询可以升级版本的软件包

yum info 软件名 #查询软件包的描述信息

yum info search [all] 关键词 #根据某个关键词来查找相关的软件包

yum search all whatprovides 命令 #查询命令属于哪个软件包

yum whatprovides netstat

yum install 包名 -y --downloadonly --downloaddir=/tmp/   #下载RPM包到指定目录

使用yum方式进行安装

yum install -y gcc gcc-c++ make

示例:

挂载失败检查【虚拟机设置】的光盘镜像是否选择,【设备状态】是否为已连接和启动时连接

本地yum源安装结束。

补充:

关闭防火墙:

补充:### 关闭防火墙软件

1. 临时关闭命令 systemctl stop firewalld.service

2. 查看服务状态 systemctl status firewalld.service

3. 永久关闭(下次开机不自启动) systemctl disable firewalld.service

####关闭 SELinux

对于 SELinux,初学者可以这么理解,它是部署在 Linux 上用于增强系统安全的功能模块。

1. 临时关闭命令 setenforce 0

2. 查看服务状态 /usr/sbin/sestatus -v

3. 永久关闭(下次开机不自启动)修改vim /etc/selinux/config     将配置文件中的SELINUX=enforcing改为SELINUX=disabled

设置永久关闭之后需要重启机器

四 源代码编译安装

4.1 编译安装概述

安装源代码软件包需要编译安装,需要安装支持c和c++程序语言的编译器,如gcc、gcc-c++、make如果使用rpm方式安装,则需要先安装多个依赖包,这样会很繁琐。这里可以使用 yum方式进行一键安装。

yum install gcc* arp-devel* pkgconfig* pcre pcre-devel libtool libxml2-devel arp-util* -y 安装关联包

gcc  --version    查看gcc版本信息

make  --version   查看make版本

实列:

[root@wsh315 home] 拖入源文件压缩包(注意拖入的目录)

[root@wsh315 home]# tar zxvf -C /opt/       #解压包到opt目录下

[root@wsh315 home]# cd /opt/

[root@wsh315 opt]# cd                       #进入解压好的目录内

[root@wsh315 yum install gcc gcc-c++ make -y   #通过yum下载c跟c++语言

[root@wsh315 install  gcc* apr-devel* pkgconfig* libapr* pcre  pcre-devel  libtool libxml2-devel apr-util*  -y                                                            #清除yum依赖包

[root@wsh315 ./configure --prefix=/usr/local/apache/      #使用源码目录中的configure脚本

[root@wsh315                            #进行make翻译

[root@wsh315 make install               #进行make安装

[root@wsh315 /usr/local/apache/bin/apachectl start      #启动apache

[root@wsh315 lsof -i:80

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:Java中instanceof关键字实例讲解
下一篇:TableSQL API和Pyhton上相关的性能优化
相关文章

 发表评论

暂时没有评论,来抢沙发吧~