源码网商城,靠谱的源码在线交易网站 我的订单 购物车 帮助

源码网商城

Nginx的使用经验小结

  • 时间:2020-04-10 10:16 编辑: 来源: 阅读:
  • 扫一扫,手机访问
摘要:Nginx的使用经验小结
[b]Nginx[/b] [b]Nginx简单介绍[/b] 一款轻量级的Web服务器/反向代理服务器及电子邮件(IMAP/POP3)代理服务器 [b]Nginx命令参数[/b] nginx -t 测试配置是否正确 nginx -s reload 加载最新配置 nginx -s stop 立即停止 nginx -s quit 优雅停止 nginx -s reopen 重新打开日志 kill -USR2 cat /usr/local/nginx/logs/nginx.pid 快速重启 [b]Nginx全局段配置[/b] worker_processes 1;工作进程为1个 CPU 数量 * 核数 events 区段 网卡请求 80 443 Nginx 触发事件 [b]Nginx配置虚拟主机[/b] listen server_name location [b]Nginx日志管理[/b] * 系统默认日志格式:log_format main '$remote_addr $request_length $body_bytes_sent $request_time[s] - - [$time_local] ' '"$request" $status $http_referer "-" "$http_user_agent" $server_name $server_addr $http_x_forwarded_for $http_x_real_ip'; * 自定义日志格式:log_format simple '$remote_addr -- $request' * 系统默认日志释义:远程IP-远程用户/用户时间 请求方法 请求body长度长度 referer 来源信息 http-user-agent 用户代理/蜘蛛 被转发请求的原始ip http_x_forwarded_for 在经过代理是 代理把你的本来的IP加在此头信息中,传输你的原始IP [b]Nginx-Laravel5 项目搭建[/b] window上传本地项目使用 secureCRT-sftp put get 命令上传 connect sftp session, 远程:cd 本地:lcd,lpwd, put *.zip Laravel5返回500权限修改:1.chmod 777 -R storage 2.chmod 777 -R bootstrap/cache/ 配置env : vi .env 修改数据库配置相关参数 执行 php artisan migrate 创建数据表 [b]Nginx 支持pathinfo [/b]
# 典型配置
location ~ .php$ {
  root      html;
  fastcgi_pass  127.0.0.1:9000;
  fastcgi_index index.php;
  fastcgi_param SCRIPT_FILENAME $DOCUMENT_ROOT$fastcgi_script_name;
  include    fastcgi_params;
}

# 修改第1,6行,支持pathinfo

location ~ .php(.*)$ { # 正则匹配.php后的pathinfo部分
  root html;
  fastcgi_pass  127.0.0.1:9000;
  fastcgi_index index.php;
  fastcgi_param SCRIPT_FILENAME $DOCUMENT_ROOT$fastcgi_script_name;
  fastcgi_param PATH_INFO $1; # 把pathinfo部分赋给PATH_INFO变量
  include    fastcgi_params;
}

[b]Nginx 支持URL重写[/b] 1.如果 不是资源文件就重写
if (!-e $request_filename) {
  rewrite (.*)$ /index.php/$1;
}
2.try_files [code]try_files $uri $uri/ /index.php?$args; [/code] [b]Nginx 反向代理与动静分离[/b] 用Nginx做反向代理用proxy_pass,以反向代理为例,nginx不自己处理图片的相关请求,而是把图片的请求转发给Apache处理。
location ~.(jpg|jpeg|png|gif)${
   proxy_pass HTTP://IP:port;
 }
反向代理导致了后端服务器接到客户端IP为前端服务器的IP而不是真正的IP解决方案
location ~ .(jpg|jpeg|png|gif) {
   proxy_set_header X-Forwarded-For $remote_addr;
   proxy_pass IP:port;
 }


[b]Nginx 集群和负载均衡[/b] Upstream{} 模块 把多台服务器加入到一个组 然后 memcache pass, fastcgi_pass, proxy_pass => upstream 组 配置Upstream
 upstream web{
   server IP:8080 weight=1 max_fails=2 fail_timeout=30s;
   server IP2:80 weight=1 max_fails=2 fail_timeout=30s;
 } 
 
  下游调用
 location ~ .(jpg|png|gif|jpeg) {
 proxy_set_header X-Forwarded-For $remote_addr;
     proxy_pass http://web;
 }
负载均衡常见的策略释义 基于cookie值区别做负载均衡(Nginx sticky 们模块)   基于URI利用一致性哈希算法做均衡(NginxHttpUPstreamConsistentHash 模块)   基于IP做负载均衡
  • 全部评论(0)
联系客服
客服电话:
400-000-3129
微信版

扫一扫进微信版
返回顶部