我们平时访问的网络网站就是WEB网络服务,允许用户通过浏览器访问互联网中的各种资源服务

WEB服务器会通过HTTP或者HTTPS的方式将请求内容传递给客户端

目前常见的WEB服务有IIS, Nginx和Apache等

WEB服务器和WEB框架的区别

WEB服务器:接收HTTP请求并返回数据
WEB框架:开发WEB应用程序,处理接收到的HTTP请求

Nginx特点:

  • 开源免费

  • 高性能,高并发

    • 支持几万并发连接

    • 资源消耗少,在3万并发连接下开启10个nginx线程消耗的内存不到200M

  • 安装灵活,使用方便

  • 功能丰富

    • 反向代理

    • 负载均衡

    • 缓存服务

    • 访问日志

1.安装

nginx   官方nginx
tenginx 淘宝nginx 这2个一模一样,我这里采用后者,并且采用源代码安装
  • 下载源代码

    wget http://tengine.taobao.org/download/tengine-2.3.2.tar.gz

  • 解压缩
    tar -zxvf tengine-2.3.2.tar.gz
  • 指定安装目录,检查编译环境
    先更新本地依赖页
    sudo apt-get update
    sudo apt-get install build-essential zlib1g-dev libpcre3 libpcre3-dev libssl-dev libxslt1-dev libxml2-dev libgeoip-dev libperl-dev libtool
    sudo apt-get install openssl
    ./configure --prefix=/opt/tng232
  • make进行编译
    sudo make
  • 生成可执行文件
    sudo make install
  • 配置环境变量
    sudo vim /etc/profile
    
    PATH="/opt/python390/bin/:/opt/tng232/sbin:/home/parallels/.local/bin:/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:/usr/games:/usr/local/games:/snap/bin"
    
    source /etc/profile

2.常用命令

  • 第一次启动

    nginx -c /../nginx.conf  # 指定启动的配置文件,不指定nginx会自动加载默认路径的配置文件
  • 平滑启动

    sudo nginx -s reload -c /opt/tng232/conf/nginx.conf # 平滑启动,重新读取nginx配置文件,不重启nginx进程
  • 停止进程

    nginx -s stop  -c /opt/tng232/conf/nginx.conf # 停止nginx进程
  • 检查Nginx配置文件语法

    nginx -t -c /opt/tng232/conf/nginx.conf

启动后可以访问

http://10.211.55.5:80

 

3.学习配置文件

配置文件在nginx安装的conf目录

nginx的配置文件是C语言风格的, 以 ;结束每一行的配置
配置文件是以代码块的形式编写的
主要有以下几个模块 http{} # 里面定义了多个代码块,是nginx的核心配置点
server{} # 虚拟主机代码块,定义了监听端口等
location{} # 域名匹配代码块
#user  nobody;
# 定义nginx的工作进程数 以CPU核数为准
worker_processes 5;
# 以下是日志功能
error_log logs/error.log;
#error_log logs/error.log notice;
#error_log logs/error.log info;
#error_log "pipe:rollback logs/error_log interval=1d baknum=7 maxsize=2G"; # 将pid写入文件中
pid logs/nginx.pid; events {
# 每个worker进程支持的最大连接数
worker_connections 1024;
} # 配置文件的核心区域
http {
include mime.types;
default_type application/octet-stream;
# 打开nginx的访问日志功能
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;
#access_log "pipe:rollback logs/access_log interval=1d baknum=7 maxsize=2G" main; sendfile on;
#tcp_nopush on; #keepalive_timeout 0;
keepalive_timeout 65; # 打开此功能,能够极大的提升网站访问,以及静态资源压缩
gzip on; # 虚拟主机的核心配置
server1 {
listen 80;
server_name localhost; # nginx编码支持
charset utf-8
#charset koi8-r; #access_log logs/host.access.log main;
#access_log "pipe:rollback logs/host.access_log interval=1d baknum=7 maxsize=2G" main; # nginx的域名匹配,所有的请求,都会进入到这里
location / {
# 定义该虚拟主机资料存放路径,可以自由修改
root html;
# 定义nginx首页文件名字,需要在root指定的目录下
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;
}
}
# 可以定义第二个虚拟主机的配置
server2 {
listen 90;
server_name localhost; # nginx编码支持
charset utf-8 # nginx的域名匹配,所有的请求,都会进入到这里
location / {
# 定义该虚拟主机资料存放路径,可以自由修改
root html;
# 定义nginx首页文件名字,需要在root指定的目录下
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;
}
}
}

4.nginx多站点功能

nginx的web站点也称为nginx的虚拟主机站点,通过文件目录的不同,定义多个不同的网站

