当前位置:首页 > IT技术 > 系统服务 > 正文

【linux】Rehat linux离线安装GCC等软件的方法
2021-09-28 17:01:06

linux编译安装软件会遇到依赖各种库,离线的情况下处理难度非常棘手,下面这个方法是比较好的方法总结:


原理:

操作系统镜像包含了各种各样的库文件,也就是我们安装软件时所依赖的,但是我们PC上安装的linux操作系统只是安装了默认的和我们选择的软件所依赖的库,其他的并没有安装。也就是依赖库虽然不存在于操作系统上,但是大多数在镜像中是存在的。

实例

以下是linux 上编译安装软件的方法,既当安装软件出现缺少某些库的时候,就到操作系统镜像下的Packages文件找对应的库安装(网站找的会有各种问题:版本不同,系统不同等)

 

到网站 http://archive.kernel.org/centos-vault/6.5/os/i386/Packages/ 下载gcc-4.4.7-4.el6.i686.rpm

rpm -Uvh gcc-4.4.7-4.el6.i686.rpm

提示安装失败,依赖

error: Failed dependencies:

        cpp = 4.4.7-4.el6 is needed by gcc-4.4.7-4.el6.i686

在http://archive.kernel.org/centos-vault/6.5/os/i386/Packages/  目录下搜索cpp 找到cpp-4.4.7-4.el6.i686.rpm

下载,rpm -Uvh cpp-4.4.7-4.el6.i686.rpm 然后 安装gcc-4.4.7-4.el6.i686.rpm

遇到这样的报错:

error: Failed dependencies:

        libmpfr.so.1 is needed by cpp-4.4.7-4.el6.i686

因为linux的库前面会有个前缀lib,所以去搜索的时候要去掉lib 直接搜mpfr 就能搜到对应的rpm

也有例外的,如

 libppl.so.7 is needed by cloog-ppl-0.15.7-1.2.el6.i686

 libppl_c.so.2 is needed by cloog-ppl-0.15.7-1.2.el6.i686

虽然报了两个依赖,实际只需下载ppl的包(ppl-0.10.2-11.el6.i686.rpm)即可

注意

该离线方法的要点是,通过命令:

cat /etc/issue 显示的是发行版本信息

lsb_release -a 显示的是发行版本信息

查出linux的发行版本6.5,然后到http://archive.kernel.org/centos-vault网站,根据自己的系统选择目录,找到/os/i386/Packages/ 下的gcc rpm 下载下来,安装。 (32位是选择i386 64选择目录x86_64)

 

Redis need tcl 8.5 or newer

hadoop@stormspark:~/workspace/redis2.6.13/src$ make test

You need tcl 8.5 or newer in order to run the Redis test

make: *** [test] Error 1

 

wget http://downloads.sourceforge.net/tcl/tcl8.6.1-src.tar.gz  

sudo tar xzvf tcl8.6.1-src.tar.gz  -C /usr/local/  

cd  /usr/local/tcl8.6.1/unix/  

sudo ./configure  

sudo make  

sudo make install

################################

 安装Redis 2.8.18时报错:

    zmalloc.h:50:31: error: jemalloc/jemalloc.h: No such file or directory

    zmalloc.h:55:2: error: #error "Newer version of jemalloc required"

    make[1]: *** [adlist.o] Error 1

    make[1]: Leaving directory `/data0/src/redis-2.6.2/src'

    make: *** [all] Error 2

make MALLOC=libc

 

l 2018.05.29​

centos 6系列的Linux发行版,是非常成功(具足UNIX精神)的发行版,可能大家都已经用得非常习惯了。

但问题是,其内核及附带的工具软件,版本却都非常老了。

centos 7上的软件版本虽然比较新,但centos 7设计风格的突变(主要是引入了很不符合UNIX精神的systemd),可能在业界也引起了不少争议。

而我们苦逼的开发者,可能面临既需要使用高版本的相关组件,又不想升级到centos 7的困境。

那就升级centos 6上的内核与工具吧。

升级内核还算好办,因为内核对编译环境的要求很低。不熟悉内核升级的朋友,可以参考如下博文。

但是升级gcc等工具,如果不熟悉情况的话,可能就不顺利了。

公司研发环境上网的不便,centos 6环境下各种高版本rpm软件包的缺失,都会给升级带来麻烦。

本文提供的离线源码升级方法,就非常适合解决上述难题。

这里顺便说明一下,本文的标题虽然带了离线二字,但并不表示本人没有通过Linux主机下载相关文件。

本文为了操作及行文的方便,可能有多处会用wget去下载相关软件包或指示下载行为。

只所以带离线二字,是因为本文提供的方法非常适用于离线操作。

最后,由于本文的升级全部是基于源码编译安装,与具体的包管理系统(如rpm、apt等)无关。

因此,本文的方法应该也适用于其他Linux发行版(如ubuntu等)。

先来看看笔者的Linux主机升级前的情况:

[root@localhost ~]# cat  /etc/redhat-release

CentOS release 6.5 (Final)

[root@localhost ~]# uname -a

Linux localhost.localdomain 2.6.32-431.el6.i686

#1 SMP Fri Nov 22 00:26:36 UTC 2013 i686 i686 i386 GNU/Linux

[root@localhost ~]# gcc  --version

gcc (GCC) 4.4.7 20120313 (Red Hat 4.4.7-4)

[root@localhost ~]# autoconf --version

autoconf (GNU Autoconf) 2.63

[root@localhost ~]# automake  --version

automake (GNU automake) 1.11.1

 

gnu binutils包含as、ld、objdump等工具。从下面的输了信息来看,相关工具的版本号,就是binutils的版本号。

[root@localhost ~]# rpm -qa binutils

binutils-2.20.51.0.2-5.36.el6.i686

[root@localhost ~]# as --version

GNU assembler version 2.20.51.0.2-5.36.el6 20100205

[root@localhost ~]# ld --version

GNU ld version 2.20.51.0.2-5.36.el6 20100205

[root@localhost ~]# objdump -v

GNU objdump version 2.20.51.0.2-5.36.el6 20100205

为什么要升级binutils呢?因为我们熟悉的编译工具gcc自己只能将C代码编译为以.s结尾的文本形式的汇编文件。

而.s到.o的过程,则需要由as来完成。而as属于gnu binutils软件包。因此,如果不升级binutils,可能会出现这种情况:

gcc按照新款cpu的特点编译 C代码,生成的.s文件中含有较新的指令,例如avx2指令(新款x86系列cpu的加速指令)。

而老版的as程序却不认识此指令,结果导致编译失败。另外,像objdump反汇编二进制文件时,也同样可能出现某些指令不能识别的问题。

好了,下面看看相关工具的升级过程吧。

先来升级gcc吧。

//创建一个干净的目录,用于下载及升级诸工具

[root@localhost ~]# mkdir  tools_update  

[root@localhost ~]# cd     tools_update/  

[root@localhost tools_update]# wget http://ftp.gnu.org/gnu/gcc/gcc-4.8.2/gcc-4.8.2.tar.bz2  

[root@localhost tools_update]# wget ftp://gcc.gnu.org/pub/gcc/infrastructure/mpfr-2.4.2.tar.bz2  

[root@localhost tools_update]# wget ftp://gcc.gnu.org/pub/gcc/infrastructure/gmp-4.3.2.tar.bz2  

[root@localhost tools_update]# wget ftp://gcc.gnu.org/pub/gcc/infrastructure/mpc-1.0.3.tar.gz  

//接下来为gcc的编译做些准备。  

//注意,我们这里不用自己去编译上面下载的3个库。  

//我们参考gcc-4.8.2/contrib/download_prerequisites中的方法,  

//让gcc的编译脚本自动帮我们配置并编译这3个库。  

//具体步骤如下:

[root@localhost tools_update]# tar -xjf gcc-4.8.2.tar.bz2   

[root@localhost tools_update]# cd gcc-4.8.2  

[root@localhost gcc-4.8.2]# tar  -xjf  ../mpfr-2.4.2.tar.bz2  

[root@localhost gcc-4.8.2]# ln   -sf mpfr-2.4.2 mpfr  

[root@localhost gcc-4.8.2]# tar  -xjf ../gmp-4.3.2.tar.bz2  

[root@localhost gcc-4.8.2]# ln   -sf gmp-4.3.2 gmp  

[root@localhost gcc-4.8.2]# tar  -xzf ../mpc-1.0.3.tar.gz  

[root@localhost gcc-4.8.2]# ln   -sf mpc-1.0.3 mpc  

 

//好了,现在开始配置gcc了。注意,配置命令中的--prefix=/usr的设置很重要。  

//因为这样设置,在后面make install时可以直接覆盖老的gcc,安装后就不用再额外设置其他东西了。

//我们后面其他工具的编译安装,也都采用此设置。这样最简单。

[root@localhost gcc-4.8.2]# ./configure  --prefix=/usr  --enable-languages=c,c++ --enable--long-long --enable-threads=posix --disable-checking --disable-multilib

//下面开始编译gcc了。注意,这个编译过程超级漫长。

[root@localhost gcc-4.8.2]# make  

[root@localhost gcc-4.8.2]# make install  

//好了,看看升级结果吧^_^  

[root@localhost gcc-4.8.2]# gcc --version  

gcc (GCC) 4.8.2

 

//然后升级binutils,毕竟这和基础的构建功能是强相关的。

[root@localhost tools_update]# wget http://ftp.gnu.org/gnu/binutils/binutils-2.25.1.tar.bz2  

[root@localhost tools_update]# tar -xjf binutils-2.25.1.tar.bz2   

[root@localhost tools_update]# cd binutils-2.25.1  

[root@localhost binutils-2.25.1]# ./configure  --prefix=/usr  

[root@localhost binutils-2.25.1]# make  

[root@localhost binutils-2.25.1]# make install  

//好了,看看结果吧^_^

[root@localhost binutils-2.25.1]# as --version  

GNU assembler (GNU Binutils) 2.25.1  

[root@localhost binutils-2.25.1]# objdump -v  

GNU objdump (GNU Binutils) 2.25.1  

[root@localhost binutils-2.25.1]# ld -v  

GNU ld (GNU Binutils) 2.25.1  

 

//接下来升级其他工具。注意,请保持顺序与本文一致。否则可能会失败。

[root@localhost automake-1.14.1]# wget http://ftp.gnu.org/gnu/autoconf/autoconf-2.68.tar.xz  

[root@localhost tools_update]# tar -xJf autoconf-2.68.tar.xz   

[root@localhost tools_update]# cd autoconf-2.68  

[root@localhost autoconf-2.68]# ./configure --prefix=/usr  

[root@localhost autoconf-2.68]# make  

[root@localhost autoconf-2.68]# make install  

 

[root@localhost tools_update]# wget http://ftp.gnu.org/gnu/automake/automake-1.14.1.tar.xz  

[root@localhost tools_update]# tar -xJf automake-1.14.1.tar.xz   

[root@localhost tools_update]# cd automake-1.14.1  

[root@localhost automake-1.14.1]# ./configure --prefix=/usr  

[root@localhost automake-1.14.1]# make  

[root@localhost automake-1.14.1]# make install  

//好了,看看结果吧^_^

[root@localhost automake-1.14.1]# autoconf  --version  

autoconf (GNU Autoconf) 2.68  

[root@localhost automake-1.14.1]# automake --version  

automake (GNU automake) 1.14.1  

 

 

不过有时候,版本高了,也会带来额外的麻烦。

像binutils,从2.22版本开始,在链接生成可执行程序时,不会自动的隐式链接所需的库,而是需要明确的指定链接什么库。

结果这导致编译内核时,执行make menuconfig失败。

不过,解决办法是有的。

按照上文介绍的方法,编译安装一个2.21版的binutils即可。

以后想切到哪个版本了,直接进入源码目录执行一下make install即可。

---------------------

作者:孙明保

版权声明:本文为原创文章,转载请附上链接!

本文摘自 :https://blog.51cto.com/l

开通会员,享受整站包年服务立即开通 >