Nginx进阶

常见的web架构

LAMP - Linux +Apache +MySQL + PHP

LNMP - Linux +Nginx + Mysql + PHP

RHEL开源  Linux系统  RHEL CentOS Fedora 开源 --- 开放源代码

Nginx和Apache本身对动态网页没有处理能力 ----> PHP

Apache + PHP ---->apxs命令 ---> DSO方式 把libphp5.so模块插入到apache 配置中

Nginx + PHP --->通过php-fpm的服务 默认9000的端口

nginx处理高并发针对静态小文件(1M) 3W并发 - Nginx 消耗内存资源150M

官方网站: www.nginx.org Nginx是俄罗斯的站点开发

Nginx  国内用的多

Apache  全球最多

Lighttpd 贴吧 豆瓣

Tengine 淘宝 天猫商城

1) Nginx的安装

两种方式:

1.yum二进制安装

2.源码编译 ---- > LNMP 都是编译

默认站点目录:

   apache -  DocumentRoot    htdocs

Nginx -- root参数指明  html目录

默认网页:

   apache配置文件中---- Directory -- index.html

nginx                index   index.html

一、Nginx的基本配置

关于Nginx模块 (解耦) module --- 插件(都是配置文档中的内容)

Nginx使用不同的模块来实现不同的功能,主要有2组模块:

1)Nginx core module (必须的)

包括: Mian模块  Events模块

2)standard HTTP module (不是必须的 但是缺省的安装的 不建议改动)

经典包括:

Core

Access

FastCGI

Gzip (压缩模块,性能优化)

Log 日志模块(访问  错误  警告日志)

Proxy   Nginx 的反向代理

Upstream  Nginx负载均衡

提示:  模块可以通过官网查询http://nginx.org/en/docs/

二、Nginx目录结构(重点目录 + 文件的介绍)

三、Nginx主配置文件介绍

Nginx的配置文件是一个纯文本文件,整个配置文件是以块的形式组织的。每个模块

一般用{}进行表示

位于最高层 Main --->Events --->http

[[email protected] ~]# egrep -v "#|^$" /usr/local/nginx/conf/nginx.conf

worker_processes  1;        //worker模式(通过一个进程 使用多个线程去处理请求) prefork模式(全部使用进程)   work进程数,写cpu的核数

events {

worker_connections  1024;     //work最大连接数

}

http {

include       mime.types;

default_type  application/octet-stream;

sendfile        on;

keepalive_timeout  65;

server {

listen       80;   监听的端口

server_name  localhost;   域名

location / {              默认站点

root   html;

index  index.html index.htm;

}

error_page   500 502 503 504  /50x.html;

location = /50x.html {

root   html;

}

}

}

虚拟主机====> 一台机器  运行多个web服务

基于域名

基于IP

基于端口

Apache ---->哪个标签 定义虚拟主机? <VirtualHost>

Nginx ---server {}

1.安全  互联网病毒--->扫面端口漏洞

2.成本  IP地址固定IP  每年年费

四、配置虚拟主机(基于域名)

egrep -v "#|^$" nginx.conf > log.lol

[[email protected] conf]# cp log.lol nginx.conf
cp:是否覆盖"nginx.conf"? y

worker_processes 3;

events {
worker_connections 1024;
}

http {
include mime.types;
default_type application/octet-stream;
sendfile on;
keepalive_timeout 65;
server {
listen 80;
server_name www.thinkmo.cn;
charset utf-8;
root html/www; #默认站点 /appliation/nginx/html/wwww
index index.html #默认网页/appliation/nginx/html/wwww/index.html
}
server {
listen 80;
server_name blog.thinkmo.cn;
charset utf-8;
root html/; #默认站点 /appliation/nginx/html/wwww
index index.html #默认网页/appliation/nginx/html/wwww/index.html
          }
server {
listen 80;
server_name bbs.thinkmo.cn;
charset utf-8;
root html/bbs; #默认站点 /appliation/nginx/html/wwww
index index.html #默认网页/appliation/nginx/html/wwww/index.html

  }

}

