百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

【系统配置】在不覆盖系统原有glibc版本情况下编译安装高版本

nanshan 2024-12-01 01:32 7 浏览 0 评论

原文链接:【系统配置】在不覆盖系统原有glibc版本情况下编译安装高版本 | 统信 | 麒麟 | 方德

Hello,大家好啊!今天给大家带来一篇关于如何在信创操作系统(如统信UOS、麒麟KOS等)上在不覆盖系统原有glibc版本的情况下安装高版本glibc的文章。glibc(GNU C Library)是Linux系统中非常重要的C标准库,几乎所有的系统程序和用户应用程序都依赖于它。因此,升级或更换glibc版本可能会导致系统不稳定,甚至引发兼容性问题。本文将介绍如何在信创操作系统上保留系统原有glibc版本的前提下,安装更高版本的glibc,并通过环境变量指定不同程序使用特定版本的glibc。欢迎大家分享转发,点个关注和在看吧!

什么是glibc?

glibc是GNU项目的C标准库,是Linux系统中几乎所有程序运行的基础。它提供了系统调用接口和各种基础函数库,比如内存分配、字符串处理、I/O操作等。通常,Linux系统会默认安装一个与当前系统内核和软件包兼容的glibc版本,但某些应用可能需要更高版本的glibc才能运行。

为什么不直接覆盖原有glibc版本?

直接升级或覆盖系统自带的glibc版本可能会导致以下问题:

系统不稳定:系统中很多依赖当前glibc版本的程序可能会出现兼容性问题,导致系统不稳定或程序无法运行。

系统崩溃:glibc是系统核心组件,升级不当可能导致系统无法启动或无法正常登录。

软件依赖冲突:如果系统自带的软件包依赖于当前的glibc版本,直接升级glibc会引发依赖关系冲突,导致部分软件无法使用。

因此,在不影响系统稳定性的前提下安装高版本的glibc,是一种更加安全可靠的方法。

1.查看系统信息

pdsyw@pdsyw1024:~/Desktop$ cat /etc/os-version
pdsyw@pdsyw1024:~/Desktop$ uname -a

2.查看系统glibc版本

pdsyw@pdsyw1024:~/Desktop$ ldd --version

3.更新系统源

pdsyw@pdsyw1024:~/Desktop/glibc-2.40/build$ sudo apt update

4.安装GNU的解析器生成器bison

pdsyw@pdsyw1024:~/Desktop/glibc-2.40/build$ sudo apt install bison -y

5.查看可下载的glibc版本

http://ftp.gnu.org/gnu/libc/

6.下载新版glibc版本

pdsyw@pdsyw1024:~/Desktop$ wget http://ftp.gnu.org/gnu/libc/glibc-2.40.tar.xz

7.解压文件

pdsyw@pdsyw1024:~/Desktop$ tar -xf glibc-2.40.tar.xz
pdsyw@pdsyw1024:~/Desktop$ cd glibc-2.40/
pdsyw@pdsyw1024:~/Desktop/glibc-2.40$

8.创建构建目录

pdsyw@pdsyw1024:~/Desktop/glibc-2.40$ mkdir build
pdsyw@pdsyw1024:~/Desktop/glibc-2.40$ cd build/
pdsyw@pdsyw1024:~/Desktop/glibc-2.40/build$

9.配置构建选项

pdsyw@pdsyw1024:~/Desktop/glibc-2.40/build$ ../configure --prefix=/opt/glibc-2.40 --disable-mathvec

选项解释

../configure:

运行configure脚本,用于设置glibc的编译和安装选项。configure脚本通常在源码目录中,而在此命令中,我们在build目录中运行,所以使用了相对路径../configure来引用源码目录中的configure脚本。

configure脚本的目的是检测当前系统环境,生成适合系统的Makefile,来确保后续的编译过程能够顺利进行。

--prefix=/opt/glibc-2.40:

--prefix用于指定编译后的安装路径。在这里,glibc会被安装到/opt/glibc-2.40目录中。

使用独立的路径(如/opt/glibc-2.40)而不是系统默认路径(如/usr或/lib)的好处是:

避免覆盖系统的原始glibc,从而减少对系统稳定性的影响。

可以为特定应用程序使用新版本glibc而不干扰其他依赖旧版glibc的程序。

--disable-mathvec:

--disable-mathvec选项用于禁用mathvec功能。mathvec是用于矢量化数学运算的功能模块,通常在一些高性能数学运算中使用。它依赖于编译器和链接器的特定功能支持。

在配置过程中,如果发现当前工具链不支持所需的特性,使用--disable-mathvec可以禁用这些功能,以避免配置过程中的兼容性问题。

