nginx-blog

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群版 2核4GB 100GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介: nginx-blog

搭建lnmp平台

1、安装Nginx(192.168.8.10):

使用Nginx官方提供的rpm包
vim  /etc/yum.repos.d/nginx.repo
[nginx]
name=nginx repo
baseurl=http://nginx.org/packages/centos/7/$basearch/
gpgcheck=0
enabled=1
执行yum安装
yum install nginx -y
systemctl start nginx
systemctl enable nginx

2、使用第三方扩展epel源安装PHP7:

第一种方法:

rpm -Uvh epel-release
rpm -Uvh https://mirror.webtatic.com/yum/el7/webtatic-release.rpm
yum install -y php72w php72w-opcache php72w-xml php72w-mcrypt php72w-gd php72w-devel \
    php72w-mysql php72w-intl php72w-mbstring
systemctl start php-fpm 

第二种方法:

yum -y install http://rpms.remirepo.net/enterprise/remi-release-7.rpm
安装 php73 版本
yum -y install  php73-php-fpm  php73-php-cli  php73-php-bcmath  php73-php-gd \
 php73-php-json  php73-php-mbstring  php73-php-mcrypt  php73-php-mysqlnd  \ 
 php73-php-opcache  php73-php-pdo  php73-php-pecl-crypto  php73-php-pecl-mcrypt \
 php73-php-pecl-geoip  php73-php-recode  php73-php-snmp  php73-php-soap  php73-php-xmll
启动 php
systemctl restart php73-php-fpm
注:因为网速问题,直接复制php-rpm包本地安装
    cd php-rpm 
    yum -y localinstall *.rpm 
    systemctl start php-fpm 
    systemctl enable php-fpm 

3、安装mysql(mariadb):

rpm -ivh http://repo.mysql.com/yum/mysql-5.6-community/el/7/x86_64/mysql-community-release-el7-5.noarch.rpm
yum install mysql-community-server -y
systemctl start mysqld
systemctl enable mysqld
修改mysql密码:mysql_secure_installation 

4.应用1:搭建wordpress

(1)下载wordpress源码包

(2)复制wordpress安装包,到虚拟机/,解压并赋权

   unzip wordpress-4.9.4-zh_CN.zip

   chmod -R 777 /wordpress

 

(3)创建虚拟主机配置文件

   vim /etc/nginx/conf.d/blog.conf

   添加:

   server {

       listen 80;

       server_name blog.benet.com;

       root /wordpress;

       index index.php index.html;


       location ~ \.php$ {

               root /wordpress;

               fastcgi_pass 127.0.0.1:9000;

               fastcgi_index index.php;

               fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;

               include fastcgi_params;

       }

   }

   保存退出

   systemctl reload nginx

(4)创建blog数据库和管理用户

   登录数据库:mysql -uroot -p123.com

   创建数据库:create database blog;

   设置管理用户及密码:grant all on blog.* to lisi@localhost identified by '123.com';

 

(5)客户端通过域名访问blog,安装并配置

  http://blog.benet.com

    登录后台

  http://blog.benet.com/wp-admin


5.应用2:搭建知乎wecenter


(1)下载wecenter源码包

(2)复制wecenter安装包,到虚拟机/zh目录下,赋权,并复制/zh目录到php服务器

   cd /zh

   unzip wecenter_3-3-4.zip

   chmod -R 777 /zh

 

(3)创建虚拟主机配置文件

   vim /etc/nginx/conf.d/zh.conf

   添加:

   server {

       listen 80;

       server_name zh.benet.com;

       root /zh;

       index index.php index.html;


       location ~ \.php$ {

               root /zh;

               fastcgi_pass 127.0.0.1:9000;

               fastcgi_index index.php;

               fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;

               include fastcgi_params;

       }

   }

   保存退出

   systemctl reload nginx

(4)创建blog数据库和管理用户

   登录数据库:mysql -uroot -p123.com

   创建数据库:create database zh;

   设置管理用户及密码:grant all on zh.* to wangwu@localhost identified by '123.com';

 

(5)客户端通过域名访问zh,安装并配置

  http://zh.benet.com

     登录后台

  http://zh.benet.com/?/admin


===================================================================

nginx: 192.168.8.10

mysql: 192.168.8.20

php:   192.168.8.30



1.lnmp实现mysql数据库迁移(192.168.8.10)

   为了实现mysql独立运行,拆分lnmp

(1)另起一台centos7(192.168.8.20),安装mysql

   rpm -ivh http://repo.mysql.com/yum/mysql-5.6-community/el/7/x86_64/mysql-community-release-el7-5.noarch.rpm

   yum install mysql-community-server -y

   systemctl start mysqld

   systemctl enable mysqld

   修改mysql密码:mysql_secure_installation