一台服务器 一个iP  三个域名

192.168.1.200  --  www.thinkmo.cn  blog.thinkmo.cn   bbs.thinkmo.cn

修改windows下hosts文件

配置站点

域名解析 ---DNS正向解析

1.去哪找? 本机hosts文件

2.如果hosts没有  --- >代理服务器

3.如果代理服务器没有 ---> 全球13个DNS根服务器 ----> www.baidu.com

4.返回给代理服务器

总结Nginx配置虚拟主机的流程:

1) 复制一段完整的server{}标签  注意: 要放在http的结束的大括号里面

2)更改server_name  和 对应的网页的root根目录

3)检查文件语法 平滑启动

[[email protected] ~]# /usr/local/nginx/sbin/nginx  -t

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

nginx: configuration file /usr/local/nginx-1.12.2/conf/nginx.conf test is successfu

[[email protected] ~]# /usr/local/nginx/sbin/nginx  -s reload

4)创建server_name 对应的网页的根目录 并且建立测试文件

5)对客户端server_name 的主机做host解析 或者DNS设置

6)浏览器访问

链接不上:拍错步骤

1)测试连通性  ping (基于icmp协议 -- 一去(echo-request)一回(echo-reply))

Tracert 追踪路径

2)测试端口 telnet

3)wget或者curl  是否响应

防火墙  权限

五、测试nginx的链接数

在配置文件的http中添加一段,并在hosts文件中添加解析

六、跳转301重定向

两种实现方式:

1)别名

在配置文件server字段的servername后面添加一个域名

当我们访问thinkmo.cn的时候就会自动访问www.thinkmo.cn

Apache指定别名 用什么标签?

ServerAlias标签

2)跳转

server {

listen       80;

server_name  www.thinkmo.cn thinkmo.cn;

root html/www;

index index.html;

rewrite ^/(.*) http://www.thinkmo.cn/$1 permanent;

}

七、

通过IP --->没有变化应---->遭受IP恶意绑定

你有域名  对方有IP没有域名   用你的域名 养IP

server {   第一个server标签

listen       80;

location / {

deny all;

}

}

八、基于端口的虚拟主机

修改配置文件的server字段中的listen端口号,可以实现端口访问  如:服务器IP:端口号

当域名与端口号都存在且并不匹配时,将按照端口号为准

九、基于IP的虚拟主机

与前者类似都是修改配置文件的server字段中的listen字段,可以在端口号前面加上虚拟IP,这样访问的对面servername页面。

十、Nginx日志 使用第三种

Apache上的日志轮询几种形式? 3种

1.cronolog

2.ratatelog

3.cron + mv + graceful

原文地址:https://www.cnblogs.com/lovedairan/p/9914895.html

时间: 2024-10-29 09:18:33

Nginx进阶的相关文章

架构设计:负载均衡层设计方案(3)——Nginx进阶

上篇文章<架构设计:负载均衡层设计方案(2)——Nginx安装>(http://blog.csdn.net/yinwenjie/article/details/46620711),我们介绍了Nginx的核心设计思想.基本安装和使用.本来准备继续介绍Nginx的几个使用特性,但是奈何博文篇幅太长,只有将一篇文章拆成两篇.本文我们将承接上文,继续讲解Nginx的实用特性,包括gzip功能.rewirte功能和一个第三方的节点监测模块.本文我们还将提到Taobao团队对Nginx的深度改造Tengi

saltstack部署nginx进阶

上一篇其实对通过saltstack部署nginx做了演示,但是可能与我目前的环境还是有点出入,然后sls的结构也不太清晰,所以就又做了改变和优化,叫做进阶可能有点噱头了,不过还是记录如下: nginx安装目标: 1)安装必要依赖 2)准备pcre安装包 2)源码安装pcre 3)准备nginx安装包 4)源码安装nginx nginx配置: 1)拷贝nginx.conf配置文件 2)拷贝启停脚本 3)添加系统服务并设置开机启动 4)拷贝日志切割脚本 5)添加定时任务 salt master上的目