这样做的结果是会缺少某些数学矢量化相关的功能,但可以使glibc成功配置和编译,以解决工具链不兼容的错误。

10.编译

pdsyw@pdsyw1024:~/Desktop/glibc-2.40/build$ make -j$(nproc)

选项解释

make:

make是一个构建自动化工具,主要用于编译和构建软件。它会根据Makefile中的规则来执行一系列的编译命令,以生成目标程序。

Makefile定义了如何将源代码转换为可执行文件或库,make工具会解析这些规则并依次执行。

-j:

-j选项用于指定同时运行的并行编译任务数。make会启动多个任务来同时编译多个文件,从而利用多核CPU的并行处理能力,加快整个编译过程。

如果没有指定-j,make会按顺序逐个编译文件,这在大型项目中会导致编译速度非常慢。

$(nproc):

$(nproc)是一个用于获取系统CPU核心数的命令。它会返回系统中可用的CPU核心数目,例如4核、8核等。

通过$(nproc),你可以动态设置编译时的并行任务数,使得编译过程尽可能利用所有的CPU核心。

11.安装

pdsyw@pdsyw1024:~/Desktop/glibc-2.40/build$ sudo make install

12.查看glibc版本

pdsyw@pdsyw1024:~/Desktop/glibc-2.40/build$ /opt/glibc-2.40/bin/ldd --version

13.编写测试程序

pdsyw@pdsyw1024:~$ vim test.c
pdsyw@pdsyw1024:~$
pdsyw@pdsyw1024:~$ cat test.c
#include <stdio.h>
int main() {
printf("Hello, glibc 2.40!\n");
return 0;
}
pdsyw@pdsyw1024:~$

14.编译源码

pdsyw@pdsyw1024:~$ gcc test.c -o test_program -nostartfiles -Wl,--dynamic-linker=/opt/glibc-2.40/lib/ld-linux-aarch64.so.1 -L/opt/glibc-2.40/lib -I/opt/glibc-2.40/include /opt/glibc-2.40/lib/crt1.o /opt/glibc-2.40/lib/crti.o /opt/glibc-2.40/lib/crtn.o -lc

选项解释

gcc test.c -o test_program:

gcc:GCC编译器,用于编译C代码。

test.c:输入的源代码文件。

-o test_program:指定输出的可执行文件名为test_program。

-nostartfiles:

该选项用于告诉GCC不要自动链接默认的启动文件。这些启动文件(如crt1.o、crti.o、crtn.o)用于初始化程序和清理工作。在本例中,我们显式提供了这些文件以避免与系统默认的启动文件冲突。

-Wl,--dynamic-linker=/opt/glibc-2.40/lib/ld-linux-aarch64.so.1:

-Wl,:这个选项告诉GCC将后面的参数传递给链接器(ld)。

--dynamic-linker=/opt/glibc-2.40/lib/ld-linux-aarch64.so.1:显式指定程序运行时使用的动态链接器。在Linux系统中,动态链接器负责在程序启动时加载所需的共享库。在此处,我们使用的是新安装的glibc的动态链接器。

-L/opt/glibc-2.40/lib:

该选项用于告诉编译器在/opt/glibc-2.40/lib目录中查找库文件。这样可以确保链接时使用的是新版本的glibc库,而不是系统默认的库。

-I/opt/glibc-2.40/include:

该选项用于告诉编译器在/opt/glibc-2.40/include目录中查找头文件。头文件包含了库函数的声明和接口,使用新版本的glibc头文件可以确保代码与新库兼容。

/opt/glibc-2.40/lib/crt1.o /opt/glibc-2.40/lib/crti.o /opt/glibc-2.40/lib/crtn.o:

这些是glibc的启动文件:

crt1.o:C程序的入口点代码。

crti.o:包含初始化代码。

crtn.o:包含终止代码。

这些文件用于初始化C程序的运行时环境,确保在程序开始和结束时完成必要的设置和清理工作。

-lc:

该选项用于链接C标准库libc,这是大多数C程序所依赖的基础库。这里显式指定链接libc库,以确保链接的是新版本的glibc。

15.执行程序测试

pdsyw@pdsyw1024:~$ ls -ltr
-rwxr-xr-x 1 pdsyw pdsyw 28600 10月 9 10:29 test_program
pdsyw@pdsyw1024:~$ ./test_program
Hello, glibc 2.40!

