CentOS 6.x 编译安装 Nginx

nginx [engine x] is an HTTP and reverse proxy server, a mail proxy server, and a generic TCP/UDP proxy server, originally written by Igor Sysoev. For a long time, it has been running on many heavily loaded Russian sites including Yandex, Mail.Ru, VK, and Rambler. According to Netcraft, nginx served or proxied 24.68% busiest sites in June 2018. Here are some of the success stories: Dropbox, Netflix,Wordpress.com, FastMail.FM.

摘自 nginx 官网http://nginx.org/en/的一段话,可以看到 nginx 是一个 HTTP 的代理服务器及反向代理服务器,邮件代理服务器,TCP/UDP 代理服务器,负载均衡器等,功能甚是强大。

一、系统环境


OS:CentOS 6.7 x64

Nginx:1.10.2

二、安装 Nginx


1 依赖安装

(1) 安装 gcc

由于是编译安装,因此,需要 gcc 的编译环境,执行如下命令,查看是否已经安装了 gcc

gcc -v

如果没有安装 gcc,执行如下命令安装:

[root@lab1 php]# yum -y install gcc

安装完成后,执行 gcc -v 可以看到版本信息

[root@lab1 php]# gcc -v

Using built-in specs.

Target: x86_64-redhat-linux

Configured with: ../configure --prefix=/usr --mandir=/usr/share/man --infodir=/usr/share/info --with-bugurl=[http://bugzilla.redhat.com/bugzilla](http://bugzilla.redhat.com/bugzilla) --enable-bootstrap --enable-shared --enable-threads=posix --enable-checking=release --with-system-zlib --enable-__cxa_atexit --disable-libunwind-exceptions --enable-gnu-unique-object --enable-languages=c,c++,objc,obj-c++,java,fortran,ada --enable-java-awt=gtk --disable-dssi --with-java-home=/usr/lib/jvm/java-1.5.0-gcj-1.5.0.0/jre --enable-libgcj-multifile --enable-java-maintainer-mode --with-ecj-jar=/usr/share/java/eclipse-ecj.jar --disable-libjava-multilib --with-ppl --with-cloog --with-tune=generic --with-arch_32=i686 --build=x86_64-redhat-linux

Thread model: posix

gcc version 4.4.7 20120313 (Red Hat 4.4.7-18) (GCC)

(2) 安装 pcre/zlib/openssl

root 用户执行如下命令安装 pcre/zlib/openssl

yum -y install pcre pcre-devel  

yum -y install zlib zlib-devel

yum -y install openssl openssl-devel

注:第(1) (2) 步也可以执行一条综合命令来一起安装

yum -y install gcc zlib zlib-devel pcre pcre-devel openssl openssl-devel

2 安装 Nginx

(1) 下载 nginx 源码

nginx 官方下载地址:

http://nginx.org/download/

此处选择1.10.2 版本, root 用户执行如下命令,下载 nginx 源码包

[root@lab1 nginx]# pwd

/opt/nginx

[root@lab1 nginx]# wget http://nginx.org/download/nginx-1.10.2.tar.gz

注:如果使用其他版本,将上方的 1.10.2 更改为其他版本即可,前提是官方有对应的版本...

(2) 解压

[root@lab1 nginx]# pwd

/opt/nginx

[root@lab1 nginx]# ls

nginx-1.10.2.tar.gz

[root@lab1 nginx]# tar zxf nginx-1.10.2.tar.gz

(3) 编译、安装

root 用户执行如下命令编译 nginx 源码:

[root@lab1 nginx]# cd nginx-1.10.2

[root@lab1 nginx-1.10.2]# pwd

/opt/nginx/nginx-1.10.2

[root@lab1 nginx-1.10.2]# ./configure --prefix=/usr/local/nginx --with-http_stub_status_module --with-http_ssl_module

编译成功:

注:

(1) 上面指定了编译目录, --prefix=/usr/local/nginx 表示编译到 /usr/local/nginx 环境,此时并不会生成 /usr/local/nginx 目录。

(2) 如果不指定路径,默认安装在 /usr/local/nginx 中

(3) 安装完成后(make install),可以使用 whereis nginx 来查询安装位置

(4) --with-httpstubstatusmodule --with-httpssl_module 表示添加 http status 模块以及 http ssl 模块

root 继续执行如下命令安装:

[root@lab1 nginx-1.10.2]#

[root@lab1 nginx-1.10.2]# pwd

/opt/nginx/nginx-1.10.2

[root@lab1 nginx-1.10.2]# make && make install

执行如下命令查看 nginx 安装位置:

[root@lab1 nginx-1.10.2]# whereis nginx

nginx: /usr/local/nginx

至此,nginx 已经成功安装

三、nginx 常用命令


1 测试配置文件

在 nginx 安装路径下的 sbin 中执行 ./nginx -t,进行配置文件测试,如下所示:

[root@lab1 sbin]# pwd

/usr/local/nginx/sbin

[root@lab1 sbin]# ./nginx -t

nginx: the configuration file /usr/local/nginx/conf/nginx.conf syntax is ok

nginx: configuration file /usr/local/nginx/conf/nginx.conf test is successful

2 启停命令

启动:安装路径下的 sbin 下执行 ./nginx

[root@lab1 sbin]# pwd

/usr/local/nginx/sbin

[root@lab1 sbin]# ./nginx

停止:安装路径下的 sbin 下执行 ./nginx -s stop 或者 ./nginx -s quit

[root@lab1 sbin]# pwd

/usr/local/nginx/sbin

[root@lab1 sbin]# ./nginx -s stop

[root@lab1 sbin]# ./nginx -s quit

重启:安装路径下的 sbin 下执行 ./nginx -s reload

[root@lab1 sbin]# pwd

/usr/local/nginx/sbin

[root@lab1 sbin]# ./nginx -s reload

平滑重启: kill -HUP [nginx 主进程号]

[root@lab1 sbin]# ps -ef|grep nginx|grep master|awk '{print $2}'|xargs kill -HUP

3 配置防火墙

root 用户执行如下命令,编辑防火墙规则文件

[root@lab1 sbin]# vim /etc/sysconfig/iptables

在 22 端口配置的下方添加如下行:

-A INPUT -m state --state NEW -m tcp -p tcp --dport 80 -j ACCEPT

root 用户执行如下命令重启防火墙:

[root@lab1 sbin]# vim /etc/sysconfig/iptables

[root@lab1 sbin]# service iptables restart

iptables: Setting chains to policy ACCEPT: filter          [  OK  ]

iptables: Flushing firewall rules:                         [  OK  ]

iptables: Unloading modules:                               [  OK  ]

iptables: Applying firewall rules:                         [  OK  ]

4 验证 nginx

查看进程:

[root@lab1 sbin]# ps -ef|grep nginx

root       8917      1  0 12:47 ?        00:00:00 nginx: master process ./nginx

nobody     8934   8917  0 12:48 ?        00:00:00 nginx: worker process

root       8990   1477  0 12:51 pts/1    00:00:00 grep nginx

浏览器中输入:

http://192.168.56.130/

如出现以下内容,表示 nginx 运行正常:

附录一:配置 nginx 环境变量


root 用户编辑系统环境变量文件:

[root@lab1 sbin]# vim /etc/profile

在文件末尾添加如下信息,并保存退出:

##### nginx #####

export NGINX_HOME=/usr/local/nginx

export PATH=$NGINX_HOME/sbin:$PATH

注:

(1) /usr/local/nginx 与安装的 nginx 所在目录保存一致,可以使用 whereis nginx 查看 nginx 的安装目录

root 用户执行如下命令,使环境变量生效:

[root@lab1 sbin]# source /etc/profile

验证:

root 用户执行如下命令,查看 PATH 中是否有 nginx 的目录

[root@lab1 sbin]# echo $PATH

/usr/local/nginx/sbin:/opt/hbase/hbase-1.3.1/bin:/opt/hadoop/hadoop-2.7.4/bin:/opt/storm/apache-storm-1.0.4/bin:/opt/zookeeper/zookeeper-3.4.10/bin:/usr/java/jdk1.8.0_20/bin:/opt/hbase/hbase-1.3.1/bin:/opt/hadoop/hadoop-2.7.4/bin:/opt/storm/apache-storm-1.0.4/bin:/opt/zookeeper/zookeeper-3.4.10/bin:/usr/java/jdk1.8.0_20/bin:/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin:/root/bin

配置环境变量以后,就可以在任何目录下直接执行 nginx 了

nginx #启动nginx

nginx -s stop    #停止 nginx

nginx -s quit    #停止 nginx

ngins -s reload    #重启 nginx

附录二、开机自启动


添加 rc.local 脚本

root 用户编辑 /etc/rc.local 脚本,并添加如下内容,保存退出:

vi /etc/rc.local

# nginx config

/usr/local/nginx/sbin/nginx

示例:

注:

(1) /usr/local/nginx/sbin/nginx 该配置与你的 nginx 的安装目录相关,如果你的 nginx 安装在其他目录,那么你需要配置你自己的安装目录下的 sbin/nginx 命令。

(2) rc.local 脚本是在所有其他的初始化脚本执行完成之后才会执行。因此,配置在该脚本中的自启动服务可能有一部分延时。

本文分享自微信公众号 - Java大联盟(javaunion)

原文出处及转载信息见文内详细说明,如有侵权,请联系 yunjia_community@tencent.com 删除。

原始发表时间:2018-08-24

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏京程一灯

精通webpack的5大关键点

webpack 是一个现代 JavaScript 应用程序的静态模块打包器,是目前最流行的打包神器。

13320
来自专栏Python编程大咖

网友提问:如何保存知乎回答里的视频,Python大神亲自操刀实现

之前在知乎看到有人问如何保存知乎回答里的视频,于是想着写个脚本直接根据知乎回答的链接下载该回答里的视频,这样岂不是十分简单方便?(因为我看到那个提问下方的回答操...

26520
来自专栏张培跃

3、你能读得懂的TypeScript教程之函数

如果你指定了返回类型为void,却偏偏要返回值,那是在找死,一样不会编译通过,如:

11830
来自专栏京程一灯

Flutter 1.0正式发布!

在昨晚的 Flutter Live 2018上,Google 宣布Flutter 1.0正式发布。这是一个基于 Dart 的移动开发平台,旨在帮助开发者在 iO...

8820
来自专栏张培跃

1、TypeScript初识及环境搭建

TypeScript最近很火,有很多开源的项目也是由其开发的,如果你是一名前端开发工程师或准备要成为一名前端开发工程师的话,现在如果再不学习TypeScript...

11410
来自专栏京程一灯

Webpack5.0 新特性尝鲜实战 ?? [每日前端夜话0x37]

在老袁写这篇文章的时候,v5版本仍然处于早期阶段,可能仍然有问题。而且作为一个major版本,其中有一些breaking changes,可能会导致一些配置和插...

26530
来自专栏Android技术分享

原来FFmpeg这么有意思(一)

其实FFmpeg大家都耳熟能详的的一个东西了,知名的ijkplayer 就是有Bilibili开源出来的播放器也是基于FFmpeg做出来的。但是FFmpeg不仅...

39130
来自专栏Android技术分享

原来FFmpeg这么有意思 (二)

文章耽搁了两星期了,可能不少老铁已经忘了,上一篇文章的内容了,不妨回顾一下,之前的文章里面就简单的提及了FFmpeg的一些简单命令的用法,官方下载不同平台的静态...

15250
来自专栏Android技术分享

Android开发Gradle高级技巧、自定义Gradle Task、打包完成自动签名、执行Shell脚本

先说下为什么有这篇文章吧,最近在写一个应用需要进行系统签名;每次我都需要先将apk生成然后使用sign.jar和系统证书进行签名,非常的麻烦而且tmd还是搞两个...

61430
来自专栏Rude3Knife的后端开发专栏

[Docker]Docker部署Scrapy-redis分布式爬虫框架实践(整合Selenium+Headless Chrome网页渲染)

我的京东价格监控网站需要不间断爬取京东商品页面,爬虫模块我采用了Scrapy+selenium+Headless Chrome的方式进行商品信息的采集。

24120

扫码关注云+社区

领取腾讯云代金券

年度创作总结 领取年终奖励