CentOS服务器上的 git 包版本控制

简介: 本文衔接上文"记录一次无聊的(经历了Nodejs -> Shell -> C)的探索问题过程",服务器上git版本是1.8.3.1,使用的pm2来管理nodejs进程,并且配置了一键deploy项目。在deploy执行过程中,新版本的pm2 => pm2-deploy的shell中没对git老版本做兼容,上文提到解决方案:1. pm2-deploy做兼容,相关shell例子也已给出2. 升级服务器git版本本文围绕一次 git 升级操作展开,并且分享此次过程的操作知识点。

本文衔接上文"记录一次无聊的(经历了Nodejs -> Shell -> C)的探索问题过程",服务器上git版本是1.8.3.1,使用的pm2来管理nodejs进程,并且配置了一键deploy项目。在deploy执行过程中,新版本的pm2 => pm2-deploy的shell中没对git老版本做兼容,上文提到解决方案:

1. pm2-deploy做兼容,相关shell例子也已给出

2. 升级服务器git版本

本文围绕一次 git 升级操作展开,并且分享此次过程的操作知识点。下面两种方案都可以升级服务器上的 git 版本,同时也适用于大多数的软件~

更换Yum源

Yum(全称为 Yellow dog Updater, Modified)是一个在Fedora和RedHat以及CentOS中的Shell前端软件包管理器。

如果没有,可以下载,官网地址:http://yum.baseurl.org/

如果有自己心仪的Yum源(里面有爽爽的较新且稳定的版本软件包),便可以通过更换Yum源来install各个软件。

阿里云服务器的开源镜像地址是:http://mirrors.aliyun.com/

国内还有网易的开源镜像:http://mirrors.163.com/

还有sohu的开源镜像:http://mirrors.sohu.com/

如果对上面的三个都不感兴趣,那么这个网站提供了更多的yum源(国内国外):https://www.centos.org/download/mirrors/

在Yum源地址内,也都提供了filelist.gz文件,供使用者查看该开源镜像内所对应的资源列表,如在网易的地址http://mirrors.163.com/centos/ 下就有个filelist.gz文件。

更换Yum源操作命令如下:

# 进入文件夹
cd /etc/yum.repos.d/

# 看看有哪些文件,瞧一眼,安安心
ls

# 创建备份 有备无患
mkdir backup
mv CentOS-Base.repo backup/CentOS-Base.repo

# 下载源 这里不管是下载了复制到这个文件夹还是wget命令操作,个人喜好
wget http://mirrors.163.com/.help/CentOS7-Base-163.repo

# 清理下缓存 这步和实现过程的影响不大,只是清理下原先的软件包
yum clean all

# 简陋元数据的缓存,保障之后下载是用这个源的
yum makecache

# 然后执行下面命令试试 现在下载的就是新的源所对应的资源了
yum install git

好了,就这简单,就能使用新的源来安装软件包了...

em… 至于其他的yum命令操作,完全可以看看官网的说明,简单易懂。

通过编译源码包来build软件

该方法比较实在,适用喜欢尝鲜的小伙伴们,比如 xxx 软件/扩展更新了功能,但官方确不见发布软件包的迹象,好紧张,如何才能趁热来一发?于是便可以通过下载这个软件的源码包,通过编译+配置先尝尝鲜了~

以本文主题升级 git 版本为例,操作如下:

# 通过git –version查看现有版本
git --version
git version <original version>

# 卸载原来的git
yum remove git

# 下载gcc编译器及MakeMaker
yum install gcc perl-ExtUtils-MakeMaker

# 首先先看看源码包里的文件 git.spec ,根据 BuildRequires 下载编译时需要用到的扩展包
# https://pkgs.org/   linux 扩展包下载地址
yum install curl-devel expat-devel gettext-devel openssl-devel zlib-devel

# 下载->解压->进入源码包
cd /usr/src
wget https://www.kernel.org/pub/software/scm/git/git-<version>.tar.gz
tar xzf git-<version>.tar.gz
cd git-<version>

# 使用 make 命令来编译源码文件并输出到指定文件夹下 
make prefix=/usr/local/git-<version> all
make prefix=/usr/local/git-<version> install

# 添加新版本 git 的环境变量并应用
echo "export PATH=$PATH:/usr/local/git-<version>/bin" >> /etc/bashrc
source /etc/bashrc

# 查看版本号
git --version
git version -<version>

因为我们编译和配置环境变量时指定了版本(git-<version>),所以我们可以通过修改$PATH来达到手动切换git版本的操作,同理可得node的版本间手动切换和管理...

完成 …

