Тази статия е огледална статия за машинен превод, моля, кликнете тук, за да преминете към оригиналната статия.

Изглед: 12990|Отговор: 5

[Уеб] Грешки, които често се появяват на уеб сървъри, по-долу е логът на грешките за бавни заявки

[Копирай линк]
Публикувано в 30.11.2014 г. 21:09:51 ч. | | |
[30-ноември-2014 20:22:25]  [басейн www] PID 10383
script_filename = /test/forum.php
[0x00007fe08a61eba8] curl_exec() /тест/източник/функция/function_filesock.php:68
[0x00007fe08a61e960] _dfsockopen() /тест/източник/функция/function_core.php:201
[0x00007fe08a61e7c0] dfsockopen() /test/source/class/class_image.php:123
[0x00007fe08a61e608] init() /test/source/class/class_image.php:45
[0x00007fe08a61e2a8] Палец() /тест/източник/функция/function_block.php:410
[0x00007fe08a61e038] block_template() /test/source/function/function_block.php:177
[0x00007fe08a61def8] block_fetch_content() /test/source/function/function_block.php:120
[0x00007fe08a61de18] block_display_batch() /тест/източник/функция/function_core.php:804
[0x00007fe08a61dbd0] block_display() /test/data/template/3_diy_forum_discuz.tpl.php:29
[0x00007fe08a61d828] +++ dump не успя

[30-ноември-2014 20:22:26]  [басейн www] PID 10392
script_filename = /test/forum.php
[0x00007fe08a61eba8] curl_exec() /тест/източник/функция/function_filesock.php:68
[0x00007fe08a61e960] _dfsockopen() /тест/източник/функция/function_core.php:201
[0x00007fe08a61e7c0] dfsockopen() /test/source/class/class_image.php:123
[0x00007fe08a61e608] init() /test/source/class/class_image.php:45
[0x00007fe08a61e2a8] Палец() /тест/източник/функция/function_block.php:410
[0x00007fe08a61e038] block_template() /test/source/function/function_block.php:177
[0x00007fe08a61def8] block_fetch_content() /test/source/function/function_block.php:120
[0x00007fe08a61de18] block_display_batch() /тест/източник/функция/function_core.php:804
[0x00007fe08a61dbd0] block_display() /test/data/template/3_diy_forum_discuz.tpl.php:29
[0x00007fe08a61d828] +++ dump не успя


Знаете каква е причината за тази грешка, а бавното изпълнение на заявка ще я запише за повече от 5 секунди, сървър nginx и php-fpm





Предишен:Ще те науча бързо да разбираш функцията за файлове в Discuz! и няма да се налага да искаш помощ за промяна на файлове оттук нататък
Следващ:[Задължително за покупка на влакови билети] 12306 Заобиколен билет за отклонение, взимане на v1.5 зелена версия
Публикувано в 1.12.2014 г. 12:20:49 ч. |
[0x00007fe08a61eba8] curl_exec() /test/source/function/function_filesock.php:68 Има грешка на ред 68, която може само да помогне :L
 Хазяин| Публикувано в 1.12.2014 г. 13:45:36 ч. |
Delver_Si Публикувано на 1.12.2014 г.
[0x00007fe08a61eba8] curl_exec() /test/source/function/function_filesock.php:68 Има грешка на линия 68, само ...

Сестра ти, също знам, че тази реплика е грешна, но не знам за какво служи този документ
Публикувано в 1.12.2014 г. 21:01:08 ч. |
/test/source/function/function_filesock.php  源代码给我
 Хазяин| Публикувано в 1.12.2014 г. 21:14:41 ч. |
Delver_Si Публикувано на 1.12.2014 21:01
/test/source/function/function_filesock.php  源代码给我

[mw_shl_code=php,true]<?php

/**
* [Дискузия!] (C) 2001-2099 Comsenz Inc.
* Това НЕ е безплатен софтуер, използването е подчинено на лицензионните условия
*
* $Id: function_filesock.php 34441 2014-04-29 07:47:26Z nemohou $
*/

if(!defined('IN_DISCUZ')) {
        изход ('Достъпът е отказан');
}

функция _dfsockopen($url, $limit = 0, $post = '', $cookie = '', $bysocket = FALSE, $ip = '', $timeout = 15, $block = ВЯРНО, $encodetype = 'URLENCODE', $allowcurl = ВЯРНО, $position = 0, $files = масив( )) {
        $return = '';
        $matches = parse_url($url);
        $scheme = $matches['scheme'];
        $host = $matches['домакин'];
        $path = $matches['път'] ? $matches['път']. ($matches['запитване'] ? '?'. $matches['query'] : '') : '/';
        $port = !празен($matches['порт']) ? $matches['port'] : ($scheme == 'http' ? '80' : '');
        $boundary = $encodetype == 'URLENCODE'? '' : случаен (40);

        if($post) {
                if(!is_array($post)) {
                        parse_str($post, $post);
                }
                _format_postkey($post, $postnew);
                $post = $postnew;
        }
        if(function_exists('curl_init') && function_exists('curl_exec') && $allowcurl) {
                $ch = curl_init();
                $httpheader = масив();
                if($ip) {
                        $httpheader[] = "Водещ: ".$host;
                }
                if($httpheader) {
                        curl_setopt($ch, CURLOPT_HTTPHEADER, $httpheader);
                }
                curl_setopt($ch, CURLOPT_URL, $scheme.'://'.( $ip? $ip : $host). ($port? ':'.$port : '').$path);
                curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, невярно);
                curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, невярно);
                curl_setopt($ch, CURLOPT_RETURNTRANSFER, вярно);
                curl_setopt($ch, CURLOPT_FOLLOWLOCATION, вярно);
                curl_setopt($ch, CURLOPT_HEADER, 1);
                if($post) {
                        curl_setopt($ch, CURLOPT_POST, 1);
                        if($encodetype == 'URLENCODE') {
                                curl_setopt($ch, CURLOPT_POSTFIELDS, $post);
                        } else {
                                foreach($post като $k => $v) {
                                        if(isset($files[$k])) {
                                                $post[$k] = '@'.$files[$k];
                                        }
                                }
                                foreach($files като $k => $file) {
                                        if(!isset($post[$k]) && file_exists($file)) {
                                                $post[$k] = '@'.$file;
                                        }
                                }
                                curl_setopt($ch, CURLOPT_POSTFIELDS, $post);
                        }
                }
                if($cookie) {
                        curl_setopt($ch, CURLOPT_COOKIE, $cookie);
                }
                curl_setopt($ch, CURLOPT_CONNECTTIMEOUT, $timeout);
                curl_setopt($ch, CURLOPT_TIMEOUT, $timeout);
                $data = curl_exec($ch);
                $status = curl_getinfo($ch);
                $errno = curl_errno($ch);
                curl_close($ch);
                if($errno || $status['http_code'] != 200) {
                        връщане;
                } else {
                        $GLOBALS['filesockheader'] = substr($data, 0, $status['header_size']);
                        $data = substr($data, $status['header_size']);
                        Върни се!$limit? $data : substr($data, 0, $limit);
                }
        }

        if($post) {
                if($encodetype == 'URLENCODE') {
                        $data = http_build_query($post);
                } else {
                        $data = '';
                        foreach($post като $k => $v) {
                                $data .= "--$boundary\r\n";
                                $data .= 'Съдържание-Разположение: форма-данни; name="'.$k.'"'. (isset($files[$k])? '; filename="'.basename($files[$k]).'"; Тип съдържание: приложение/октетен поток' : '')." \r\n\r\n";
                                $data .= $v." \r\n";
                        }
                        foreach($files като $k => $file) {
                                if(!isset($post[$k]) && file_exists($file)) {
                                        if($fp = @fopen($file, 'r')) {
                                                $v = fread($fp, filesize($file));
                                                fclose($fp);
                                                $data .= "--$boundary\r\n";
                                                $data .= 'Съдържание-Разположение: форма-данни; name="'.$k.'"; filename="'.basename($file).'"; Тип съдържание: приложение/октет-поток'." \r\n\r\n";
                                                $data .= $v." \r\n";
                                        }
                                }
                        }
                        $data .= "--$boundary\r\n";
                }
                $out = "POST $path HTTP/1.0\r\n";
                $header = "Приеми: */*\r\n";
                $header .= "Приеми-език: zh-cn\r\n";
                $header .= $encodetype == 'URLENCODE'? "Тип съдържание: application/x-www-form-urlencoded\r\n" : "Тип съдържание: multipart/form-data; граница=$boundary\r\n";
                $header .= 'Дължина на съдържанието: '.strlen($data)." \r\n";
                $header .= "Потребител-агент: $_SERVER[HTTP_USER_AGENT]\r\n";
                $header .= "Водещ: $host:$port\r\n";
                $header .= "Връзка: Близо\r\n";
                $header .= "Cache-Control: no-cache\r\n";
                $header .= "Куки: $cookie\r\n\r\n";
                $out .= $header;
                $out .= $data;
        } else {
                $out = "GET $path HTTP/1.0\r\n";
                $header = "Приеми: */*\r\n";
                $header .= "Приеми-език: zh-cn\r\n";
                $header .= "Потребител-агент: $_SERVER[HTTP_USER_AGENT]\r\n";
                $header .= "Водещ: $host:$port\r\n";
                $header .= "Връзка: Близо\r\n";
                $header .= "Куки: $cookie\r\n\r\n";
                $out .= $header;
        }

        $fpflag = 0;
        if(!$fp = @fsocketopen(($ip ? $ip : $host), $port, $errno, $errstr, $timeout)) {
                $context = масив(
                        'http' => масив(
                                'метод' => $post ? 'POST' : 'GET',
                                'header' => $header,
                                'съдържание' => $post,
                                'тайм-аут' => $timeout,
                        ),
                );
                $context = stream_context_create($context);
                $fp = @fopen($scheme.'://'.( $ip? $ip : $host).':'.$port.$path, 'b', false, $context);
                $fpflag = 1;
        }

        if(!$fp) {
                return '';
        } else {
                stream_set_blocking($fp, $block);
                stream_set_timeout($fp, $timeout);
                @fwrite($fp, $out);
                $status = stream_get_meta_data($fp);
                if(!$status['timed_out']) {
                        докато (!feof($fp) && !$fpflag) {
                                $header = @fgets($fp);
                                $headers .= $header;
                                if($header && ($header == "\r\n" ||  $header == "\n")) {
                                        прекъсване;
                                }
                        }
                        $GLOBALS['filesockheader'] = $headers;

                        if($position) {
                                for($i=0; $i<$position; $i++) {
                                        $char = fgetc($fp);
                                        if($char == "\n" && $oldchar != "\r") {
                                                $i++;
                                        }
                                        $oldchar = $char;
                                }
                        }

                        if($limit) {
                                $return = stream_get_contents($fp, $limit);
                        } else {
                                $return = stream_get_contents($fp);
                        }
                }
                @fclose($fp);
                връщане $return;
        }
}

функция _format_postkey($post, &$result, $key = '') {
        foreach($post като $k => $v) {
                $_k = $key? $key.' ['.$k.']' : $k;
                if(is_array($v)) {
                        _format_postkey($v, $result, $_k);
                } else {
                        $result[$_k] = $v;
                }
        }
}

?>[/mw_shl_code]
Публикувано в 2.12.2014 г. 0:08:32 ч. |
Не разбирам
Отричане:
Целият софтуер, програмни материали или статии, публикувани от Code Farmer Network, са само за учебни и изследователски цели; Горното съдържание не трябва да се използва за търговски или незаконни цели, в противен случай потребителите ще понесат всички последствия. Информацията на този сайт идва от интернет, а споровете за авторски права нямат нищо общо с този сайт. Трябва напълно да изтриете горното съдържание от компютъра си в рамките на 24 часа след изтеглянето. Ако ви харесва програмата, моля, подкрепете оригинален софтуер, купете регистрация и получете по-добри услуги. Ако има нарушение, моля, свържете се с нас по имейл.

Mail To:help@itsvse.com