## **對日志文件的IP出現的次數進行統計,并顯示次數最多的前5名**
### **Nginx日志格式如下所示:**
```
log_format main '$remote_addr - $remote_user [$time_local] '
'fwf[$http_x_forwarded_for] '
'$http_host $request '
'$status $upstream_response_time $request_time '
'$request_length '
'$body_bytes_sent $http_referer '
'$http_user_agent $server_addr $http_x_real_ip';
```
### **日志內容示例如下:**
```
47.112.193.218 - - [21/Jan/2021:00:51:55 +0800] fwf[-] txw-api.dhclgl.com GET / HTTP/1.1 200 0.002 0.003 149 31 - python-requests/2.20.1 192.168.1.15 -
47.112.193.218 - - [21/Jan/2021:03:35:57 +0800] fwf[-] txw-api-pro.dhclgl.com GET / HTTP/1.1 200 0.002 0.003 153 32 - python-requests/2.20.1 192.168.1.15 -
47.112.193.218 - - [21/Jan/2021:04:55:16 +0800] fwf[-] txw-api.dhclgl.com GET / HTTP/1.1 200 0.004 0.003 149 31 - python-requests/2.20.1 192.168.1.15 -
47.112.193.218 - - [21/Jan/2021:07:37:25 +0800] fwf[-] txw-api-pro.dhclgl.com GET / HTTP/1.1 200 0.003 0.003 153 32 - python-requests/2.20.1 192.168.1.15 -
47.112.193.218 - - [21/Jan/2021:08:51:27 +0800] fwf[-] txw-api.dhclgl.com GET / HTTP/1.1 200 0.002 0.002 149 31 - python-requests/2.20.1 192.168.1.15 -
47.112.193.218 - - [21/Jan/2021:11:36:00 +0800] fwf[-] txw-api-pro.dhclgl.com GET / HTTP/1.1 200 0.003 0.003 153 32 - python-requests/2.20.1 192.168.1.15 -
```
### **awk處理如下:**
```
awk '{print $1}' test.log | uniq -c | sort -nr | head -5
```
- PHP篇
- 函數傳值和傳引用的區別
- 簡述PHP的垃圾回收機制
- 簡述CGI、FAST-CGI、PHP-FPM的關系
- 常見正則表達式
- 多進程寫文件,如何保證都寫成功
- php支持回調函數的數組函數
- MySQL篇
- MySQL的兩種存儲引擎區別
- 事務的四大特性
- 數據庫事務隔離級別
- 什么是索引
- 索引有哪些數據結構,優缺點
- 索引的一些潛規則
- SQL的優化方案
- 簡述MySQL的鎖機制
- 死鎖是怎么產生的?怎么解決?
- 簡述MySQL的主從復制過程,延遲問題怎么解決
- 分布式事務的解決方案
- 數據庫中間件MyCat
- Linux篇
- Linux常用命令
- 對日志文件的IP出現的次數進行統計,并顯示次數最多的前5名
- WEB篇
- 跨域是怎么產生的,如何解決跨域
- Redis篇
- redis介紹
- redis和memcached區別
- redis的持久化方案
- 緩存穿透、擊穿、雪崩、預熱、更新、降級
- 網絡篇
- 計算機網絡體系結構
- 簡述TCP的三次握手、四次揮手過程
- UDP、TCP 區別,適用場景
- HTTP常見狀態碼含義
- 設計模式篇
- 單例模式
- 簡單工廠模式
- 抽象工廠模式
- 觀察者模式
- 策略模式
- 注冊模式
- 適配器模式
- 安全篇
- 跨站腳本攻擊(XSS)
- 跨站點請求偽造(CSRF)
- SQL 注入
- 應用層拒絕服務攻擊
- PHP安全
- 運維篇
- docker面試題
- 消息隊列篇
- 架構篇
- 數據結構與算法篇