1、环境

系统版本:CentOS Linux release 7.4.1708

docker版本:docker-ce-18.09

主机IP:192.168.121.121

2、载入MySQL和PHP镜像

$ docker pull mysql

$ docker pull php:7.2-apache

3、创建网络

$ docker network create lamp
6549dbc105bba9e51d4d0b13df7ae17916c3628f5a07c81551203fb63c15892e

查看网络

$ docker network ls
NETWORK ID NAME DRIVER SCOPE
be6ab252106a bridge bridge local
3f26bc9f85e3 host host local
6549dbc105bb lamp bridge local
7f2db0f13ffc none null local

4、创建生成mysql和php容器的脚本

$ vi docker_lamp.sh
#!/bin/bash
function mysql()
{
docker run --name mysql --net lamp -p : \
-v /data/docker/mysql/data:/var/lib/mysql \
-v /data/docker/mysql/conf:/etc/mysql/conf.d \
-v /data/docker/mysql/logs:/logs \
-e MYSQL_ROOT_PASSWORD=Test1234 \
-d mysql:latest --character-set-server=utf8
} function httpd_php()
{
docker run --name httpd-php --net lamp -p : \
-v /data/docker/httpd/conf:/etc/apache2/sites-enabled \
-v /data/docker/www:/var/www/html \
-v /data/docker/httpd/logs:/var/log/apache2 \
-d php:7.2-apache
}
$

5、启动mysql和php容器

$ sh docker_lamp.sh mysql
9c2362b5e32f24bd9e21ae13f8accb6d35c359621dc5b5e36a273d1e64424920 $ sh docker_lamp.sh httpd_php
d466d5de8d133343d3e591b598c4f5b5958618e47f841ebfeaa81cae56ad6139

查看容器

$ docker ps
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
d466d5de8d13 php:7.2-apache "docker-php-entrypoi…" seconds ago Up second 0.0.0.0:->/tcp httpd-php
9c2362b5e32f mysql:latest "docker-entrypoint.s…" seconds ago Up seconds 0.0.0.0:->/tcp, /tcp mysql

6、写测试页面进行测试

为目录赋权

# chown -R dkuser:dkuser /data

写测试页面

$ echo "<?php phpinfo();?>" > /data/docker/www/index.php

浏览器访问地址 192.168.121.121 ,出现 PHP 的页面就说明是OK的。

7、修改mysql密码加密方式为mysql_native_password

$ vi /data/docker/mysql/conf/docker_mysql.conf
[mysqld]
default-authentication-plugin=mysql_native_password

8、数据库操作

登陆mysql容器,创建、配置wordpress数据库

$ docker exec -it mysql /bin/bash
root@9c2362b5e32f:/# chown -R mysql:mysql /var/lib/mysql
root@9c2362b5e32f:/# mysql -uroot -pTest1234
mysql> create database wordpress;
mysql> create user wps@localhost identified by '';
mysql> grant all privileges on wordpress.* to wps@localhost;
mysql> create user wps@172.18.0.1 identified by '';
mysql> grant all privileges on wordpress.* to wps@172.18.0.1;
mysql> alter user wps@172.18.0.1 identified with mysql_native_password by '';

9、配置wordpress博客系统

9.1、下载wordpress包并解压

$ wget https://cn.wordpress.org/wordpress-4.9.4-zh_CN.tar.gz

$ tar -zxf wordpress-4.9.-zh_CN.tar.gz -C /data/docker/www

9.2、修改wordpress配置

$ cd /data/docker/www/wordpress/
$ vi wp-config-sample.php
/** WordPress数据库的名称 */
define('DB_NAME', 'wordpress'); /** MySQL数据库用户名 */
define('DB_USER', 'wps'); /** MySQL数据库密码 */
define('DB_PASSWORD', ''); /** MySQL主机 */
define('DB_HOST', '192.168.121.121'); /** 创建数据表时默认的文字编码 */
define('DB_CHARSET', 'utf8'); /** 数据库整理类型。如不确定请勿更改 */
define('DB_COLLATE', '');
$ mv wp-config-sample.php wp-config.php

9.3、修复问题

从PHP5.0开始不推荐使用mysql_connect()函数,从PHP7.0开始就废弃了该函数,替代的函数是mysqli_connect(),下面是解决办法:

进入php容器安装mysqli扩展

$ docker exec -it httpd-php /bin/bash
root@d466d5de8d13:/var/www/html# apt-get update
root@d466d5de8d13:/var/www/html# apt-get install libpng-dev
root@d466d5de8d13:/var/www/html# cd /usr/local/bin/
root@d466d5de8d13:/usr/local/bin# ./docker-php-ext-install gd mysqli
root@d466d5de8d13:/usr/local/bin# ./docker-php-ext-enable gd mysql

退出容器,重启容器

$ docker restart httpd-php

替换方法

$ cd /data/docker/www/wordpress
$ sed -i "s/mysql_connect/mysqli_connect/g" wp-includes/wp-db.php

9.4、打开wordpress页面进行配置

打开页面 http://192.168.121.121/wordpress ---> 在出现的页面点击 “现在就开始”  ---> 填写下面所示的数据库信息:

