进步始于交流
收获源于分享

docker配置WordPress及MySQL

安装MySQL

docker pull mysql
docker run --name tlmysql -d -p 3306:3306 -v /ZZZZZ/mysql/data:/var/lib/mysql -e MYSQL_ROOT_PASSWORD="XXXXXXX" mysql

ZZZZ指路径,XXXXXX是mysql的root账号的初始密码设置,mysql新版本不允许root密码为空,所以一定要设置这个环境变量,否则无法run
其他参数:–name就是给容器取名字,-d后台运行,-v加上后面的目录表示把容器中的/var/lib/mysql目录和宿主机中的/ZZZZZ/mysql/data目录做映射,把数据库数据保存在本地。

安装PhpMyAdmin

docker run --name tlphpmyadmin -d --link tlmysql:db -p 20201:80 phpmyadmin/phpmyadmin

link了刚建立的tlmysql容器,并且命名为别名db。在这个容器内通过tlmysql或者db均能访问到tlmysql容器的端口,如使用tlmysql:3306或者db:3306均可,注意不要使用Localhost这样访问的是当前容器(tlphpmyadmin)

安装WordPress

docker run --name tlwordpress -d -p 80:80 --link tlmysql:wpdb -v /XXXXX/wordpress:/var/www/html wordpress

link了刚建立的tlmysql容器,并且命名为别名wpdb 。在这个容器内通过tlmysql或者db均能访问到tlmysql容器的端口,如使用tlmysql:3306或者wpdb :3306均可,注意不要使用Localhost这样访问的是当前容器(tlwordpress),在初始化wp的过程需要设置数据库地址,此处地址就要写wpdb:3306即可,写localhost是无法连接的,当然如果是外部数据库直接写外部地址就行

数据备份还原

只需要备份/XXXXX/wordpress,/ZZZZZ/mysql/data文件目录即可。可保证数据不丢失

若只修改wp的wp-content目录,可以在-v后只映射wp-content目录-v /XXXXX/wordpress/wp-content:/var/www/html/wp-content。这样可以避免对wp的静态文件做备份。

还原只需要将run时的-v指向新的路径即可

其他注意

wp新版对mysql5.5+版本使用的默认是utf8mb4编码,而不是utf8/gbk等格式,迁移时注意编码避免乱码

使用Nginx反向代理

docker的wp默认是Apache,使用nginx进行反向代理,首先pull下来nginx的镜像,然后启动镜像,下面的代码是要先cd到自己建立好的目录下使用

docker run -p 80:80 --name tlnginx -v $PWD/nginx.conf:/etc/nginx/nginx.conf -v $PWD/conf.d:/etc/nginx/conf.d  -v $PWD/logs:/wwwlogs  -d --link wordpress:wp nginx

首先绑定了80端口,然后容器名字为tlnginx,把nginx.conf文件映射到了本地文件,同时把conf.d目录页映射了,最后将这个容器与wordpress的容器连接重命名为wp

注意如果这么设置,需要将wp的容器的-p 80:80删除,也就是wp容器不对外开放端口,nginx可通过link方式直接获取到wp的80端口,当然也可以选择映射到指定端口

然后nginx.conf文件默认不用修改就行,因为文件最后包含了conf.d目录下的所有*.conf文件,下面给出两个文件的内容。

nginx.conf:

user  nginx;
worker_processes  1;

error_log  /var/log/nginx/error.log warn;
pid        /var/run/nginx.pid;


events {
    worker_connections  1024;
}


