搭建 LAMP + WORDPRESS 环境

一、环境介绍

二、必装依赖软件

三、编译安装 Nginx-1.6.3

四、二进制安装 MYSQL-5.5.33

五、编译安装 PHP-5.3.27

六、检测 nginx与mysql nginx与php 是否相连

七、安装 wordpress (分别基于IP,域名访问)

一、环境介绍

搭建这个环境,所有服务都安装在一台虚拟机中,在此介绍一下我的虚拟机

CentOS-6.7-x86_64    保证虚拟机可以正常上网

IP:192.168.6.36

hostname:yuci

关闭  iptbales   selinux

clip_image002

二、必装依赖软件

全部通过 yum 安装

lrzsz      # 软件和此环境没有什么关系。安装后可以通过xshell直接拖拽软件包

pcre

pcre-devel

openssl-devel

yum -y install lrzsz pcre pcre-devel openssl-devel

rpm -qa lrzsz pcre pcre-devel openssl-devel

clip_image004

clip_image006

三、编译安装 Nginx-1.6.3

创建一个专门用于存放软件包的目录

mkdir -p /home/yuci/tools

clip_image008

创建 nginx 用户,并检查

useradd -s /sbin/nologin/ -M nginx

id nginx

clip_image010

解压 nginx 压缩包(安装过 lrzsz ,所以可直接拖拽软件的该目录)

tar zxf nginx-1.6.3.tar.gz

clip_image012

开始编译安装 nginx , 在 nginx 目录下输入一下命令

clip_image014

./configure --prefix=/application/nginx-1.6.3 --user=nginx \

--group=nginx --with-http_ssl_module \

--with-http_stub_status_module \

&& make && make install

创建一个软连接,保留软件版本的同时方便操作

ln -s /application/nginx-1.6.3/ /application/nginx

clip_image016

启动 nginx 服务

/application/nginx/sbin/nginx 

clip_image018

浏览器输入IP地址,nginx 搭建成功

clip_image020

四、二进制安装 MYSQL-5.5.33

解压 mysql 安装包

tar zxf mysql-5.5.33-linux2.6-x86_64.tar.gz

clip_image022

切到 /application 目录,lamp 环境中的所有服务都将安装到此目录中,方便管理

将 mysql 移动到 /application 目录中,并保留 mysql 版本号

mv /home/yuci/tools/mysql-5.5.33-linux2.6-x86_64 ./mysql-5.5.33

clip_image024

为 mysql 创建软连接,方便管理

ln -s /application/mysql-5.5.33/ /application/mysql

clip_image026

创建 mysql 用户

useradd -s /sbin/nologin/ -M mysql

id mysql

clip_image028

初始化 mysql

/application/mysql/scripts/mysql_install_db --basedir=/application/mysql/ --datadir=/application/mysql/data/ --user=mysql

clip_image030

授权 mysql ,将其属主属组改为 mysql 用户

chown -R mysql:mysql /application/mysql

clip_image032

拷贝 mysql 配置文件,选取 small 就好

cp support-files/my-small.cnf /etc/my.cnf

clip_image034

修改 mysql 的启动脚本 mysqld_safe,因为 mysql 的默认安装路径在 /usr/local/mysql,但现在 mysql 在 /application 目录中,所以通过 sed 命令更改

sed -i 's#/usr/local/mysql#/application/mysql#g' /application/mysql/bin/mysqld_safe

clip_image036

启动 mysql ,通过启动脚本 mysql_safe,并放入后台执行

/application/mysql/bin/mysqld_safe &

clip_image038

通过端口检查 mysql 是否启动

lsof -i :3306

clip_image040

每次通过 mysqld_safe 启动比较麻烦,所以配置变量,通过修改 /etc/profile 实现即可

vim /etc/profile      

PATH="/application/mysql/bin:$PATH" 

source /etc/profile      # 刷新生效

clip_image042

clip_image044

拷贝 mysql 启动脚本,重命名为 mysqld 。

替换 mysql 启动脚本中的路径,将/usr/local/mysql 替换为 /application/mysql。

给 mysqld 这个脚本增加执行权限

cp support-files/mysql.server /etc/init.d/mysqld

sed -i 's#/usr/local/mysql#/application/mysql#g' /etc/init.d/mysqld

chmod +x /etc/init.d/mysqld

clip_image046

使用 killall 命令杀死正在运行的 mysql 服务,重复杀,直到出现 mysqld: no process killed 的提示

killall mysqld

clip_image048

