应用最普遍的博客系统|wordpress部署

Docker部署wordpress

1.拉取 wordpress 镜像
docker pull wordpress:latestphp

  1. 查看镜像
    docker images;html

  2. 启动容器 docker run --name=wordpress -p 8003:22 -p 8001:80 -v /var/wordpress:/data wordpress
    • 经过8001端口访问
    • 本机须要php环境
    • 暂时不清楚wordpress安装数据在那个地方
    • 注意数据库路径是本机(宿主)而不是另外一个容器或者当前容器的话,须要填写本机的内网ip,而不能够是localhost或者127.0.0.1
    • 可能由于nginx配置致使样式丢失

其余问题:docker 端口映射错误解决方法

docker: Error response from daemon: driver failed programming external connectivity。。。
  • 重启docker解决 sudo systemctl restart docker

样式没法正常显示

  • 估计是nginx配置问题,这个就不深究了

最终使用和typecho同样使用站点的方式配置

  • 安装php环境,下载压缩包,解压到 /var/www/html这个和typecho同样就很少说了 ,须要注意的是目录目录权限问题java

  • 安装配置mysql和NGINXmysql

  • 相关配置参考typecho的配置linux

贴一段NGINX的配置

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;
    }

常见问题解决方案

  • 英文包转换成中文环境,在站点根目录找到wp-config.php,将define('WPLANG', '');改成define('WPLANG', 'zh_CN');没有则添加便可,而后刷新控制台面板出现更新直接下载中文包便可
  • 下载包须要验证ftp,编辑wp-config.php以下便可,官方建议升级完成以后修改回来
define('WPLANG', 'zh_CN');
define("FS_METHOD", "direct");
define("FS_CHMOD_DIR", 0777);
define("FS_CHMOD_FILE", 0777);
  • 解决“在裁剪您的图像时发生了错误” php-gd或者相关扩展没有安装吧,官方论坛搜索便可

打开域名访问主页变成下载index.php页面的源代码,其余路径的页面能够正常访问或者访问域名跳转到127.0.0.1

出现这个问题,就有点懵了,毕竟NGINX的配置没有怎么改,以前都是好好地,可是配置文件更换频繁致使的,浏览器客户端不解析php,回家访问一次发现解决了这个问题怀疑是浏览器缓存致使的,浏览器记住了以前的配置不会解析php成htmlnginx

解决方案:这个是由于浏览器缓存的缘由致使的,清除浏览器缓存便可redis

连续刷新页面出现502 错误,php-cgi程序崩溃了

照抄网上的解决方案

  • 查看当前的PHP FastCGI进程数是否够用,若是实际使用的“FastCGI进程数”接近预设的“FastCGI进程数”,那么,说明“FastCGI进程数”不够用,须要增大

netstat -anpo | grep "php-cgi" | wc -lsql

  • 部分PHP程序的执行时间超过了Nginx的等待时间,能够适当增长nginx.conf配置文件中FastCGI的timeout时间,例如:
http

{

......

fastcgi_connect_timeout 300;

fastcgi_send_timeout 300;

fastcgi_read_timeout 300;

......
 
}
  • php.ini中memory_limit设低了会出错,修改了php.ini的memory_limit为64M,重启nginx,发现好了,原来是PHP的内存不足了

这样屡次刷新依然出现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数据库

上传的文件尺寸超过php.ini中定义的upload_max_filesize值。

  • 修改/etc/php.ini中的属性值便可

Jetpack致使页面卡慢

事实证实,再好的东西,不合适就是不合适,再说这个插件实际使用也没多好,反正页面卡慢,严重影响速度和心态

解决Linux下php-fpm进程过多致使内存耗尽问题

感谢这位小伙伴提供的资料
最近发现博客打开常常出现数据库没法链接而且在网络正常的状况下出现的链接卡慢的问题;刚开始觉得是以前的redis漏洞致使的挖矿程序入侵

可是free -h查看以后发现不是CPU占用问题而是内存占用过多致使的,平均每个fpm进程占用了2%内存
查看内存消耗最多的 40个进程 ps auxw|head -1;ps auxw|sort -rn -k4|head -40
img

查看第四列内存使用占比,发现除了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
再次查看内存使用状况, 使用内存下降不少:
img

其余相关设置

ps:查看php-fpm开启的进程数以及每一个进程的内存限制

  1. 经过命令查看服务器上一共开了多少的 php-cgi 进程

ps -fe |grep "php-fpm"|grep "pool"|wc -l

  1. 查看已经有多少个php-cgi进程用来处理tcp请求
    netstat -anp|grep "php-fpm"|grep "tcp"|grep "pool"|wc -l
  2. 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/

但愿可以认识一些热爱技术的小伙伴,欢迎友连接哟

相关文章
相关标签/搜索