検索
ホームページ運用・保守NginxNginx Rewrite モジュールの適用シナリオは何ですか?

应用场景1——基于域名的跳转

公司旧域名 ,因业务需求有变更,需要使用新域名www.kgc.com 代替

1.不能废除旧域名
2.从旧域名跳转到新域名,且保持其参数不变

部署环境

一台linux服务器(192.168.142.130)
一台测试主机windows 7

1,安装nginx服务

[root@localhost ~]# rpm -uvh http://nginx.org/packages/centos/7/noarch/rpms/nginx-release-centos-7-0.el7.ngx.noarch.rpm
#安装nginx官方源

[root@localhost ~]# yum install nginx -y  
#yum安装nginx

2,修改nginx默认配置文件

[root@localhost ~]# vim /etc/nginx/conf.d/default.conf ##修改默认配置文件
server {
    listen    80;
    server_name www.accp.com;  ##修改主机名

    #charset koi8-r;
    access_log /var/log/nginx/www.accp.com-access.log main;  ##开启日志服务

3,安装bind解析服务

[root@localhost ~]# yum install bind -y

4,修改主配置文件(named.conf)

[root@localhost ~]# vim /etc/named.conf 
options {
                listen-on port 53 { any; };     ##监听所有
                ...
                allow-query   { any; };      ##允许所有

5,修改区域配置文件(named.rfc1912.zones)

[root@localhost ~]# vim /etc/named.rfc1912.zones  ##配置区域配置文件

zone "accp.com" in {
                type master;
                file "accp.com.zone";       ##accp区域数据配置文件
                allow-update { none; };
};

6,修改区域数据配置文件(accp.com.zone)

[root@localhost ~]# cd /var/named/ 
[root@localhost named]# cp -p named.localhost accp.com.zone  ##复制模板
[root@localhost named]# vim accp.com.zone  ##修改区域配置文件

$ttl 1d
@    in soa @ rname.invalid. (
                                    1d   ; refresh
                                    1h   ; retry
                                    1w   ; expire
                                    3h )  ; minimum
                ns   @
                a    127.0.0.1
www in a    192.168.142.130         ##本机地址
[root@localhost named]# systemctl start named   ##开启dns服务
[root@localhost named]# systemctl stop firewalld.service  ##关闭防火墙
[root@localhost named]# setenforce 0
[root@localhost named]# systemctl start nginx  ##开启nginx服务

7,用测试机测试网页

Nginx Rewrite模块应用的场景有哪些

8,修改配置文件,设置域名跳转

[root@localhost named]# vim /etc/nginx/conf.d/default.conf ##修改配置文件
  server {
      listen    80;
      server_name www.accp.com;

      #charset koi8-r;
      access_log /var/log/nginx/www.accp.com-access.log main;

      location / {
          if ($host = "www.accp.com"){    ##匹配如果域名是老域名
                  rewrite ^/(.*)$ http://www.kgc.com/$1 permanent;  ##则永久设置跳转新域名
          }
          root  /usr/share/nginx/html;
          index index.html index.htm;
      }

9,添加新域名解析

[root@localhost named]# vim /etc/named.rfc1912.zones 

zone "kgc.com" in {
                type master;
                file "kgc.com.zone";       ##accp区域数据配置文件
                allow-update { none; };
};

[root@localhost named]# cp -p /var/named/accp.com.zone /var/named/kgc.com.zone
##复制区域数据配置文件为kgc的数据配置文件
[root@localhost named]# systemctl restart named  ##重启解析服务
[root@localhost named]# systemctl restart nginx   ##重启nginx服务

10,用旧域名访问,查看网页跳转

Nginx Rewrite模块应用的场景有哪些

Nginx Rewrite模块应用的场景有哪些

11,旧域名后加上参数,查看跳转新域名时是否有参数

Nginx Rewrite模块应用的场景有哪些

Nginx Rewrite模块应用的场景有哪些

应用场景2——基于客户端ip访问跳转

公司业务版本上线,所有ip访问任何内容都显示一个固定维护页面,只有公司ip访问正常

1,修改nginx默认配置文件

[root@localhost ~]# cd /etc/nginx/conf.d/
[root@localhost conf.d]# vim default.conf 

server {
    listen    80;
    server_name www.accp.com;
    #charset koi8-r;
    access_log /var/log/nginx/www.accp.com-access.log main;
    #设置是否合法的ip标志
    set $rewrite true;     ##设置变量为真
    #判断是否为合法的ip
    if ($remote_addr = "192.168.142.120"){
        set $rewrite false;  ##匹配合法ip,将变量设置为假,正常跳转页面
    }
    #非法ip进行判断打上标记
    if ($rewrite = true){        ##匹配非法ip,跳转到main的网页
        rewrite (.+) /main.html;
    }
    #匹配标记进行跳转站点
    location = /main.html {       ##精确匹配
        root /usr/share/nginx/html;  ##站点路径
    }

    location / {
        root  /usr/share/nginx/html;
        index index.html index.htm;
    }

2,创建非法ip站点及main的网页页面

[root@localhost conf.d]# cd /usr/share/nginx/html/ ##切换到站点中
[root@localhost html]# vim main.html  ##编辑非法ip访问网页内容
<h1 id="this-nbsp-is-nbsp-test-nbsp-web">this is test web</h1>
[root@localhost html]# systemctl restart nginx  ##重启nginx服务

3,访问测试网页

Nginx Rewrite模块应用的场景有哪些

Nginx Rewrite模块应用的场景有哪些

应用场景3——基于旧,新域名跳转并加目录

将域名http://bbs.accp.com 下面的发帖都跳转到http://www.accp.com/bbs 且域名跳转后保持参数不变

1,修改nginx默认配置文件

[root@localhost ~]# cd /etc/nginx/conf.d/
[root@localhost conf.d]# vim default.conf  ##修改默认配置文件
server {
    listen    80;
    server_name bbs.accp.com;  ##修改服务名称

    #charset koi8-r;
    access_log /var/log/nginx/www.accp.com-access.log main;
    location /post {     ##用location匹配post目录
        rewrite (.+) http://www.accp.com/bbs$1 permanent;  ##永久重定向跳转
    }

2,修改dns的区域数据配置文件(accp.com.zone)

[root@localhost conf.d]# cd /var/named/
[root@localhost named]# vim accp.com.zone  ##修改区域数据配置文件
$ttl 1d
@    in soa @ rname.invalid. (
                          0    ; serial
                          1d   ; refresh
                          1h   ; retry
                          1w   ; expire
                          3h )  ; minimum
        ns   @
        a    127.0.0.1
bbs in a    192.168.142.130
[root@localhost named]# systemctl restart named  ##重启解析服务
[root@localhost named]# systemctl restart nginx   ##重启nginx服务
[root@localhost named]# echo "nameserver 192.168.142.130" > /etc/resolv.conf 
##将解析服务器地址放到本地解析配置文件中

3,测试网页

Nginx Rewrite模块应用的场景有哪些

Nginx Rewrite模块应用的场景有哪些

应用场景4——基于参数匹配的跳转

浏览器访问:http://www.accp.com/100-(100|200)-100.html 跳转到http://www.accp.com 页面

1,修改nginx默认配置文件

[root@localhost ~]# cd /etc/nginx/conf.d/
[root@localhost conf.d]# vim default.conf 

server {
    listen    80;
    server_name www.accp.com;
    #charset koi8-r;
    access_log /var/log/nginx/www.accp.com-access.log main;
    if ($request_uri ~ ^/100-(100|200)-(\d+).html$){    
    ##匹配正则开头为100-(100|200)-一次多次的整数html为结尾的
        rewrite (.*) http://www.accp.com permanent;    ##永久重定向跳转到主页
    }

2,修改dns区域数据配置文件

  [root@localhost conf.d]# vim /var/named/accp.com.zone ##修改区域数据配置文件
  www in a    192.168.142.130  
  [root@localhost conf.d]# systemctl restart named ##重启解析服务 
  [root@localhost conf.d]# systemctl restart nginx   ##重启nginx服务

3,测试网页

Nginx Rewrite模块应用的场景有哪些

Nginx Rewrite模块应用的场景有哪些

应用场景5——基于目录下所有php文件跳转

访问http://www.accp.com/upload/1.php 跳转到首页

1,修改nginx默认配置文件

[root@localhost ~]# cd /etc/nginx/conf.d/
  [root@localhost conf.d]# vim default.conf  ##修改默认配置文件
  server {
      listen    80;
      server_name www.accp.com;
      #charset koi8-r;
      access_log /var/log/nginx/www.accp.com-access.log main;
      location ~* /upload/.*\.php$ {     ##匹配不分大小写,匹配upload后零次或多次以.php为结尾的
          rewrite (.+) http://www.accp.com permanent;  ##跳转到首页
      }
  [root@localhost conf.d]# systemctl restart nginx  ##重启nginx服务

2,测试网页

Nginx Rewrite模块应用的场景有哪些

Nginx Rewrite模块应用的场景有哪些

应用场景6——基于最普通url请求的跳转,访问一个具体的页面跳转到首页

1,修改nginx默认配置文件

[root@localhost ~]# cd /etc/nginx/conf.d/
  [root@localhost conf.d]# vim default.conf  ##修改nginx默认配置文件
  server {
      listen    80;
      server_name www.accp.com;
      #charset koi8-r;
      access_log /var/log/nginx/www.accp.com-access.log main;
      location ~* ^/abc/123.html {    ##匹配某一个特定的网页
          rewrite (.+) http://www.accp.com permanent; ##跳转到首页
      }
  [root@localhost conf.d]# systemctl restart nginx  ##重启nginx服务

2,测试网页

Nginx Rewrite模块应用的场景有哪些

Nginx Rewrite模块应用的场景有哪些

以上がNginx Rewrite モジュールの適用シナリオは何ですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明
この記事は亿速云で複製されています。侵害がある場合は、admin@php.cn までご連絡ください。
Nginxの主な機能:パフォーマンス、スケーラビリティ、セキュリティNginxの主な機能:パフォーマンス、スケーラビリティ、セキュリティApr 13, 2025 am 12:09 AM

Nginxは、イベント駆動型のアーキテクチャと非同期処理機能を通じてパフォーマンスを向上させ、モジュラー設計と柔軟な構成を通じてスケーラビリティを向上させ、SSL/TLSの暗号化と要求レートの制限を介してセキュリティを改善します。

Nginx vs. Apache:Webホスティングとトラフィック管理Nginx vs. Apache:Webホスティングとトラフィック管理Apr 12, 2025 am 12:04 AM

Nginxは、高い並行性と低リソース消費シナリオに適していますが、Apacheは複雑な構成と機能的拡張を必要とするシナリオに適しています。 1.Nginxは、高性能と多数の同時接続を処理することで知られています。 2。Apacheは、その安定性とリッチモジュールのサポートで知られています。選択するときは、特定のニーズに基づいて決定する必要があります。

NGINX:最新のWebアプリケーション用の汎用ツールNGINX:最新のWebアプリケーション用の汎用ツールApr 11, 2025 am 12:03 AM

nginxisentialformodernwebapplicationsdueToitsRolesasareverseproxy、loadbalancer、andwebserver、weberporformanceandscalability.1)itactsasaReverseproxy、拡張、およびパフォーマンスを強化し、パフォーマンスを強化し、積極的に積極的なものを増やします

nginx SSL/TLS構成:HTTPSでWebサイトを保護しますnginx SSL/TLS構成:HTTPSでWebサイトを保護しますApr 10, 2025 am 09:38 AM

NGINXを通じてWebサイトのセキュリティを確保するには、次の手順が必要です。1。基本的な構成を作成し、SSL証明書と秘密鍵を指定します。 2。構成を最適化し、HTTP/2を有効にし、OCSPSTAPLING。 3.証明書パスや暗号化スイートの問題などの一般的なエラーをデバッグします。 4。let'sencryptの使用やセッションの多重化など、アプリケーションのパフォーマンス最適化の提案。

Nginxインタビューの質問:DevOps/System管理インタビューをAceNginxインタビューの質問:DevOps/System管理インタビューをAceApr 09, 2025 am 12:14 AM

Nginxは、高性能のHTTPおよびリバースプロキシサーバーであり、高い並行接続の取り扱いに優れています。 1)基本的な構成:ポートを聞いて静的ファイルサービスを提供します。 2)高度な構成:逆プロキシとロードバランシングを実装します。 3)デバッグスキル:エラーログを確認し、構成ファイルをテストします。 4)パフォーマンスの最適化:GZIP圧縮を有効にし、キャッシュポリシーを調整します。

nginxキャッシュテクニック:ウェブサイトのパフォーマンスの向上nginxキャッシュテクニック:ウェブサイトのパフォーマンスの向上Apr 08, 2025 am 12:18 AM

Nginxキャッシュは、次の手順を通じてWebサイトのパフォーマンスを大幅に改善できます。1)キャッシュ領域を定義し、キャッシュパスを設定します。 2)キャッシュ有効期間を構成します。 3)異なるコンテンツに従って異なるキャッシュポリシーを設定します。 4)キャッシュストレージと負荷分散を最適化します。 5)キャッシュ効果を監視およびデバッグします。これらの方法により、Nginxキャッシュはバックエンドサーバーの圧力を軽減し、応答速度とユーザーエクスペリエンスを向上させることができます。

