12

Ubuntu PHP で PCNTL を有効にする方法に関するヘルプが必要です。

$ mkdir /tmp/phpsource
$ cd /tmp/phpsource


$ wget http://museum.php.net/php5/php-5.3.2.tar.gz
$ tar xvf php-5.3.2.tar.gz
$ cd php-5.3.2/ext/pcntl


$ phpize   -bash: phpize: command not found

phpizeを実行しようとするまで、すべてがうまくいきました! そして、「-bash:phpize:コマンドが見つかりません」というエラーが表示されます?? 何か案は?

更新が実行されました:

$ sudo apt-get update

そして実行しました:

$ sudo apt-get install php5-dev

ニックの助けを借りて、なんとか手続きを終えることができました。しかし、「make test」は失敗しますか???

$ phpize
$ ./configure
$ make

$ cp modules/pcntl.so /usr/lib/php5/20090626/
$ echo "extension=pcntl.so" > /etc/php5/conf.d/pcntl.ini

$ make test - FAILED!

ヘルプ: 「echo "extension=pcntl.so" > /etc/php5/conf.d/pcntl.ini ではなく、「echo "extension=pcntl.so > /etc/php5/conf.d/pcntl.ini」と入力しました。 'これを初めて実行したとき.それは悪いですか?

--------------------------------- Make TEst エラー メッセージ ------------- -------------------------

PHP Deprecated: Comments starting with '#' are deprecated in /tmp/phpsource/php-5.3.2/ext/pcntl/tmp-php.ini on line 1850 in Unknown on line 0
PHP Deprecated: Comments starting with '#' are deprecated in /tmp/phpsource/php-5.3.2/ext/pcntl/tmp-php.ini on line 1852 in Unknown on line 0
PHP Deprecated: Comments starting with '#' are deprecated in /tmp/phpsource/php-5.3.2/ext/pcntl/tmp-php.ini on line 1850 in Unknown on line 0
PHP Deprecated: Comments starting with '#' are deprecated in /tmp/phpsource/php-5.3.2/ext/pcntl/tmp-php.ini on line 1852 in Unknown on line 0
PHP Warning: Module 'pcntl' already loaded in Unknown on line 0

Warning: Module 'pcntl' already loaded in Unknown on line 0
PHP Deprecated: Comments starting with '#' are deprecated in /tmp/phpsource/php-5.3.2/ext/pcntl/tmp-php.ini on line 1850 in Unknown on line 0
PHP Deprecated: Comments starting with '#' are deprecated in /tmp/phpsource/php-5.3.2/ext/pcntl/tmp-php.ini on line 1852 in Unknown on line 0
PHP Warning: Module 'pcntl' already loaded in Unknown on line 0

Warning: Module 'pcntl' already loaded in Unknown on line 0

=====================================================================
PHP : /usr/bin/php
PHP_SAPI : cli
PHP_VERSION : 5.3.2-1ubuntu4.18
ZEND_VERSION: 2.3.0
PHP_OS : Linux - Linux lvps217-8-253-63.vps.webfusion.co.uk 2.6.32-042stab068.8 #1 SMP Fri Dec 7 17:06:14 MSK 2012 x86_64
INI actual : /tmp/phpsource/php-5.3.2/ext/pcntl/tmp-php.ini
More .INIs :
CWD : /tmp/phpsource/php-5.3.2/ext/pcntl
Extra dirs :
VALGRIND : Not used
=====================================================================
TIME START 2013-01-02 23:05:56
=====================================================================
FAIL Test pcntl wait functionality [tests/001.phpt]
FAIL pcntl: pcntl_sigprocmask(), pcntl_sigwaitinfo(), pcntl_sigtimedwait() [tests/002.phpt]
FAIL pcntl: SIG_BLOCK, SIG_UNBLOCK, SIG_SETMASK [tests/003.phpt]
FAIL Bug #47566 (return value of pcntl_wexitstatus()) [tests/bug47566.phpt]
FAIL pcntl_alarm() [tests/pcntl_alarm.phpt]
FAIL pcntl_exec() [tests/pcntl_exec.phpt]
FAIL pcntl_exec() 2 [tests/pcntl_exec_2.phpt]
FAIL pcntl_exec() 3 [tests/pcntl_exec_3.phpt]
FAIL Test function pcntl_fork() by calling it with its expected arguments [tests/pcntl_fork_basic.phpt]
FAIL Test function pcntl_fork() by testing the process isolation in the forking hierarchy father -> son -> grandson where father can not knows his grandson [tests/pcntl_fork_variation.phpt]
FAIL pcntl_signal() [tests/pcntl_signal.phpt]
FAIL pcnt_signal_dispatch() [tests/pcntl_signal_dispatch.phpt]
FAIL pcntl_wait() [tests/pcntl_wait.phpt]
FAIL Closures as a signal handler [tests/signal_closure_handler.phpt]
=====================================================================
TIME END 2013-01-02 23:05:59

=====================================================================
TEST RESULT SUMMARY
---------------------------------------------------------------------
Exts skipped : 0
Exts tested : 44
---------------------------------------------------------------------