Nginx 进阶 (ssl、fpm、rewrite、cache配置等)

一.配置https网站 1.自建CA (1)生成私钥文件 mkdir -p /etc/pki/CA/private #创建私钥保存的目录 (umask 077;openssl genrsa -out /etc/pki/CA/private/cakey.pem 4096) #创建私钥 ll /etc/pki/CA/private/ # 私钥只能自己保存,对保密性要求高 (2)生成自签证书 openssl req -new -x509 -key /etc/pki/CA/private/cakey.p

Nginx服务企业应用

1.1 常用来提供静态服务的软件 Apache :这是中小型Web服务的主流,Web服务器中的老大哥, Nginx :大型网站Web服务的主流,曾经Web服务器中的初生牛犊,现已长大. Nginx 的分支 Tengine ( http://tengine.taobao.org/)目前也在飞速发展• Lighttpd :这是一个不溫不火的优秀 Web软件,社区不活跃,静态解析效率很高.在 Nginx 流行前,它是大并发静态业务的首选,国内百度贴吧.豆瓣等众多网站都有Lighttpd奋斗的身彩" 1

nginx服务企业级应用

1.1 常用来提供静态服务的软件 Apache :这是中小型Web服务的主流,Web服务器中的老大哥, Nginx :大型网站Web服务的主流,曾经Web服务器中的初生牛犊,现已长大. Nginx 的分支 Tengine ( http://tengine.taobao.org/)目前也在飞速发展? Lighttpd :这是一个不溫不火的优秀 Web软件,社区不活跃,静态解析效率很高.在 Nginx 流行前,它是大并发静态业务的首选,国内百度贴吧.豆瓣等众多网站都有Lighttpd奋斗的身彩" 1

Nginx入门到实践-Nginx 中间件

第1章 课程前言总览课程,介绍课程学习须知,环境准备,了解课程意义.1-1 课程介绍1-2 学习环境准备 第2章 基础篇讲解Nginx的快速部署安装.模块.基础配置语法.Nginx的日志输出.Nginx默认配置模块.Nginx对于请求的处理,访问控制模块使用,并区别介绍连接限制与请求限制.2-1 什么是Nginx2-2 常见的中间件服务2-3 Nginx优势多路IO复用2-4 Nginx使用Epoll模型的优势介绍2-5 Nginx-CPU亲和2-6 Nginx-sendfile2-7 Ngin

架构设计:负载均衡层设计方案(8)——负载均衡层总结上篇

1.概述 很明显通过前面的八篇文章的介绍,并不能覆盖负载均衡层的所有技术,但是可以作为一个引子,告诉各位读者一个学习和使用负载均衡技术的思路.虽然后面我们将转向“业务层”和“业务通信”层的介绍,但是对负载均衡层的介绍也不会停止.在后续的时间我们将穿插进行负载均衡层的新文章的发布,包括Nginx技术的再介绍.HaProxy.LVS新的使用场景等等. 这篇文章我们对前面的知识点进行总结,并有意进行一些扩展,以便于各位读者找到新的学习思路. 2.负载均衡层的核心思想 2-1.一致性哈希与Key的选取

架构设计:负载均衡层设计方案(4)——LVS原理

之前我们花了两篇文章的篇幅,详细讲解了Nginx的原理.安装和特性组件.请参看<负载均衡层设计方案(2)——Nginx安装>(http://blog.csdn.net/yinwenjie/article/details/46620711)和<架构设计:负载均衡层设计方案(3)——Nginx进阶>(http://blog.csdn.net/yinwenjie/article/details/46742661)两篇文章.虽然不包括Nginx的所有知识(也不可能全部包括),但是足够读者将

nginx配置进阶(三)

nginx配置进阶(三) ======================================================================================= 概述: ======================================================================================= ngx_http_fastcgi_module模块:构建lnmp  1.The ngx_http_fastcgi_