一、Nginx简介
1、Nginx基本概念
Nginx是一个高性能的HTTP和反向代理服务器,其特点是占有内存少,并发能力强。
中文文档: http://www.nginx.cn/doc/
2、Nginx的用处
A、正向代理
B、反向代理
C、负载均衡
D、动静分离
二、Nginx安装
下面的操作是以Centos7为例
1、使用xshell远程连接工具连接Centos7操作系统
2、安装nginx相关依赖
gcc
pcre
openssl
zlib
① 安装 nginx 需要先将官网下载的源码进行编译,编译依赖 gcc 环境,如果没有 gcc 环境,则需要安装:
$ yum install gcc-c++
② PCRE(Perl Compatible Regular Expressions) 是一个Perl库,包括 perl 兼容的正则表达式库。nginx 的 http 模块使用 pcre 来解析正则表达式,所以需要在 linux 上安装 pcre 库,pcre-devel 是使用 pcre 开发的一个二次开发库。nginx也需要此库。命令:
$ yum install -y pcre pcre-devel
③ zlib 库提供了很多种压缩和解压缩的方式, nginx 使用 zlib 对 http 包的内容进行 gzip ,所以需要在 Centos 上安装 zlib 库。
$ yum install -y zlib zlib-devel
④ OpenSSL 是一个强大的安全套接字层密码库,囊括主要的密码算法、常用的密钥和证书封装管理功能及 SSL 协议,并提供丰富的应用程序供测试或其它目的使用。
nginx 不仅支持 http 协议,还支持 https(即在ssl协议上传输http),所以需要在 Centos 安装 OpenSSL 库。
$ yum install -y openssl openssl-devel
3、安装Nginx
① 下载nginx,两种方式
a. 直接下载.tar.gz安装包,地址:https://nginx.org/en/download.html
b. 使用wget命令下载(推荐)。确保系统已经安装了wget,如果没有安装,执行 yum install wget 安装。
$ wget -c https://nginx.org/download/nginx-1.18.0.tar.gz
② 依然是直接命令:
$ tar -zxvf nginx-1.18.0.tar.gz
$ cd nginx-1.18.0
③ 配置:
其实在 nginx-1.12.0 版本中你就不需要去配置相关东西,默认就可以了。当然,如果你要自己配置目录也是可以的。
1.使用默认配置
$ ./configure
2.自定义配置(不推荐)
$ ./configure \
--prefix=/usr/local/nginx \
--conf-path=/usr/local/nginx/conf/nginx.conf \
--pid-path=/usr/local/nginx/conf/nginx.pid \
--lock-path=/var/lock/nginx.lock \
--error-log-path=/var/log/nginx/error.log \
--http-log-path=/var/log/nginx/access.log \
--with-http_gzip_static_module \
--http-client-body-temp-path=/var/temp/nginx/client \
--http-proxy-temp-path=/var/temp/nginx/proxy \
--http-fastcgi-temp-path=/var/temp/nginx/fastcgi \
--http-uwsgi-temp-path=/var/temp/nginx/uwsgi \
--http-scgi-temp-path=/var/temp/nginx/scgi
注:将临时文件目录指定为/var/temp/nginx,需要在/var下创建temp及nginx目录
④ 编辑安装
$ make && make install
查看版本号(使用nginx操作命令前提条件:必须进入nginx的目录/usr/local/nginx/sbin.)
$ ./nginx -v
查找安装路径:
$ whereis nginx
⑤ 启动,停止nginx
$cd/usr/local/nginx/sbin/
$ ./nginx
$ ./nginx -s stop
$ ./nginx -s quit
$ ./nginx -s reload
查询nginx进程:
$ ps aux|grep nginx
启动成功后,在浏览器可以看到这样的页面(这里如果访问不成,进不去,要考虑是否将防火墙关闭!):
防火墙配置(开放端口号)
查看防火墙开放的端口号
firewall-cmd --list-all
设置开放的端口号
firewall-cmd --add-service=http –permanent
sudo firewall-cmd --add-port=80/tcp --permanent
重启防火墙
firewall-cmd –reload
实现工作
修改nginx配置文件, nginx.conf