## mod_alias模塊
這個模塊即可以完成別名定義,也可以處理URL請求。
### 別名定義
* Alias 將URL映射到定義的目錄或文件上
* AliasMatch 使用正則表達式定義
* ScriptAlias 定義一個目錄為CGI容器
* ScriptAliasMatch 使用正則表達式定義
### 重定向定義
Redirect permanent /download http://www.abc.com/download
* pernanent 狀態碼301 表示永久移動
* temp 狀態碼302 表示找到資源,默認
* seeother 狀態代碼303 資源位置被替換
* gone 狀態代碼410 表示資源已經不存在
* RedirectPermanent 表示 Redirect permanent
* RedirectTemp 表示 Redirect temp
## mod_rewrite模塊
### 工作流程

### 重寫指令
* RewriteEngine指令
參數為on或者off,設置是否啟用或者禁止模塊
* RewriteRule指令
語法格式
~~~
RewriteRule Pattern Substitution [flags]
~~~
#### Pattern
為當前請求的URL正則表達式,這個URL可能被RewriteRule規則或者alias指令修改過。使用“!”求反操作,不能使用匹配模式中的分組通配。
#### Substitution
參數是當原始URL與Pattern匹配時,用來替換的字符串。
* 對Pattern中的分組可以使用$N進行反向引用。
* 對RewriteCond中的分組可以使用%N進行反向引用。
* 規則條件測試字符串%{VARNAME}中的服務器變量
* 映射函數調用${mapname:key|default},用戶可以通過${mapname:key|default}的形式來調用RewriteMap定義的映射。
* “-”作用是不做任何處理
1 重寫到文件系統的路徑
~~~
RewriteRule "^/games" "/usr/local/games/web"
~~~
2 重寫到DocumentRoot目錄下的路徑
~~~
RewriteRule "^/foo$" "/bar"
~~~
3 重寫到完整的URL
~~~
RewriteRule "^/product/view$" "http://site2.example.com/seeproduct.html" [R]
~~~
#### flags
* last|L 結尾規則
這個標記用于阻止當前已被重寫的URL被后繼規則再次重寫
* proxy|P 強制為代理
此標記使替換成分被內部地強制作為代理請求發送,并立即中斷重寫處理,然后把處理移交給mod_proxy模塊。替換串是一個能夠被mod_proxy處理的有效URI(比如以http://hostname開頭)。可以把某些遠程成分映射到本地服務器域名空間,從而增強了ProxyPass指令的功能。注意:要使用這個功能,必須已經啟用了mod_proxy模塊。
* redirect|R[=code]
強制外部重定向
* forbidden|F
強制禁止當前URL響應,并像客戶端發送一個403httpd響應代碼
* gone|G
強制廢棄當前URL,并像客戶端發送一個410 httpd響應代碼
* nocase|NC
忽略pattern中的大小寫
* redirect|R [code]
將重寫的URL作為重定向處理,默認是302
* next|N 從頭再來
重新執行重寫操作(從第一個規則重新開始)。此時再次進行處理的URL已經不是原始的URL了,而是經最后一個重寫規則處理過的URL。它對應于Perl中的next命令或C語言中的continue命令。此標記可以重新開始重寫操作(立即回到循環的開頭)。但是要小心,不要制造死循環!
* noescape|NE 在輸出中不對URI進行轉義
此標記阻止mod_rewrite對重寫結果應用常規的URI轉義規則。一般情況下,特殊字符('%', '$', ';'等)會被轉義為等值的十六進制編碼('%25', '%24', '%3B'等)。
* chain|C 鏈接下一規則
此標記使當前規則與下一個規則相鏈接。它產生這樣的效果:如果一個規則被匹配,則繼續處理其后繼規則,也就是這個標記不起作用;如果該規則不被匹配,則其后繼規則將被跳過。比如,在一個目錄級規則中執行一個外部重定向時,你可能需要刪除".www"(此處不應該出現".www")。
* passthrough|PT 移交給下一個處理器
此標記強制重寫引擎將內部request_rec結構中的uri字段設置為filename字段的值,使得RewriteRule指令的輸出能夠被(從URI轉換到文件名的)Alias, ScriptAlias, Redirect等指令進行后續處理。
舉一個能說明其含義的例子:如果要將/abc重寫為/def,然后再使用mod_alias將/def轉換為/ghi,可以這樣:
```
RewriteRule ^/abc(.*) /def$1 [PT] Alias /def /ghi
```
如果省略了PT標記,雖然將uri=/abc/...重寫為filename=/def/...的部分運作正常,但是后續的mod_alias在試圖將URI轉換到文件名時會遭遇失效。
注意:如果需要混合使用多個將URI轉換到文件名的模塊時,就必須使用這個標記。。此處混合使用mod_alias和mod_rewrite就是個典型的例子。
~~~
Alias /icons /usr/local/apache/icons
RewriteRule /pics/(.+).jpg /icons/$1.gif [PT]
~~~
當請求/pics/下的圖片文件時, 實際是返回的是 /icons/目錄下的同名文件. 需要注意的是一定要設置 [PT] 標志. 否則Alias設置無效.
### RewriteCond
RewriteCond用來定義重寫條件
~~~
RewriteCond TestString CondPattern
~~~
* 對RewriteRule中的分組可以使用$N進行反向引用。
* 對RewriteCond中的分組可以使用%N進行反向引用。
* 服務器變量

#### CondPattern
* < CondPattern 將CondPattern視為純字符串,與teststring按字典順序進行比較,teststring小于CondPattern為真
* \> CondPattern 將CondPattern視為純字符串,與teststring按字典順序進行比較,teststring大于CondPattern為真
* = CondPattern 將CondPattern視為純字符串,與teststring按字典順序進行比較,teststring等于CondPattern為真
* -d 將teststring視為路徑名并測試是否為一個存在的目錄
* -f 將teststring視為路徑名并測試是否為一個存在的常規文件
* -s 將teststring視為路徑名并測試是否為一個存在的切大于0的常規文件
* -l 將teststring視為路徑名并測試是否為一個存在的常規文件
* -f 將teststring視為路徑名并測試是否為一個存在的符號鏈接
* -x 將teststring視為路徑名并測試是否為一個存在的可執行文件
* -F 檢查teststring是否為有效的文件
* -U檢查tesstring是否為有效的URL
nocase|NC 忽略大小寫
ornext|OR 多個條件或者關系
### RewriteBase
在目錄重寫中,只要請求的URL不能與本地的文件系統匹配時,就需要每個目錄設置一個重寫的基準URL,
- 目錄
- 離散的內容
- IO模型
- 網卡綁定
- ssh
- 硬件測試
- 硬件
- limits
- 網絡流量
- 硬盤IO
- 硬盤
- tmux
- 主機名和域名
- http_proxy
- iptables
- 內核參數
- 塊設備和字符設備
- 內存
- 虛擬內存并非交換分區
- 網絡延時
- 概念
- 多核壓縮
- linux基礎
- SSH協議
- 軟件管理
- yum
- 制作本地源 yum系列
- 制作本地源 apt系列
- apt
- 在 Linux 中移除從源代碼安裝的程序的一種簡單的方法
- 其他
- 源碼編譯和二進制安裝后更改配置
- DNS
- bind
- 守護進程
- 特殊權限
- limit.conf配置
- 網絡
- shell-ok
- 變量ok
- 數組ok
- 系統變量和環境變量
- 運算符和計算-ok
- 條件測試-ok
- 選擇-ok
- shell循環-ok
- 輸出echo和printf-ok
- 技巧-ok
- pre-web
- http協議
- web服務器
- Apache
- apache安裝
- yum安裝
- 二進制安裝
- 編譯安裝
- httpd命令
- 運行 監控apache
- apache配置文件
- 常用配置
- MPM多處理模塊
- 編譯模塊
- apache模塊
- apache核心模塊
- apache標準模塊
- apache第三方模塊
- 虛擬主機
- 1
- CGI-FastCGI-SSI
- 別名和重定向
- apache應用
- 301重定向
- apache防盜鏈
- http轉化為https
- 訪問時間段控制
- 控制訪問目錄
- 限制指定USER_AGENT
- 不同客戶端訪問不同網頁
- apache黑名單
- httpd之禁止解析php
- 不記錄css/js/img的訪問日志
- 瀏覽器端靜態緩存
- apache訪問日志自動切割
- order-require
- 壓縮傳輸
- httpd-ssl
- apache代理
- 正向代理
- 反向代理
- apache調優
- httpd壓力測試工具ab
- CGI測試
- php
- php原理
- httpd和php的結合方式
- php yum安裝之DSO模式
- php 編譯安裝之DSO模式
- php-fpm詳解
- php yum安裝之php-fpm模式
- php 編譯安裝之FastCGI模式
- php擴展之mysql
- php擴展之gd
- php擴展之pcntl
- php擴展之xcache
- php擴展之ZendGuardLoader
- phpMyAdmin
- wordpress
- 數據庫-mysql
- 數據庫原理
- mysql數據庫原理
- mysql源碼編譯安裝
- mysql二進制包安裝
- mysql命令行工具
- 更改密碼
- 數據庫授權grant
- mysql日志
- 命令
- 常用
- 小命令大作為
- awk 報告生成器
- 網絡命令
- 命令查找
- 壓縮歸檔命令
- 文件管理
- 文件管理命令
- 文件查看命令
- 目錄管理命令
- 用戶管理命令
- 用戶權限管理
- curl
- cheat
- chrony
- command
- crontab任務計劃
- cut
- date
- dd
- df
- echo
- find
- grep
- hash
- iftop
- kill pkill killall
- ls
- lsmod和modprobe
- lsof
- man
- mkpasswd
- mount
- mtr
- netstat
- nmap
- nc
- NTP
- passwd
- rm
- rdate
- pv
- sar系統活動情況報告
- sed文本處理命令
- setup
- screen
- shutdown
- sort 命令
- sudo
- tcpdump
- top
- uniq
- wget
- who
- xargs
- 監控
- zabbix郵件報警
- Redis
- redis安裝
- redis數據類型和操作方法
- redis持久化和配置
- redis主從配置
- php連接redis
- redis實現session共享
- 安裝測試
- redis設置密碼
- ELK日志分析系統
- elasticsearch
- logstash
- logstash插件
- filebeat日志收集
- kibana
- jenkins
- jenkins安裝與配置
- 案例1
- 案例2
- 案例3
- 代碼倉庫之svn
- svn服務端配置
- 常用操作
- svn備份
- LB集群
- LVS負載均衡集群
- ipvsadm使用方法
- LVS調度方法
- NAT原理
- NAT實踐
- DR原理
- DR實踐
- TUN原理
- LVS持久連接
- HA集群
- HPC集群
- 共享存儲
- ftp協議
- vsftpd
- NFS
- 網站架構發展
- 文件同步
- rsync基本用法
- rsync安裝和使用_拉取模式
- lsyncd安裝和用法
- zabbix
- zabbix服務端安裝
- zabbix客戶端安裝
- zabbix編譯安裝
- zabbix監控tomcat
- zabbix監控mysql
- gitlab
- supervisor
- nsq
- ruby
- nodejs
- consul
- mesos
- zookeeper
- rwho
- 對象存儲
- 工具
- rclone
- minio
- linux 性能調優
- CPU
- 第一部分 CPU
- 安全