LNMP博客以及数据库分离搭建实战

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了LNMP博客以及数据库分离搭建实战相关的知识,希望对你有一定的参考价值。

nginx搭建命令

cd /home/oldboy/tools 安装存放软件包路径

yum install openssl openssl-devel -y 安装Nginx所需的库、和加密协议 

yum install pcre pcre-devel -y 安装Nginx所需的库、和加密协议

rpm -qa openssl-devel pcre-devel  openssl openssl-devel 检查是否安装好

wget -q http://nginx.org/download/nginx-1.6.3.tar.gz 下载软件包

useradd www -s /sbin/nologin -M  创建用户

tar xf nginx-1.6.3.tar.gz 解压软件

cd nginx-1.6.3

./configure --user=www --group=www --with-http_ssl_module --with-http_stub_status_module --prefix=/application/nginx-1.6.3/ 编译安装

make 

make install

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

/application/nginx/sbin/nginx 开启服务

ps -ef|grep nginx 检查

创建网页目录

[[email protected] html]# mkdir {www,bbs,blog} -p

[[email protected] www]# echo "www.etiantian.org" >index.html


修改主配置文件

添加access日志及虚拟主机目录

    log_format  main  ‘$remote_addr - $remote_user [$time_local] "$request" ‘

                       ‘$status $body_bytes_sent "$http_referer" ‘

                       ‘"$http_user_agent" "$http_x_forwarded_for"‘;


#nginx vhosts config

    include extra/www.conf;

    include extra/bbs.conf;

    include extra/blog.conf;



创建存放虚拟主机的目录

[[email protected] conf]# mkdir extra

[[email protected] extra]# touch www.conf

[[email protected] extra]# touch bbs.conf

[[email protected] extra]# touch blog.conf

修改每个虚拟主机的conf目录

   server {

        listen       80;

        server_name  www.etiantian.org etiantian.org;

        location / {

            root   html/www;

            index  index.html index.htm;

        }

        access_log logs/access_www.log main;

        }


设置开机启动

[[email protected] oldboy]# echo "/application/nginx/sbin/nginx " >>/etc/rc.local 

[[email protected] oldboy]# tail -1 /etc/rc.local

/application/nginx/sbin/nginx 




mysql搭建命令

安装MySQL

上传MySQL  

ls mysql-5.5.49-linux2.6-x86_64.tar.gz 

tar xf mysql-5.5.49-linux2.6-x86_64.tar.gz

mkdir /application -p 

mv mysql-5.5.49-linux2.6-x86_64 /application/mysql-5.5.49 

ln -s /application/mysql-5.5.49 /application/mysql 

useradd mysql -s /sbin/nologin -M 创建用户和授权目录

chown -R mysql.mysql /application/mysql/ 创建用户和授权目录

cd /application/mysql 

./scripts/mysql_install_db --user=mysql --basedir=/application/mysql --datadir=/application/mysql/data/ 初始化时数据库

ll data/

\cp support-files/my-small.cnf  /etc/my.cnf 创建基本需求

cp support-files/mysql.server /etc/init.d/mysqld 创建基本需求

chmod +x /etc/init.d/mysqld  给执行权限

sed -i ‘s#/usr/local/mysql#/application/mysql#g‘ /application/mysql/bin/mysqld_safe /etc/init.d/mysqld 修改配置文件

/etc/init.d/mysqld start 开启服务、

netstat -lntup|grep mysql 检查

echo "PATH="/application/mysql/bin:$PATH"" >>/etc/profile

chkconfig --add mysqld 开启服务

chkconfig mysqld on 开启服务

