当前位置:首页 > 技术文章 > 正文内容

源码安装包管理

arlanguage4个月前 (12-23)技术文章34

  • 1. 源码包基本概述
  • 2. 源码包的好处
  • 3. 源码包的获取
  • 4. 源码包分类
  • 5. 源码包的安装5.1 configure脚本的功能5.2 编译安装注意事项5.3 源码包编译实例

1. 源码包基本概述

在linux环境下面安装源码包是比较常见的, 早期运维管理工作中,大部分软件都是通过源码安装的。那么安装一个源码包,是需要我们自己把源代码编译成二进制的可执行文件。

源码包的编译用到了linux系统里的编译器,通常源码包都是用C语言开发的,这也是因为C语言为linux上最标准的程序语言。Linux上的C语言编译器叫做gcc,利用它就可以把C语言变成可执行的二进制文件。所以如果你的机器上没有安装gcc就没有办法去编译源码。可以使用yum -y install gcc来完成安装。

2. 源码包的好处

  • 自定义修改源代码
  • 定制需要的相关功能
  • 新版软件优先更新源码

3. 源码包的获取

官方网站, 可以获得最新的软件包
Apache官方网站
Nginx官方网站
Mysql官方网站

4. 源码包分类

  • 源码格式(需要编译安装)
  • 二进制格式(解压后可以直接使用)

5. 源码包的安装

编译需要编译环境,开发环境,开发库,开发工具。
常用的编译环境有c、c++、perl、java、python5种
c环境的编译器:gcc(GNU C Complier)
c++环境的编译器:g++
make:c、c++的统一项目管理工具,编译时有可能调用gcc也有可能调用g++。使用makefile文件定义make按何种次序去编译源程序文件中的源程序

源码安装三部曲(常见):
第一步: ./configure(定制组件)

1.指定安装路径,例如 --prefix=/opt/nginx-1.12
2.启用或禁用某项功能, 例如 --enable-ssl
3.和其它软件关联,例如--with-pcre
4.检查安装环境,例如是否有编译器 gcc,是否满足软件的依赖需求
5.检测通过后生成Makefile文件

第二步: make

1.执行make命令进行编译, 可以使用-j指定CPU核心数进行编译
2.按Makefile文件进行编译, 编译成可执行二进制文件
3.生成各类模块和主程序

第三步: make install

1.按Makefile定义好的路径拷贝至安装目录中

上面介绍的源码三部曲不能百分百通用于所有源码包, 也就是说源码包的安装并非存在标准安装步骤,但是大部分源码安装都是类似的步骤

建议:
拿到源码包解压后,然后进入到目录找相关的帮助文档,通常会以INSTALL或者README为文件名

5.1 configure脚本的功能

  • 让用户选定编译特性
  • 检查编译环境是否符合程序编译的基本需要

5.2 编译安装注意事项

  • 如果安装时不是使用的默认路径,则必须要修改PATH环境变量,以能够识别此程序的二进制文件路径;修改/etc/profile文件或在/etc/profile.d/目录建立一个以.sh为后缀的文件,在里面定义export PATH=$PATH:/path/to/somewhere
  • 默认情况下,系统搜索库文件的路径只有/lib,/usr/lib增添额外库文件搜索路径方法:在/etc/ld.so.conf.d/中创建以.conf为后缀名的文件,而后把要增添的路径直接写至此文件中。此时库文件增添的搜索路径重启后有效,若要使用增添的路径立即生效则要使用ldconfig命令ldconfig:通知系统重新搜索库文件