最近这段时间觉得代码真是越写越起劲,学了也多分享下~ 同时也是当做笔记,差记性总是比不过好笔头的~

 

相关文章
|
10天前
|
存储 运维 网络协议
【Syslog】Centos下的syslog服务器配置
通过本文的配置指导,您不仅学会了如何安装和配置 `rsyslog`,还掌握了如何在防火墙中开放必要的端口,并验证服务器的配置是否正确。希望这些知识能够帮助您更好地管理和维护您的Linux系统。
64 15
|
2月前
|
存储 开发工具 git
[Git] 深入理解 Git 的客户端与服务器角色
Git 的核心设计理念是分布式,每个仓库既可以是客户端也可以是服务器。通过 GitHub 远程仓库和本地仓库的协作,Git 实现了高效的版本管理和代码协作。GitHub 作为远程裸仓库,存储项目的完整版本历史并支持多客户端协作;本地仓库则通过 `.git` 文件夹独立管理版本历史,可在离线状态下进行提交、回滚等操作,并通过 `git pull` 和 `git push` 与远程仓库同步。这种分布式特性使得 Git 在代码协作中具备强大的灵活性和可靠性。
78 18
[Git] 深入理解 Git 的客户端与服务器角色
|
2月前
|
网络安全 Apache 开发工具
图解Git——服务器上的Git《Pro Git》
Git 远程仓库及通信协议简介:远程仓库为团队协作提供平台,支持共享代码。常见形式为裸仓库,仅保存 Git 元数据。Git 支持多种协议,包括本地协议(适合局域网)、HTTP/HTTPS(推荐智能 HTTP,安全易用)、SSH(企业内部协作首选)和 Git 协议(高效只读访问)。选择协议需根据协作需求、安全性和配置难度权衡。此外,搭建 Git 服务器涉及创建裸仓库、上传至服务器、初始化共享仓库等步骤。生成 SSH 公钥、配置服务器及使用 GitWeb 或 GitLab 等工具可进一步增强功能。第三方托管服务如 GitHub 提供便捷的托管选项,适合快速启动和开源项目。总结而言,自行运行服务器提
62 11
|
2月前
|
安全 大数据 Linux
云上体验最佳的服务器操作系统 - Alibaba Cloud Linux | 飞天技术沙龙-CentOS 迁移替换专场
本次方案的主题是云上体验最佳的服务器操作系统 - Alibaba Cloud Linux ,从 Alibaba Cloud Linux 的产生背景、产品优势以及云上用户使用它享受的技术红利等方面详细进行了介绍。同时,通过国内某社交平台、某快递企业、某手机客户大数据业务 3 大案例,成功助力客户实现弹性扩容能力提升、性能提升、降本增效。 1. 背景介绍 2. 产品介绍 3. 案例分享
|
4月前
|
测试技术 持续交付 开发工具
Git版本控制在团队协作中具有重要作用
Git版本控制在团队协作中具有重要作用
58 1
|
4月前
|
数据可视化 开发工具 git
如何解决 Git 版本控制系统中冲突的问题?
在Git版本控制系统中,冲突是指在合并或拉取操作时,两个或多个开发者对同一文件的同一部分进行了不同的修改,导致Git无法自动确定应该采用哪种修改。
92 1
|
4月前
|
Ubuntu 开发工具 git
Git高手必备:掌握这些版本控制最佳实践,让你的代码管理效率翻倍!
【10月更文挑战第25天】使用 Git 进行版本控制是现代软件开发的重要部分。本文详细介绍了 Git 的安装、配置、基本操作、分支管理、冲突解决及常用命令,帮助开发者提高工作效率,确保代码质量和团队协作的顺利进行。通过合理使用 Git,可以有效管理代码变更,支持多人协作,并追踪历史记录。
208 4
|
4月前
|
开发工具 C# git
C#一分钟浅谈:Git 版本控制与 GitFlow 工作流
【10月更文挑战第22天】本文介绍了 Git 和 GitFlow 的结合使用,从基础概念到具体操作,涵盖了安装配置、基本命令、GitFlow 工作流的核心分支和流程示例。同时,文章还讨论了常见的问题和易错点,如忽略文件、冲突解决、回退提交和分支命名规范,并提供了代码案例。通过学习本文,读者可以更好地理解和应用 Git 及 GitFlow,提高团队协作效率。
103 1
|
4月前
|
存储 项目管理 开发工具
掌握Git版本控制,提升团队协作效率
掌握Git版本控制,提升团队协作效率
105 0
|
4月前
|
开发工具 git
掌握Git版本控制,提升团队协作效率
掌握Git版本控制,提升团队协作效率

热门文章

最新文章