nginx使用-1(源码安装nginx)

Nginx概述

Nginx (engine x) 是一个高性能的HTTP和反向代理web服务器,同时也提供了IMAP/POP3/SMTP服务。Nginx是由伊戈尔·赛索耶夫为俄罗斯访问量第二的Rambler.ru站点(俄文:Рамблер)开发的,第一个公开版本0.1.0发布于2004年10月4日。

Nginx是一款轻量级的Web 服务器/反向代理服务器及电子邮件(IMAP/POP3)代理服务器,在BSD-like 协议下发行。其特点是占有内存少,并发能力强,事实上nginx的并发能力确实在同类型的网页服务器中表现较好,*使用nginx网站用户有:百度、京东、新浪、网易、腾讯、淘宝等。

# curl -I 域名地址
Server:Nginx

☆ 常见用法

1) web服务器软件 httpd(apache)
同类型web服务器软件:apache nginx(俄罗斯) iis(微软) lighttpd(德国)
2) 提供了IMAP/POP3/SMTP服务
3) 充当反向代理服务器,实现负载均衡功能。LB=>Load Blance

☆ Nginx特点

① 高可靠:稳定性 master进程 管理调度请求分发到哪一个worker=> worker进程 响应请求 一master多worker

② 热部署 :(1)平滑升级 (2)可以快速重载配置

③ 高并发:可以同时响应更多的请求 事件 epoll模型 几万

④ 响应快:尤其在处理静态文件上,响应速度很快 sendfile

⑤ 低消耗:cpu和内存 1w个请求 内存2-3MB

⑥ 分布式支持:反向代理 七层负载均衡,新版本也支持四层负载均衡

编译安装Nginx

源码安装

第一步:安装依赖库

[root@server01 ~] # yum -y install pcre-devel zlib-devel openssl-devel

第二步:创建账号

[root@server01 ~] # useradd -r -s /sbin/nologin www

第三步:配置/编译与安装

tar xvf nginx-1.18.0.tar.gz

cd nginx-1.12.2
./configure --prefix=/usr/local/nginx --user=www --group=www --with-http_ssl_module --with-http_stub_status_module --with-http_realip_module make && make install

编译参数说明

参数 作用
--prefix 编译安装到的软件目录
--user worker进程运行用户
--group worker进程运行用户组
--with-http_ssl_module 支持https 需要pcel-devel依赖
--with-http_stub_status_module 基本状态信息显示 查看请求数、连接数等
--with-http_realip_module 定义客户端地址和端口为header头信息 常用于反向代理后的真实IP获取

Nginx目录介绍

目录 作用
conf 配置文件
html 网站默认目录
logs 日志
sbin 可执行文件 [软件的启动 停止 重启等]

软件操作参数

nginx使用-1(源码安装nginx) |

参数 作用
-V 显示版本号和配置选项
-s stop关闭 quit优雅关闭 reload重载 reopen重开日志

Nginx服务配置

#Nginx服务配置到该文件中
vim /usr/lib/systemd/system/nginx.service [Unit]
Description=nginx
After=network.target [Service]
Type=forking
ExecStart=/usr/local/nginx/sbin/nginx -c /usr/local/nginx/conf/nginx.conf
ExecReload=/usr/local/nginx/sbin/nginx -s reload
ExecStop=/usr/local/nginx/sbin/nginx -s quit
PrivateTmp=true [Install]
WantedBy=multi-user.target 扩展:
Type=forking,forking代表后台运行

启动Nginx服务:

[root@server01 ~] # systemctl start nginx.service

设置Nginx开机启动:

[root@server01 ~] # systemctl enable nginx.service

配置文件介绍

查看nignx目录下的配置文件

/usr/local/nginx/conf/nginx.conf

