博客
关于我
Nginx动静分离实现负载均衡
阅读量:674 次
发布时间:2019-03-16

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

在使用Debian环境部署web项目时,Nginx和Tomcat是常用且高效的组合。以下是基于Nginx配置的实用指南。

Nginx配置说明

默认安装Nginx后,/etc/nginx/nginx.conf 是主要配置文件。以下是关键配置项:

  • 进程参数配置
  • worker_processes 8;worker_rlimit_nofile 65535;

    根据CPU核心数设置工作进程数,并与ulimit一致调整文件描述数。

    1. 网络模型优化
    2. events {    use epoll;    worker_connections 65535;}

      epoll模型提升性能, worker_connections指定单个进程的最大连接数。

      1. 缓存与压缩
      2. gzip on;gzip_min_length 1k;gzip_buffers 16 64k;

        开启gzip压缩,优化带宽使用。

        1. 负载均衡设置
        2. server {    listen 80;    server_name your domaine.com;    location / {        index index.html;        proxy_pass http://backend_server;    }    location ~ /.*\.js|\.css|\.ico|\.png|.jpg|.woff {        proxy_cache cache_zone;        proxy_cache_valid 200 304 5d;        proxy_pass http://backend_server;        expires 30d;    }    location ~ /.* {        proxy_pass http://backend_server;    }}

          配置反向代理,合理分配静态和动态资源,确保负载均衡和缓存有效性。

          动静资源分离

          将Nginx配置为缓存性能优化。修改nginx.conf

          location ~ .\.(js|css|ico|png|jpg|eot|svg|ttf|woff) {    proxy_cache cache_zone;    proxy_cache_valid 200 304 5d;    proxy_pass http://backend_server;    expires 30d;}

          这段代码实现静态资源缓存,提升性能。

          动态页面反向代理

          确保动态页面访问Tomcat服务:

          location / {    proxy_pass http://backend_server:8080;}

          SSL配置(可选)

          使用 自签名证书:

          server {    listen 443 ssl;    ssl on;    ssl_certificate /path/client.pem;    ssl_key_file /path/client.key.unsecure;}

          注意事项

        3. 权限设置

          user www www; 为Nginx设置权限。

        4. 防火墙检查

          关闭防火墙,确保Nginx服务正常。

        5. 缓存管理

          这些配置均衡分布至多台服务器,集群部署。

        6. 升级建议

          升级Nginx版本,获取最新功能和性能提升。

        7. 这配置将实现高效、稳定的资源分离和反向代理。

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

    你可能感兴趣的文章
    MySQL 常用列类型
    查看>>
    mysql 常用命令
    查看>>
    Mysql 常见ALTER TABLE操作
    查看>>
    MySQL 常见的 9 种优化方法
    查看>>
    MySQL 常见的开放性问题
    查看>>
    Mysql 常见错误
    查看>>
    mysql 常见问题
    查看>>
    MYSQL 幻读(Phantom Problem)不可重复读
    查看>>
    mysql 往字段后面加字符串
    查看>>
    mysql 快速自增假数据, 新增假数据,mysql自增假数据
    查看>>
    Mysql 批量修改四种方式效率对比(一)
    查看>>
    Mysql 报错 Field 'id' doesn't have a default value
    查看>>
    MySQL 报错:Duplicate entry 'xxx' for key 'UNIQ_XXXX'
    查看>>
    Mysql 拼接多个字段作为查询条件查询方法
    查看>>
    mysql 排序id_mysql如何按特定id排序
    查看>>
    Mysql 提示:Communication link failure
    查看>>
    mysql 插入是否成功_PDO mysql:如何知道插入是否成功
    查看>>
    Mysql 数据库InnoDB存储引擎中主要组件的刷新清理条件:脏页、RedoLog重做日志、Insert Buffer或ChangeBuffer、Undo Log
    查看>>
    mysql 数据库中 count(*),count(1),count(列名)区别和效率问题
    查看>>
    mysql 数据库备份及ibdata1的瘦身
    查看>>