PHP使用Session遇到的一個(gè)Permission denied Notice解決辦法
來源:易賢網(wǎng) 閱讀:1363 次 日期:2014-08-04 16:01:34
溫馨提示:易賢網(wǎng)小編為您整理了“PHP使用Session遇到的一個(gè)Permission denied Notice解決辦法”,方便廣大網(wǎng)友查閱!

如果在ubuntu/Debian下, 采用apt安裝的PHP, 那么在使用Session的時(shí)候, 就可能會有小概率遇到這個(gè)提示.

代碼如下:

PHP Notice: session_start(): ps_files_cleanup_dir:

   opendir(/var/lib/php5) failed: Permission denied (13)

   in /home/laruence/www/htdocs/index.php on line 22

這是因?yàn)? 在PHP中, 如果使用file_handler作為Session的save handler, 那么就有概率在每次session_start的時(shí)候運(yùn)行Session的Gc過程.

代碼如下:

//有省略

        int nrdels = -1;

        nrand = (int) ((float) PS(gc_divisor) * php_combined_lcg(TSRMLS_C));

        if (nrand < PS(gc_probability)) {

            PS(mod)->s_gc(&PS(mod_data), PS(gc_maxlifetime), &nrdels TSRMLS_CC);

        }

//有省略

這個(gè)警告的原因是因?yàn)樵赼pt的PHP中, session的默認(rèn)目錄/var/lib/php5的權(quán)限是733 with sticky bit, 也就是

代碼如下:

drwx-wx-wt  root  root

而一般PHP的worker都運(yùn)行在非root身份下, 所以是沒有權(quán)限來打開這個(gè)文件夾的(但是因?yàn)榭梢詗rite, 所以不影響正常的Session文件讀取). 于是在s_gc中的如下代碼, 就會觸發(fā)開頭所說的Notice:

代碼如下:

//對于file handler來說, s_gc間接調(diào)用ps_files_cleanup_dir:

   dir = opendir(dirname);

    if (!dir) {

        php_error_docref(NULL TSRMLS_CC, E_NOTICE,

           "ps_files_cleanup_dir: opendir(%s) failed: %s (%d)",

           dirname, strerror(errno), errno);

        return (0);

    }

當(dāng)然, 在ubuntu/Debian下, 還是有g(shù)c回收的, 只不過是外部的cron進(jìn)程來完成的, 默認(rèn)的在/etc/cron.d/php5:,

代碼如下:

09,39 *     * * *     root   [ -x /usr/lib/php5/maxlifetime ]

&& [ -d /var/lib/php5 ] && find /var/lib/php5/

 -type f -cmin +$(/usr/lib/php5/maxlifetime) -print0

| xargs -n 200 -r -0 rm

另外, 可以看到, 在判別s_gc是否運(yùn)行的時(shí)候, 有倆個(gè)關(guān)鍵變量: PS(gc_divisor)和PS(gc_probability), 這倆個(gè)變量分別對應(yīng)著session的運(yùn)行時(shí)配置項(xiàng)的倆個(gè)同名配置項(xiàng):

session.gc_probability和session.gc_divisor, 他們分別默認(rèn)為1和100.

而php_combined_lcg是一個(gè)隨機(jī)數(shù)發(fā)生器, 生成0到1范圍的隨機(jī)數(shù), 所以上面的判別相當(dāng)于:

代碼如下:

rand < probability / gc_divisor

也就是說, 默認(rèn)情況下, 差不多是100次能調(diào)用一次gc過程. 所以也就是小概率的可以看到這個(gè)Notice.

要關(guān)閉這個(gè)Notice, 只需要設(shè)置:

session.gc_probability = 0, 讓s_gc完全沒有運(yùn)行的可能即可.

當(dāng)然, 你也可以改變這個(gè)文件夾的權(quán)限…

更多信息請查看IT技術(shù)專欄

更多信息請查看網(wǎng)絡(luò)編程
易賢網(wǎng)手機(jī)網(wǎng)站地址:PHP使用Session遇到的一個(gè)Permission denied Notice解決辦法
由于各方面情況的不斷調(diào)整與變化,易賢網(wǎng)提供的所有考試信息和咨詢回復(fù)僅供參考,敬請考生以權(quán)威部門公布的正式信息和咨詢?yōu)闇?zhǔn)!

2025國考·省考課程試聽報(bào)名

  • 報(bào)班類型
  • 姓名
  • 手機(jī)號
  • 驗(yàn)證碼
關(guān)于我們 | 聯(lián)系我們 | 人才招聘 | 網(wǎng)站聲明 | 網(wǎng)站幫助 | 非正式的簡要咨詢 | 簡要咨詢須知 | 加入群交流 | 手機(jī)站點(diǎn) | 投訴建議
工業(yè)和信息化部備案號:滇ICP備2023014141號-1 云南省教育廳備案號:云教ICP備0901021 滇公網(wǎng)安備53010202001879號 人力資源服務(wù)許可證:(云)人服證字(2023)第0102001523號
云南網(wǎng)警備案專用圖標(biāo)
聯(lián)系電話:0871-65099533/13759567129 獲取招聘考試信息及咨詢關(guān)注公眾號:hfpxwx
咨詢QQ:526150442(9:00—18:00)版權(quán)所有:易賢網(wǎng)
云南網(wǎng)警報(bào)警專用圖標(biāo)