启动 mysql,并检查

/etc/init.d/mysqld start

clip_image050

将 mysql 设为开机启动

chkconfig mysqld on

clip_image052

设置 mysql 的 root 密码为 123456,并登陆 mysql

mysqladmin -uroot password "123456"

mysql -uroot -p123456

clip_image054

五、编译安装 PHP-5.3.27

安装 PHP 太麻烦,先确定一下流程吧

1)确认nginx ,mysql服务已经启动

2)通过 yum 安装

       freetype-devel

       libjpeg-devel    # 因为版本升级的问题,yum 执行安装时是 libjpeg-devel ,但实际安装的是 libjpeg-turbo-devel

       libpng-devel

       gd

       gd-devel

       libcurl-devel

       libxslt-devel

3)编译安装 libiconv-1.14 介个软件,因为它无法通过 yum 成功安装

4)通过 wget 新下载一个 epel 源

5)安装 libmcrypt   libmcrypt-devel 包

6)安装 mhash 加密扩展库

7)安装 mcrypt 加密扩展库

8)编译安装 PHP-5.3.7

1

在安装 PHP 之前首先应该确认一下 nginx与mysql 服务都已经启动

lsof -i :80

lsof -i :3306

clip_image056

2

安装php需要的各种lib库文件,其中安装 gd-devel 时安装失败,同时安装 gd gd-devel 才安装上

yum -y install freetype-devel libjpeg-devel libpng-devel gd gd-devel libcurl-devel libxslt-devel

rpm -qa freetype-devel libjpeg-turbo-devel libpng-devel gd gd-devel libcurl-devel libxslt-devel

(libjpeg-devel == libjpeg-turbo-devel)

clip_image058

3

安装 libiconv,这个软件无法通过 yum 安装,只能编译安装了

解压软件 -> 切到其目录中 -> 执行命令,编译安装

tar zxf libiconv-1.14.tar.gz

cd libiconv-1.14

./configure --prefix=/usr/local/libiconv && make && make install

clip_image060

4

安装 epel 源,因为后面还要安装的 libmcrypt 库。介个库离不开介个源

wget -O /etc/yum.repos.d/epel.repo http://mirrors.aliyun.com/repo/epel-6.repo

clip_image062

5

安装 libmcrypt   libmcrypt-devel 包,并检查

yum -y install libmcrypt-devel    # 可以同时安装 libmcrypt   libmcrypt-devel

rpm -qa libmcrypt*

clip_image064

clip_image066

6)

安装 mhash 加密扩展库,并检查

yum -y install mhash mhash-devel

rpm -qa mhash mhash-devel

clip_image068

clip_image070

7

安装 mcrypt 加密扩展库,并检查

yum -y install mcrypt

rpm -qa mcrypt

clip_image072

clip_image074

8

编译安装 PHP-5.3.7,将 php 的安装包放到规定的 /home/yuci/tools 目录中

tar zxf php-5.3.27.tar.gz

cd php-5.3.27

clip_image076

创建文件,不创建 PHP 编译中会报错

touch ext/phar/phar.phar

clip_image078

创建一个软连接文件

ln -s /application/mysql/lib/libmysqlclient.so.18 /usr/lib64/

clip_image080

正式编译安装 PHP, 编译路径如下, PHP 目录下执行即可

./configure \

--prefix=/application/php5.3.27 \

--with-mysql=/application/mysql \

--with-iconv-dir=/usr/local/libiconv \

--with-freetype-dir \

--with-jpeg-dir \

--with-png-dir \

--with-zlib \

--with-libxml-dir=/usr \

--enable-xml \

--disable-rpath \

--enable-safe-mode \

--enable-bcmath \

--enable-shmop \

--enable-sysvsem \

--enable-inline-optimization \

--with-curl \

--with-curlwrappers \

--enable-mbregex \

--enable-fpm \

--enable-mbstring \

--with-mcrypt \

--with-gd \

--enable-gd-native-ttf \

--with-openssl \

--with-mhash \

--enable-pcntl \

--enable-sockets \

--with-xmlrpc \

--enable-zip \

--enable-soap \

--enable-short-tags \

--enable-zend-multibyte \

--enable-static \

--with-xsl \

--with-fpm-user=nginx \

--with-fpm-group=nginx \

--enable-ftp

make && make install

看到以下画面,说明安装成功,继续操作

clip_image082

给 php 创建一个软连接

ln -s /application/php5.3.27/ /application/php

clip_image084

