【Linux】Linux开发工具(yum、gdb、git)详解

简介: 【Linux】Linux开发工具(yum、gdb、git)详解

一、软件包管理器 yum

1、什么是软件包

  • 在 Linux 下安装软件,通常的办法是下载到程序的源代码,并进行编译,得到可执行程序。
  • 但这样太麻烦了,于是有些人把一些常用的软件提前编译好,做成软件包(可以理解成在 Windows 上的安装程序)放在一个服务器上,通过包管理器可以很方便的获取到这个编译好的软件包,直接进行安装。
  • 软件包和软件包管理器,就好比 "App" 和 “应用商店” 这样的关系。
  • yum(Yellow dog Updater, Modified) 是 Linux 下非常常用的一种包管理器。主要应用在 Fedora,RedHat,Centos 等发行版上。

Linux 下安装软件的方式:

  • 源代码安装。
  • rpm 包安装。
  • yum 工具(yum 是一条命令)。

【总结】

yum 是什么?

在 Linux 中下载资源的一种工具,类似于手机上的应用商店。

yum 可以为我们提供什么服务呢?
  • 查找、安装、卸载资源。
  • 解决依赖关系。

在手机应用商店上面搜索下载软件,本质是在该公司的后端服务器上搜索下载软件。

那么应用商店如何知道该去哪个服务器上下载软件呢?
  • 这个应用商店在本地一定有相关软件的配置信息(比如软件名和其对应的下载链接)。
  • 所以 yum 工具中一定也有配置文件,指明我们应该去哪里下载资源。

2、查看、安装和卸载软件包