数据库名 wordpress
用户名 wps
密码 123456
数据库主机 192.168.121.121
表前缀 wp_

---> 点击 “安装WordPress” ---> 点击 “登陆” ---> 使用账户和密码登陆博客,之后就可以进入博客页面,进而对博客进行管理了。

参考:

https://blog.51cto.com/andyxu/2177116

docker学习---搭建Docker LAMP环境的更多相关文章

  1. docker学习---搭建Docker私有库及删除库内镜像

    环境准备系统: cat /etc/redhat-release CentOS Linux release (Core) 主机两台,分别是docker私有库服务器(IP 192.168.121.121) ...

  2. 一文教您如何通过 Docker 快速搭建各种测试环境(Mysql, Redis, Elasticsearch, MongoDB) | 建议收藏

    欢迎关注个人微信公众号: 小哈学Java, 文末分享阿里 P8 高级架构师吐血总结的 <Java 核心知识整理&面试.pdf>资源链接!! 个人网站: https://www.ex ...

  3. Docker-教你如何通过 Docker 快速搭建各种测试环境

    今天给大家分享的主题是,如何通过 Docker 快速搭建各种测试环境,本文列举的,也是作者在工作中经常用到的,其中包括 MySQL.Redis.Elasticsearch.MongoDB 安装步骤,通 ...

  4. docker学习5-docker安装tomcat环境和部署war包

    前言 tomcat部署web项目非常方便,把war包放到webapps目录就可以了.本篇使用docker快速搭建一个tomcat环境 下载tomcat镜像 拉取官方最新版tomcat镜像 [root@ ...

  5. PyCharm使用之利用Docker镜像搭建Python开发环境

      在我们平时使用PyCharm的过程中,一般都是连接本地的Python环境进行开发,但是如果是离线的环境呢?这样就不好搭建Python开发环境,因为第三方模块的依赖复杂,不好通过离线安装包的方式安装 ...

  6. 使用Docker快速搭建PHP开发环境

    最近有个同事找过来,希望我对在很早之前写的一个PHP网站上增加一些功能,当时开发使用xampp构建的本地开发环境,但是现在我的笔记本电脑已经更新,没有当时的开发环境.本着尽量不往电脑上装无用软件的原则 ...

  7. Docker容器搭建android编译环境

    Docker容器搭建android编译环境 目录 1 部署容器 1.1 手动部署 1.1.1 配置docker 1.1.2 启动容器 1.1.3 配置环境 1.2 Dockerfile 2 镜像管理 ...

  8. Docker学习笔记 — Docker私有仓库搭建

    Docker学习笔记 — Docker私有仓库搭建   目录(?)[-] 环境准备 搭建私有仓库 测试 管理仓库中的镜像 查询 删除 Registry V2   和Mavan的管理一样,Dockers ...

  9. Docker学习之Docker容器基本使用

    Docker学习之Docker容器基本使用 新建容器并启动 命令格式:docker run --options repository:tag 后台运行 命令格式:-d 已存在的容器相关操作 启动:do ...

随机推荐

  1. mysql在插入数据前判断是否存在数据

    记录一次mysql插入数据的操作,要先判断表中是否存在对应的值. 以往我们的操作都是先select,再insert,今天给大家分享另一种操作,一条sql语句来实现: inset into user(u ...

  2. 读书笔记-----javascript基本数据类型

    由于js基础差, 记性也不好,准备一边读书一边做记录,希望这样能加深一下记忆 /*   第一天     */ javascript 基本数据类型 js一共只有五种数据类型 Undefined,  Nu ...

  3. ES5新增方法(数组,字符串,对象)

    一.数组方法 迭代(遍历)方法:forEach().map().filter().some().every(): 1. array. forEach(function(value,index,arr) ...

  4. 2018-8-10-win10-UWP-ListView-

    title author date CreateTime categories win10 UWP ListView lindexi 2018-08-10 19:16:53 +0800 2018-2- ...

  5. 单实例安装elastic和启动报错解决

    下载 先到官网https://www.elastic.co/cn/downloads/past-releases/elasticsearch-5-5-2下载,我安装的是5.5.2的版本,其他版本直接访 ...

  6. Codeforces 1149D 最短路 状压DP

    题意及思路:https://blog.csdn.net/yzyyylx/article/details/90145400 这题主要巧妙在分析了最短路算法的性质,得出大小小于等于3的连通块一定不会被再次 ...

  7. jq 手机键盘消失出现白色延迟

    input 输入框失去焦点 $("#input").blur() 接口调用setTimeout 让输入框消失后再出现loading和调用接口 ios手机loading覆盖不完全 自 ...

  8. getElementsBy 系列方法相比querySelector系列的区别

    最近在做的项目中,使用querySelectorAll获取了同class名的元素后,绑定onmouseover事件和onmouseout后,多次在几个元素上移入移出操作时,控制台出现了报错的问题,最后 ...

  9. 使用 @Log4j2 log.error() 打印异常日志

    public static void main(String[] args) { int a = 10; try { int i = 1/0; } catch (Exception e) { Syst ...

  10. 快速给一个表插入数据 用bulk_create()