(2)把原lnmp服务器(192.168.8.10)上的数据库文件导出,并复制到新的mysql(192.168.8.20)上

   mysqldump -uroot -p123.com  --all-databases > mysql-all.sql

   scp mysql-all.sql root@192.168.8.20:/root


(3)在新的mysql服务器(192.168.8.20)上导入数据库文件

   mysql -uroot -p123.com < /root/mysql-all.sql

   systemctl restart mysqld


(4)在新mysql服务器上创建同名管理用户和密码

   mysql -uroot -p123.com         #登录

   grant all on blog.* to lisi@'%' identified by '123.com';

   grant all on zh.* to wangwu@'%' identified by '123.com';

     

(5)在原服务器上修改blog、zh的配置文件,重新指定数据库服务器ip

   先查看blog的配置位置:

       cd /wordpress        #切换到blog网页根目录

       grep -R 123.com        #搜索保存密码的配置文件位置

       vim /wordpress/wp-config.php

       修改:

       define('DB_NAME', 'blog');            #WordPress数据库的名称

       define('DB_USER', 'lisi');            #MySQL数据库用户名

       define('DB_PASSWORD', '123.com');    #MySQL数据库密码

       define('DB_HOST', '192.168.8.20');    #新MySQL主机ip

       保存退出

 

   先查看zh的配置文件位置:

       cd /zh

       grep -R 123.com

       vim /zh/system/config/database.php

       修改:

       'host' => '192.168.8.20',            #新MySQL主机ip

       'username' => 'wangwu',                #MySQL数据库用户名

       'password' => '123.com',            #MySQL数据库密码

       'dbname' => 'zh',                    #zh数据库的名称

       保存退出


2.拆分php(192.168.8.30)

(1)启动一台centos7,安装php

   rpm -Uvh https://dl.fedoraproject.org/pub/epel/epel-release-latest-7.noarch.rpm

   rpm -Uvh https://mirror.webtatic.com/yum/el7/webtatic-release.rpm

   yum -y install php72w php72w-cli php72w-common php72w-devel php72w-embedded php72w-gd php72w-mbstring php72w-pdo php72w-xml php72w-fpm php72w-mysqlnd php72w-opcache

 

(2)修改nginx服务器上的配置文件,重新指向新的php服务器(zh步骤相同)

vim /etc/nginx/conf.d/blog.conf

修改为:

server {

       listen 80;

       server_name blog.benet.com;

       root /wordpress;

       index index.php index.html;


       location ~ \.php$ {

               root /wordpress;

               fastcgi_pass 192.168.8.30:9000;

               fastcgi_index index.php;

               fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;

               include fastcgi_params;

       }

}

保存退出

systemctl restart nginx


(3)修改php服务器的配置文件

vim /etc/php-fpm.d/www.conf

定位并修改为:

listen = 192.168.8.30:9000

listen.allowed_clients = 192.168.8.10

保存退出

重启php:systemctl restart php-fpm


(4)从原服务器复制wordpress和zh的安装目录到php服务器

   scp -rp /wordpress root@192.168.8.30:/

   scp -rp /zh root@192.168.8.30:/


(5)客户端验证访问


相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
3月前
|
开发框架 .NET 应用服务中间件
LNMP详解(六)——Nginx location语法详解
LNMP详解(六)——Nginx location语法详解
34 1
|
12月前
|
Cloud Native 应用服务中间件 网络安全
15.1k Star! 一个不用会 Nginx 的反向代理神器 - Nginx Proxy Manager
应用简览 Nginx Proxy Manager 是一个开源的反向代理工具,不需要了解太多 Nginx 或 Letsencrypt 的相关知识,即可快速将你的服务暴露到外部环境,并且支持 SSL 配置。
328 0
|
3月前
|
负载均衡 算法 前端开发
Nginx笔记
Nginx笔记
33 1
|
10月前
|
应用服务中间件 nginx
nginx详细笔记
nginx详细笔记
|
11月前
|
关系型数据库 MySQL 应用服务中间件
nginx-blog
nginx-blog
43 0
|
12月前
|
关系型数据库 MySQL PHP
nginx-blog、zh
nginx-blog、zh
65 0
|
关系型数据库 MySQL 应用服务中间件
nginx搭建blog
nginx搭建blog
88 0
|
应用服务中间件 Linux nginx
【nginx】user nginx; 是干什么的?底层原理是什么?
【nginx】user nginx; 是干什么的?底层原理是什么?
1499 0
|
负载均衡 算法 安全
Nginx教程(1)
Nginx教程(1)
112 0
|
应用服务中间件 nginx
Nginx教程(2)
Nginx教程(2)
121 0
Nginx教程(2)