Linux入职基础-7.12_编译小结

本文详细介绍了GCC编译器的工作流程,包括-c选项的作用、不同类型的库文件及其生成方式,以及库搜索路径等关键技术要点。

编译小结

1、gcc编译选项-c 加与不加的区别

gcc  –c  hell.c mian.c

gcc  hell.c  main.c

gcc  hell.c main.c  -o testhello

如果加-c选项:

GNU汇编器将源文件转化为目标代码之后就结束, 只调用了C编译器(ccl)和汇编器(as), 而连接器(ld)并没有被执行。

如果不加-c选项:

gcc默认会将源文件编译连接生成可执行文件,这过程调用C编译器(ccl)、GNU汇编器(as)和连接器工具(ld)。

文件的名称由-o选项指定,否则默认输出a.out。

2、Applications(应用程序)

Applications通常是有固定的目录,

/usr/bin:系统通用程序放在,这里有GNU的编译器gcc

/usr/local/bin或者/opt:系统管理员在本地计算机安装的程序通常放在这目录下。

/usr/local : 个人用到的程序都放在此目录。

当升级或者重装系统的时候,只要把/usr/local的程序备份一下就可以了。

3、Head Files(头文件)

/usr/include:对于C语言,头文件基本位于此目录和它的子文件夹下。

/usr/include/X11 :X Window系统库函数

/usr/include/g++ :GNU C++的库函数分布。

如果想引用位于标准位置之外的头文件,我们需要在调用编译器的时候加上-I标志,来显式的说明头文件所在文件夹。如下:

gcc-I/usr/include hello.c

4、Library Files(库文件)

/lib以及/usr/lib :系统调用的标准库函数存放这里,C编译器默认查找这里。.a 指静态链接库;.so 指动态链接库。

库函数通常放在标准位置,但我们也可以通过-L标识符,来添加新的搜索文件夹,-l指定特定的库函数文件。比如:

gcc -o x11fred-L/usr/lib  x11fred.c  -lX11

5、库有关环境变量

LIBRARY_PATH环境变量:指定程序静态链接库文件搜索路径

LD_LIBRARY_PATH环境变量:指定程序动态链接库文件搜索路径

6、Linux库的小结:

6.1、库的种类

linux下的库有两种:静态库和共享库(动态库)。

二者的不同点在于代码被载入的时刻不同。

静态库的代码在编译过程中已经被载入可执行程序,因此体积较大。

共享库的代码是在可执行程序运行时才载入内存的,在编译过程中仅简单的引用,因此代码体积较小。

6.2、库的命名

静态库的名字一般为libxxxx.a,其中xxxx是该lib的名称。

动态库的名字一般为libxxxx.so.major.minor,xxxx是该lib的名称,major是主版本号, minor是副版本号。

6.3、库的生成

静态库的后缀是.a,它的产生分两步

Step 1.由源文件编译生成一堆.o,每个.o里都包含这个编译单元的符号表

Step 2.ar命令将很多.o转换成.a,成为静态库。

动态库的后缀是.so,它由gcc加特定参数编译产生。

6.1、库搜索路径顺序

在linux下,库文件一般放在/usr/lib和/lib下。

静态库链接时搜索路径顺序:

1. ld会去找GCC命令中的参数-L

2. 再找gcc的环境变量LIBRARY_PATH

3. 再找内定目录 /lib /usr/lib /usr/local/lib 这是当初compile gcc时写在程序内的

动态链接时、执行时搜索路径顺序:

1. 编译目标代码时指定的动态库搜索路径;

2. 环境变量LD_LIBRARY_PATH指定的动态库搜索路径;

3. 配置文件/etc/ld.so.conf中指定的动态库搜索路径;

4. 默认的动态库搜索路径/lib;

5. 默认的动态库搜索路径/usr/lib。


### 配置和启动 Elasticsearch 7.12.0 #### 下载与解压软件包 为了在 Linux 上安装 Elasticsearch 7.12.0,需先从官方地址下载对应的版本: ```bash wget https://artifacts.elastic.co/downloads/elasticsearch/elasticsearch-7.12.0-linux-x86_64.tar.gz ``` 接着将压缩包移至目标位置并执行解压操作[^1]。 ```bash mv elasticsearch-7.12.0-linux-x86_64.tar.gz /usr/local/software/elasticsearch/ cd /usr/local/software/elasticsearch/ tar -xzvf elasticsearch-7.12.0-linux-x86_64.tar.gz ``` #### 设置挂载目录 对于持久化存储的需求,在 Docker 中部署时可以指定卷映射来保存数据。而在直接于主机操作系统运行的情况下,则应创建适当的数据路径供 Elasticsearch 使用[^2]。 ```bash mkdir -p /data/es/data chown -R 1000:1000 /data/es/data ``` 这里假设 `/data/es/data` 是所选的位置;同时赋予正确的权限给该文件夹以确保服务能够正常读写。 #### 修改配置文件 `elasticsearch.yml` 编辑位于 `<ES_HOME>/config/` 文件夹下的 `elasticsearch.yml` 来调整必要的参数设置[^3]。例如: ```yaml cluster.name: my-application node.name: node-1 path.data: /data/es/data bootstrap.memory_lock: true network.host: 0.0.0.0 discovery.type: single-node ``` 上述配置适用于单一节点环境测试用途,请依据实际生产需求修改相应选项。 #### 启动 Elasticsearch 完成以上准备工作之后就可以尝试启动 Elasticsearch 实例了。进解压后的 Elasticsearch 安装目录下找到 bin 子目录中的脚本来启动它。 ```bash cd /usr/local/software/elasticsearch/elasticsearch-7.12.0/bin ./elasticsearch & ``` 注意:由于安全原因,默认情况下不允许作为 root 用户启动此进程。如果遇到权限问题建议切换到非特权账户或者通过 systemd 创建服务单元来进行管理。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值