通过本文的介绍,您已经了解了如何在不影响系统原有glibc版本的情况下,在信创操作系统上安装高版本的glibc。此方法可以确保系统的稳定性,并为特定应用程序提供所需的glibc版本。如果您觉得这篇文章有用,请分享和转发,同时别忘了点个关注和在看,以便未来获取更多实用的技术信息和教程。感谢大家的阅读,我们下次再见!

相关推荐

在 Ubuntu 上安装 Zabbix(以 Zabbix 6.4 LTS 版本为例)

Zabbix是一个流行的开源监控解决方案,能够监控各种网络参数和服务器健康状态。一、环境准备系统要求Ubuntu20.04/22.04LTS至少2GBRAM(生产环境建议4GB+)至少1...

如何在 Ubuntu 24.04 服务器上安装 Apache Solr

ApacheSolr是一个免费、开源的搜索平台,广泛应用于实时索引。其强大的可扩展性和容错能力使其在高流量互联网场景下表现优异。Solr基于Java开发,提供了分布式索引、复制、负载均衡及自...

如何在 Ubuntu 24.04 LTS 或 22.04/20.04 上安装 Apache Maven

Maven是由Apache托管的开源工具,用于管理Java项目。它包含一个项目对象模型(POM):一个配置文件(XML),其中包含项目的基本信息,包括配置、项目依赖项等。Maven可以处理...

Cursor的终极对手——Trae Pro最新系统提示词

前段时间,字节的AI编程神器Trae国际版,终于甩出了Pro订阅计划!很多对它又爱又恨的小伙伴,直呼:终于等到你。爱它,是因为Trae长期免费+体验真香;恨它?还不是那该死的排队等待,...

AI系统提示词:V0(ai代码提示)

以下是对V0系统提示词(SystemPrompt)的分部分讲解与解读,帮助你理解其核心内容和设计意图。V0系统提示词##CoreIdentity-Youarev0,Vercel&...

8岁男童失踪第13天,搜救人员发现可疑水库,更恶心的事情发生了

Lookingatyourrequest,Ineedtorewritethearticleaboutthe8-year-oldmissingboywhilemaking...

docker常用指令及安装rabbitMQ(docker安装zabbix)

一、docker常用指令启动docker:systemctlstartdocker停止docker:systemctlstopdocker重启docker:systemctlrestart...

三步教你用Elasticsearch+PyMuPDF实现PDF大文件秒搜!

面对100页以上的大型PDF文件时,阅读和搜索往往效率低下。传统关系型数据库在处理此类数据时容易遇到性能瓶颈,而Elasticsearch凭借其强大的全文检索和分布式架构,成为理想解决方案。通过...

ElasticSearch中文分词插件(IK)安装

坚持原创,共同进步!请关注我,后续分享更精彩!!!前言ElasticSearch默认的分词插件对中文支持很不友好。一段话按规则会以每个中文字符来拆解,再分别建立倒排索引。如"中华人民共和国国歌...

SpringBoot使用ElasticSearch做文档对象的持久化存储?

ElasticSearch是一个基于Lucene的开源搜索引擎,广泛应用于日志分析、全文搜索、复杂查询等领域,在有些场景中使用ElasticSearch进行文档对象的持久化存储是一个很不错的选择...

Elasticsearch数据迁移方案(elasticsearch copyto)

前言最近小编要去给客户部署一套系统涉及到了Mysql和ES数据的迁移,下面就给大家分享一下ES数据迁移的几套方案,根据具体的使用场景来选择不同的迁移方案能使你事倍功半,话多说下面就一一介绍。Elast...

Rancher部署单体ElasticSearch(rancher2.5部署)

Rancher是k8s图形管理界面,之前曾有写文章介绍如何安装。ElasticSearch是热门搜索引擎,很多地方都有用到,常规安装部署略显繁琐,本文介绍在k8s下用rancher简易部署ES。1.在...

Elasticsearch在Java项目的搜索实践:从零开始构建高效搜索系统

Elasticsearch在Java项目中的搜索实践:从零开始构建高效搜索系统在现代的Java项目中,数据量激增,传统的数据库查询方式已经无法满足快速检索的需求。这时,Elasticsearch(E...

小白入门-Kibana安装(kibana安装配置)

一Kibana基础1.1介绍Kibana是一款免费且开放的前端应用程序,其基础是ElasticStack,可以为Elasticsearch中索引的数据提供搜索和数据可视化功能。Kiban...

Docker上使用Elasticsearch,Logstash,Kibana

在对一个项目做性能测试时我需要处理我们web服务器的访问日志来分析当前用户的访问情况。因此,我想这是试用ELK的一个好机会。ELK栈首先要注意的是使用它是非常简单的。从决定使用ELK到在本机上搭一个...

取消回复欢迎 发表评论: