免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 52634 | 回复: 2
打印 上一主题 下一主题

Dockerfile分离构建LNMP环境部署wordpress [复制链接]

论坛徽章:
1
15-16赛季CBA联赛之同曦
日期:2017-01-17 18:19:30
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2017-06-22 15:24 |只看该作者 |倒序浏览
最近忙着写自己的项目,也把一个站点的bbs论坛打算迁移到Docker中,测试没发现啥大问题。在单台上面的架构如下;(往后我们也是要讲到compose和swarm调度的慢慢来)


1、首先我们先安装一下docker,好多人都发现国内用yum安装有各种问题;这里我们用国内的https://www.daocloud.io.登录后注册,然后点击下载。里面有提示,我们点击Linxu安装然后复制代码执行到shell上即可。
[root@test nginx]# curl -sSL https://get.daocloud.io/docker | sh

2、安装好之后,安装dockhub加速器,点击加速器,复制代码粘贴到shell.
  1. [root@test nginx]# curl -sSL https://get.daocloud.io/daotools/set_mirror.sh | sh -s http://681a96df.m.daocloud.io
  2. {"registry-mirrors": ["http://681a96df.m.daocloud.io"],
  3.     "live-restore": true
  4. }
  5. Success.
  6. You need to restart docker to take effect: sudo systemctl restart docker
复制代码
##执行脚本,主要是把仓库地址写到daemon.json文件下。
  1. [root@test nginx]# cat /etc/docker/daemon.json
  2. {"registry-mirrors": ["http://681a96df.m.daocloud.io"],
  3.     "live-restore": true
  4. }
复制代码
3、准备工作都已经完成了,接下来我们来构建一下dockerfile在三个目录下,看下目录结构:
  1. [root@test test]# tree -L 2 --charset ASCII
  2. |-- mysql
  3. |   |-- Dockerfile
  4. |   |-- epel-6.repo
  5. |   |-- my.cnf
  6. |   `-- startup.sh
  7. |-- nginx
  8. |   |-- Dockerfile
  9. |   |-- nginx-1.11.10
  10. |   |-- nginx-1.11.10.tar.gz
  11. |   |-- nginx.conf
  12. |   `-- nginx_default.conf
  13. `-- php-fpm
  14.     |-- Centos-6.repo
  15.     |-- Dockerfile
  16.     |-- epel-6.repo
  17.     |-- php-5.5.38
  18.     `-- php-5.5.38.tar.gz
复制代码
4、看一下nginx 的 Dockerfile:
  1. [root@test nginx]# cat Dockerfile
  2. #lnmp centos 6.0
  3. from centos:centos6
  4. MAINTAINER xiaoluo <xiaoluo@test.com>
  5. ENV APP_DIR /web
  6. add nginx-1.11.10 /nginx-1.11.10
  7. RUN yum -y groupinstall "Development Tools" "Server Platform Deveopment"
  8. RUN yum -y install openssl-devel pcre-devel
  9. RUN useradd nginx -s /sbin/nologin
  10. RUN cd /nginx-1.11.10 && ./configure --prefix=/usr/local/nginx --user=nginx --group=nginx --with-http_ssl_module --with-http_flv_module --with-http_stub_status_module --with-http_gzip_static_module  --with-pcre && make && make install
  11. RUN mkdir /usr/local/nginx/conf/vhosts
  12. RUN mkdir /var/log/nginx
  13. ADD nginx.conf /usr/local/nginx/conf/nginx.conf
  14. ADD nginx_default.conf /usr/local/nginx/conf/vhosts/default.conf
  15. EXPOSE 80
  16. CMD ["/usr/local/nginx/sbin/nginx"]
