Linux安装及管理工具(rpm和yum)

一、Linux应用程序基础

(一)应用程序与系统命令的关系

角色 系统命令 应用程序
文件位置 —般在/bin和/sbin目录中,或为Shell内部指令 通常在/usr/bin、/usr/sbin和/usr/local/bin、/usr/local/sbin目录中
主要用途 完成对系统的基本管理工作,例如IP配置工具 完成相对独立的其他辅助任务,例如网页浏览器
适用环境 一般只在字符操作界面中运行 根据实际需要,有些程序可以在图形界面中运行
运行格式 一般包括命令字、命令选项和命令参数 通常没有固定的执行格式,由程序开发者自行定义

(二)典型应用程序的目录结构

文件类型 保存目录 说明
普通的可执行程序 /usr/bin 所有用户可执行
服务器程序、管理程序命令 /usr/sbin 只有管理员能执行
应用程序配置文件 /etc 通过rpm或者yum方式安装的应用程序
日志文件 /var/log 系统日志
应用程序参考文档文件 /usr/share/doc 关于应用程序的参考文档等数据
应用程序手册页文件 /usr/share/man 执行文件及配置文件的man手册

(三)常见的软件包封装类型

文件类型 保存目录
RPM软件包 扩展名为".rpm" ,适用于RHEL、CentOS等系统
DEB软件包 扩展名为".deb",适用于Ubuntu、Debian等系统
源代码软件包 一般为".tar.gz"、".tar.bz2"等格式的压缩包,包含程序的原始代码,需要编译安装
附带安装程序的软件包 软件包的扩展名不一以TarBall格式的居多,在软件包中会提供用于安装的可执行程序或者脚本文件。例:install.sh、setup等 ,安装时只需运行安装文件就可以根据向导程序的提示完成安装操作

二、RPM包管理工具

(一)概述

1.RPM软件包管理器Red-Hat Package Manager

1.由Red Hat公司提出,被众多Linux发行版所采用
2.建立统一的文件数据库
3.详细记录软件包安装、卸载、升级等变化信息
4.自动分析软件包依赖关系

2. RPM软件包

1.软件素材参考:http://www.rpm.org
2.一般命名格式:在这里插入图片描述
例如:libusal-1.1.11-23.el7.x86_64.rpm(可以使用rpm -qi libusal 查询软件详细信息)
软件名:libusal 版本号:1.1.11 发布次数:23.el7(发布23次 el7:CentOS 7)硬件平台:x86_64 扩展名: .rpm

(二)RPM命令格式

1.rpm命令能实现几乎所有对RPM软件包的管理功能
2.执行"man rpm"命令可以获得关于rpm命令的详细帮助信息
3…rpm命令功能

  • 查询、验证RPM软件包的相关信息
  • 安装、升级、卸载RPM软件包
  • 维护重建RPM数据库信息等综合管理操作

(三)查询RPM包软件信息

1.查询已安装的rpm软件信息

rpm -q 软件名      查询指定软件名(完整名称)是否已安装
rpm -qi 软件名     显示已安装的指定软件的详细信息 
rpm -ql 软件名     显示已安装的指定软件的文件列表 
rpm -qc 软件名     列出已安装的指定软件的配置文件 
rpm -qd 软件名     列出己安装的指定软件的软件包文档所在位置 
rpm -qR 软件名     列出己安装的指定软件的依赖的软件包及文件
rpm -qF 文件或目录  查询已安装的指定软件属于哪个安装包 

rpm -qa    显示当前系统中以 rpm方式安装的所有软件列表 
rpm -qa | grep -i postfix    查询软件postfix是否已安装(可以不是完整的软件名)

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

rpm -qpi RPM包文件名     查询指定软件包的详细信息 
rpm -qpl RPM包文件名     查询指定软件包的文件列表 
rpm -qpc RPM包文件名     查询指定软件包的配置文件 
rpm -qpd RPM包文件名     查询指定软件包的软件包文档的位置

(四)安装、升级、卸载 RPM 软件包

1.命令格式

rpm [选项] RPM包文件
rpm -ivh RPM软件包

2.常用选项

  • -i:安装一个新的 RPM 软件包。
  • -U:升级某个软件包,若未安装过,则进行安装
  • -F:升级某个软件包,若未安装过,则放弃安装。
  • -h:在安装或升级软件包的过程中,以“#”号显示安装进度
  • -v:显示软件安装过程中的详细信息。
  • --force:强制安装某个软件包,比如要安装版本更旧的软件包
  • -e:卸载指定名称的软件包。
  • - -nodeps:在安装或升级、卸载一个软件包时,不检查与其他软件包的依赖关系。