多虚拟主机的实现方式

  • 基于域名的多虚拟主机

    修改hosts文件,强制写入域名对应关系,比较麻烦
  • 基于端口的虚拟主机

    修改nginx.conf的端口配置,定义两个server与区块,如下
     # 目前这里是第一个server {} 区域块,端口是85
    server {
    # 定义该网站的端口
    listen 85;
    server_name localhost;
    charset utf-8;
    location / {
    root /python/;
    index index.html index.htm;
    }
    } # 目前这里是第二个server {} 区域块,端口是85
    server {
    # 定义该网站的端口
    listen 89;
    server_name localhost;
    charset utf-8;
    location / {
    root /linux/;
    index index.html index.htm;
    }
    }
  • 基于IP的虚拟主机
    通过不同的IP区分不同的虚拟主机,此类比较少见,一般业务需要多IP的常见都会在负载均衡中绑定

5.nginx日志

日志作用

nginx的方可日志,能够记录,分析用户的请求行为
-什么时间点,访问的最频繁,比如某网站,网站的流量,基本都在晚上,学生下了班,在线学习各种技术
-记录用户的请求频率,以此检测是否是爬虫等恶意请求,进行封禁。

操作

改nginx.conf  在 http{}代码块中,打开如下注释即可

    #打开此nginx的访问日志功能,即可查看日志
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; 日志变量解释
$remote_addr 记录客户端ip
$remote_user 远程用户,没有就是 “-”
$time_local    对应[14/Aug/2018:18:46:52 +0800]
$request     对应请求信息"GET /favicon.ico HTTP/1.1"
$status     状态码
$body_bytes_sent  571字节 请求体的大小
$http_referer  对应“-”  由于是直接输入浏览器就是 -
$http_user_agent  客户端身份信息,以此可以nginx判断,用户客户端是手机浏览器,就转发移动端页面给与用户
如果是pc的客户端,就转发给pc页面给与用查看

6.反向代理

正向代理,代理的是客户端

反向代理,代理的是服务端

nginx反向代理的操作:

第一个server{}标签,用于反向代理的作用,修改nginx.conf如下

    #   第一个虚拟主机的配置,作用是反向代理了
server {
listen 80;
server_name localhost;
charset utf-8;
error_page 404 /40x.html;
# 如果你写的是proxy_pass参数,就是一个请求转发,反向代理功能
location / {
proxy_pass http://192.168.178.140:90;
} }

第二个server{}标签,作用是返回机器上的资料,也就是一个web站点的功能

#第二个虚拟主机,作用是web站点功能,资源服务器,提供页面的
server {
listen 90;
server_name _;
location / {
root /s25proxy/;
index index.html;
}
}

7.负载均衡

负载均衡就是将请求均衡的分给不通的web服务端

负载均衡的搭建

第一个虚拟主机server{}的作用,是反向代理,80端口

    # 用upstream关键词定义负载均衡池,写入资源服务器的地址
# 负载均衡的算法,默认是轮询机制,一台服务器处理一次
upstream s25real_server {
server 192.168.178.140:90;
server 192.168.178.140:95;
}
server {
listen 80;
server_name localhost;
charset utf-8;
error_page 404 /40x.html;
location / {
proxy_pass http://s25real_server;
} }

第二个server{}标签的配置,作用是提供资源给用户看的,90端口

#第二个虚拟主机,作用是web站点功能,资源服务器,提供页面的
server {
listen 90;
server_name _;
location / {
root /s25lol/;
index index.html;
}
}

第三个server{}标签的作用,同样是返回资源页面,查看负载均衡效果的,95端口

#第三个server{}虚拟主机,作用是 提供资源服务器的内容的
server {
listen 95;
server_name _;
location / {
root /s25dnf/;
index index.html; }
}

nginx负载均衡算法

- 轮询机制:默认的,每台服务器各一次

- 加权轮训机制

    upstream  s25real_server  {
server 192.168.178.140:90 weight=4;
server 192.168.178.140:95 weight=1;
}

8.搭建文件服务器

server {
listen 80;
server_name localhost; #charset koi8-r; #access_log logs/host.access.log main;
#access_log "pipe:rollback logs/host.access_log interval=1d baknum=7 maxsize=2G" main; location / {
root /opt/tng232/download;
autoindex on; # 索引,开启目录文件列表
autoindex_exact_size on; # 显示文件大小
autoindex_localtime on; # 显示文件时间
}
}