cp -a /application/mysql/bin/* /usr/local/sbin/ 

ln -s /application/mysql/bin/* /usr/local/sbin/

mysql 



1、安装php基础库

yum install zlib-devel libxml2-devel libjpeg-devel libjpeg-turbo-devel libiconv-devel -y

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

rpm -qa zlib-devel libxml2-devel libjpeg-devel libjpeg-turbo-devel libiconv-devel freetype-devel libpng-devel gd-devel libcurl-devel libxslt-devel

需要先安装支持的软件包

cd /home/oldboy/tools 

wget http://ftp.gnu.org/pub/gnu/libiconv/libiconv-1.14.tar.gz

tar zxf libiconv-1.14.tar.gz

cd libiconv-1.14

./configure --prefix=/usr/local/libiconv

make

make install

cd ../


2、PHP相关扩展库

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

yum -y install libmcrypt-devel

yum -y install mhash

yum -y install mcrypt

rpm -qa libmcrypt-devel mhash mcrypt


解压php安装包,编辑

上传PHP包

tar xf php-5.5.32.tar.gz 解压php安装包

./configure \

--prefix=/application/php5.5.32 \

--with-mysql=/application/mysql/ \

--with-pdo-mysql=mysqlnd \

--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-bcmath \

--enable-shmop \

--enable-sysvsem \

--enable-inline-optimization \

--with-curl \

--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-soap \

--enable-short-tags \

--enable-static \

--with-xsl \

--with-fpm-user=www \

--with-fpm-group=www \

--enable-ftp \

--enable-opcache=no



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

touch ext/phar/phar.phar


make

make install

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

ls /application/php/

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

配置php解析文件

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

配置php-fpm配置文件

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

启动php-fpm

/application/php/sbin/php-fpm 

lsof -i :9000

ps -ef|grep php-fpm


[email protected] extra]# cat blog.conf       

    server {

        listen       80;

        server_name  blog.etiantian.org;

        location / {

            root   html/blog;

            index  index.html index.htm;

        }

        location ~ .*\.(php|php5)?$ {

            root html/blog;

            fastcgi_pass  127.0.0.1:9000;

            fastcgi_index index.php;

            include fastcgi.conf;

        }

    }

[[email protected] extra]# ../../sbin/nginx  -t

nginx: the configuration file /application/nginx-1.6.3//conf/nginx.conf syntax is ok

nginx: configuration file /application/nginx-1.6.3//conf/nginx.conf test is successful

[[email protected] extra]# ../../sbin/nginx  -s reload

[[email protected] blog]# cat test_mysql.php 

<?php

        $link_id=mysql_connect(‘localhost‘,‘root‘,‘oldboy123‘) or mysql_error();

        if($link_id){

                echo "mysql successful by oldboy !";

        }else{

                echo mysql_error();

        }

?>




搭建blog命令

mysql -uroot -poldboy123

create database wordpress;

show databases;

grant all on wordpress.* to [email protected]‘localhost‘ identified by ‘123456‘;

select user,host from mysql.user;

show grants for [email protected]‘localhost‘;

flush privileges;


下载博客安装

 wget https://cn.wordpress.org/wordpress-4.5.1-zh_CN.tar.gz

  ll

 tar xf wordpress-4.5.1-zh_CN.tar.gz 

 ls wordpress

 cp -a wordpress/* /application/nginx/html/blog/

 ls /application/nginx/html/blog/

 chown -R www.www /application/nginx/html/blog/

 ls /application/nginx/html/blog/

 ls /application/nginx/html/blog/ -l

 history 



分离命令

wed命令

mysqldump -uroot -poldboy123 wordpress -B |gzip>bak.sql.gz

scp bak.sql.gz  [email protected]:/tmp


数据库MySQL命令

cd /tmp

gzip xf bak.sql.tar.gz

mysql -uroot -poldboy123 -e "show databases like ‘wordpress‘;"

mysql -uroot -poldboy123 -e "use wordpress;show tables;"

mysql -uroot -poldboy123

grant all on wordpress.* to [email protected]‘172.16.1.%‘ identified by ‘123456‘;

flush privileges;

select user,host from mysql.user;



更改.8配置文件 wp-config.php

32 define(‘DB_HOST‘, ‘172.16.1.51‘);

关闭本地数据库

/etc/init.d/mysqld stop

chkconfig mysqld off

成功。


2、将blog的资源文件迁移到NFS

[[email protected] blog]# tree wp-content/uploads/

资源目录为:wp-content/uploads/


nfs命令

echo "/uploads 172.16.1.0/24(rw,sync)" /etc/exports

MySQL数据库命令

mount -t nfs  172.16.1.31:/uploads /application/nginx/html/blog/




根据老男孩老师的讲解,和实际操作搭建出来
















本文出自 “11255195” 博客,请务必保留此出处http://11265195.blog.51cto.com/11255195/1774901

以上是关于LNMP博客以及数据库分离搭建实战的主要内容,如果未能解决你的问题,请参考以下文章

安装PHP以及搭建博客服务迁移分离

0537-实战将lnmp服务中的数据库独立分离到服务器

部署LNMP动静分离并搭建memcache缓存服务器

部署LNMP动静分离并搭建memcache缓存服务器

LNMP平台搭建网站实战案例

linux入门系列20--Web服务之LNMP架构实战