/etc/ld.so.conf和/etc/ls.so.conf.d/*.conf //配置文件

/etc/ld.so.cache //缓存文件

-v //显示重新搜索库的过程

-p //打印出系统启动时自动加载并缓存到内存中的可用库文件名及文件路径映射关系

  • 头文件:输出给系统默认:系统在/usr/include中找头文件,若要增添头文件搜索路径,使用链接进行
  • man文件路径:安装在--prefix指定的目录下的man目录默认:系统在/usr/share/man中找man文件。此时因为编译安装的时候不是安装到默认路径下,如果要查找man文件则可以使用以下两种方法:man -M /path/to/man_dir command在/etc/man_db.conf文件中添加一条MANPATH

5.3 源码包编译实例

下面通过编译安装nginx来深入理解源码包安装

//1.基础环境准备

[root@localhost ~]# yum -y install gcc gcc-c++ make wget

//2.下载源码包(源码包一定要上官方站点下载,其他站点不安全)

[root@localhost ~]# cd /usr/src

[root@localhost src]# wget http://nginx.org/download/nginx-1.12.2.tar.gz

//3.解压源码包,并进入相应目录

[root@localhost src]# tar xf nginx-1.12.2.tar.gz

[root@localhost src]# cd nginx-1.12.2

//4.配置相关的选项,并生成Makefile

[root@localhost nginx-1.12.2]# ./configure --help|head

--help print this message

--prefix=PATH set installation prefix

--sbin-path=PATH set nginx binary pathname

--modules-path=PATH set modules path

--conf-path=PATH set nginx.conf pathname

--error-log-path=PATH set error log pathname

--pid-path=PATH set nginx.pid pathname

--lock-path=PATH set nginx.lock pathname

//后面的内容省略了,使用 ./configure --help 命令查看可以使用的选项//一般常用的有 --prefix=PREFIX 这个选项的意思是定义软件包安装到哪里//建议,源码包都是安装在/opt/目录下

//5.指定编译参数

[root@localhost nginx-1.12.2]# ./configure --prefix=/opt/nginx-1.12.2

//6.验证这一步命令是否成功, 非0的都不算成功

[root@localhost nginx-1.12.2]# echo $?0

//7.编译并安装

[root@localhost nginx-1.12.2]# make

[root@localhost nginx-1.12.2]# make install

[root@localhost nginx-1.12.2]# echo $?

//8.建立软链接

[root@localhost nginx-1.12.2]# ln -s /opt/nginx-1.12.2 /opt/nginx

源码编译报错信息处理

checking for C compiler ... not found ./configure: error: C compiler cc is not found

//解决方案

[root@localhost ~]# yum -y install gcc gcc-c++ make

./configure: error: the HTTP rewrite module requires the PCRE library.

You can either disable the module by using --without-http_rewrite_moduleoption, or install the PCRE library into the system, or build the PCRE library

statically from the source with nginx by using --with-pcre=<path> option.

//解决方案

[root@localhost ~]# yum install -y pcre-devel

./configure: error: the HTTP gzip module requires the zlib library.

You can either disable the module by using --without-

http_gzip_module option, or install the zlib library into the

system, or build the zlib library statically from the source with

nginx by using --with-zlib=<path> option.

//解决方案:

[root@localhost ~]# yum -y install zlib-devel

./configure: error: SSL modules require the OpenSSL library.

You can either do not enable the modules, or install the OpenSSL

library into the system, or build the OpenSSL library staticallyfrom the source with nginx by using --with-openssl=<path> option.

//解决方案

[root@localhost ~]# yum -y install openssl-devel

扫描二维码推送至手机访问。

版权声明:本文由AR编程网发布,如需转载请注明出处。

本文链接:http://www.arlanguage.com/post/374.html

分享给朋友:

“源码安装包管理” 的相关文章

Nginx负载均衡的一些安全配置说明

在之前的几篇文章里,我们都说到了负载均衡,而负载均衡的转发服务器使用了Nginx,但是我们没有详细的对Nginx的安全配置做一个分析,如果对负载均衡的知识比较有兴趣,欢迎订阅我的头条号:一点热,然后再阅读我之前的文章。快速入口java项目如何实现单一的nginx负载均衡关于Nginx的一些安全设置,...

使用Keepalived实现Nginx的自动重启及双主热备高可用

推荐阅读:20年清华架构师耗时整整一百天打造1000+道Java高频面试手册1、概述之前我们使用Keepalived实现了Nginx服务的双机主备高可用,但是有几个问题没有解决,今天一起探讨一下。1)在双机主备机制中,Keepalived服务如果宕了,会自动启用备机进行服务,但Nginx服务如果负载...

如何让Nginx后端服务收到真实的客户IP?

背景开发有一个服务部署在阿里云上,依赖阿里云的CLB(传统型负载均衡)暴露服务,因特殊要求,CLB和后端服务之间需要通过自建Nginx做代理,拓扑图如下,应用拓扑操作客户端的请求经过了两层代理,这里CLB和Nginx都要做配置。1,配置CLBCLB的配置比较简单,在配置“监听”时,要附加“X-For...

基于 consul + nginx 的Spring boot微服务集群部署

consul + nginx 负载均衡最近做的基于consul的微服务项目,仅仅在单机上部署了一套,压测的时候扛不住(并发太高的时候linux文件连接数超过上限),于是想办法搞个集群部署。最终在我们的服务器的三台机器(mirage05-mirage07)上完成部署。一. 背景介绍以及项目现状1. c...

如何让Nginx更安全? nginx怎么保证高可用

网络安全的重要性不言而喻。那么小伙伴们有没有在日常使用 Nginx 的时候,特意去关注下它的安全配置呢?今天松哥和小伙伴们讨论一下如何安全的使用 Nginx,给大伙几个建议。一 使用最新版建议使用最新版的 Nginx,对于已经部署的 Nginx,要及时更新到最新版本,以确保所有已知的安全漏洞都已修补...

K8S灰度环境频繁出现502 k8s ingress 灰度发布

公司一个需求版本开发、测试结束,升级到灰度环境之后频繁出现502公司使用的是php + nginx 所以分析也是按照这个方向来分析的。nginx报错:NGINX ERROR 10.9.95.75 !!!2020/07/21 17:05:12 [error] 7#7: *38808 recv() fa...