linux cpu占用率如何看
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小时内删除侵权内容。
发表评论
暂时没有评论,来抢沙发吧~