事情起因

系统版本为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的更多相关文章

  1. CentOS7创建本地YUM源的三种方法

    这篇文章主要介绍了CentOS7创建本地YUM源的三种方法,本文讲解了使用CentOS光盘作为本地yum源.如何为CentOS创建公共镜像.创建完全自定义的本地源等内容,需要的朋友可以参考下     ...

  2. 本地yum源及更新

    创建本地yumrepo源 概述 在生产环境中,由于网络环境隔离,很多内网机器,无法直接通过网络下载安装相关软件包,所以这个时候就需要在内网搭建一个yum源,然后通过下载将需要的软件包rpm下载下来,然 ...

  3. CentOS 7更改yum源与更新系统

    在CentOS 7下更改yum源与更新系统. [1] 首先备份/etc/yum.repos.d/CentOS-Base.repo cp /etc/yum.repos.d/CentOS-Base.rep ...

  4. 在CentOS 7下更改yum源与更新系统

    在CentOS 7下更改yum源与更新系统. [1] 首先备份/etc/yum.repos.d/CentOS-Base.repo cp /etc/yum.repos.d/CentOS-Base.rep ...

  5. linux 下载rpm包到本地,createrepo:创建本地YUM源

    如何下载rpm包到本地 设置yum安装时,保留rpm包. 1.编辑 /etc/yum.conf 将keepcache的值设置为1; 这样就可以将yum安装时的rpm包保存在 /var/cache/yu ...

  6. [转载]CentOS 7 创建本地YUM源

    本文中的"本地YUM源"包括三种类型:一是直接使用CentOS光盘作为本地yum源,优点是简单便捷,缺点是光盘软件包可能不完整(centos 7 Everything 总共才6.5 ...

  7. 创建本地yum源仓库

    更新本地yum源 yum仓库服务端配置如下 : 1. 创建yum仓库目录 mkdir -p /data/yum_data/ cd /data/yum_data/ #可以上传rpm包到此目录,此目录下面 ...

  8. 创建本地repo源

    1,保留rpm包 yum 安装时保留包至指定目录 编辑/etc/yum.conf 将keepcache的值设置为1: 2,使用插件 1,yum-plugin-downloadonly插件 sudo y ...

  9. LINUX创建本地yum源

    .创建一个文件夹,把光盘中所有的RPM安装包都拷贝进来 # mkdir /rpms_yum .把光盘上的RPM包全部复制到rpms_yum中 # cd /mnt/cdrom/Packages/ # c ...

随机推荐

  1. [HUST 1017] Exact cover

    Exact cover Time Limit: 15s Memory Limit: 128MB Special Judge Submissions: 6012 Solved: 3185 DESCRIP ...

  2. -_-#【减少 DOM 访问】缓存已经访问过的元素

    Minimize DOM Access Cache references to accessed elements 选择器查询是开销很大的方法.所以,使用选择器的次数应该越少越好,并且尽可能缓存选中的 ...

  3. 抽离CodeIgniter的数据库访问类 可以独立使用

    好吧,因为组织需要,最近又开始转战php了,业务逻辑都还好说,主要是老大要求在数据访问层上加上登录态验证.其实这种要求也是合理的,互联网服务要求上层保护下层,但下层不能完全相信上层.但是问题也就来了, ...

  4. nginx根据域名做http,https分发

    omcat端口:8080 做好虚拟主机 参照我的另一篇文章nginx端口:80 根据域名分派 在conf/nginx.conf中的http中增加 include www.huozhe.com.conf ...

  5. Tdxtreelist变色

    ACanvas.Font.Color := clRed;   //如果有加印的  变颜色

  6. 关于 UGUI 字体花屏或乱码。

    我们项目从某个时候开始ui突然开始出现字体花屏现象(unity 开发版本:5.3.6p6),而且很难必现却又时有发生,确实查找和解决起来不太容易. 关于这个问题,uwa官方给出了解释,http://b ...

  7. kafka的安装和使用

    简单说kafka是一个高吞吐的分部式消息系统,并且提供了持久化. kafka的架构 • producer:消息生存者• consumer:消息消费者• broker:kafka集群的server,负责 ...

  8. 多线程归并排序的实现 java

    多线程是非常适合归并排序的,因为归并排序是分治法,所以分割后可以独立运行,最后将结果归并起来就行了.如何写一个多线程程序呢?今天无聊,总结一下啊. 首先写个普通的归并排序,以后的多线程就调用这个排序. ...

  9. linux内核中分配4M以上大内存的方法

    在内核中, kmalloc能够分配的最大连续内存为2的(MAX_ORDER-1)次方个page(参见alloc_pages函数,     "if (unlikely(order >= ...

  10. Linker Special Section Types

    转载自http://processors.wiki.ti.com/index.php/Linker_Special_Section_Types#NOLOAD_Sections_2 Introducti ...