复制代码
##nginx 相关php配置:
  1. [root@test nginx]# cat nginx_default.conf
  2. server {
  3.     listen       80 default_server;
  4.     server_name  localhost;
  5.     #charset koi8-r;
  6.     location / {
  7.         root   /web;
  8.         index  index.php index.html index.htm;
  9.     }
  10.     # redirect server error pages to the static page /50x.html
  11.     #
  12.     error_page   500 502 503 504  /50x.html;
  13.     location = /50x.html {
  14.         root   APP_DIR;
  15.     }
  16.     # Disable nginx log write favicon.ico
  17.     location = /favicon.ico {
  18.     log_not_found off;
  19.     access_log off;
  20.         }
  21.     # pass the PHP scripts to FastCGI server listening on port 9000
  22.     #
  23.     location ~ \.php$ {
  24.         root           /web;
  25.         fastcgi_pass   php:9000;
  26.         #fastcgi_pass  unix:/tmp/php-fpm.sock;
  27.         fastcgi_index  index.php;
  28.         fastcgi_param  SCRIPT_FILENAME  $document_root$fastcgi_script_name;
  29.         include        fastcgi_params;
  30.     }
  31. }
复制代码
###php:9000是通过后面的--link 容器之间互联指定
5、开始构建nginx镜像:
  1. [root@test nginx]# docker build -t lnmp/nginx:1.0 .
复制代码
##查看是否生成镜像:
  1. [root@test nginx]# docker images
  2. REPOSITORY          TAG                 IMAGE ID            CREATED             SIZE
  3. lnmp/nginx          1.0                 5f5d4169189d        4 minutes ago       669 MB
复制代码
6、开始构建php镜像:
  1. [root@test php-fpm]# cat Dockerfile
  2. from centos:centos6
  3. ADD Centos-6.repo /etc/yum.repos.d/CentOS-Base.repo
  4. ADD epel-6.repo /etc/yum.repos.d/epel.repo
  5. add php-5.5.38 /php-5.5.38
  6. RUN yum -y groupinstall  "Desktop Platform Development"
  7. RUN yum -y install libmcrypt-devel bzip2-devel gcc openssl-devel php-mcrypt libmcrypt
  8. RUN cd /php-5.5.38 && ./configure --prefix=/usr/local/php --with-mysql=mysqlnd --with-pdo-mysql=mysqlnd --with-mysqli=mysqlnd --with-openssl --enable-mbstring --with-freetype-dir --with-jpeg-dir --with-png-dir --with-zlib --with-libxml-dir=/usr --enable-xml --enable-sockets --with-mcrypt  --with-bz2 --enable-fpm --with-gd && make && make install
  9. RUN cp /php-5.5.38/php.ini-production  /usr/local/php/etc/php.ini
  10. RUN mv /usr/local/php/etc/php-fpm.conf.default /usr/local/php/etc/php-fpm.conf
  11. RUN useradd -M -s /sbin/nologin php
  12. RUN sed -i -e 's\;pid = run/php-fpm.pid\pid = run/php-fpm.pid\g' -e 's\nobody\php\g' -e 's\listen = 127.0.0.1:9000\listen = 0.0.0.0:9000\g' /usr/local/php/etc/php-fpm.conf
  13. RUN sed -i 's\;daemonize = yes\daemonize = no\g' /usr/local/php/etc/php-fpm.conf
  14. EXPOSE 9000
  15. CMD ["/usr/local/php/sbin/php-fpm"]
复制代码
7、开始构建php镜像:
  1. [root@test php-fpm]# docker build -t lnmp/php:1.0 .
复制代码
8、构建mysql镜像的Dockerfile:
  1. [root@test mysql]# cat Dockerfile
  2. FROM centos:centos6  
  3. MAINTAINER xiaoluo "18878774@163.com"  
  4. RUN yum install -y mysql-server mysql  
  5. ADD ./startup.sh /opt/startup.sh
  6. RUN chmod +x /opt/startup.sh
  7. EXPOSE 3306
  8. CMD ["/bin/bash","/opt/startup.sh"]
复制代码
##启动脚本:
  1. [root@test mysql]# cat startup.sh
  2. #!/bin/bash
  3. if [ ! -f /var/lib/mysql/ibdata1 ]; then
  4.         mysql_install_db
  5.         /usr/bin/mysqld_safe &
  6.         sleep 10s
  7.         mysql -e "grant all privileges on *.* to 'root'@'%' identified by '123456'; FLUSH PRIVILEGES;"
  8.         killall mysqld
  9.         sleep 10s
  10. fi
  11. /usr/bin/mysqld_safe
复制代码
**正常启动的时候,是没有问题的;当时当我们用-v做持久化的时候,好像说用户就失去对/var/lib/mysql的控制权,所以启动的时候我们要判断初始化才可以用-v来持久化相关目录,这个地方之前搞了好久就是挂不起来,后面原来是这个地方。

9、开始构建mysql镜像:
  1. [root@test mysql]# docker build -t lnmp/mysql:1.0 .
复制代码
10、下面我们开始启动相关容器:
  1. [root@test web]# docker run -dit --name php -v /web:/web lnmp/php:1.0
  2. [root@test web]# docker run -dit --name web -p 80:80 -v /web:/web --link php:php lnmp/nginx:1.0
  3. [root@test web]#docker run -dit --name mysql -p 3306:3306 -v /opt/data:/var/lib/mysql lnmp/mysql:1.0
  4. #####
  5. [root@test mysql]# docker ps
  6. CONTAINER ID        IMAGE               COMMAND                  CREATED              STATUS              PORTS                    NAMES
  7. 3527cddb4c50        lnmp/mysql:1.0      "/bin/bash /opt/st..."   4 seconds ago        Up 3 seconds        0.0.0.0:3306->3306/tcp   mysql
  8. fab93953c438        lnmp/nginx:1.0      "/usr/local/nginx/..."   About a minute ago   Up About a minute   0.0.0.0:80->80/tcp       web
  9. d5854337c10b        lnmp/php:1.0        "/usr/local/php/sb..."   3 minutes ago        Up 2 minutes        9000/tcp
复制代码
              php
##可以看到我们已经都启动了所有的容器了。

11、接下来我们登录一下mysql.创建一下wordpress使用的数据库:
  1. [root@test mysql]# mysql -uroot -p123456 -h 192.168.63.200
  2. MySQL [(none)]> CREATE DATABASE wordpress DEFAULT CHARACTER SET utf8;
  3. Query OK, 1 row affected (0.00 sec)
复制代码
12、然后我们把wordpress代码放到我们挂载的本地/web目录下面:
  1. [root@test web]# wget https://cn.wordpress.org/wordpress-4.7.2-zh_CN.tar.gz
复制代码

#然后解压出来。我们直接访问一下当前主机的IP地址:


直接往下走注册即可:



##到此在Docker 分离下安装wordpress已经完成,但是我们要思考一个问题,就是有没有更好的方法统一编排一下这些容器呢,给容器更好的分组管理:可以留意一下docker-compose,在1.13之后更是结合栈来实现跨主机编排。

##还有一个就是如何给这些容器做成集群管理,保证节点的高可用。和资源监控调度呢。可以看一下1.12之后的docker swarm,构建集群非常简单。

论坛徽章:
1
黑曼巴
日期:2017-11-27 16:06:48
2 [报告]
发表于 2018-01-03 09:39 |只看该作者
docker-compose
  1. version: '2'

  2. services:
  3.   db:
  4.     image: reg.smartcourt.cn/tools/mysql
  5.     environment:
  6.       - MYSQL_ROOT_PASSWORD=mypass
  7.     volumes:
  8.       - /data/app/wordpress/dbdata:/var/lib/mysql
  9.       - /usr/bin/rz:/usr/bin/rz
  10.       - /usr/bin/sz:/usr/bin/sz

  11.   wp:
  12.     image: reg.smartcourt.cn/tools/wordpress
  13.     environment:
  14.       - WORDPRESS_DB_HOST=db
  15.       - WORDPRESS_DB_PASSWORD=mypass
  16.     volumes:
  17.       - /data/app/wordpress/wpdata:/var/www/html
  18.     ports:
  19.       - 8101:80
复制代码

论坛徽章:
0
3 [报告]
发表于 2018-07-30 15:36 |只看该作者
需要租用服务器可以联系 小何 2880269166  
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP