Гость
Целевая тема:
Создать новую тему:
Автор:
Форумы / PHP, Perl, Python [игнор отключен] [закрыт для гостей] / Функция / 14 сообщений из 14, страница 1 из 1
21.10.2004, 19:52
    #32749292
Spooki
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Функция
Привет всем!

Хотел узнать, какую из этих функций лучше использовать

эту mysql_connect()
или эту mysql_pconnect()

и почему?
...
Рейтинг: 0 / 0
21.10.2004, 23:29
    #32749410
*
*
Гость
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Функция
Прежде, чем задавать вопрос, неплохо бы заглядывать в мануал. Хотя бы ради приличия.
mysql_connect
mysql_pconnect
Постоянные соединения с базами данных
...
Рейтинг: 0 / 0
22.10.2004, 13:27
    #32750352
Spooki
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Функция
Да ты чё, ух ты!

А то я не в курсе, вопрос был, какая лучше? А их различия я знаю.
...
Рейтинг: 0 / 0
22.10.2004, 13:53
    #32750436
*
*
Гость
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Функция
Да я уже понял, что ты не в курсе, а кроме того, либо не любишь читать, либо не умеешь думать, предпочитая жить на всём готовеньком. Постоянные соединения с базами данных
...
Рейтинг: 0 / 0
22.10.2004, 14:43
    #32750637
Spooki
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Функция
Вообщем-то суть не ясна.

Типа лучше не юзать mysql_pconnect, а то много чего не будет, да и вообще все нафиг заблокируется и отвалится к чертям в месте с сервером и компом.
...
Рейтинг: 0 / 0
22.10.2004, 17:09
    #32751061
*
*
Гость
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Функция
По моему всё предельно ясно - во-первых, всё зависит от задач и от того, как установлен PHP - если как CGI - никакой разницы между connect и pconnect нет, если как модуль Apache или xSAPI - pconnect "удерживает" соединение и не "пересоединяется" при каждом запросе (минусы такого подхода описаны там же, в мане - "если скрипт блокирует таблицу и по каким-либо причинам не может ее освободить, при использовании постоянного соединения все последующие скрипты, которые используют это соединение будут блокированы бесконечно долго" и "открытые транзакции, если они не были закрыты до завершения работы скрипта, будут продолжены в следующем скрипте, использующем это же постоянное соединение", плюс - "если затраты на установку соединения велики, постоянные соединения могут вам существенно помочь" за счёт снижения затрат на установку соединения с базой + физически, насколько я понимаю, мы имеем лишь одно соединение с БД - поэтому если есть ограничение на количество одновременно открытых соединений - это позволяет "нарваться" на лимит гораздо позже - могу ошибаться, может я неправильно трактую ман). В общем, "Фактически, постоянные соединения не предоставляют никакой функциональности, которая была бы невозможна в непостоянных аналогичных соединениях" и решать вопрос эффективности того или иного способа надо в зависимости от стоящих задач, "индивидуально" ;)
...
Рейтинг: 0 / 0
22.10.2004, 18:30
    #32751214
Spooki
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Функция
Итог:

Эта функция нах не нужна.
Ибо!
Если будите её юзать, то кранты вашему приложению рано или поздно все равно придет)
...
Рейтинг: 0 / 0
22.10.2004, 19:01
    #32751253
taj
taj
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Функция
* все правильно тебе расписал, и ссылки дал хорошие, но выводы не совсем верные ;)
Если бы одна функция была бы однозначно лучше другой, то другой бы просто не было (если речь не идет о backward compatibility какой-нить).
...
Рейтинг: 0 / 0
22.10.2004, 19:11
    #32751263
*
*
Гость
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Функция
taj , а как же 'решать вопрос эффективности того или иного способа надо в зависимости от стоящих задач, "индивидуально" ;)' ;)
...
Рейтинг: 0 / 0
23.10.2004, 13:44
    #32751504
*
*
Гость
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Функция
Кстати, до кучи, возможно будет интересно почитать топик на xpoint е.
...
Рейтинг: 0 / 0
23.10.2004, 18:06
    #32751611
Alex Rootoff
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Функция
taj, а как же превосходство sizeof() над count()?
Spooki, юзал я функцию не раз и кранты моим скриптам не наставали, наоборот я економил время в тех случаях, где процедура конекта к базе данных занимала немало времени. Но в большынстве слечаев связка Mysql+php+apache работает чень быстро и устойчивое соединение не требуется.


With best regards Alex Rootoff
...
Рейтинг: 0 / 0
25.10.2004, 16:11
    #32753210
taj
taj
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Функция
* taj , а как же 'решать вопрос эффективности того или иного способа надо в зависимости от стоящих задач, "индивидуально" ;)' ;)Гм? Недопонял :) Я имел в виду что выводы автора топика насчет ненужности - не совсем верные. А с тобой по поводу индивидуальности я согласен - например, лавировать при ограниченном кол-ве соединений с сервером, когда они, соединения, осуществляются с одной тачки с одинаковыми credentials.

Alex Rootofftaj, а как же превосходство sizeof() над count()? PHP Manualsizeof
sizeof -- Alias of count()
Description
This function is an alias of count().
...
Рейтинг: 0 / 0
25.10.2004, 20:44
    #32753834
*
*
Гость
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Функция
Alex Rootofftaj, а как же превосходство sizeof() над count()? taj Речь, видимо, о несколько древней статье Оптимизация программ на PHP . Если кому интересно - может доказать или опровергнуть данное в этой статье утверждение, например, при помощи Профайлера для скриптов на PHP
...
Рейтинг: 0 / 0
27.10.2004, 15:14
    #32757287
taj
taj
Участник
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Функция
Статья интересная, уважаю людей, которые не ленятся копаться, доискиваться до чего-то нетривиального.
Профайлер качать не стал, написал такой код, заимствовав тип нагрузки из статьи.
Код: plaintext
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
11.
12.
13.
14.
15.
16.
17.
18.
19.
20.
21.
22.
23.
24.
25.
26.
27.
28.
29.
30.
31.
32.
33.
34.
35.
36.
37.
38.
39.
40.
41.
42.
43.
44.
45.
46.
47.
<?
set_time_limit( 60 );

$test = ""; // нагрузочный массив
$a_size =  100000 ; // размер нагрузочного массива
$a_value = "!"; // значение в каждой ячейке массива
$iterations =  5 ; // кол-во итераций цикла (для увеличения выборки => точности)
$c_time =  0 ; // время, затраченное при использовании count() 
$s_time =  0 ; // время, затраченное при использовании size_of()                                                 

function gettime() // время с микросекундами
{ 
	list($msec, $sec) = split(" ", microtime()); 
	return ((float)$msec + (float)$sec); 
} 

for ($i= 0 ; $i<$a_size; $i++) // заполняем нагрузочный массив
	$test[] = $a_value;

for ($i= 0 ; $i<$iterations; $i++)
{
	$a_count[$i]["begin"] = gettime(); // заносим в массив время начала цикла
	$x= 0 ; 
	for ($it= 0 ; $it<count($test); $it++)  
		$x=sprintf("test%08i",$test[$it]);
	$a_count[$i]["end"] = gettime(); // заносим в массив время окончания цикла
}


for ($i= 0 ; $i<$iterations; $i++)
{
	$a_sizeof[$i]["begin"] = gettime();
	$x= 0 ; 
	for ($it= 0 ; $it<sizeof($test); $it++) 
		$x=sprintf("test%08i",$test[$it]);
	$a_sizeof[$i]["end"] = gettime();
}

for ($i= 0 ; $i<$iterations; $i++)
{                                                         
	$c_time += ($a_count[$i]["end"] - $a_count[$i]["begin"]);
	$s_time += $a_sizeof[$i]["end"] - $a_sizeof[$i]["begin"];
}
$c_time = $c_time / $iterations; // усредненные значения по итерациям
$s_time = $s_time / $iterations;

echo "count = ".($c_time)."\nsizeof = ".($s_time);
?>
Запускал для чистоты эксперимента из командной строки.
Результаты после нескольких запусков примерно такие:
Код: plaintext
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
count =  0 . 48946084976196 
sizeof =  0 . 48834891319275 

count =  0 . 48651175498962 
sizeof =  0 . 48780460357666 

count =  0 . 49119200706482 
sizeof =  0 . 49274916648865 

count =  0 . 49285798072815 
sizeof =  0 . 49556179046631 
В среднем получается что разброс не более 3-4мс (менее 1%) в ту и другую сторону.
Имхо мануал был прав (WinXP, PHP4.3.9).
...
Рейтинг: 0 / 0
Форумы / PHP, Perl, Python [игнор отключен] [закрыт для гостей] / Функция / 14 сообщений из 14, страница 1 из 1
Найденые пользователи ...
Разблокировать пользователей ...
Читали форум (0):
Пользователи онлайн (0):
x
x
Закрыть


Просмотр
0 / 0
Close
Debug Console [Select Text]