Dockerを使用したNginx:コンテナ化されたアプリケーションの展開とスケーリングDockerを使用したNginx:コンテナ化されたアプリケーションの展開とスケーリングApr 07, 2025 am 12:08 AM

DockerComposeを使用すると、Nginxの展開と管理が簡素化され、DockerswarmまたはKubernetesをスケーリングすることは一般的な慣行です。 1)DockerComposeを使用してNginxコンテナを定義および実行する、2)DockerswarmまたはKubernetesを介してクラスター管理と自動スケーリングを実装します。

Advanced Nginx構成:マスタリングサーバーブロックとリバースプロキシAdvanced Nginx構成:マスタリングサーバーブロックとリバースプロキシApr 06, 2025 am 12:05 AM

nginxの高度な構成は、サーバーブロックとリバースプロキシを介して実装できます。1。サーバーブロックにより、複数のWebサイトを1つの場合に実行することができます。各ブロックは個別に構成されます。 2.逆プロキシは、リクエストをバックエンドサーバーに転送して、負荷分散とキャッシュアクセラレーションを実現します。

See all articles

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

AtomエディタMac版ダウンロード

AtomエディタMac版ダウンロード

最も人気のあるオープンソースエディター

SAP NetWeaver Server Adapter for Eclipse

SAP NetWeaver Server Adapter for Eclipse

Eclipse を SAP NetWeaver アプリケーション サーバーと統合します。

PhpStorm Mac バージョン

PhpStorm Mac バージョン

最新(2018.2.1)のプロフェッショナル向けPHP統合開発ツール

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

mPDF

mPDF

mPDF は、UTF-8 でエンコードされた HTML から PDF ファイルを生成できる PHP ライブラリです。オリジナルの作者である Ian Back は、Web サイトから「オンザフライ」で PDF ファイルを出力し、さまざまな言語を処理するために mPDF を作成しました。 HTML2FPDF などのオリジナルのスクリプトよりも遅く、Unicode フォントを使用すると生成されるファイルが大きくなりますが、CSS スタイルなどをサポートし、多くの機能強化が施されています。 RTL (アラビア語とヘブライ語) や CJK (中国語、日本語、韓国語) を含むほぼすべての言語をサポートします。ネストされたブロックレベル要素 (P、DIV など) をサポートします。