1.PHP 如何實現不用自帶的 cookie 函數為用戶端下發 cookie。對於分散式系統,如何來儲存 session 值。
這個題有點繞。考的還是 COOKIE 和 SESSION 的基礎知識。伺服器端通過 set-cookie 命令來通知用戶端儲存 cookie。
只要按照 domain path 過期時間等規則 用 header 函數就可以實現。
分散式系統 session,集中處理。按我們公司的架構,為了實現高可用和高容災,提供一個分散式的驗簽服務。具體的可以看下 redis 的分散式服務架構。
2、資料庫中的存放了使用者 ID, 扣費很多行,redis 中存放的是使用者的錢包,現在要寫一個指令碼,將資料庫中的扣費記錄同步到 redis 中,每 5 分鐘執行一次。請問要考慮哪些問題?
思路:生產者和消費者模式。這個問題也沒有說其他的狀態,比如資料庫的資料會實時增加麼?redis 中每個錢包是否有其他服務在讀取或者寫入啊。什麼的。資料庫和 REDIS 放一起,要麼考資料一致性,要麼考出現鎖,導致效率降低。
3、根據 access.log 檔案統計最近 5 秒的 qps,並以如下格式顯示,01 1000(難點在 01 序號)
tail -f access.log | awk -F '[' '{print $2}' | awk '{print $1}' | uniq -c
4.redis 是如何進行同步的,同步的方式,同步回滾怎麼辦,資料異常怎麼辦,同時會問 MYSQL 的同步方式和相關異常情況
redis 叢集主從同步的簡單原理
Redis 的複製功能是基於記憶體快照的持久化策略基礎上的,也就是說無論你的持久化策略選擇的是什麼,只要用到了 Redis 的複製功能,就一定會有記憶體快照發生。
當 Slave 啟動並連線到 Master 之後,它將主動傳送一個 SYNC 命令 (首先 Master 會啟動一個後台進程,將資料快照儲存到檔案中 [rdb 檔案] Master 會給 Slave 傳送一個
Ping 命令來判斷 Slave 的存活狀態 當存活時 Master 會將資料檔案傳送給 Slave 並將所有寫命令傳送到 Slave )。
Slave 首先會將資料檔案儲存到本地 之後再將 資料 載入到記憶體中。
當第一次連結 或者是 故障後 重新連線 都會先判斷 Slave 的存活狀態 在做全部資料的同步 , 之後只會同步 Master 的寫操作 (將命令傳送給 Slave)
問題:
當 Master 同步資料時 若資料量較大 而 Master 本身只會啟用一個後台進程 來對多個 Slave 進行同步 , 這樣 Master 就會壓力過大 , 而且 Slave 恢復的時間也會很慢!
redis 主從複製的優點:
(1)在一個Redis叢集中,master負責寫請求,slave負責讀請求,這麼做一方面通過將讀請求分散到其他機器從而大大減少了master伺服器的壓力,另一方面slave專注於提供
讀服務從而提高了響應和讀取速度。
(2) 在一個 Redis 叢集中,如果 master 宕機,slave 可以介入並取代 master 的位置,因此對於整個 Redis 服務來說不至於提供不了服務,這樣使得整個 Redis 服務足夠安全。
(3) 水平增加 Slave 機器可以提高效能
5.兩台 mysql 伺服器,其中一台掛了,怎麼讓業務端無感切換,並保證正常情況下講台伺服器的資料是一致的
不是核心業務的話,先停寫,把備機拉起來,檢視兩台機器的紀錄檔,進行資料補償,開寫。
如果是核心業務的話,現在所有的寫操作都在正常的狀態機器上。把好的這台機器的備機拉起來,當主機。
以上全是應急操作。實際上資料庫的容災設計要複雜的多。
面試官要是問你,備機的資料不一致怎麼辦,你要勇敢懟回去,你們每秒多少寫入操作。按照百萬級表,每秒 1000 的寫入效率,正常的設計是,分布在 2 台機器上每台 500。這個級別的資料同步,出現差異的概率 可以忽略不計的。有一台出現問題,另一台也可以抗住。
(正常的操作,還是先停寫,等資料一致,切換,開寫。我們公司搞這些切換都是在凌晨 4.00 左右,核心業務的每秒寫操作,只有十幾個。前後耽擱不到 20 秒)。
6.請寫出自少三種擷取檔名字尾的方法或函數(PHP 原生函數和自己實現函數均可)
echo substr(strrchr($file, '.'), 1); echo substr($file, strrpos($file, '.')+1); $arr=explode('.', $file); echo $arr[count($arr)-1]; $arr=explode('.', $file); echo end($arr); echo strrev(explode('.', strrev($file))[0]); echo pathinfo($file)['extension']; echo pathinfo($file, PATHINFO_EXTENSION);
7.寫一個函數,獲取一篇文章內容中的全部圖片,並下載
function download_images($article_url = '', $image_path = 'tmp'){ // 獲取文章類容 $content = file_get_contents($article_url); // 利用正規表示式得到圖片連結 $reg_tag = '/<img.*?"([^"]*(jpg|bmp|jpeg|gif|png)).*?>/'; $ret = preg_match_all($reg_tag, $content, $match_result); $pic_url_array = array_unique($match_result1[1]); // 建立路徑 $dir = getcwd() . DIRECTORY_SEPARATOR .$image_path; mkdir(iconv("UTF-8", "GBK", $dir), 0777, true); foreach($pic_url_array as $pic_url){ // 獲取檔案資訊 $ch = curl_init($pic_url); curl_setopt($ch, CURLOPT_HEADER, 0); curl_setopt($ch, CURLOPT_NOBODY, 0); curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, FALSE ); curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, FALSE ); curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1); $fileInfo = curl_exec($ch); $httpinfo = curl_getinfo($ch); curl_close($ch); // 獲取圖片檔案字尾 $ext = strrchr($pic_url, '.'); $filename = $dir . '/' . uniqid() . $ext; // 儲存圖片資訊到檔案 $local_file = fopen($filename, 'w'); if(false !== $local_file){ if( false !== fwrite($local_file, $filecontent) ){ fclose($local_file); } } } }
8.10瓶水,其中一瓶有毒,小白鼠喝完有毒的水之後,會在 24 小時後死亡,問:最少用幾隻小白鼠可以在 24 小時後找到具體是哪一瓶水有毒。
四隻
二進位制問題。薛定諤的老鼠。
一隻老鼠有兩個狀態,死活,對應 01。假設老鼠的個數為 A,則有 2^A>=10; A=4;
思路很簡單,十瓶藥編號:0,1,10,11....1001;
0 不喝。第一隻老鼠喝所有個位是 1 的:13579,第二只喝十位是 1 的,第三隻和百位是 1 的,第四只喝千位是 1 的。
24 小時後,看下死了的是 1,活著的是 0。按老鼠的順序乖乖站好…… 假如第一隻和第三隻死了,那就是 0101,就是 5 有問題。
以上就是經典的八個PHP高階工程面試題(附答案)的詳細內容,更多請關注TW511.COM其它相關文章!