LAMP是目前比较流行的web框架,即Linux+Apache+Mysql+PHP的网站架构方案。docker是目前很是流行的虚拟化应用容器,能够为任何应用建立一个轻量级、可移植的容器。如今咱们就来经过docker来部署LAMP环境,而且搭建wordpress博客系统来测试。
系统环境
操做系统版本:Centos 7.5 64位
Docker版本:18.06.1-ce(社区版)
ip地址:192.168.2.226
lamp网络ip地址:172.18.0.1
一、下载mysql、php-apache镜像php
docker pull mysql docker pull php:7.2-apache
建立自定义网络lamphtml
docker network create lamp docker network ls
二、建立生成mysql、httpd-php容器的脚本
vim docker_lamp.shmysql
#!/bin/bash function mysql() { docker run --name mysql --net lamp -p 3306:3306 \ -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=test123456 \ #设置mysql的root密码 -d mysql:latest --character-set-server=utf8 #使用utf8编码 } function httpd_php() { docker run --name httpd-php --net lamp -p 80:80 \ -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 } $1
三、启动mysql、httpd-php容器web
sh docker_lamp.sh mysql sh docker_lamp.sh httpd_php
四、写一个php的首页文件来进行测试sql
echo "<?php phpinfo(); ?>" > /data/docker/www/index.php
经过浏览器访问http://192.168.2.226
五、修改mysql的密码加密方式为mysql_native_password
vim /data/docker/mysql/conf/docker_mysql.cnfdocker
[mysqld] default-authentication-plugin=mysql_native_password
若是不修改加密方式的话,低版本的mysql客户端登录时会报如下错误
六、数据库操做
登录mysql容器,建立、配置wordpress数据库数据库
docker exec -it mysql /bin/bash mysql -uroot -ptest123456 mysql> create database wordpress; mysql> create user wps@localhost identified by '123456'; mysql> grant all privileges on wordpress.* to wps@localhost; mysql> create user wps@172.18.0.1 identified by '123456'; 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 '123456'; mysql> exit exit
七、下载wordpress博客系统apache
wget https://cn.wordpress.org/wordpress-4.9.4-zh_CN.tar.gz tar -zxvf wordpress-4.9.4-zh_CN.tar.gz -C /data/docker/www/
八、配置wordpress博客
浏览器访问http://192.168.2.226/wordpress
提交后发现报500错误
刷新页面后报错,提示:表前缀不能为空
前面数据库的信息填写都正确,又试了一次仍是报这个错。
即然如此,咱们就直接修改wp-config-sample.php配置文件吧。
九、修改wp-config-sample.php配置
cd /data/docker/www/wordpress/
vim wp-config-sample.php #修改如下内容vim
/** WordPress数据库的名称 */ define('DB_NAME', 'wordpress'); /** MySQL数据库用户名 */ define('DB_USER', 'wps'); /** MySQL数据库密码 */ define('DB_PASSWORD', '123456'); /** MySQL主机 */ define('DB_HOST', 'mysql'); /** 建立数据表时默认的文字编码 */ define('DB_CHARSET', 'utf8'); /** 数据库整理类型。如不肯定请勿更改 */ define('DB_COLLATE', '');
将文件名改成wp-config.phpmv wp-config-sample.php wp-config.php
再用浏览器访问http://192.168.2.226/wordpress
查阅资料后发现,原来从PHP5.0开始就不推荐使用mysql_connect()函数了,而到了php7.0则直接废弃了该函数,替代的函数是mysqli_connect(),终于找到问题缘由了。
十、Call to undefined function mysql_connect()问题解决方法
进入到mysql容器里安装mysqli扩展浏览器
docker exec -it httpd-php /bin/bash apt-get update apt-get install libpng-dev cd /usr/local/bin/ ./docker-php-ext-install gd mysqli ./docker-php-ext-enable gd mysqli exit docker restart httpd-php
编写一个测试链接mysql的php
vim /data/docker/www/test.php
<?php echo "Hello PHP<br/>"; $conn = mysqli_connect("mysql","wps","123456"); if(!$conn){ echo "链接数据库失败"; }else{ echo "链接数据库成功"; } phpinfo(); ?>
浏览器访问http://192.168.2.226/test.php
修改wp-db.php文件,将mysql_connect替换为mysqli_connect
cd /data/docker/www/wordpress/ sed -i "s/mysql_connect/mysqli_connect/g" wp-includes/wp-db.php mv wp-config.php wp-config-sample.php
十一、从新配置wordpress博客
浏览器访问http://192.168.2.226/wordpress
按前面的步骤填写完链接mysql的配置信息后,看到以下页面,表示mysql链接成功。
须要手工建立wp-config.php文件,将以上信息贴入wp-config.php文件中
vim /data/docker/www/wordpress/wp-config.php
而后点击“如今安装”,出现如下页面
输入完以上信息后,点击“安装WordPress”至此,wordpress博客系统就搭建完成了。