(五)维护RPM数据库

1.重建 RPM 数据库

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

rpm --rebuilddb		或者		rpm --initdb

2.导入验证公钥

1.在没有导入用于数字签名验证的公钥文件之前,安装光盘中的一部分RPM软件包时会报错。需要向RPM数据库中导入位于光盘根目录下的公钥文件

mount /dev/sr0 /mnt/     挂载光盘
rpm --import /mnt/RPM-GPG-KEY-CentOS-7   切换到挂载目录查看目录信息ls

(六)解决依赖关系

1.安装有依赖关系的多个软件时

  • 被依赖的软件包需要先安装
  • 可同时指定多个.rpm包文件进行安装

2.卸载有依赖关系的多个软件时

  • 依赖其他程序的软件包需要先卸载
  • 可同时指定多个软件名进行卸载

3.忽略依赖关系
结合“–nodeps”选项,但可能导致软件异常

如果使用rpm方式安装,则需要先安装多个依赖包,这样会很繁琐。这里可以使用 yum方式进行一键安装

三、源代码编译

(一)概述

1.优点

1.获得最新的软件版本,及时修复bug
2.根据用户需要,灵活定制软件功能应用场合举例

2.应用场景

1.安装较新版本的应用程序时
2.当前安装的程序无法满足需要时
3.需要为应用程序添加新的功能时

3.Tarball封包

1.tar.gz和.tar.bz2格式居多
2.软件素材参考: http://sourceforge.net完整性校验

4.完整性校验

1.md5sum校验工具
md5sum httpd-2.4.25.tar.gz
24fb8b9e36cf131d78caae864fea0f6a httpd-2.4.25.tar.gz确认

5.源代码编译环境

需安装支持C/C++程序语言的编译器,如:gcc、gCC-C++、make、…

6.编译安装过程

在这里插入图片描述

四、yam安装

(一)配置本地yum源仓库

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

cd /etc/yum.repos.d/     包含了一些安装包不建议删除,可以创建一个目录做备份
mkdir repos.bak        创建备份目录
mv *.repo repos.bak    移动所有以.repo为后缀的文件到备份目录中

vim local.repo
[local]			仓库类别
name=local		仓库名称与所创建的文件名一致
baseurl=file:///mnt	指定URL 访问路径为光盘挂载目录,file://(格式)/mnt(目录)
enabled=1		开启此yum源,此为默认项,可省略
gpgcheck=0		不验证软件包的签名

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

yum clean                           可以拆分成两个步骤来进行
yun makecache

(二)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 httpd

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

yum whatprovides 命令	    查询命令属于哪个软件包
yum whatprovides netstat    查询netstat命令属于哪个软件包

(三)使用yum方式进行安装

1.yum install -y gcc gcc-c++ make

五、挂载Windows中的共享目录(补充)

(一)Windos端共享权限设定

1.解禁Guest
右击我的电脑选择管理——本地用户和组——在用户选项汇总双击Guset用户——取消账号已禁用选项
2.设置共享目录权限
右击共享目录点属性——在共享页面中点击共享选项——下拉选择共享对象为Everyone 点击添加 选择读写——点击共享按钮
在这里插入图片描述

3.设置本地策略
打开命令框——输入sepol.msc——选择本地策略
用户权限分配——拒绝从网络访问这台计算机——把Guest用户删除
安全选项——网络访问:本地账户的共享和安全模型——下拉选择仅来宾

(二)Linux挂载端

1.扫描共享目录
smbclient -L //192.168.71.1/ (Windows端的IP地址)
不需要输入密码直接回车
2.挂载共享目录
yum install -y cifs-utils
mkdir /data
在这里插入图片描述

3.mount.cifs //192.168.71.1/share /data ###share:要分享的目录,这里我用的是windows常用软件的文件夹做共享
不需要输入密码直接回车

4.df -h #查看挂载
ls / data #显示挂载目录内容
在这里插入图片描述

(三)具体操作过程产生的问题

问题一(协议连接失败:连接复位):protocol negotiation failed:NT_STATUS_CONNECTION_RESET
在这里插入图片描述

**解决办法:**vim /etc/samba/smb.conf修改文件,在global标签下增加如下两个参数项:
client min protocol = CORE
client max protocol = SMB3

在这里插入图片描述

问题二:在这里插入图片描述
**解决办法:**打开windows控制面板—>程序—>程序和功能—>启动或关闭windows功能
在这里插入图片描述

在这里插入图片描述

猜你喜欢

转载自blog.csdn.net/weixin_53567573/article/details/113625550