nginx

简介: nginx

# 概念


  • 是什么,可以做什么
  • 反向代理
  • 负载均衡
  • 动静分离


# 安装使用,配置



  • linux中安装
  • 常用命令
  • 查看nginx版本号 ./nginx -v
  • 关闭: ./nginx -s stop
  • 启动: ./nginx
  • 热加载: ./nginx -s reload
  • 检查配置文件:./nginx -t

  • 配置文件
  • 组成部分:
  1. 全局块:
  2. events块:
  3. http块:

# 全局块 --------------------------------------------------------------------------------start
#user  nobody;
# 越大并发数量越多
worker_processes  1;
#error_log  logs/error.log;
#error_log  logs/error.log  notice;
#error_log  logs/error.log  info;
#pid        logs/nginx.pid;
# 全局块 --------------------------------------------------------------------------------end
# events块 ------------------------------------------------------------------------------start
events {
    worker_connections  1024;    # 支持最大的连接数
}
# events块 ------------------------------------------------------------------------------end
# http块 ------------------------------------------------------------------------------start
http {
    include       mime.types;
    default_type  application/octet-stream;
    #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;
    sendfile        on;
    #tcp_nopush     on;
    #keepalive_timeout  0;
    keepalive_timeout  65;
    #gzip  on;
    server {
        listen       80;
        server_name  localhost;
        #charset koi8-r;
        #access_log  logs/host.access.log  main;
        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块 ------------------------------------------------------------------------------end


  • location


image.png

# 配置实例



  • 反向代理

server {
        listen       80;
        server_name  localhost;
        #charset koi8-r;
        #access_log  logs/host.access.log  main;
        # 相当于是匹配路径
        location ~ /server1/ {
            proxy_pass http://localhost:9701;
        }
        # ~ 表示是正则
        location ~ /server2/ {
            proxy_pass http://localhost:9702;
        }


  • 负载均衡
  • 分配策略:
  • 轮询(默认), 会自动剔除无效的服务
  • 权重 weight, 默认是1
  • ip_hash,可保证同一个ip(用户)一直访问同一个服务器
  • fair,根据服务响应时间来分配

http {
    # 负载均衡服务
    upstream blance_server{
        # ip_hash的方式分配请求
        #ip_hash;
        # 根据服务响应时间来分配
        # fair
        # 权重的方式分配请求
        server localhost:9701 weight=1;
        server localhost:9702 weight=2;
    }
  server {
        listen       80;
        server_name  localhost;
        location ~ /blance/ {
            proxy_pass http://blance_server;
            proxy_connect_timeout 10;
        }
    }
}


  • 动静分离


提高访问效率


image.png

高可用集群


image.png



# 原理



image.png

相关文章
|
2月前
|
安全 应用服务中间件 nginx
nginx allow什么意思?
综上所述,通过精心设计的 `allow`和 `deny`指令策略,Nginx能够有效地帮助管理员构建坚固的访问权限体系,确保服务在开放互联网环境中的安全与稳定。为了确保您的云服务器配置达到最优状态,推荐参考[专业云服务提供商]那里提供了包括但不限于高性能云服务器、高防服务器在内的多种解决方案,助您轻松应对各类业务挑战。
48 0
|
3月前
|
缓存 应用服务中间件 nginx
nginx(四)
nginx(四)
|
7月前
|
缓存 负载均衡 应用服务中间件
Nginx(一)
Nginx(一)
64 0
|
7月前
|
缓存 负载均衡 Java
什么是Nginx服务?
Nginx是一个高性能的开源的HTTP和反向代理服务器,以及邮件(IMAP/POP3)代理服务器。它最初由Igor Sysoev创建,并于2004年首次公开发布。Nginx的主要特点包括高性能、低内存占用、高并发处理能力以及高度的可靠性。
88 2
|
7月前
|
负载均衡 JavaScript 应用服务中间件
nginx使用
nginx使用
|
负载均衡 前端开发 安全
nginx能帮我们做什么?
Nginx是一款高性能的开源Web服务器软件,它可以帮助我们完成以下几个方面的任务:
104 0
|
负载均衡 Unix 应用服务中间件
Nginx
 Nginx (engine x) 是一个高性能的http和反向代理web服务器,同时也提供了IMAP/POP3/SMTP服务。Nginx是由伊戈尔·赛索耶夫为俄罗斯访问量第二的Rambler.ru站点(俄文:Рамблер)开发的,第一个公开版本0.1.0发布于2004年10月4日。其将源代码以类BSD许可证的形式发布,因它的稳定性、丰富的功能集、示例配置文件和低系统资源的消耗而闻名。2011年6月1日,nginx 1.0.4发布。
111 1
|
缓存 负载均衡 算法
Nginx——详解
Nginx是lgor Sysoev为俄罗斯访问量第二的rambler.ru站点设计开发的。从2004年发布至今,凭借开源的力量,已经接近成熟与完善。
152 0
Nginx——详解
|
存储 机器学习/深度学习 负载均衡
nginx几个简单问题
《基础系列》
124 0

热门文章

最新文章