程序包编译安装

一、几个概念

    1、开放源码

        程序代码,人类可能读懂的程序语言,但是计算机不能识别和执行;

    2、编译程序

        将程序代码翻译成计算机可以识别的语言;

    3、二进程程序 

        经过编译程序翻译后得到的可以被执行的程序文件。

二、编译源程序的步骤

    1、configure

        检测程序,并生成makefile文件,其检测的内容如下:

            是否有适合的编译程序;

            是否有本软件所需的函数库或其他需要的相关软件;

            操作系统平台是否支持些软件;

            内核的头定义文件是否存在。

        configure脚本的使用:

            1)获取帮助

                ./configure –help

            2)较通用的一些选项

            安装路径相关

                –prefix =/path/to/somewhere:指定安装路径

                –sysconfdir=/path/to/somewhere:指定配置文件安装路径

            指定启用/禁用的特征

                –enable -FEATURE:例如 –enable -fpm

                –disable -FEATURE:例如 –disable -sochet

            指定所依赖的功能 :程序或文件

                –with -FUNCTION [=/path/to/somewhere]

                –without -FUNCTION

    2、make

        根据makefile文件中所记录的内容,来对源码进行编译。

    3、make install 

        安装软件。

三、编译安装Nginx

    前提:在进行编译安装前必须安装gcc编译器。

    1、检查运行环境

1.png

        –prefix:指定nginx的安装路径;

        –conf-path:指定主配置文件的位置;

        –with-pcre:指定pcre源码包的位置;

        –with-zlib:指定zlib源码包的位置;

        注意:pcre和zlib都是源码包的位置,而不是安装的路径,如下图所示:

1.1.png

    2、编译程序(调用gcc)

2.png

    3、安装程序 

3.png

    4、启动nginx服务

4.png

        使用浏览器访问测试:

5.png

    5、安装后的配置

        1)让二进制程序直接运行,而无须输入路径

            在目录/etc/profile.d/中创建nginx.sh文件,内容如下:

6.png

            重新登录终端后,测试效果:

7.png8.png

        2)导出手册页(模拟)

            因为nginx没有man手册,我们只能假设nginx的man手册的路径为/usr/local/nginx/man,如果想使用man命令直接调用手册的话,可以进行以下操作:

            在/etc/man.config文件中加入一行,如下图所示:

9.png10.png

        3)导出库文件(模拟)

            在/etc/ld.so.conf.d/目录中创建nginx.conf文件

11.png            触发系统重新搜索所有的库文件并生成缓存:

12.png

        4)导出头文件(模拟)

            假设nginx的头文件在/usr/local/nginx/include目录中;

            系统找头文件的路径:/usr/include

            导出方式是创建链接文件:

                ln -sv /usr/local/nginx/include /usr/include/nginx

原创文章,作者:petmaster,如若转载,请注明出处:http://www.178linux.com/3975

(0)
petmasterpetmaster
上一篇 2015-05-11 14:11
下一篇 2015-05-11 14:18

相关推荐

  • iptables

    iptables简介   iptables 是与最新的 3.5 版本 Linux 内核集成的 IP 信息包过滤系统。如果 Linux 系统连接到因特网或 LAN、服务器或连接 LAN 和因特网的代理服务器, 则该系统有利于在 Linux 系统上更好地控制 IP 信息包过滤和防火墙配置。 iptables基础   规则(rules)其实就是网络管理员预定义的条…

    Linux干货 2017-02-16
  • 马哥教育网络班21期-第四周课程练习

    第四周作业 1、复制/etc/skel目录为/home/tuser1,要求/home/tuser1及其内部文件的属组和其它用户均没有任何访问权限。 [root@localhost ~]# cp -a /etc/skel /home/tuse1   [root@localhost …

    Linux干货 2016-07-17
  • Linux systemd管理

                                                      &nbsp…

    系统运维 2016-09-28
  • ftp的配置

    FTP服务器配置 VSFTP主配置文件路径:/etc/vsftpd/vsftpd.conf,重要参数: anonymous_enable=yes/no 是否允许匿名用户访问 anon_upload_enable=yes/no 是否允许匿名用户上传文件 anon_mkdir_write_enable=yes/no 是否允许匿名用户创建目录 anon_other…

    2017-10-16
  • LINUX课堂笔记(第二周)

    2018.03.12 rpm httpd*** service httpd start ab 模仿用户访问 cat /var/log/httpd/access_log curl 访问web服务 rev 字符颠倒显示 sort  -r 执行反方向(由上至下)整理  -R 随机排序  -n 执行按数字大小整理  -f 选项忽略(fold)字符串中的字符大…

    Linux干货 2018-03-17
  • 20160803普通权限与特殊权限及umask

    权限     任何一个可执行程序文件能不能启动为进程,取决发起者对程序文件是否拥有执行权限.即权限决定用户对文件或者目录的使用范围.在Linux系统中,root的权限是最高的,可操作的权限最大,通常情况下root账号只用于管理系统的重要信息,并不做日常维护工作,所以正确设定用户的权限对系统的安全性尤为重要. 普通权限: 文件目录只针对三类…

    Linux干货 2016-08-04

评论列表(1条)

  • stanley
    stanley 2015-05-11 14:16

    干净,清爽,赞