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

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

然后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.techieliang.com;
    location / {
        #反向代理路径
        proxy_pass http://wp:80;
        #反向代理的超时时间
        proxy_connect_timeout 10;
    } 
}

注意server_name是访问地址,也可以用自己的其他地址比如blog.techieliang.com,location后面的/是表明将www.techieliang.com/地址代理到下面的地址,当然你也可以增加一层路径比如“location /wp {}”这样只有输入www.techieliang.com/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,一般大小建议如下:

物理内存 建议的交换空间大小 如果开启休眠功能建议的交换空间大小
? 2GB 2倍 3倍
> 2GB – 8GB 相等 2倍
> 8GB – 64GB >4GB 1.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) 打赏
未经允许不得转载:Techie亮博客 » docker配置WordPress及MySQL

评论 抢沙发

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址

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

支付宝扫一扫打赏

微信扫一扫打赏