配置 PHP 解析文件,php.ini

ls -l php.ini*

clip_image086

clip_image088

将配置文件复制到 php 安装目录,并改名为 php.ini

cp php.ini-production /application/php/lib/php.ini

clip_image090

php进程管理文件生效(php-fpm.conf 进程管理)

clip_image092

cp php-fpm.conf.default php-fpm.conf

clip_image094

启动 php-fpm,检查是否启动,查看 php-fpm 端口

/application/php/sbin/php-fpm

ps -ef | grep php-fpm

ss -lntup | grep php-fpm

clip_image096

六、编辑 nginx.conf 文件

将文件过滤,看着也方便,编辑如下

egrep -v "#|^$" nginx.conf.default > nginx.conf

clip_image098

检测 nginx与mysql nginx与php 是否相连

在此目录下分别创建 phpinifo.php,mysql.php 两个文件,文件内容如下

clip_image100

<?php

phpinfo();

?>

clip_image102

<?php

       $link_id=mysql_connect('localhost','root','123456') or mysql_error();

       if($link_id){

                echo "mysql successful by yuci.";

       }else{

                echo mysql_error();

       }

?>            

clip_image104

检查语法,平滑加载

/application/nginx/sbin/nginx -t

/application/nginx/sbin/nginx -s reload

clip_image106

浏览器中分别输入

192.168.6.36/phpinfo.php

192.168.6.36/mysql.php

clip_image108

clip_image110

七、安装 wordpress

wordpress 需要使用 mysql 的数据库,所以先来操作 mysql

首先登陆 mysql

clip_image112

创建 wordpress 同名的数据库,并检查

create database wordpress;

show databases; 

clip_image114

创建对 wordpress 用户和密码,并授予其权限,刷新生效

grant all on wordpress.* to wordpress@'localhost' identified by '123456';

flush privileges;

clip_image116

到此为止可以先在虚拟机中创建一个快照,方便后面的实验。

跟别会有一个基于 IP 地址的测试和基于 域名 的测试

七、安装 wordpress

将 wordpress 安装包复制到 /home/yuci/tools,并解压

tar zxf wordpress-4.2.2-zh_CN.tar.gz

clip_image118

切到 html 目录中,将解压的 wordpress 文件中的内容剪切过去,并赋予 html 目录下的所有文件 777 权限

cd /application/nginx/html

mv /home/yuci/tools/wordpress/* ./

chmod -R 777 ./

clip_image120

编辑 /application/nginx/conf/nginx.conf 文件,添加一个动态页面

cd /application/nginx/conf/

vim nginx.conf

clip_image122

clip_image124

clip_image126

/application/nginx/sbin/nginx -t

/application/nginx/sbin/nginx -s reload

clip_image128

在浏览器中输入IP地址,开始配置

根据提示,开始新建并配置 wp-config.php 文件

clip_image130

clip_image132

clip_image134

clip_image136

clip_image138

clip_image140

clip_image142

最后访问 IP 地址,成功访问博客

clip_image144

基于域名访问博客 blog.yuci.com

以为之前配置的基于 IP 地址访问的,所以先做好备份。

cd /application/nginx/conf/nginx.conf

cp nginx.conf nginx.conf.bak

编辑 /application/nginx/conf/nginx.conf 文件

vim nginx.conf

include    extra/blog.conf;

clip_image146

在 conf 目录中创建一个 extra 目录

mkdir extra

clip_image148

因为在 nginx.conf 文件中 include  指定了 extra/blog.conf 所以需要先创建 extra 目录,在创建 blog.conf 文件

查看之前的 nginx.conf 的备份文件 nginx.conf.bak,使用 sed 命令搞定 blog.conf 文件

sed -n '10,22p' nginx.conf.bak > extra/blog.conf

clip_image150

有基础需要改动,如下喽

clip_image152

解压 wordpress 安装包

tar zxf wordpress-4.2.2-zh_CN.tar.gz

clip_image154

blog.conf 中的选项 root  html ,所以先切到 html 目录中

mv /home/yuci/tools/wordpress/* ./

clip_image156

将 html 中的所有文件设置为 777,这样不安全应该是目录755文件644,但是实验就懒一下吧

clip_image158

chmod -R 777 extra/

clip_image160

重新检测,平滑加载

/application/nginx/sbin/nginx -t

/application/nginx/sbin/nginx -s reload

clip_image162

还需要在手动修改本机的 hosts 文件

clip_image164

输入 blog.yuci.com  OK了

clip_image166