http {
    include       /etc/nginx/mime.types;
    default_type  application/octet-stream;

    log_format  main  '$remote_addr - $remote_user [$time_local] "$request" '
                      '$status $body_bytes_sent "$http_referer" '
                      '"$http_user_agent" "$http_x_forwarded_for"';

    access_log  /var/log/nginx/access.log  main;

    sendfile        on;
    #tcp_nopush     on;

    keepalive_timeout  65;

    #gzip  on;

    include /etc/nginx/conf.d/*.conf;
}
conf.d/wp.conf
server {
    listen       80;
    server_name   www.www.coologic.cn;
    location / {
        #反向代理路径
        proxy_pass http://wp:80;
        #反向代理的超时时间
        proxy_connect_timeout 10;
    } 
}

注意server_name是访问地址,也可以用自己的其他地址比如blog.www.coologic.cn,location后面的/是表明将www.www.coologic.cn/地址代理到下面的地址,当然你也可以增加一层路径比如“location /wp {}”这样只有输入www.www.coologic.cn/wp才能跳转

下面的proxy_pass http://wp:80;应该是指向一个具体路径,此处使用的wp,因为两个容器关联了,所以可以通过wp解析到容器具体ip,wp容器可以直接不对外映射端口

后面运行就行,如果docker ps -a无法看到正在运行nginx,请用docker logs tlnginx查看日志

低内存空间开启swap

内存过小docker可能会出现exited(137)错误,随机关闭某个容器,我这mysql被关了好几次。这实际上是os关的,并非docker。可以建立swap交换空间。

查看当前已有swap大小

free -m
total used free shared buff/cache available
Mem: 992 436 75 34 480 364
Swap: 0 0 0

可以看到 Swap 只有0,下面我们来扩大到2G,为什么2G,因为我这个物理内存是1G,一般大小建议如下:

物理内存建议的交换空间大小如果开启休眠功能建议的交换空间大小
? 2GB2倍3倍
> 2GB – 8GB相等2倍
> 8GB – 64GB>4GB1.5倍
> 64GB>4GB不推荐休眠

创建一个 Swap 文件

首先cd到一个想要创建文件的地方,要注意这个目录所在硬盘分区要有大于所要创建大小的空间

mkdir /swap
cd /swap
sudo dd if=/dev/zero of=swapfile bs=1024 count=2000000

然后会提示创建成功,创建的大小、用时、拷贝速度

将普通文件转换成 Swap 文件

sudo mkswap -f swapfile

给出如下提示:

Setting up swapspace version 1, size = 1999996 KiB
no label, UUID=XXXXXXXXXXX

激活 Swap 文件

sudo swapon swapfile

再次查看 free -m 的结果

卸载Swap文件及自动挂载

如果需要卸载这个 swap 文件,可以进入建立的 swap 文件目录。执行下列命令。

sudo swapoff swapfile

如果需要一直保持这个 swap开机自动挂载,可以把它写入 /etc/fstab 文件。

/XXXX/swapfile /XXXX swap defaults 0 0

补充dd指令含义

dd:用指定大小的块拷贝一个文件,并在拷贝的同时进行指定的转换
注意:指定数字的地方若以下列字符结尾,则乘以相应的数字:b=512;c=1;k=1024;w=2
1. if=文件名:输入文件名,缺省为标准输入。即指定源文件。< if=input file >
2. of=文件名:输出文件名,缺省为标准输出。即指定目的文件。< of=output file >
3. ibs=bytes:一次读入bytes个字节,即指定一个块大小为bytes个字节。
  obs=bytes:一次输出bytes个字节,即指定一个块大小为bytes个字节。
  bs=bytes:同时设置读入/输出的块大小为bytes个字节。
4. cbs=bytes:一次转换bytes个字节,即指定转换缓冲区大小。
5. skip=blocks:从输入文件开头跳过blocks个块后再开始复制。
6. seek=blocks:从输出文件开头跳过blocks个块后再开始复制。
注意:通常只用当输出文件是磁盘或磁带时才有效,即备份到磁盘或磁带时才有效。
7. count=blocks:仅拷贝blocks个块,块大小等于ibs指定的字节数。
8. conv=conversion:用指定的参数转换文件。
  ascii:转换ebcdic为ascii
  ebcdic:转换ascii为ebcdic
  ibm:转换ascii为alternate ebcdic
  block:把每一行转换为长度为cbs,不足部分用空格填充
  unblock:使每一行的长度都为cbs,不足部分用空格填充
  lcase:把大写字符转换为小写字符
  ucase:把小写字符转换为大写字符
  swab:交换输入的每对字节
  noerror:出错时不停止
  notrunc:不截短输出文件
  sync:将每个输入块填充到ibs个字节,不足部分用空(NUL)字符补齐。
上述建立过程就是bs=1024 count=2000000,以1024位块大小,建立2000000个块,总共2048000000字节,所以显示的不是2GB大小,因为不是2097152字节。
赞(1) 打赏
未经允许不得转载:Coologic » docker配置WordPress及MySQL

评论 3

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址
  1. #0

    我的WordPress没有设置 -p ,Nginx设置了link,但是访问的时候显示找不到wp的服务器IP地址,这是怎么回事儿啊?

    venom3年前 (2020-04-14)回复
  2. #0

    wordpress在生成容器的时候-p 80:80 ,后面nginx再做端口映射-p 80:80貌似会报错吧..

    路人甲4年前 (2019-01-19)回复
    • 那是肯定的,nginx容器做了link操作,那就不需要将wp容器端口-p操作了

      Techie亮4年前 (2019-01-31)回复

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

微信扫一扫打赏