想了解phpfpm端口监听listen=[::]:9000的新动态吗?本文将为您提供详细的信息,我们还将为您解答关于php-fpm监听端口的相关问题,此外,我们还将为您介绍关于.NET端口监听、/us
想了解php fpm 端口监听 listen = [::]:9000的新动态吗?本文将为您提供详细的信息,我们还将为您解答关于php-fpm监听端口的相关问题,此外,我们还将为您介绍关于.NET 端口监听、/usr/local/php-5.2.14/sbin/php-fpm start Starting php_fpm ?fpm-config的错误解决、12.21 php-fpm 的 pool 12.22 php-fpm 慢执行日志 12.23 open_basedir 12.24 php-fpm 进程管理、centos7 - centos 7.2 /var/run/php-fpm/php-fpm.sock不存在的新知识。
本文目录一览:- php fpm 端口监听 listen = [::]:9000(php-fpm监听端口)
- .NET 端口监听
- /usr/local/php-5.2.14/sbin/php-fpm start Starting php_fpm ?fpm-config的错误解决
- 12.21 php-fpm 的 pool 12.22 php-fpm 慢执行日志 12.23 open_basedir 12.24 php-fpm 进程管理
- centos7 - centos 7.2 /var/run/php-fpm/php-fpm.sock不存在
php fpm 端口监听 listen = [::]:9000(php-fpm监听端口)
docker 安装PHP7
启动时
daemonize = no
端口设置成
listen = [::]:9000
启动
docker run -d -p 9100:9000 -v /data/sysadmin/service_deploy_data/php/image.face.api.ulucu.com:/data/sysadmin/service_deploy_data/image.face.api.ulucu.com --entrypoint="/data/sysadmin/soft_installed/php7.1.7/sbin/php-fpm" php7
.NET 端口监听
1. 直接调用微软 socket 对象处理
static void Main(string[] args)
{
try
{
IPAddress ip = new IPAddress(new byte[] { 127, 0, 0, 1 });
//在3721端口新建一个TcpListener对象
TcpListener listener = new TcpListener(ip, 3721);
listener.Start();
Console.WriteLine("started listening..");
//开始监听
while (true)
{
Socket s = listener.AcceptSocket();
string remote = s.RemoteEndPoint.ToString();
//允许js跨越访问
var bytes = System.Text.Encoding.UTF8.GetBytes("HTTP/1.1 200 OK\r\nAccess-Control-Allow-Origin: * \r\n\r\nOK");
s.Send(bytes);
s.Shutdown(SocketShutdown.Send);
}
}
catch (System.Security.SecurityException)
{
Console.WriteLine("firewall says no no to application – application cries..");
}
catch (Exception)
{
Console.WriteLine("stoped listening..");
}
}
/usr/local/php-5.2.14/sbin/php-fpm start Starting php_fpm ?fpm-config的错误解决
1.将fpm打包放到php源代码中
gzip -cd php-5.2.8-fpm-0.5.10.diff.gz | patch -d php-5.2.8 -p1
2.编译安装php 记得带上
?enable-cgi ?enable-fpm 两个参数哦。
遇到以下问题: 问题1,接以下参数编译时,
./configure ? prefix=/usr/local/php-5.2.14 ? with-config-file-path=/usr/local/php-5.2.14/etc ? enable-fastcgi ?with-mysql ?with-mysqli=/usr/lib/mysql/mysql_config -with-freetype-dir ? with-jpeg-dir ?with-png-dir ?with-zlib ?with-libxml-dir ?enable-xml ?with-curl ? enable-force-cgi-redirect ?enable-mbstring ?with-mcrypt make
的时候出现以下错误, /usr/bin/ld: cannot find -lltdl collect2: ld returned 1 exit status make: *** [sapi/cgi/php-cgi] 错误 1
解决方法: 去掉这个参数?with-mcrypt 或者 安装 mcrypt包。 这个包主要用于加密。
立即学习“PHP免费学习笔记(深入)”;
遇到问题: 问题2
/usr/local/php-5.2.14/sbin/php-fpm start Starting php_fpm ?fpm-config /usr/local/php-5.2.14/etc/php-fpm.conf Error in argument 1, char 1: no argument for option - Usage: php-cgi [-q] [-h] [-s] [-v] [-i] [-f
…
解决方案:
重装编译安装php
参数如下
./configure ?prefix=/usr/local/php-5.2.14 ?with-mysql ?with-mysqli=/usr/lib/mysql/mysql_config ? with-freetype-dir ?with-jpeg-dir ?with-png-dir -with-zlib ?enable-xml ?disable-rpath ?enable-discard-path ? enable-safe-mode ?enable-bcmath ?enable-shmop ?enable-sysvsem ?enable-inline-optimization ?with-curl ? with-curlwrappers ?enable-mbregex ?enable-fastcgi ?enable-fpm ?enable-force-cgi-redirect ?enable-mbstring ? with-gd ?enable-gd-native-ttf ?with-openssl ?with-mhash ?enable-pcntl ?enable-sockets ?with-ldap ? with-ldap-sasl
以上就是/usr/local/php-5.2.14/sbin/php-fpm start Starting php_fpm ?fpm-config的错误解决的内容。
12.21 php-fpm 的 pool 12.22 php-fpm 慢执行日志 12.23 open_basedir 12.24 php-fpm 进程管理
12.21 php-fpm 的 pool
每一个站点使用独立的 pool (池子), 好处是当其中一个 php 502 了 (php 资源耗尽了), 也不会影响到其他网站.
vim /usr/local/php-fpm/etc/php-fpm.conf //在[global]部分增加如下, 并删除默认的 www 的pool
include = etc/php-fpm.d/*.conf
/usr/local/php-fpm/sbin/php-fpm -t //测试php-fpm.conf语法错误
mkdir /usr/local/php-fpm/etc/php-fpm.d/
cd /usr/local/php-fpm/etc/php-fpm.d/
vim www.conf //内容如下
[www]
listen = /tmp/php-fcgi.sock
listen.mode = 666
user = php-fpm
group = php-fpm
pm = dynamic
pm.max_children = 50
pm.start_servers = 20
pm.min_spare_servers = 5
pm.max_spare_servers = 35
pm.max_requests = 500
rlimit_files = 1024
vim test.conf //内容如下
[test]
listen = /tmp/www.sock
listen.mode=666
user = php-fpm
group = php-fpm
pm = dynamic
pm.max_children = 50
pm.start_servers = 20
pm.min_spare_servers = 5
pm.max_spare_servers = 35
pm.max_requests = 500
rlimit_files = 1024
测试:
service php-fpm restart // 或者 /etc/init.d/php-fpm restart
ps aux | grep php //可以看到有多个pool
可以把 vim /usr/local/nginx/conf/vhost/test.com.conf 的 sock 给改掉成 test.sock
/usr/local/nginx/sbin/nginx -t && /usr/local/nginx/sbin/nginx -s reload
访问网站 测试是否正确解析 php : http://www.test.com/1.php
12.22 php-fpm 慢执行日志
慢执行日志,我们用来分析 php 网站为什么访问慢
vim /usr/local/php-fpm/etc/php-fpm.d/test.conf //加入如下内容
request_slowlog_timeout = 2 //超过2秒钟,我就要记录日志 一般情况写成2秒, 1秒太短了点
slowlog = /usr/local/php-fpm/var/log/test-slow.log
/usr/local/php-fpm/sbin/php-fpm -t
/etc/init.d/php-fpm reload //重新加载php 配置文件
看见产生了慢执行日志
vim /data/wwwroot/test.com/sleep.php//写入如下内容
?php
echo “test slow log”;
sleep(3);
echo “done”;
?>
curl -x127.0.0.1:80 www.test.com/sleep.php 测试报错:
编辑 vim /usr/local/php-fpm/etc/php.ini
打开
/etc/init.d/php-fpm reload
查看到语法错误
修改 vim /data/wwwroot/test.com/sleep.php // 用英文的双引号和分号
<?php
echo "test slow log";
sleep(3);
echo "done";
?>
curl -x127.0.0.1:80 www.test.com/sleep.php
cat /usr/local/php-fpm/var/log/www-slow.log //查看慢执行日志
会告诉你哪个php文件慢, 而且会告诉你php文件第三行慢
12.23 open_basedir
安全选项 open_basedir, 主要用来定义 限制网站能访问的目录 (限制 php 在指定的目录里活动)
vim /usr/local/php-fpm/etc/php-fpm.d/test.conf //加入如下内容
php_admin_value[open_basedir]=/data/wwwroot/test.com:/tmp
创建测试php脚本,进行测试
etc/init.d/php-fpm restart
curl -x127.0.0.1:80 www.test.com/1.php -I
再次更改test.conf,修改路径,再次测试
故意改错成 php_admin_value[open_basedir]=/data/wwwroot/111test.com:/tmp
配置错误日志
vim /usr/local/php-fpm/etc/php.ini
display_errors=off //是否在页面上显示错误, 如果否, 需定义log_errors
log_errors=on //错误日志是否开启 如果是, 则需定义 log_errors 和 error_log , error_reporting
error_log = /usr/local/php-fpm/var/log/php_errors.log //定义错误日志的路径
error_reporting=E_ALL & ~E_NOTICE //错误日志记录的级别, 生产环境用 E_ALL & ~E_NOTICE(阿铭说) , 我看到默认生产环境配置文件 用 E_ALL & ~E_DEPRECATED & ~E_STRICT
创建错误日志文件并设置权限
touch /usr/local/php-fpm/var/log/php_errors.log
chmod 666 /usr/local/php-fpm/var/log/php_errors.log
/etc/init.d/php-fpm restart
再次测试
查看错误日志
tail -f /usr/local/php-fpm/var/log
12.24 php-fpm 进程管理
/usr/local/php-fpm/etc/php.ini , 注释用;号,用 #号不太对,如;pm = dynamic
动态进程管理,先一开始启动20个进程, 根据需求(访问量)自动生成进程, 服务器闲也会自动销毁,
也可以是static, static只有 pm.max_children有效, start_servers /min_spare_servers /max_spare_servers 都会失效
pm = dynamic //动态进程管理
pm.max_children = 50 //最大子进程数,ps aux可以查看
pm.start_servers = 20 //启动服务时会启动的进程数
pm.min_spare_servers = 5 //定义在空闲时段,子进程数的最少数量,如果达到这个数值时,php-fpm服务会自动派生新的子进程。
pm.max_spare_servers = 35 //定义在空闲时段,子进程数的最大值,如果高于这个数值就开始清理空闲的子进程。
pm.max_requests = 500 //定义一个子进程最多处理的请求数,也就是说在一个php-fpm的子进程最多可以处理这么多请求,当达到这个数值时,它会自动退出。
rlimit_files = 1024 //设置文件打开描述符的rlimit限制. 默认值: 系统定义值 系统默认可打开句柄是1024,可使用 ulimit -n查看,ulimit -n 2048修改。
centos7 - centos 7.2 /var/run/php-fpm/php-fpm.sock不存在
要在nginx中配置重写规则,其中有这么一句:
fastcgi_pass unix:/var/run/php-fpm/php-fpm.sock
可是在centos7.2中,这个路径没有这个文件,只有一个php-fpm.pid文件,那么上面这个文件在哪里?
回复内容:
要在nginx中配置重写规则,其中有这么一句:
fastcgi_pass unix:/var/run/php-fpm/php-fpm.sock
可是在centos7.2中,这个路径没有这个文件,只有一个php-fpm.pid文件,那么上面这个文件在哪里?
用find / -name "*php*.sock"找一下sock文件的位置,如果没找到的话就是没配置Unix Socket,只能访问TCP端口,可以为改为fastcgi_pass 127.0.0.1:9000
立即学习“PHP免费学习笔记(深入)”;
今天关于php fpm 端口监听 listen = [::]:9000和php-fpm监听端口的讲解已经结束,谢谢您的阅读,如果想了解更多关于.NET 端口监听、/usr/local/php-5.2.14/sbin/php-fpm start Starting php_fpm ?fpm-config的错误解决、12.21 php-fpm 的 pool 12.22 php-fpm 慢执行日志 12.23 open_basedir 12.24 php-fpm 进程管理、centos7 - centos 7.2 /var/run/php-fpm/php-fpm.sock不存在的相关知识,请在本站搜索。
本文标签: