1.拉取 wordpress 镜像
docker pull wordpress:latestphp
查看镜像
docker images;html
docker: Error response from daemon: driver failed programming external connectivity。。。
sudo systemctl restart docker
安装php环境,下载压缩包,解压到 /var/www/html
这个和typecho同样就很少说了 ,须要注意的是目录目录权限问题java
安装配置mysql和NGINXmysql
相关配置参考typecho
的配置linux
server { listen 80; server_name www.imisty.cn imisty.cn; root /var/www/html/wordpress; index index.html index.htm index.php; client_max_body_size 100M; if (!-e $request_filename) { rewrite ^(.*)$ /index.php$1 last; } location ~ .*\.php(\/.*)*$ { include fastcgi.conf; fastcgi_index index.php; fastcgi_pass 127.0.0.1:9000; fastcgi_connect_timeout 300; fastcgi_send_timeout 300; fastcgi_read_timeout 300; } error_log logs/error_wordpress.log; access_log logs/misty.log combined; }
define('WPLANG', '');
改成define('WPLANG', 'zh_CN');
没有则添加便可,而后刷新控制台面板出现更新直接下载中文包便可wp-config.php
以下便可,官方建议升级完成以后修改回来define('WPLANG', 'zh_CN'); define("FS_METHOD", "direct"); define("FS_CHMOD_DIR", 0777); define("FS_CHMOD_FILE", 0777);
index.php
页面的源代码,其余路径的页面能够正常访问或者访问域名跳转到127.0.0.1出现这个问题,就有点懵了,毕竟NGINX的配置没有怎么改,以前都是好好地,可是配置文件更换频繁致使的,浏览器客户端不解析php,回家访问一次发现解决了这个问题怀疑是浏览器缓存致使的,浏览器记住了以前的配置不会解析php成htmlnginx
解决方案:这个是由于浏览器缓存的缘由致使的,清除浏览器缓存便可redis
netstat -anpo | grep "php-cgi" | wc -l
sql
http { ...... fastcgi_connect_timeout 300; fastcgi_send_timeout 300; fastcgi_read_timeout 300; ...... }
这样屡次刷新依然出现502错误docker
Nginx错误日志 recv() failed (104: Connection reset by peer) while reading response header from upstream, client: 183.54.41.123, server: www.imisty.cn, request: "GET /index.php?rest_route=/yoast/v1/statistics HTTP/1.1", upstream: "fastcgi://127.0.0.1:8001", host: "imisty.cn", referrer: "http://imisty.cn/wp-admin/"
php-fpm
服务进行管理,解决屡次刷新页面502的问题yum install php70w-fpm
安装,由于以前安装过旧版本,存在冲突,这里须要指定版本service php-fpm restart
启动php-fpm服务lsof查看php-cgi端口kill掉;php-fpm默认的端口是9000数据库
/etc/php.ini
中的属性值便可事实证实,再好的东西,不合适就是不合适,再说这个插件实际使用也没多好,反正页面卡慢,严重影响速度和心态
感谢这位小伙伴提供的资料
最近发现博客打开常常出现数据库没法链接而且在网络正常的状况下出现的链接卡慢的问题;刚开始觉得是以前的redis漏洞致使的挖矿程序入侵
可是free -h
查看以后发现不是CPU占用问题而是内存占用过多致使的,平均每个fpm进程占用了2%
内存
查看内存消耗最多的 40个进程 ps auxw|head -1;ps auxw|sort -rn -k4|head -40
查看第四列内存使用占比,发现除了mysql数据库服务以外,php-fpm服务池开启了太多子进程,占用超过大半内存,问题找到了,咱们开始解决问题:设置控制php-fpm进程池进程数量
解决方案:
经过各类搜索手段,发现能够经过配置 pm.max_children 属性,控制php-fpm子进程数量,首先,打开php-fpm配置文件,执行指令:
vi /etc/php-fpm.d/www.conf
找到 pm.max_children
字段,发现其值过大:
pm.max_children
值为50,每个进程占用1%-2.5%的内存,加起来就耗费大半内存了,因此咱们须要将其值调小,博主这里将其设置为25,同时,检查如下两个属性:
pm.max_spare_servers
: 该值表示保证空闲进程数最大值,若是空闲进程大于此值,此进行清理 pm.min_spare_servers
: 保证空闲进程数最小值,若是空闲进程小于此值,则建立新的子进程;
这两个值均不能不能大于 pm.max_children
值,一般设置 pm.max_spare_servers
值为 pm.max_children
值的60%-80%。
service php-fpm status
查看服务状态发现配置错误
[pool www] pm.min_spare_servers(5) and pm.max_spar...en(25)
开始的时候max_children
设置为25 ,max_spare_servers
设置为35 发现服务没法启动
最后,重启php-fpm
systemctl restart php-fpm
或者service php-fpm restart
再次查看内存使用状况, 使用内存下降不少:
其余相关设置
ps:查看php-fpm开启的进程数以及每一个进程的内存限制
ps -fe |grep "php-fpm"|grep "pool"|wc -l
netstat -anp|grep "php-fpm"|grep "tcp"|grep "pool"|wc -l
linux+nginx+php
环境中,每一个php-fpm进程的内存限制设置方法:
编辑php-fpm.conf配置文件
php_admin_value[memory_limit] = 128M
(我服务器上的配置文件在/etc/php5/fpm/pool.d/www.conf
这个文件是被包含在php-fpm.conf里的) 后边的数字能够随便更改:32M,64M,128M,256M,512M,这个设置可根据你的服务器内存大小和你的需求来写,修改后要加载一下php-fpm服务。
每一丝灵感都值得被记录,每一笔记录都是成长,每一点成长都值得欢呼
博主我的站: www.imisty.cn
CSDN博客: https://blog.csdn.net/lookinthefog
博客园 :https://imist.cnblogs.com/
但愿可以认识一些热爱技术的小伙伴,欢迎友连接哟