nginx安装

1. 安装依赖包和必要的库

1.1 安装依赖包

# yum -y install gcc gcc-c++ automake autoconf make libtool

这些依赖包是编译所必需的,如果yum上没有的话可以去下载源码来安装

1.2 安装必要的库

这些库都是nginx中一些功能模块所依赖的,如without-http_gzip_module需要zlib库来构建和运行此模块,http_rewrite_module需要pcre库来构建和运行此模块,http_ssl_module需要OpenSSL库来构建和运行此模块

1.安装pcre库(版本8.42)

# wget http://ftp.pcre.org/pub/pcre/pcre-8.42.tar.gz
# tar -zxvf pcre-8.42.tar.gz
# cd pcre-8.42
# ./configure
# make && make install# pcre-config --version

注:也可用 yum install pcre-devel 替代


2.安装zlib库(版本1.2.11)

# wget http://www.zlib.net/zlib-1.2.11.tar.gz
# tar -zxvf zlib-1.2.11.tar.gz
# cd zlib-1.2.11
# ./configure
# make && make install
  • 注:也可用 yum install zlib-devel 替代

3.安装OpenSSL(版本1.1.0h)


# wget https://www.openssl.org/source/openssl-1.1.0h.tar.gz
# tar -zxvf openssl-1.1.0h.tar.gz
# cd openssl-1.1.0h
# ./config
# make && make install
  • 注:也可用 yum install openssl-devel 替代

问题

在Centos7上编译安装openssl后,运行openssl version出现如下错误:

openssl: error while loading shared libraries: libssl.so.1.1: cannot open shared object file: No such file or directory

这是由于openssl库的位置不正确造成的。

解决方法:

在root用户下执行:

ln -s /usr/local/lib64/libssl.so.1.1 /usr/lib64/libssl.so.1.1
ln -s /usr/local/lib64/libcrypto.so.1.1 /usr/lib64/libcrypto.so.1.1


**以上三个可以用YUM安装**


 

# yum -y pcre-devel zlib-devel openssl-devl

2. 选择稳定nginx版本

centos的yum不提供nginx安装,通过配置官方yum源的方式获取到的也只是源码包。所以我们找到了Nginx官网看下官方提供的安装方式:Nginx源码包下载的官网地址(http://nginx.org/en/download.html) 
从官网上提供三个类型的版本,分别是Mainline version、Stable version、Legacy versions

  • Mainline version:Mainline 是 Nginx 目前主力在做的版本,可以说是开发版
  • Stable version:最新稳定版,生产环境上建议使用的版本
  • Legacy versions:遗留的老版本的稳定版

在这里我们选择Stable 版本的 nginx-1.12.2.tar.gz 

安装过程所执行的命令需要root权限,所以我们选择使用root用户安装。

2.1 添加用户和用户组

# groupadd -r www
# useradd -r -g www www

groups 查看当前登录用户的组内成员
groups www 查看www用户所在的组,以及组内成员
whoami 查看当前登录用户名

2.2 nginx编译选项详解

# wget http://nginx.org/download/nginx-1.12.2.tar.gz
# tar -zxvf nginx-1.12.2.tar.gz
# cd nginx-1.12.2.tar
# ./configure --help

可以在编译时./configure –help列出大部分常用模块和编译选项,列出的编译选项中以–without开头的都默认安装,以PATH结尾的需要手动指定依赖库源码目录。

【更多编译选项请查看】

完整编译指令

./configure \
--prefix=/usr/local/nginx \
--user=www \
--group=www \
--with-http_realip_module \
--with-http_ssl_module \--with-http_sub_module \
--with-http_stub_status_module \
--with-http_gzip_static_module \
--with-zlib=/data/soft/zlib/zlib-1.2.11 \
--with-pcre=/data/soft/pcre/pcre-8.42 \
--with-openssl=/data/soft/openssl/openssl-1.1.0h \

注意:如果不指定 --with-zlib 或 --with-pcre 或 --with-openssl,则使用系统,前提是使用yum安装 zlib-devel,pcre-devel,openssl-devl

nginx安装

# make && make install

2.3 nginx相关命令

2.3.1 检查配置文件是否正确

注意,启动前和修改了配置文件nginx.conf后最好先检查一下修改过的配置文件是否正确,以免重启后Nginx出现错误影响服务器稳定运行。判断Nginx配置是否正确命令如下:

# /usr/local/nginx/sbin/nginx -t

2.3.2 启动


# /usr/local/nginx/sbin/nginx        # 默认配置文件 conf/nginx.conf, -c指定其他配置文件

启动成功会在logs目录中出现nginx.pid文件,即nginx进程号 
若未成功可以查看logs目录下的error.log文件查看报错日志

2.3.3 平滑重启nginx

如果更改了配置就要重启Nginx,要先关闭Nginx再打开?不是的,可以向Nginx 发送信号,平滑重启。

/usr/local/nginx/sbin/nginx -s reload

kill -HUP 进程号或进程号文件路径

2.3.4 停止Nginx

停止操作是通过向nginx进程发送信号来进行的 
步骤1:查询nginx主进程号

ps -ef | grep nginx

步骤2:发送信号 
1.正常关闭

kill -QUIT 主进程号
  • 2.快速停止Nginx:
kill -TERM 主进程号
  • 3.强制停止Nginx:
pkill -9 nginx

Nginx 其他命令

以下包含了 Nginx 常用的几个命令:

/usr/local/nginx/sbin/nginx -t                 # 检查配置文件
/usr/local/nginx/sbin/nginx                   # 启动
/usr/local/nginx/sbin/nginx -s reload            # 重新载入配置文件
/usr/local/nginx/sbin/nginx -s reopen            # 重启 Nginx
/usr/local/nginx/sbin/nginx -s stop              # 停止 Nginx

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值