再Docker中架设完整的WordPress站点全攻略
前端之家收集整理的这篇文章主要介绍了
再Docker中架设完整的WordPress站点全攻略,
前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
1. 安装 Docker
在我们真正开始之前,我们需要确保在我们的 Linux 机器上已经安装了 Docker。我们使用的主机是 CentOS 7,因此我们用下面的命令使用 yum 管理器安装 docker。
2. 创建 wordpress 的 Dockerfile
我们需要创建用于自动安装 wordpress 以及其前置需求的 Dockerfile。这个 Dockerfile 将用于构建 wordpress 的安装镜像。这个 wordpress Dockerfile 会从 Docker Registry Hub 获取 CentOS 7 镜像并用最新的可用更新升级系统。然后它会安装必要的软件,例如 Nginx Web 服务器、PHP、MariaDB、Open SSH 服务器,以及其它保证 Docker 容器正常运行不可缺少的组件。最后它会执行一个初始化 wordpress 安装的脚本。
然后,我们需要将下面的配置行添加到 Dockerfile中。
<div class="jb51code">
<pre class="brush:plain;">
FROM centos:centos7
MAINTAINER The CentOS Project cloud-ops@centos.org
RUN yum -y update; yum clean all
RUN yum -y install epel-release; yum clean all
RUN yum -y install mariadb mariadb-server mariadb-client Nginx PHP-fpm PHP-cli PHP-MysqL PHP-gd PHP-imap PHP-ldap PHP-odbc PHP-pear PHP-xml PHP-xmlrpc PHP-magickwand PHP-magpieRSS PHP-mbstring PHP-mcrypt PHP-mssql PHP-shout PHP-snmp PHP-soap PHP-tidy PHP-apc pwgen python-setuptools curl git tar; yum clean all
ADD ./start.sh /start.sh
ADD ./Nginx-site.conf /Nginx.conf
RUN mv /Nginx.conf /etc/Nginx/Nginx.conf
RUN rm -rf /usr/share/Nginx/html/
RUN /usr/bin/easy_install supervisor
RUN /usr/bin/easy_install supervisor-stdout
ADD ./supervisord.conf /etc/supervisord.conf
RUN echo %sudo ALL=NOPASSWD: ALL >> /etc/sudoers
ADD http://wordpress.org/latest.tar.gz /wordpress.tar.gz
RUN tar xvzf /wordpress.tar.gz
RUN mv /wordpress/ /usr/share/Nginx/html/.
RUN chown -R apache:apache /usr/share/Nginx/
RUN chmod 755 /start.sh
RUN mkdir /var/run/sshd
EXPOSE 80
EXPOSE 22
CMD ["/bin/bash","/start.sh"]
3. 创建启动脚本
我们创建了 Dockerfile 之后,我们需要创建用于运行和配置 wordpress 安装的脚本,名称为 start.sh。它会为 wordpress 创建并配置数据库和密码。用我们喜欢的文本编辑器打开 start.sh。
打开 start.sh 之后,我们要添加下面的配置行到文件中。
<div class="jb51code">
<pre class="brush:bash;">
!/bin/bash
check() {
if [ -f /usr/share/nginx/html/wp-config.php ]; then
exit
fi
}
create_user() {
创建用于 SSH 登录的用户
SSH_USERPASS=pwgen -c -n -1 8
useradd -G wheel user
echo user:$SSH_USERPASS | chpasswd
echo ssh user password: $SSH_USERPASS
}
__mysql_config() {
启用并运行 MySQL
yum -y erase mariadb mariadb-server
rm -rf /var/lib/mysql/ /etc/my.cnf
yum -y install mariadb mariadb-server
mysql_install_db
chown -R mysql:mysql /var/lib/mysql
/usr/bin/mysqld_safe &
sleep 10
}
__handle_passwords() {
在这里我们生成随机密码(多亏了 pwgen)。前面两个用于 mysql 用户,最后一个用于 wp-config.php 的随机密钥。
WORDPRESS_DB="wordpress"
MYSQL_PASSWORD=pwgen -c -n -1 12
WORDPRESS_PASSWORD=pwgen -c -n -1 12
这是在日志中显示的密码。
echo mysql root password: $MYSQL_PASSWORD
echo wordpress password: $WORDPRESS_PASSWORD
echo $MYSQL_PASSWORD > /MysqL-root-pw.txt
echo $wordpress_PASSWORD > /wordpress-db-pw.txt
这里原来是一个包括 sed、cat、pipe 和 stuff 的很长的行,但多亏了
现在没有了
sed -e "s/database_name_here/$wordpress_DB/
s/username_here/$wordpress_DB/
s/password_here/$wordpress_PASSWORD/
/'AUTH_KEY'/s/put your unique phrase here/pwgen -c -n -1 65
/
/'SECURE_AUTH_KEY'/s/put your unique phrase here/pwgen -c -n -1 65
/
/'LOGGED_IN_KEY'/s/put your unique phrase here/pwgen -c -n -1 65
/
/'NONCE_KEY'/s/put your unique phrase here/pwgen -c -n -1 65
/
/'AUTH_SALT'/s/put your unique phrase here/pwgen -c -n -1 65
/
/'SECURE_AUTH_SALT'/s/put your unique phrase here/pwgen -c -n -1 65
/
/'LOGGED_IN_SALT'/s/put your unique phrase here/pwgen -c -n -1 65
/
/'NONCE_SALT'/s/put your unique phrase here/pwgen -c -n -1 65
/" /usr/share/Nginx/html/wp-config-sample.PHP > /usr/share/Nginx/html/wp-config.php
}
__httpd_perms() {
chown apache:apache /usr/share/Nginx/html/wp-config.php
}
_startMysqL() {
systemctl 启动 MysqLd 服务
MysqLadmin -u root password $MysqL_PASSWORD
MysqL -uroot -p$MysqL_PASSWORD -e "CREATE DATABASE wordpress; GRANT ALL PRIVILEGES ON wordpress.* TO 'wordpress'@'localhost' IDENTIFIED BY '$wordpress_PASSWORD'; FLUSH PRIVILEGES;"
killall MysqLd
sleep 10
}
__run_supervisor() {
supervisord -n
}
check
create_user
MysqL_config
handle_passwords
__httpd_perms
start_MysqL
run_supervisor