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. shell script 学习

    终于来到了shell脚本的学习,貌似很牛叉. shell script鸟叔解释:利用shell的功能写的一个program,使用纯文本文件,将一些shell语法和指令写在里面,搭配正则表示法,管线命令 ...

  2. redis-布隆过滤器使用

    占用空间测试地址 https://krisives.github.io/bloom-calculator/

  3. master挂了的话pm2怎么处理 使用pm2方便开启node集群模式

    本文为转载 Introduction As you would probably know, Node.js is a platform built on Chrome's JavaScript ru ...

  4. 解决Addin开发不能断点调试的问题

    ArcMap或CAD在调试C#二次开发的插件的时候,在一些情况下不能正常进入到断点中,原因是debugger type不对应. eg. 右键单击Solution Explorer,选择Add-> ...

  5. 开启.NET Core 3时代,DevExpress v19.2.5带你全新启航

    DevExpress Universal Subscription(又名DevExpress宇宙版或DXperience Universal Suite)是全球使用广泛的.NET用户界面控件套包,De ...

  6. linux安装zabbix的tar包和另外一个并存

    在安装zabbix客户端的时候,发现存在一个zabbix客户端,现在我们要重新建一个来与之并存 第一步安装: cd /data0/software/ tar xf zabbix-3.0.28.tar. ...

  7. 每天一个Linux命令:ls(1)

    ls ls命令用于显示指定工作目录下之内容(列出目前工作目录所含之文件及子目录). 格式 ls [-alrtAFR] [name...] 参数选项 参数 备注 -a 列出目录下的所有文件,包括以 . ...

  8. 数据结构和算法设计专题之---二分查找(Java版)

    1.前提:二分查找的前提是需要查找的数组必须是已排序的,我们这里的实现默认为升序 2.原理:将数组分为三部分,依次是中值(所谓的中值就是数组中间位置的那个值)前,中值,中值后:将要查找的值和数组的中值 ...

  9. GDI及Windows的消息机制

    什么是GDI? GDI, Graphics Device Interface GDI在以下位置已经被微软列为Legacy Graphics,不建议使用来开发应用程序(http://msdn.micro ...

  10. MySQL数据库(六) —— SQL注入攻击、视图、事物、存储过程、流程控制

    SQL注入攻击.视图.事物.存储过程.流程控制 一.SQL注入攻击 1.什么是SQL注入攻击 import pymysql conn = pymysql.Connect( user="roo ...