CentOS6.7安装部署LNMP(nginx1.8.0+php5.6.10+mysql5.6.12)

IP-10.0.0.8

1.安装nginx

mkdir -p /server/tools
cd /server/tools
yum install -y pcre pcre-devel openssl openssl-devel gcc gcc+
wget http://nginx.org/download/nginx-1.8.0.tar.gz
useradd www -M -s /sbin/nologin
tar xf nginx-1.8.0.tar.gz
cd nginx-1.8.0/
sed -i "179s/#//" auto/cc/gcc
mkdir /application
./configure --prefix=/application/nginx-1.8.0 --user=www 
--group=www --with-http_stub_status_module --with-http_ssl_module
make && make install
ln -s /application/nginx-1.8.0/ /application/nginx
# Centos7采用yum方式安装nginx
rpm -Uvh http://nginx.org/packages/centos/7/noarch/RPMS/nginx-release-centos-7-0.el7.ngx.noarch.rpm
yum -y install nginx
systemctl start nginx.service

2.安装php

yum -y install zlib-devel libxml2-devel libjpeg-devel libjpeg-turbo-devel
libpng-devel freetype-devel libcurl-devel gd-devel libxslt-devel 
mhash mcrypt libmcrypt libmcrypt-devel  
# libiconv-devel没有这包
cd /server/tools/
wget http://ftp.gnu.org/pub/gnu/libiconv/libiconv-1.14.tar.gz
tar xf libiconv-1.14.tar.gz
cd libiconv-1.14/
./configure --prefix=/usr/local/libiconv
make && make install
# PHP的编译参数
cd /server/tools/
wget http://cn2.php.net/distributions/php-5.6.10.tar.gz
tar -zxvf php-5.6.10.tar.gz
cd php-5.6.10
./configure --prefix=/opt/php --with-mysql 
--with-mysqli=mysqlnd --with-pdo-mysql=mysqlnd 
--with-iconv-dir=/usr/local/libiconv  --with-zlib 
--with-libxml-dir --enable-xml --with-curl --enable-fpm 
--enable-mbstring --with-gd --with-openssl --with-mhash 
--enable-sockets --with-xmlrpc --enable-zip --enable-soap 
--with-libdir=/usr/lib64 --with-jpeg-dir=/usr/lib64 
--with-freetype-dir=/usr/lib64 --with-png-dir=/usr/lib64 
--with-xsl --with-fpm-user=www --with-fpm-group=www
make
make install clean

3.解决问题

# 安装MySQL参考上一篇博文
# 解决缺少共享库的问题,两种方法(先用find查到这个库的位置):
vi /etc/ld.so.conf
/opt/mysql-5.6.21/libmysql/
ldconfig  # 生效
ln -s /opt/mysql-5.6.21/libmysql/libmysqlclient.so.18 /usr/lib64/
# 如果make的时候报:ext/phar/phar.phar没有这个文件
cd php-5.6.10
touch ext/phar/phar.phar
# 本机没有安装mysql时,可以使用下面的参数
--enable-mysqlnd
--with-mysqli=mysqlnd
--with-pdo-mysql=mysqlnd
# 配置并启动php-fpm
cp php.ini-production /opt/php/lib/php.ini
cd /opt/php/etc/
cp php-fpm.conf.default php-fpm.conf
cd /server/tools/php-5.6.10/sapi/fpm/
cp init.d.php-fpm /etc/init.d/php-fpm
chmod +x /etc/init.d/php-fpm
service php-fpm start # 或者/opt/php/sbin/php-fpm

cat blog.conf
server {
    listen       80;
    server_name  blog.etiantian.com;
    location / {
        root html/blog;
        index index.php index.html;
    }
    location ~.*.(php|php5)?$ {
        root html/blog;
        fastcgi_pass 127.0.0.1:9000;
        fastcgi_index index.php;
        include fastcgi.conf;
    }
}
/application/nginx/sbin/nginx -s reload
mkdir /application/nginx/html/blog/
echo "<?php phpinfo(); ?>" > /application/nginx/html/blog/test.php
# 连接数据库测试
cat /application/nginx/html/blog/conn_mysql.php
<?php
	$con = mysql_connect("localhost","root","root123") or mysql_error();
	if ($con){
		echo "connect mysql successfully";
	}
	else{
		echo mysql_error();  
	}
?>

4.搭建WordPress博客

create database wordpress;
grant all on wordpress.* to wordpress@'localhost' identified by '123456';
show grants for wordpress@'localhost'G;
# 如果授权授大了,在user表中删除用户是不行的,得drop然后重新授权
drop user wordpress@'localhost';
# revoke貌似不太好使
revoke all on *.* from wordpress@localhost;

wget https://cn.wordpress.org/wordpress-4.5.1-zh_CN.tar.gz
cp -a wordpress/* /application/nginx/html/blog/
# 这个权限是为了让先能用,以后还要改
chown -R www.www /application/nginx/html/blog/
# 现在blog目录下的文件有22个,安装后会多出一个配置文件
# 访问blog.etiantian.com,点击安装,会生成一个连接数据库的配置文件--wp-config.php
# 图片上传目录为:/application/nginx/html/blog/wp-content/uploads

5.分离数据库

# 导出wordpress数据并修改连接数据库的文件(web01上)
vi wp-config.php
define('DB_HOST', '172.16.1.51');
mysqldump -uroot -poldboy123456 wordpress -B | gzip > bak.sql.gz
# 导入数据(db01上)
mysql -uroot -poldboy123456 < /tmp/bak.sql
grant all on wordpress.* to wordpress@'172.16.1.%' identified by '123456';
# 在其他服务器上就能以这样的语句访问51的数据库了
mysql -u wordpress -h 172.16.1.51 -p

6.静态图片放在nfs上

# 10.0.0.31是之前的NFS服务器,在10.0.0.31上创建用户,与10.0.0.8上的www的id相同
useradd -u 891 www
vi /etc/exports
/data 172.16.1.0/24(rw,sync,all_squash,root_squash,anonuid=891,anongid=891)
mkdir /data/nfs-blog
chown -R www.www /data/
# 在web01上操作
rpm -qa rpcbind nfs-utils
/etc/init.d/rpcbind status
cd /application/nginx/html/blog/wp-content/uploads
mv 2018 /tmp/
mount -t nfs 172.16.1.31:/data/nfs-blog /application/nginx/html/blog/wp-content/uploads/
cp -a /tmp/2018/ .
排错:
touch: cannot touch `aaa': Permission denied
# 挂载完之后,无法创建文件,是因为在/etc/exports中将anonuid写成了893,
# 在改成891之后,还是无法写入,重启客户端rpcbind之后,可以正常写入.

7.wordpress实现伪静态

管理站点-设置-固定链接-自定义结构:
/archives/%post_id%.html
文章的url就会变成这样的形式:
http://blog.etiantian.com/archives/9.html

cat blog.conf
server {
    listen       80;
    server_name  blog.etiantian.com;
    location / {
        root html/blog;
        index index.php index.html;
        try_files $uri $uri/ /index.php?$args;
    }
    location ~ .*.(php|php5)?$ {
        root html/blog;
        fastcgi_pass 127.0.0.1:9000;
        fastcgi_index index.php;
        include fastcgi.conf;
    }

}
原文地址:https://www.cnblogs.com/fawaikuangtu123/p/10168821.html