Number of tests : 14 14
Tests skipped : 0 ( 0.0%) --------
Tests warned : 0 ( 0.0%) ( 0.0%)
Tests failed : 14 (100.0%) (100.0%)
Expected fail : 0 ( 0.0%) ( 0.0%)
Tests passed : 0 ( 0.0%) ( 0.0%)
---------------------------------------------------------------------
Time taken : 3 seconds
=====================================================================

=====================================================================
FAILED TEST SUMMARY
---------------------------------------------------------------------
Test pcntl wait functionality [tests/001.phpt]
pcntl: pcntl_sigprocmask(), pcntl_sigwaitinfo(), pcntl_sigtimedwait() [tests/002.phpt]
pcntl: SIG_BLOCK, SIG_UNBLOCK, SIG_SETMASK [tests/003.phpt]
Bug #47566 (return value of pcntl_wexitstatus()) [tests/bug47566.phpt]
pcntl_alarm() [tests/pcntl_alarm.phpt]
pcntl_exec() [tests/pcntl_exec.phpt]
pcntl_exec() 2 [tests/pcntl_exec_2.phpt]
pcntl_exec() 3 [tests/pcntl_exec_3.phpt]
Test function pcntl_fork() by calling it with its expected arguments [tests/pcntl_fork_basic.phpt]
Test function pcntl_fork() by testing the process isolation in the forking hierarchy father -> son -> grandson where father can not knows his grandson [tests/pcntl_fork_variation.phpt]
pcntl_signal() [tests/pcntl_signal.phpt]
pcnt_signal_dispatch() [tests/pcntl_signal_dispatch.phpt]
pcntl_wait() [tests/pcntl_wait.phpt]
Closures as a signal handler [tests/signal_closure_handler.phpt]

何か案は!?!カール

4

5 に答える 5

10

Ubuntu 12.04で見つけたものは次のとおりです。

  • 無効になっている pnctl 関数については、PHP.ini を確認してください。

    disable_functions =     pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority
    
  • phpinfo は関数が既にロードされていることを報告しますが、pcntl.ini ファイルを /etc/php5/conf.d に配置しないと実際には機能しません。

悲しいことに、これにより /etc/cron.d の PHP セッションのクリーンアップ cron が開始されるたびに「モジュールが既にロードされています」というエラーが発生しますが、これらの両方が配置されていないと PCNTL は機能しません。 「既に読み込まれている」エラーを無効にするソリューション。面倒で見苦しく、私のルート メールに迷惑メールが届きます。解決策が見つかったら、投稿します。これまでのところ、この問題に遭遇したのは 12.04 だけです。

アップデート

/usr/lib/php5/maxlifetime スクリプト ファイルをハッキングして、pnctl エラー ( PHP 警告: モジュール 'pcntl' が行 0 の Unknown に既にロードされている) でスパム行為を停止しました。これが私の編集です-メッセージを静かにするために「E_DEPRECATED」行に具体的に追加しました。

8 行目:

    cur=$(php5 -c /etc/php5/${sapi}/php.ini -d "error_reporting='E_ALL & ~E_DEPRECATED'" -r 'print ini_get("session.gc_maxlifetime");' 2> /dev/null)
于 2013-02-06T20:09:01.740 に答える
7

次のようないくつかの手順があります: (私の OS は debian7.2 xfce x86 です)。

1: このように pcntl をインストールします

#mkdir php
#cd php 
#apt-get source php5 
#cd php5-5.4.4/ext/pcntl
#phpize
#./configure
#make
#echo "extension=pcntl.so" > /etc/php5/mods-available/pcntl.ini
#ln -s /etc/php5/mods-available/pcntl.ini /etc/php5/conf.d/pcntl.ini

2: nginx または apache2 を再起動すると、php に 1 つの警告が表示されます。

「PHP 警告: モジュール 'pcntl' は行 0 の不明に既にロードされています」

3:だから私

「rm -rf /etc/php5/mods-available/pcntl.ini および /etc/php5/conf.d/pcntl.ini」

4: 「php.ini」ファイルを編集します。

a.apache2, it's in "/etc/php5/apache2/php.ini"
b.cgi like nginx,it's in "/etc/php5/cgi/php.ini"

を作る

"disable_functions = pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited..."
comments, add  " ; "  in front of "disable_functions".

サーバーを再起動すると、警告が消えます。幸運を祈ります。

于 2013-10-18T04:46:22.653 に答える
4

ubuntu 12.10(およびそれ以前のバージョンも)を搭載した私の開発マシンでは、pcntlはすでに有効になっています。

$ php -m | grep pcntl
pcntl

それが問題だと思います:

PHP 警告: モジュール 'pcntl' は行 0 の Unknown に既にロードされています

したがって、再インストールしないでください。

于 2013-01-02T23:21:06.623 に答える
1

サーバーを再起動する必要がありました! そして今、それは機能します!Doh.. 皆様のご意見をお寄せいただきありがとうございます。

于 2013-01-03T00:03:53.920 に答える