1.nginx学习的更多相关文章

  1. Nginx学习回顾总结 部分:

    21:46 2015/11/9Nginx学习回顾总结进程间通信,近似于socket通信的的东西:才发现这种通信并不是很难,并不是我想象的那样很多内容,新领域,入门只是几个函数的使用而已.以前猜过是这样 ...

  2. Nginx学习笔记4 源码分析

    Nginx学习笔记(四) 源码分析 源码分析 在茫茫的源码中,看到了几个好像挺熟悉的名字(socket/UDP/shmem).那就来看看这个文件吧!从简单的开始~~~ src/os/unix/Ngx_ ...

  3. Nginx学习笔记~目录索引

    回到占占推荐博客索引 前几天整理了<Docker的学习笔记索引>,受到了很多朋友的关注,今天把Nginx的文章也整理一下,以后将永久更新,像大叔之前的<EF文章系列>,< ...

  4. Nginx学习系列二Linux下Nginx实现负载均衡

    关于在本地虚拟机(VMware 14)下安装Linux同时安装Nginx,请参考Nginx学习系列之搭建环境 1.启动Nginx 在Nginx安装成功的前提下,启动Nginx 已root模式登陆(权限 ...

  5. Nginx系列0:Nginx学习历程

    Nginx学习历程 一.初识Nginx 1.Nginx适用于哪些场景 (1)静态资源服务 通过本地文件系统提供服务 (2)反向代理服务 Nginx的强大性能 缓存 负载均衡 (3)API服务 Open ...

  6. nginx 学习资料

    nginx 学习资料 table th:first-of-type { width: 90px; } table th:nth-of-type(2) { } table th:nth-of-type( ...

  7. Nginx学习总结

    2017年2月23日, 星期四 Nginx学习总结 Nginx是目前比较主流的HTTP反向代理服务器(其企业版提供了基于TCP层的反向代理插件),对于构建大型分布式web应用,具有举足轻重的作用.简单 ...

  8. nginx 学习笔记(2) nginx新手入门

    这篇手册简单介绍了nginx,并提供了一些可以操作的简单的工作.前提是nginx已经被安装到你的服务器上.如果没有安装,请阅读上篇:nginx 学习笔记(1) nginx安装.这篇手册主要内容:1. ...

  9. Nginx学习---Nginx的详解_【all】

    1.1. Nginx简介 1.什么是nginx nginx:静态的,开源的www软件,可以解析静态的小文件(低于1M ),支持高并发占用较发少的资源(3W并发,10个进程,内存150M),跨平台 te ...

  10. Nginx学习之从零搭建静态资源网站

    前言   在某学习网站学习了nginx的安装和使用,以此文记录. 环境准备   安装在VMWare下的Centos虚拟机.由于我这是新装的虚拟机.所以很多插件都没有,这里干脆一次性安装上. wget ...

随机推荐

  1. 【java】学习路径26-泛型,集合使用自定义的类型

    接着上一节的内容,上一节我们使用到了ArrayList.Vector.LinkedList三个集合类型. 但是目前我们有一个问题:如果集合中存储的是Integer类型的数据(int的引用类型),那我们 ...

  2. ELK技术-IK-中文分词器

    1.背景 1.1 简介 ES默认的分词器对中文分词并不友好,所以一般会安装中文分词插件,以便能更好的支持中文分词检索. 本例参考文档:<一文教你掌握IK中文分词> 1.2 IK分词器 IK ...

  3. 使用verdaccio+docker搭建npm私有仓库以及使用

    公司内部前端组件或库的共享等,搭建一个npm私有库就很方便,现在中大型公司也基本都有自己的npm私有库,这篇文章,和大家一起共同搭建一个npm私有库,共同学习 前置条件 一台电脑 可以联网 一.安装d ...

  4. SpringMvc(四)- 下载,上传,拦截器

    1.图片下载 图片下载:将服务器端的文件以流的形式写到客户端,通过浏览器保存到本地,实现下载: 1.1 图片下载步骤 1.通过session获取上下文对象(session.getServletCont ...

  5. JavaWeb核心篇(2)——Request和Response

    JavaWeb核心篇(2)--Request和Response 上篇文章中提及到了Servlet,在Servlet中我们主要继承了HTTPServlet类,在HTTPServlet类中我们会接触到两个 ...

  6. FastDFS配置文件思维导图(内含各配置文件详细参数说明)

  7. MySQL集群搭建(4)-MMM+LVS+Keepalived

    1 LVS 介绍 1.1 简介 LVS 是 Linux Virtual Server 的简写,意即 Linux 虚拟服务器,是一个虚拟的服务器集群系统.本项目在 1998 年 5 月由章文嵩博士成立, ...

  8. 延申三大问题中的第一个问题处理---原先shell脚本中启动jar文件命令的配置,附加参数等

    经过一系列的试错,最终采用的解决办法如下: 采用的配置文件 附加的启动参数 或者把这些都给统一添加到ConfigMap中

  9. 1. Fluentd安装方法

    Fluentd是一个跨平台的开源系统,支持在Linux(Redhat.Ubuntu.Debian).Windows平台上运行.MacOS呢?官方并没有明显指出,但是在安装说明中列出了通过Ruby Ge ...

  10. Linux 宝塔部署 ASP.NET Core 应用

    第一步,发步应用 我这是一个API 应用和 MVC 应用 设置,服务器上要运行的端口 API 端口5000 MVC 端口5001 打包文件夹,发步 1.桌面新建俩个文件夹 2.右键项目发步,选中iis ...