精华内容
下载资源
问答
  • nginx代理转发说明

    2020-10-19 16:29:49
    1、nginx默认转发header,个别字段除外 说明: (1)proxy_hide_header 语法: proxy_hide_headerfield; 默认值: — 上下文: http,server,location nginx默认不会将“Date”、“Server”、“X-Pad...

    1、nginx 默认转发header,个别字段除外

    说明:

    (1)proxy_hide_header

    语法:proxy_hide_header field;
    默认值:
    上下文:httpserverlocation

    nginx默认不会将“Date”、“Server”、“X-Pad”,和“X-Accel-...”响应头发送给客户端。proxy_hide_header指令则可以设置额外的响应头,这些响应头也不会发送给客户端。相反的,如果希望允许传递某些响应头给客户端,可以使用proxy_pass_header指令。

    (2)proxy_pass_header(其功能与proxy_hide_header相反,会将原来不允许转发的改为允许转发)

    语法:proxy_pass_header field;
    默认值:
    上下文:httpserverlocation

    允许传送被屏蔽的后端服务器响应头到客户端。

    (3)proxy_set_header

    语法:proxy_set_header field value;
    默认值:
    proxy_set_header Host $proxy_host;
    proxy_set_header Connection close;
    上下文:httpserverlocation

    允许重新定义或者添加发往后端服务器的请求头。value可以包含文本、变量或者它们的组合。 当且仅当当前配置级别中没有定义proxy_set_header指令时,会从上面的级别继承配置。 默认情况下,只有两个请求头会被重新定义:

    proxy_set_header Host       $proxy_host;
    proxy_set_header Connection close;
    

    如果不想改变请求头“Host”的值,可以这样来设置:

    proxy_set_header Host       $http_host;
    

    但是,如果客户端请求头中没有携带这个头部,那么传递到后端服务器的请求也不含这个头部。 这种情况下,更好的方式是使用$host变量——它的值在请求包含“Host”请求头时为“Host”字段的值,在请求未携带“Host”请求头时为虚拟主机的主域名:

    proxy_set_header Host       $host;
    

    此外,服务器名可以和后端服务器的端口一起传送:

    proxy_set_header Host       $host:$proxy_port;
    

    如果某个请求头的值为空,那么这个请求头将不会传送给后端服务器:

    proxy_set_header Accept-Encoding "";

    2、nginx 默认转发body

    说明:

    proxy_pass_request_body(默认是打开的)

    Syntax:proxy_pass_request_body on | off;
    Default:
    proxy_pass_request_body on;
    Context:httpserverlocation

    Indicates whether the original request body is passed to the proxied server.

    location /x-accel-redirect-here/ {
        proxy_method GET;
        proxy_pass_request_body off;
        proxy_set_header Content-Length "";
    
        proxy_pass ...
    }
    

    See also the proxy_set_header and proxy_pass_request_headers directives.

    参考:

    (1)Nginx基础入门之proxy反向代理常用配置项说明:https://blog.51cto.com/blief/1739178

    (2)Nginx中文手册:http://tengine.taobao.org/nginx_docs/cn/docs/http/ngx_http_proxy_module.html#proxy_hide_header

    (3)Nginx英文手册:http://nginx.org/en/docs/http/ngx_http_proxy_module.html#proxy_pass_header

    展开全文
  • 服务转发失败 运行 vim /var/log/nginx/error.log 检查nginx的log会发现log提示权限不足,可是我们已经把文件权限付给了nginxnginx错误日志 最终得知是因为selinux的缘故,此时只需运行 setenforce 0 即可关闭...

    本文章仅作为个人笔记

    1.搭建php运行环境

    php:

    判断是否有php的yum源: yum search php

    b1c924886126

    php源比较旧

    系统本身自带php的yum源,但是版本太旧,还是5.4的,为了安装最新的源这里准备安装新yum源。

    安装php的yum源:

    rpm -Uvh https://mirror.webtatic.com/yum/el7/epel-release.rpm

    rpm -Uvh https://mirror.webtatic.com/yum/el7/webtatic-release.rpm

    也有可能有部分用户无法访问这两个文件,此时可以换用下面方式(7.2),因此后面的部分教程可能也会不一样,需注意

    yum install epel-release -y

    rpm -Uvh http://rpms.famillecollet.com/enterprise/remi-release-7.rpm

    此时再运行 yum search php 会发现多出来更多选项

    b1c924886126

    有php源

    安装php及部分相关插件(php-cli为shell相关,php-common为常用函数相关,php-devel为编译相关,php-fpm为服务相关,php-gd为图片处理相关,php-intl为国际化相关,php-mbstring为多字符串处理相关,php-mcrypt为加密相关,php-mysqlnd为mysql相关,php-opcache为性能加速相关,php-pdo为数据对象相关,php-pear为php应用扩展相关,php-xml为xml相关)(这里安装php7.1):yum install php71w-cli.x86_64 php71w-common.x86_64 php71w-fpm.x86_64 php71w-devel.x86_64 php71w-gd.x86_64 php71w-intl.x86_64 php71w-mbstring.x86_64 php71w-mcrypt.x86_64 php71w-mysqlnd.x86_64 php71w-opcache.x86_64 php71w-pdo.x86_64 php71w-pear.noarch php71w-xml.x86_64 -y

    如果使用第二种方案安装源的,请用如下脚本

    yum install php72-php-cli.x86_64 php72-php-common.x86_64 php72-php-fpm.x86_64 php72-php-devel.x86_64 php72-php-gd.x86_64 php72-php-intl.x86_64 php72-php-mbstring.x86_64 php72-php-pecl-mcrypt.x86_64 php72-php-mysqlnd.x86_64 php72-php-opcache.x86_64 php72-php-pdo.x86_64 php72-php-pear.noarch php72-php-xml.x86_64 -y

    运行php –version查看php是否安装并配置完成。出现与截图类似的版本信息则表示安装php配置完成,

    b1c924886126

    php版本

    运行service php-fpm start启动php-fpm服务,运行ps aux | grep php-fpm验证是否成功安装php-fpm服务。

    b1c924886126

    php-fpm测试

    2.安装周边服务(nginx/composer/git/mysql/redis)

    这几个服务基本可以在基本yum源中安装,如果没有composer,可运行cd /tmp

    mv composer.phar/usr/local/bin/composer  即可完成composer的安装

    3.服务代码准备

    为了方便php服务的部署和更新,笔者使用git进行项目下载及更新。

    进入准备部署服务的文件夹,运行 git clone git地址(例:git clone root@www.temp.com:/git/php/markingphp)

    b1c924886126

    下载php代码

    此时项目权限为root,如果这样运行php-fpm可能会权限不足,笔者这里为了简便及对php项目静态资源nginx管理,将项目权限更改为nginx,并将php-fpm的运行者权限改为nginx。

    4.php及项目相关配置

    运行 chown nginx:nginx -Rf 文件夹名(例:chown nginx:nginx -Rf markingphp)

    运行rpm -ql php17w-fpm.x86_64获取php-fpm安装地址

    b1c924886126

    获取php-fpm安装地址

    尝试得知 /etc/php-fpm.d/www.conf 为配置文件

    b1c924886126

    php-fpm配置文件

    更改user = apache与 group = pache 为 user = nginx group = nginx 如果有必要可以更改127.0.0.1:9000为想要的端口

    为了服务器信息安全及项目大小控制,git项目未上传项目配置与项目引用库,所以需要重新新建项目配置文件并配置

    b1c924886126

    项目结构

    b1c924886126

    配置文件

    运行 composer update -vvv 下载库

    b1c924886126

    下载库失败

    如果库下载失败,可能是库被墙的原因,更改composer.json添加国内源再运行即可。

    "repositories": {

    "packagist": {

    "type": "composer",

    "url": "https://packagist.phpcomposer.com"

    }

    }

    b1c924886126

    国内源

    再运行 php artisan serve 可测试当前项目库是否完整,出现如下说明项目库下载完成。

    b1c924886126

    尝试启动项目测试

    初始化项目mysql表(php artisan migrate:refresh)

    b1c924886126

    初始化mysql

    配置nginx以转发80端口服务到php-fpm的服务,

    server {

    listen 80;

    location / {

    root /php/markingphp/public/;

    index index.php index.html index.jsp;

    }

    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;

    }

    }

    运行curl localhost 判断服务是否正常转发。

    b1c924886126

    服务转发失败

    运行 vim /var/log/nginx/error.log 检查nginx的log会发现log提示权限不足,可是我们已经把文件权限付给了nginx。

    b1c924886126

    nginx错误日志

    最终得知是因为selinux的缘故,此时只需运行 setenforce 0 即可关闭selinux(临时),再修改配置文件 /etc/selinux/config,将SELINUX=enforcing改为SELINUX=disabled,这样下次重启selinux依然是关闭的。再运行curl localhost 会发现服务已经可以正常服务了。

    展开全文
  • windows 下配置 Nginx 常见问题 2015年01月16日 技术分享 评论 2 条 阅读 11,866 次 因为最近的项目需要用到负载均衡,不用考虑,当然用大名鼎鼎的Nginx啦。至于Nginx的介绍,这里就不多说了...

    windows 下配置 Nginx 常见问题

    2015年01月16日  技术分享  评论 2 条  阅读 11,866 次

    因为最近的项目需要用到负载均衡,不用考虑,当然用大名鼎鼎的Nginx啦。至于Nginx的介绍,这里就不多说了,直接进入主题如何在Windows下配置。

    我的系统是win7旗舰版的,到官网下载最新版本 nginx/Windows-1.7.9 解压到英文目录下(我刚开始是放到中文目录下的,启动时会有问题,下面常见错误里会讲到)。

    一、  Nginx配置

    找到 conf 目录里的 nginx.conf 文件,配置Nginx

    #user  nobody;
    #指定nginx进程数
    worker_processes  1;
    
    #全局错误日志及PID文件
    #error_log  logs/error.log;
    #error_log  logs/error.log  notice;
    #error_log  logs/error.log  info;
    
    #pid        logs/nginx.pid;
    
     
    events {
        # 连接数上限
        worker_connections  1024;
    }
    
    #设定http服务器,利用它的反向代理功能提供负载均衡支持
    http {
    
        #设定mime类型,类型由mime.type文件定义
        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 指令指定 nginx 是否调用 sendfile 函数(zero copy 方式)来输出文件,对于普通应用,    
        sendfile        on;
        #tcp_nopush     on;
    
        #连接超时时间
        #keepalive_timeout  0;
        keepalive_timeout  65;
    
        #开启gzip压缩
        #gzip  on;
    
    
    
        #设定负载均衡的服务器列表 支持多组的负载均衡,可以配置多个upstream  来服务于不同的Server.
        #nginx 的 upstream 支持 几 种方式的分配 
        #1)、轮询(默认) 每个请求按时间顺序逐一分配到不同的后端服务器,如果后端服务器down掉,能自动剔除。 
        #2)、weight 指定轮询几率,weight和访问比率成正比,用于后端服务器性能不均的情况。 跟上面样,指定了权重。
        #3)、ip_hash 每个请求按访问ip的hash结果分配,这样每个访客固定访问一个后端服务器,可以解决session的问题。 
        #4)、fair       
        #5)、url_hash #Urlhash
        upstream mysvr {
          #weigth参数表示权值,权值越高被分配到的几率越大   
          #1.down 表示单前的server暂时不参与负载
          #2.weight 默认为1.weight越大,负载的权重就越大。     
          #3.backup: 其它所有的非backup机器down或者忙的时候,请求backup机器。所以这台机器压力会最轻。  
          #server 192.168.1.116  down;
          #server 192.168.1.116  backup;
          server 192.168.1.121  weight=1;
          server 192.168.1.122  weight=2;
        }
    
        #配置代理服务器的地址,即Nginx安装的服务器地址、监听端口、默认地址
        server {
            #1.侦听80端口 
            listen       80;
    
            #对于server_name,如果需要将多个域名的请求进行反向代理,可以配置多个server_name来满足要求
            server_name  localhost;
            
            #charset koi8-r;
    
            #access_log  logs/host.access.log  main;
    
            location / {
                # 默认主页目录在nginx安装目录的html子目录。
                root   html;
                index  index.html index.htm;           
                proxy_pass http://mysvr; #跟载均衡服务器的upstream对应   
            }
    
            #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;
        #    }
        #}
    
    }

    二、  启动Nginx

    cmd 进入Nginx解压目录 执行 start nginx启动Nginx服务

    启动后如何检查是否启动成功呢? 输入命令 tasklist /fi "imagename eq nginx.exe"   看到以下信息说明启动成功了

    windows 下配置 Nginx 常见问题

     

    一切就绪,访问一下server 里配置的 server_name 是不是被重定向到 upstream配置的服务器上了,是不是很简单!

    三、常见错误

    如果启动失败 可以看下logs目录下 error.log 文件里的错误信息。

    我在第一次安装的时遇到两个错误,也是最容易碰到的问题,在这里列出来方便大家碰到相同的问题时快速解决。

    1.  端口占用问题

    我的配置文件里服务侦听的是 80 端口,由于机器上部署了IIS,80端口被默认站点占用,把站点关闭就可以了,这个问题在错误日志里记录是这样的。

     

    2015/01/15 10:44:12 [emerg] 8800#5988: bind() to 0.0.0.0:80 failed (10013: An attempt was made to access a socket in a way forbidden by its access permissions)

     

    碰到类似的错误,请确认端口是否被占用或被防火墙屏蔽

     

    2.Nginx所在目录有中文

    错误日志大致输出一下内容

    2015/01/15 11:55:55 [emerg] 5664#8528: CreateFile() "E:\软件\nginx-1.7.8/conf/nginx.conf" failed (1113: No mapping for the Unicode character exists in the target multi-byte code page)

    3. 启用缓存时报错

    2015/01/15 17:26:50 [emerg] 17068#20356: shared zone "cache_one" has no equal addresses: 02CF0000 vs 02A20000
    2015/01/15 17:26:50 [alert] 11536#11228: worker process 17068 exited with code 1

    我一直没有找到解决的方法,有人说重启服务,或者缓存设置大一点就可以了,我试了一下没有用的,官网原文是这样讲的,只能认为windwos下无解了。

    : The cache and other modules which require shared memory support do 
    : not work in Windows Vista and later due to address space layout 
    : randomization being enabled in these Windows versions.
    展开全文
  • Centos7下安装Nginx并配置内网转发

    千次阅读 2017-05-25 12:33:08
    Centos7下安装Nginx并配置内网转发

    Centos7下安装Nginx并配置内网转发

    腾讯云学生优惠的服务器最近买了一台。但是一直没有用。今天要打算把写好的项目部署到上面。

    1. 下载Nginx源码
      输入 yum info nginx 可以获取到nginx的官网地址
      下面是我获取到的。链接就是http://nginx.org/
    已安装的软件包
    名称    :nginx
    架构    :x86_64
    时期       :1
    版本    :1.10.2
    发布    :1.el7
    大小    :1.4 M
    源    :installed
    来自源:epel
    简介    : A high performance web server and reverse proxy server
    网址    :http://nginx.org/
    协议    : BSD
    描述    : Nginx is a web server and a reverse proxy server for HTTP, SMTP, POP3 and
             : IMAP protocols, with a strong focus on high concurrency, performance and low
             : memory usage.
    

    打开后虽然是英文。但是千万别发愁。点开一个稳定版。然后就可以进入到下载页面。
    如果看不懂可以参照我下载的。我下载是的 http://nginx.org/download/nginx-1.8.1.tar.gz
    我下载到了 /usr/local/ 路径下。
    输入sudo wget http://nginx.org/download/nginx-1.8.1.tar.gz 下载nginx源码。
    下载好后会得到 nginx-1.8.1.tar.gz 的压缩包。我们解压它,输入:
    sudo tar -xvzf nginx-1.8.1.tar.gz
    解压文件夹。
    然后得到目录:nginx-1.8.1 。进入到目录中,可以看到有这么多文件

    auto     CHANGES.ru  configure  html     Makefile  objs    src
    CHANGES  conf        contrib    LICENSE  man       README

    我们依次输入
    sudo ./configure --prefile=/usr/local/nginx
    sudo make
    sudo make install
    就可以安装好nginx。

    如果安装中出错,可能是没有安装相应的依赖。我遇到的问题是没有安装zlib
    输入 yum install zlib-devel 安装zlib 就可以解决。

    安装好后,我们要启动nginx服务。
    在/usr/local/nginx/sbin/下输入 ../nginx 启动服务
    ./nginx -s stop 停止服务
    ./nginx -s reload 重新加载配置
    ./nginx -h 获取帮助信息
    注意如果需要管理员权限就加 sudo

    2. 启用内网转发

    在nginx的安装目录下。cd 到 conf 目录下。里面有 nginx.conf
    vim nignx.conf 编辑
    如果是第一次配置的话千万别怕。

    {
        keepalive_timeout  65;
    
        server {
            listen       80;
            server_name  lyx.cn;  #域名 
    
            charset utf8; # 编码
    
            #access_log  logs/host.access.log  main;
    
            # # #号为注释
            #  配置内网转发。外部访问  域名下的根目录的时候就会转发到本机的 8080 端口
            location / {
                proxy_pass   http://127.0.0.1:8080;
            }
    
            location = /50x.html {
                root   html;
            }
        }
    }
    
    
    展开全文
  • Nginx

    2019-07-27 11:26:37
    文章目录NginxNginx相关概念反向代理负载均衡安装下载nginx上传并解压nginx编译nginx检查安装环境编译安装配置nginx配置反向代理负载均衡 Nginx Nginx相关概念 反向代理 反向代理(Reverse Proxy)方式是指以代理...
  • nginx

    2020-01-14 19:45:37
    Nginx 主要内容 Nginx简介 代理方式 安装Nginx 操作Nginx Ngixn的使用 学习目标 知识点 要求 Redis简介 了解 代理方式 掌握 安装Nginx 掌握 操作Nginx 掌握 Ngixn的使用 掌握 顺口溜来了!~~~~~~ 一、 Nginx简介 1 ...
  • Nginx URL Rewrite – URL 转发规则

    千次阅读 2012-03-21 09:31:41
    Nginx(engine x)是由Igor Sysoev主导设计和实现的高性能的web服务器和邮件代理服务器,目前它已经成为代替在web服务器市场遥遥领先的apache服务器的首选替代品. 随着越来越多的大型站点的加入(大房注:国内有...
  • nginx可以在nginx.conf中进行配置,根据http请求头中accept-language转发到不同的页面

空空如也

空空如也

1 2 3 4 5 ... 20
收藏数 5,656
精华内容 2,262
关键字:

nginx转发英文