创建本地RPM源之更新系统旧版软件mysql
事情起因
系统版本为Centos6.6 ,因为之前同事没有采用最小化选择性安装,所以系统安装好后自带有mysql5.1的三个安装包:
[root@test ~]# rpm -qa | grep mysql
mysql-5.1.-.el6_6.x86_64
mysql-devel-5.1.-.el6_6.x86_64
mysql-lib-5.1.-.el6_6.x86_64
在安装新版本mysql前卸载旧版本
卸载掉了 mysql 和 mysql-devel,但没能成功卸载 mysql-libs,因为存在着依赖关系,所以打算采用rpm更新操作来将其更替:
[root@test ~/Downloads/V137788-]# rpm -Uvh mysql-commercial-libs-5.7.-1.1.el6.x86_64.rpm
warning: mysql-commercial-client-5.7.-1.1.el6.x86_64.rpm: Header V3 DSA/SHA1 Signature, key ID 5072e1f5: NOKEY
error: Failed dependencies:
mysql-commercial-common(x86-) = 5.7.-1.1.el6 is needed by mysql-commercial-libs-5.7.-1.1.el6.x86_64
libmysqlclient.so.()(64bit) is needed by (installed) postfix-:2.6.-.el6_5.x86_64
libmysqlclient.so.(libmysqlclient_16)(64bit) is needed by (installed) postfix-:2.6.-.el6_5.x86_64
看来还需要添加上:mysql-commercial-common
[root@test ~/Downloads/V137788-]# rpm -U mysql-commercial-libs-5.7.-1.1.el6.x86_64.rpm mysql-commercial-common-5.7.-1.1.el6.x86_64.rpm
warning: mysql-commercial-libs-5.7.-1.1.el6.x86_64.rpm: Header V3 DSA/SHA1 Signature, key ID 5072e1f5: NOKEY
error: Failed dependencies:
libmysqlclient.so.()(64bit) is needed by (installed) postfix-:2.6.-.el6_5.x86_64
libmysqlclient.so.(libmysqlclient_16)(64bit) is needed by (installed) postfix-:2.6.-.el6_5.x86_64
但是这样还是没能解决,而且卸载postfix会引发更多的rpm包卸载,这样的实施成本就提高了,不是愿意看到的,所以又想到创建本地yum源来更新软件。
安装createrepo包
[root@test ~/Downloads/V137788-]# yum install -y createrepo [root@test ~/Downloads/V137788-]# mkdir /opt/soft; cd /opt/soft/
将mysql的rpm包文件移动到这个目录下
[root@test /opt/soft]# mv ~/Downloads/V137788-/mysql* ./
=================================================================================
查看
[root@test /opt/soft]# ls
libmcrypt-2.5.-4.3.x86_64.rpm
libmcrypt-devel-2.5.-4.3.x86_64.rpm
mysql-commercial-client-5.7.-1.1.el6.x86_64.rpm
mysql-commercial-common-5.7.-1.1.el6.x86_64.rpm
mysql-commercial-devel-5.7.-1.1.el6.x86_64.rpm
mysql-commercial-embedded-5.7.-1.1.el6.x86_64.rpm
mysql-commercial-embedded-devel-5.7.-1.1.el6.x86_64.rpm
mysql-commercial-libs-5.7.-1.1.el6.x86_64.rpm
mysql-commercial-libs-compat-5.7.-1.1.el6.x86_64.rpm
mysql-commercial-server-5.7.-1.1.el6.x86_64.rpm
mysql-commercial-test-5.7.-1.1.el6.x86_64.rpm
nginx-1.9.-.el6.icefox.x86_64.rpm
使用createrepo创建本地yum源
这时会在本地yum源目录中多出一个repodata目录(存放有本地yum源的rpm包的文件信息)
[root@test /]# createrepo -v /opt/soft/ [root@test /opt/soft]# ls
libmcrypt-2.5.-4.3.x86_64.rpm
libmcrypt-devel-2.5.-4.3.x86_64.rpm
mysql-commercial-client-5.7.-1.1.el6.x86_64.rpm
mysql-commercial-common-5.7.-1.1.el6.x86_64.rpm
mysql-commercial-devel-5.7.-1.1.el6.x86_64.rpm
mysql-commercial-embedded-5.7.-1.1.el6.x86_64.rpm
mysql-commercial-embedded-devel-5.7.-1.1.el6.x86_64.rpm
mysql-commercial-libs-5.7.-1.1.el6.x86_64.rpm
mysql-commercial-libs-compat-5.7.-1.1.el6.x86_64.rpm
mysql-commercial-server-5.7.-1.1.el6.x86_64.rpm
mysql-commercial-test-5.7.-1.1.el6.x86_64.rpm
nginx-1.9.-.el6.icefox.x86_64.rpm
repodata 编辑repo文件
[root@test /]# vim /etc/yum.repos.d/local.repo
[LC]
name=local-rpm
baseurl=file:///opt/soft
enabled=
gpgcheck=
安装新版mysql
[root@test /]# yum install mysql-commercial-libs mysql-commercial-server mysql-commercial-client mysql-commercial-devel
...
Installed:
mysql-commercial-client.x86_64 :5.7.-1.1.el6
mysql-commercial-devel.x86_64 :5.7.-1.1.el6
mysql-commercial-libs.x86_64 :5.7.-1.1.el6
mysql-commercial-libs-compat.x86_64 :5.7.-1.1.el6
mysql-commercial-server.x86_64 :5.7.-1.1.el6 Dependency Installed:
mysql-commercial-common.x86_64 :5.7.-1.1.el6 Replaced:
mysql-libs.x86_64 :5.1.-.el6_5 Complete!
这里问题算是解决了,安装新版mysql并将旧版移除。
总结
1) 在使用createrepo命令创建本地rpm源信息时,要使用绝对路径而非相对路径;
2) 如果有新的软件包需要放在本地yum源中,需要再次执行createrepo更新本地rpm源信息;
3) 本地yum源能很好解决旧版软件间的依赖关系,不再需要手动一步步解决。
创建本地RPM源之更新系统旧版软件mysql的更多相关文章
- CentOS7创建本地YUM源的三种方法
这篇文章主要介绍了CentOS7创建本地YUM源的三种方法,本文讲解了使用CentOS光盘作为本地yum源.如何为CentOS创建公共镜像.创建完全自定义的本地源等内容,需要的朋友可以参考下 ...
- 本地yum源及更新
创建本地yumrepo源 概述 在生产环境中,由于网络环境隔离,很多内网机器,无法直接通过网络下载安装相关软件包,所以这个时候就需要在内网搭建一个yum源,然后通过下载将需要的软件包rpm下载下来,然 ...
- CentOS 7更改yum源与更新系统
在CentOS 7下更改yum源与更新系统. [1] 首先备份/etc/yum.repos.d/CentOS-Base.repo cp /etc/yum.repos.d/CentOS-Base.rep ...
- 在CentOS 7下更改yum源与更新系统
在CentOS 7下更改yum源与更新系统. [1] 首先备份/etc/yum.repos.d/CentOS-Base.repo cp /etc/yum.repos.d/CentOS-Base.rep ...
- linux 下载rpm包到本地,createrepo:创建本地YUM源
如何下载rpm包到本地 设置yum安装时,保留rpm包. 1.编辑 /etc/yum.conf 将keepcache的值设置为1; 这样就可以将yum安装时的rpm包保存在 /var/cache/yu ...
- [转载]CentOS 7 创建本地YUM源
本文中的"本地YUM源"包括三种类型:一是直接使用CentOS光盘作为本地yum源,优点是简单便捷,缺点是光盘软件包可能不完整(centos 7 Everything 总共才6.5 ...
- 创建本地yum源仓库
更新本地yum源 yum仓库服务端配置如下 : 1. 创建yum仓库目录 mkdir -p /data/yum_data/ cd /data/yum_data/ #可以上传rpm包到此目录,此目录下面 ...
- 创建本地repo源
1,保留rpm包 yum 安装时保留包至指定目录 编辑/etc/yum.conf 将keepcache的值设置为1: 2,使用插件 1,yum-plugin-downloadonly插件 sudo y ...
- LINUX创建本地yum源
.创建一个文件夹,把光盘中所有的RPM安装包都拷贝进来 # mkdir /rpms_yum .把光盘上的RPM包全部复制到rpms_yum中 # cd /mnt/cdrom/Packages/ # c ...
随机推荐
- (转载)php array_merge 和 两数组相加区别
(转载)http://www.cnblogs.com/shistou/archive/2013/03/16/2963586.html PHP中两个数组合并可以使用+或者array_merge,但之间还 ...
- 谈谈分布式事务之三: System.Transactions事务详解[下篇]
在前面一篇给出的Transaction的定义中,信息的读者应该看到了一个叫做DepedentClone的方法.该方法对用于创建基于现有Transaction对 象的“依赖事务(DependentTra ...
- 谈谈分布式事务之三: System.Transactions事务详解[上篇]
在.NET 1.x中,我们基本是通过ADO.NET实现对不同数据库访问的事务..NET 2.0为了带来了全新的事务编程模式,由于所有事务组件或者类型均定义在System.Transactions程序集 ...
- Oracle.ManagedDataAccessDTC.dll 使用
ODP.NET, Managed Driver Setup This section explains the setup and configuration steps required for u ...
- sed命令教程
转载自:http://coolshell.cn/articles/9104.htmlawk于1977年出生,今年36岁本命年,sed比awk大2-3岁,awk就像林妹妹,sed就是宝玉哥哥了.所以 林 ...
- android智能家居在线语音控制
对于android 智能家居项目,如果能实现语音控制,无疑会丰富项目功能,改善用户体验,android语音识别的方法有三种:一是使用intent调用语音识别程序,二 是应用程序自己调用语音识别库,三是 ...
- HW5.1
public class Solution { public static void main(String[] args) { int count = 0; for(int i = 1; i < ...
- HDOJ-ACM1005(JAVA)
转载声明:原文转自http://www.cnblogs.com/xiezie/p/5502918.html JAVA语言实现: 拿到题目第一反应是简单地实现递归: import java.util.* ...
- 从源码剖析一个Spark WordCount Job执行的全过程
原文地址:http://mzorro.me/post/55c85d06e40daa9d022f3cbd WordCount可以说是分布式数据处理框架的”Hello World”,我们可以以它为 ...
- OpenSSH 高级运用两则
00×0.相关介绍 OpenSSH(OpenBSD Secure Shell)使用 SSH 通过计算机网络加密通信的实现. 它是替换由 SSH Communications Security 所提供的 ...