#nginx子进程启动用户
#user nobody;
#子进程数量 一般调整为cpu核数或者倍数
worker_processes 1;
#错误日志定义
#error_log logs/error.log;
#error_log logs/error.log notice;
#error_log logs/error.log info; #进程pid 存储文件
#pid logs/nginx.pid; #事件
events {
#每个子进程的连接数 nginx当前并发量 worker_processes * worker_connections
worker_connections 1024;
} #http协议段
http {
#引入 文件扩展名和与文件类型映射表
include mime.types;
#默认文件类型
default_type application/octet-stream;
#访问日志access.log的格式
#log_format main '$remote_addr - $remote_user [$time_local] "$request" '
# '$status $body_bytes_sent "$http_referer" '
# '"$http_user_agent" "$http_x_forwarded_for"';
#访问日志存储路径
#access_log logs/access.log main;
#linux内核 2.6提供文件读写的机制
sendfile on;
#tcp_nopush on; #keepalive_timeout 0;
#长连接超时时间 单位为s
keepalive_timeout 65;
#gzip压缩
#gzip on;
#server虚拟主机的配置
server {
#监听端口
listen 80;
#域名 可以有多个 用空格分隔
server_name localhost;
#默认编码
#charset koi8-r; #access_log logs/host.access.log main;
#location 用来匹配url
location / {
#默认访问的网站路径
root html;
#默认访问页面 从前往后的顺序查找
index index.html index.htm;
} #error_page 404 /404.html; # redirect server error pages to the static page /50x.html
#
error_page 500 502 503 504 /50x.html;
location = /50x.html {
root html;
} # proxy the PHP scripts to Apache listening on 127.0.0.1:80
#
#location ~ \.php$ {
# proxy_pass http://127.0.0.1;
#} # pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000
#
#location ~ \.php$ {
# root html;
# fastcgi_pass 127.0.0.1:9000;
# fastcgi_index index.php;
# fastcgi_param SCRIPT_FILENAME /scripts$fastcgi_script_name;
# include fastcgi_params;
#} # deny access to .htaccess files, if Apache's document root
# concurs with nginx's one
#
#location ~ /\.ht {
# deny all;
#}
} # another virtual host using mix of IP-, name-, and port-based configuration
#
#server {
# listen 8000;
# listen somename:8080;
# server_name somename alias another.alias; # location / {
# root html;
# index index.html index.htm;
# }
#} # HTTPS server
#
#server {
# listen 443 ssl;
# server_name localhost; # ssl_certificate cert.pem;
# ssl_certificate_key cert.key; # ssl_session_cache shared:SSL:1m;
# ssl_session_timeout 5m; # ssl_ciphers HIGH:!aNULL:!MD5;
# ssl_prefer_server_ciphers on; # location / {
# root html;
# index index.html index.htm;
# }
#} }

主要注意:

http=>server=>location 递进关系

一个有多个server

一个server可以有多个location

server配置

1.1、server虚拟主机配置

在实际生产业务环境中,一台web服务器,需要使用多个网站部署。搭建vhost虚拟机主机实现不同域名,解析绑定到不同的目录。

核心语法

#基于http的web服务
server{
#监听端口
listen 80;
#配置虚拟机
server_name shop.lnmp.com;
root html/tp5shop;
location / {
index index.php index.html index.htm;
}
location ~ \.php$ {
fastcgi_pass 127.0.0.1:9000;
fastcgi_index index.php;
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
include fastcgi_params;
}
}

一般server虚拟主机配置有三类:

①基于域名,将域名配置到server_name上

②基于IP,将IP配置到server_name上

③基于端口,将端口配置到listen

案例一:基于域名的虚拟机配置

①建立网站访问目录

[root@server01 ~] # cd /usr/local/nginx/html
[root@server01 ~] # mkdir tp5shop
[root@server01 ~] # cd tp5shop
#创建测试文件
[root@server01 ~] # echo "shop.lnmp.com" >> index.html
[root@server01 ~] # echo "shop site by php" >> index.php

②解析域名并绑定

当前客户端是通过windows的浏览器,需要在win下的hosts文件(C:\Windows\System32\drivers\etc\hosts)进行解析域名

nginx配置文件绑定域名

server {
#监听端口
listen 80;
#绑定域名
server_name shop.lnmp.com;
#网站目录
root html/tp5shop;
#默认访问页面
index index.html;
#这段一定不要忘了配置,需要解析php使用到
location ~ \.php$ {
fastcgi_pass 127.0.0.1:9000;
fastcgi_index index.php;
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
include fastcgi_params;
}
}

③浏览器访问查看效果

案例二:配置基于端口的虚拟主机

还是使用上面创建好的tp5shop目录

修改listen配置进行测试

案例三:配置基于IP的虚拟主机

①添加IP

yum install -y net-tools
#临时绑定IP
[root@server01 ~] # ifconfig ens33:1 192.168.17.220
#查看IP是否绑定成功
[root@server01 ~] # ip a
#如果ip不能够临时绑定,出现错误 networkManerger 服务关闭

②nginx配置文件添加

server {
listen 80;
server_name 192.168.17.220;
root html/ip;
}

③建立一个IP测试目录

[root@server01 ~] # cd /usr/local/nginx/html
[root@server01 ~] # mkdir ip
[root@server01 ~] # echo "ip site" >> index.html
上一篇:JavaScript——Prototype详探


下一篇:工作笔记-- 源码安装nginx