(1)查看软件包(yum list

通过此命令可以罗列出当前一共有哪些软件包。由于包的数目非常之多,一般配合管道(grep 命令)筛选出我们关注的包。

例如:

$ sudo yum list | grep lrzsz

结果如下:

# 软件包的名称和版本
lrzsz.x86_64                             0.12.20-36.el7                @os 

注意

  • 第 1 列:软件包名称,主版本号.次版本号.源程序发行号-软件包的发行号.主机平台.cpu架构。
  • “x86_64” 后缀表示 64 位系统的安装包,“i686” 后缀表示 32 位系统安装包,选择包时要和系统匹配。
  • 第 2 列:“el7” 表示操作系统发行版的版本,“el7” 表示的是 centos7/redhat7。
  • 第 3 列:表示的是 “软件源” 的名称,即该软件包的发布方,类似于 “微信官网”,“华为应用商店” 这样的概念。

(2)安装软件(yum install
$ sudo yum install -y sl # 一个好玩的东西,可以在屏幕上跑一个小火车

yum 会自动找到都有哪些软件包需要下载,-y 表示直接安装,中途不需要确认。出现 complete! 的字样说明软件安装完成。

注意

  1. 安装软件时由于需要向系统目录中写入内容,一般需要 sudo 命令或者切到 root 账户下才能完成。
  2. yum 安装软件只能一个装完了再装另一个。在 yum 安装一个软件的过程中,如果再尝试用 yum 安装另外一个软件,yum 会报错。

(3)卸载软件(yum remove
$ sudo yum remove -y sl # 卸载sl软件以及它的依赖包

更新 yum 源

yum 的配置文件 /etc/yum.conf,这个一般不要去改动。

在 yum 配置路径下,会有 yum 源:

[ll@VM-0-12-centos 5]$ ls /etc/yum.repos.d/ # 查看yum源
CentOS-Base.repo  CentOS-Epel.repo  epel.repo  epel-testing.repo
 
# CentOS-Base.repo: yum源,要求软件可靠稳定才能放进yum源中,这里的软件版本迭代比较慢
# CentOS-Epel.repo: 扩展源,比如某个软件新开发的版本,就可以放到epel源中

在 CentOS-Base.repo 文件中可以进行软件源(即软件的下载链接)的配置,当你使用 yum install 安装软件时,就会去对应的服务器上下载软件。

执行 vim /etc/yum.repos.d/CentOS-Base.repo


3、关于 rz / sz 工具

(1)功能

这个工具用于本地 Windows 机器和远端的 Linux 服务器通过 XShell 传输文件。

安装完毕之后可以通过拖拽的方式将文件上传过去。

安装 rz / sz 工具:

$ sudo yum install -y lszrz  # lszrz是要安装的软件名称

安装完毕之后可以通过拖拽的方式将文件上传过去。


(2)用法

1、rz 命令,上传 Windows 中的文件到远端 Linux 服务器中:

$ rz # 运行该命令会弹出一个文件选择窗口,从本地选择文件上传到服务器,上传到服务器的路径为当前执行rz命令的目录。

2、sz 命令,将选定的文件发送到本地 windows 机器:

$ sz filename # filename是文件名

二、Linux 开发工具调试器 gdb

1、背景

  • 程序的发布方式有两种:debug 模式和 release 模式。
  • Linux gcc / g++ 出来的二进制程序,默认是 release 模式
  • 要使用 gdb 调试,必须在源代码生成二进制程序的时候, 加上 -g 选项。
$ gcc test.c -o test_debug -g

2、基本概念

  • 程序的发布的两种模式:
  • debug 模式(在生成可执行程序的时候,会加入调试信息,可调试)。
  • release 模式(没有调试信息,不可被调试)。

Linux gcc / g++ 编译生成的 release 版本和 debug 版本的可执行程序区别:


3、基本操作

gdb 命令格式:gdb [目标文件名]

这些基本操作中,常用操作都在下面举了例子,例子也是大致按照调试步骤来排列的。

  • list/l + 行号:显示程序源代码,接着上次的位置往下列,每次列 10 行。
(gdb) list 1  # 从第一行代码开始显示。接着按回车键,会继续往下显示代码,每次列10行。
  • list/l + 函数名:列出某个函数的源代码。(比如:l main 列出 main 函数的代码)
  • b / break + 行号在某一行设置断点。
(gdb) b 7
Breakpoint 1 at 0x400543: file test.c, line 7. # 断点1位于0x400543:文件test.c,第7行
  • break 函数名:在某个函数开头设置断点。(实际上是这个断点是打在该函数的第一行)
  • info b查看断点信息。当前设置了哪些断点。
(gdb) info b
Num     Type           Disp Enb Address            What
1       breakpoint     keep y   0x0000000000400543 in main at test.c:7  # 第7行
2       breakpoint     keep y   0x0000000000400555 in main at test.c:10 # 第10行
  • r 或 run:开始调试,如果没有设置断点,就直接运行结束。(断点打完了,该如何让程序执行起来,开始调试呢?相当于 VS 中的 F5
(gdb) r
Starting program: /home/ll/xxxx/test_debug 
 
Breakpoint 1, main () at test.c:7  # 此时来到了第一个断点处(第7行)
7   for (; i < 10; i++) {
(1)问题:此时我想跳到第二个断点去调试程序,该怎么办呢?
  • continue / c:从当前位置开始连续而非单步执行程序。(运行至下一个断点处停下来
(gdb) continue
Continuing.
 
Breakpoint 2, main () at test.c:10 # 此时来到了第二个断点处(第10行)
10    printf("sum = %d\n", sum);
  • n 或 next:单条执行。逐过程,不会进入函数,相当于 VS 中的 F10
(gdb) n
8     sum += i; # 单步执行,此时来到了第8行
  • s 或 step:进入函数调用。逐语句,会进入函数,相当于 VS 中的 F11
  • print / p + 变量打印变量值。
(gdb) p i
$1 = 3
(gdb) p sum
$2 = 3
(gdb) p &i
$3 = (int *) 0x7fffffffe44c
(gdb) p &sum
$4 = (int *) 0x7fffffffe448
(2)问题:我想要这些变量值随着调试的进行而不断变化,该怎么办呢?
  • display + 变量名设置常显示。跟踪查看一个变量,每次停下来都显示它的值。
(gdb) display i   # 跟踪查看变量i
1: i = 3
(gdb) display sum # 跟踪查看变量sum
2: sum = 3
(gdb) n    # 单步调试
7   for (; i < 10; i++) {
2: sum = 6 # 显示变量i的值,前面的2:是它的序号
1: i = 3   # 显示变量sum的值,前面的1:是它的序号
  • undisplay + 序号取消常显示。取消对先前设置的那些变量的跟踪。
(gdb) undisplay 2
(gdb) undisplay 1
  • delete breakpoint:删除所有断点
  • delete / d Num删除序号为 Num 的断点。
  • disable Num禁用断点。
  • enable Num启用断点。
  • until X(指定行号)跳转到第 X 行。
  • finish执行到当前函数返回,然后停下来等待命令。输入 finish 可直接结束当前函数调用,用此命令可以快速判断一个程序中到底是哪个函数出了 bug(此命令在非 main 函数中才有效)。
(gdb) finish 
Run till exit from #0  Sum (n=10) at test.c:4
0x0000000000400609 in main () at test.c:18
18    int sum = Sum(n);   # 结束Sum函数调用,直接返回函数结果
Value returned is $1 = 55 # Sum函数的返回值
  • print§:打印表达式的值,通过表达式可以修改变量的值或者调用函数(print 中可以执行各种表达式)。
  • set var i = 100:修改变量 i 的值(比如在调试过程中,有一个 if 语句本来该进去的,结果没进去,所以我怀疑是不是变量的值有问题,就通过这种方式来修改变量的值,观察它是否会进入这个 if 语句)。
  • bt / breaktrace:查看各级函数调用及参数(相当于 VS 中的查看调用堆栈)。
(gdb) bt     # 查看调用堆栈,main函数上面压的是SUm函数
#0  Sum (n=10) at test.c:4
#1  0x0000000000400609 in main () at test.c:18
  • info(i) locals:查看当前栈帧局部变量的值
  • q / quit退出 gdb。

注意:调试程序完毕,或者调试中间过程,调试痕迹很重要,当调试一个大的项目,可能有几十个断点,某个断点调试完了,不要直接把它删除,而是暂时禁用它,等程序没有任何问题了,再把所有断点删除。


三、Linux 开发工具分布式版本控制软件 git

1、背景

git 是一个分布式版本控制软件,最初由林纳斯·托瓦兹创作,于 2005 年以 GPL 许可协议发布。最初目的是为了更好地管理 Linux 内核开发而设计。


2、使用 git

(1)预备工作

安装 git:

$ sudo yum install -y git

在 gitee / github 创建新仓库,然后在创建好的仓库页面中复制远程仓库的地址 url,推荐 HTTPS。


(2)克隆远程仓库到本地
$ git clone [url] # 这里的url就是刚刚建立好的仓库的链接

执行命令后,输入 gitee / github 的用户名和密码,将会直接在本地创建一个放置代码的目录。

仓库中的内容(注意:不要修改隐藏文件 .git 里面的内容):


(3)把需要提交的代码拷贝到本地仓库

(4)三板斧(提交本地仓库文件到远程仓库)
# 添加所有文件到暂存区,将需要用git管理的文件告知git
$ git add .
 
# 提交文件到本地仓库,""中写提交日志,不能乱写,描述改动的详细内容
$ git commit -m "first commit"
 
# 推动本地仓库的文件到远程仓库,即同步到远端服务器上
$ git push origin master

最后的 "." 表示当前目录。

最后一步需要填入用户名密码。同步成功后,刷新页面就能看到代码改动了。

执行 git commit -m “msg” 时,会让你设置用户名和邮箱(每次 git 提交都会使用到该信息,它被永远的嵌入到了你的提交中):

$ git config --global user.email "you@example.com" # 邮箱
$ git config --global user.name "Your Name"        # 用户名

当依次执行三个命令后,输入 gitee/github 的用户名和密码,在 gitee/github 上的远程仓库刷新就可以看到自己的代码啦。


(5)配置免密码提交

git本地免密码和账号pull、push_没有git账号怎么拉代码-CSDN博客


(6)补充
$ git log    # 查看所有提交日志信息
$ git status # 查看本地仓库所有文件状态


相关实践学习
阿里云图数据库GDB入门与应用
图数据库(Graph Database,简称GDB)是一种支持Property Graph图模型、用于处理高度连接数据查询与存储的实时、可靠的在线数据库服务。它支持Apache TinkerPop Gremlin查询语言,可以帮您快速构建基于高度连接的数据集的应用程序。GDB非常适合社交网络、欺诈检测、推荐引擎、实时图谱、网络/IT运营这类高度互连数据集的场景。 GDB由阿里云自主研发,具备如下优势: 标准图查询语言:支持属性图,高度兼容Gremlin图查询语言。 高度优化的自研引擎:高度优化的自研图计算层和存储层,云盘多副本保障数据超高可靠,支持ACID事务。 服务高可用:支持高可用实例,节点故障迅速转移,保障业务连续性。 易运维:提供备份恢复、自动升级、监控告警、故障切换等丰富的运维功能,大幅降低运维成本。 产品主页:https://www.aliyun.com/product/gdb
相关文章
|
5月前
|
NoSQL Linux C语言
Linux GDB 调试
Linux GDB 调试
74 10
|
5月前
|
NoSQL Linux C语言
嵌入式GDB调试Linux C程序或交叉编译(开发板)
【8月更文挑战第24天】本文档介绍了如何在嵌入式环境下使用GDB调试Linux C程序及进行交叉编译。调试步骤包括:编译程序时加入`-g`选项以生成调试信息;启动GDB并加载程序;设置断点;运行程序至断点;单步执行代码;查看变量值;继续执行或退出GDB。对于交叉编译,需安装对应架构的交叉编译工具链,配置编译环境,使用工具链编译程序,并将程序传输到开发板进行调试。过程中可能遇到工具链不匹配等问题,需针对性解决。
193 3
|
5月前
|
NoSQL Linux 编译器
内核实验(一):使用QEMU+GDB断点调试Linux内核代码
如何配置环境并使用QEMU虚拟机结合GDB进行Linux内核代码的断点调试,包括安装QEMU、交叉编译工具链,编译内核以及通过GDB远程连接进行调试的详细步骤。
239 0
内核实验(一):使用QEMU+GDB断点调试Linux内核代码
|
7月前
|
NoSQL 编译器 Linux
【Linux】--- Linux编译器-gcc/g++、调试器-gdb、项目自动化构建工具-make/Makefile 使用
【Linux】--- Linux编译器-gcc/g++、调试器-gdb、项目自动化构建工具-make/Makefile 使用
112 0
|
8月前
|
NoSQL 搜索推荐 openCL
【C/C++ 调试 GDB指南 】gdb调试基本操作
【C/C++ 调试 GDB指南 】gdb调试基本操作
437 2
|
8月前
|
NoSQL Linux 开发工具
【深入解析git和gdb:版本控制与调试利器的终极指南】(下)
【深入解析git和gdb:版本控制与调试利器的终极指南】
112 0
|
2月前
|
NoSQL 编译器 C语言
C语言调试是开发中的重要技能,涵盖基本技巧如打印输出、断点调试和单步执行,以及使用GCC、GDB、Visual Studio和Eclipse CDT等工具。
C语言调试是开发中的重要技能,涵盖基本技巧如打印输出、断点调试和单步执行,以及使用GCC、GDB、Visual Studio和Eclipse CDT等工具。高级技巧包括内存检查、性能分析和符号调试。通过实践案例学习如何有效定位和解决问题,同时注意保持耐心、合理利用工具、记录过程并避免过度调试,以提高编程能力和开发效率。
56 1
|
5月前
|
NoSQL
技术分享:如何使用GDB调试不带调试信息的可执行程序
【8月更文挑战第27天】在软件开发和调试过程中,我们有时会遇到需要调试没有调试信息的可执行程序的情况。这可能是由于程序在编译时没有加入调试信息,或者调试信息被剥离了。然而,即使面对这样的挑战,GDB(GNU Debugger)仍然提供了一些方法和技术来帮助我们进行调试。以下将详细介绍如何使用GDB调试不带调试信息的可执行程序。
155 0
|
7月前
|
NoSQL Linux C语言
Linux gdb调试的时候没有对应的c调试信息库怎么办?
Linux gdb调试的时候没有对应的c调试信息库怎么办?
59 1
|
7月前
|
NoSQL Linux C语言
Linux gdb调试的时候没有对应的c调试信息库怎么办?
Linux gdb调试的时候没有对应的c调试信息库怎么办?
40 0