博客
关于我
nginx介绍安装
阅读量:683 次
发布时间:2019-03-17

本文共 1592 字,大约阅读时间需要 5 分钟。

Nginx简介

Apache仍然是占用率最高的Web服务器,市场占有率约为50%。了解它的优势:支持静态资源服务器且开源,模块丰富,技术支持成熟。

Nginx则由俄罗斯开发,是一款高性能的HTTP和反向代理服务器。其优势在于:支持5万级别的高并发连接, 系统资源消耗低,稳定性强。目前市场占有率已达33%,且发展势头强劲。选择Nginx的理由简单:高并发支持、成本低、可免费使用,并支持商业用途。

Nginx在系统架构中的作用清晰:作为网关入口,mainly负责路由、负载均衡和静态资源服务。具体来看:

  • 路由功能:根据域名或路径选择后台服务器,适用于微服务架构。
  • 负载功能:对后台服务器集群进行智能分载,应对高并发高可用需求。
  • 静态服务功能:作为静态资源服务器,性能远超Tomcat,适用于MVVM模式下的文件读取。
  • Nginx的工作模式分为正向代理和反向代理。正向代理是客户端请求中介,代为代理事务;反向代理是服务器-end向前发出的服务代理。两者的共同点是加速流量处理。

    Nginx安装方法有三种:

    1. 源码编译安装
    步骤如下:

    • 安装依赖软件:yum -y install autoconf automake make gcc gcc-c++ pcre pcre-devel zlib zlib-devel openssl openssl-devel
    • 使用wget获取源码:wget nginx-1.9.15.tar.gz
    • 解包并配置:cd nginx-1.9.15 && ./configure --prefix=/usr/local/nginx --with-http_stub_status_module --with-http_ssl_module
    • 编译并安装:make && make install
    • 启动:nginx -c /usr/local/nginx/nginx.conf

    2. Yum安装方法(CentOS6)

    • 扩展源:yum install epel-release -y
    • 直接安装:yum install nginx -y
      安装完成后,配置目录结构为:/etc/nginx, 再打开 /usr/local/nginx/conf/nginx.conf 进行配置。

    启动或停止命令为:

    • 开始:nginx -c /usr/local/nginx/nginx.conf
    • 停止:nginx -s stop
    • 退出:nginx -s quit
    • 重新加载:nginx -s reload
      默认情况下,执行命令时可省略配置选项,系统会自动读取默认配置文件。

    Nginx的工作模型分为主进程(master)和多个工作进程(worker)。主进程负责套接字绑定、配置管理;工作进程负责处理客户端连接及任务执行。为了性能,最好将工作进程设置为非特权用户运行。

    Nginx配置文件结构以nginx.conf为中心,采用模块化设计,便于扩展。其主要包括:

    • 全局配置项:userworker_processeserror_log等。
    • HTTP服务器模块:http,设置默认类型、日志格式、ssl模块等。
    • 虚拟服务器段server:指定监听地址、端口、域名及请求路径。
      -Location匹配:定义路由规则,支持静态资源及其错误页面配置。

    通过Nginx日志可以追踪客户端行为和服务器状态。配置access_log并指定路径,可自定义日志格式,打印信息如$remote_addr$request等。 LogManager接口支持灵活配置,支持日志切割和归档管理。

    日志切割可编写脚本实现,生成基于时间戳的日志文件并归档。同时,配置rsyslog和crond后,可实现定时日志清理和信息收集。

    以上均为对Nginx的系统性介绍,实践中可根据具体需求调整配置选项,充分发挥其性能优势。

    转载地址:http://cpkhz.baihongyu.com/

    你可能感兴趣的文章
    Netty事件注册机制深入解析
    查看>>
    Netty原理分析及实战(四)-客户端与服务端双向通信
    查看>>
    Netty客户端断线重连实现及问题思考
    查看>>
    Netty工作笔记0006---NIO的Buffer说明
    查看>>
    Netty工作笔记0007---NIO的三大核心组件关系
    查看>>
    Netty工作笔记0011---Channel应用案例2
    查看>>
    Netty工作笔记0013---Channel应用案例4Copy图片
    查看>>
    Netty工作笔记0014---Buffer类型化和只读
    查看>>
    Netty工作笔记0020---Selectionkey在NIO体系
    查看>>
    Vue踩坑笔记 - 关于vue静态资源引入的问题
    查看>>
    Netty工作笔记0025---SocketChannel API
    查看>>
    Netty工作笔记0027---NIO 网络编程应用--群聊系统2--服务器编写2
    查看>>
    Netty工作笔记0050---Netty核心模块1
    查看>>
    Netty工作笔记0057---Netty群聊系统服务端
    查看>>
    Netty工作笔记0060---Tcp长连接和短连接_Http长连接和短连接_UDP长连接和短连接
    查看>>
    Netty工作笔记0063---WebSocket长连接开发2
    查看>>
    Netty工作笔记0070---Protobuf使用案例Codec使用
    查看>>
    Netty工作笔记0077---handler链调用机制实例4
    查看>>
    Netty工作笔记0084---通过自定义协议解决粘包拆包问题2
    查看>>
    Netty工作笔记0085---TCP粘包拆包内容梳理
    查看>>