LNMP/LEMP项目搭建
{
    项目框架        # Linux_____WEB_____PHP_____DB
            # rhel7_____apache__-(libphp5.so)-__php__-(php-mysql)-__mariadb-server
            # rhel7_____nginx___-(spawn-fcgi)-__php__-(php-mysql)-__mariadb-server
    安装软件包    # WEB 程序
            # CGI 管理器    @作用     ()监听9000端口 ()调用Php命令
                    @软件    spawn-fcgi
            # php 程序    php
            # 数据库程序    mariadb-server
            # php-db驱动     php-mysql
    配置nginx    # /etc/nginx/conf.d/
    配置spawn-fcgi     # /etc/sysconfig/spawn-fcgi
    配置mariadb-server
    创建数据文件    # 成品的php网站
    测试
}

LNMP/LEMP项目搭建 实验
{
[root@serverb ~]# mount 172.25.254.250:/content /mnt
[root@serverb ~]# rpm -ivh /mnt/item/nginx/other/nginx--.el7.ngx.x86_64.rpm
[root@serverb ~]# rpm -ivh /mnt/item/nginx/epel/spawn-fcgi--.el7.x86_64.rpm
[root@serverb ~]# yum install -y php mariadb-server php-mysql
[root@serverb ~]# cd /etc/nginx/conf.d/
[root@serverb conf.d]# cp default.conf www.bbs.com.conf
[root@serverb conf.d]# vim www.bbs.com.conf
server {
    listen ;
    server_name    www.bbs.com;
    root /usr/share/nginx/bbs.com;
    index index.php index.html index.htm;
    location ~ \.php$ {
    fastcgi_pass ;
    fastcgi_index index.php;
    fastcgi_param SCRIPT_FILENAME /usr/share/nginx/bbs.com$fastcgi_script_name;
    include fastcgi_params;
    }
    }
[root@serverb conf.d]# mkdir /usr/share/nginx/bbs.com
[root@serverb conf.d]# systemctl restart nginx.service
[root@serverb conf.d]# vim /etc/sysconfig/spawn-fcgi
OPTIONS="-u nginx -g nginx -p 9000 -C 32 -F 1 -P /var/run/spawn-fcgi.pid -- /usr/bin/php-cgi"
[root@serverb conf.d]# systemctl start spawn-fcgi
[root@serverb conf.d]# /sbin/chkconfig spawn-fcgi on
[root@serverb conf.d]# systemctl enable mariadb.service
[root@serverb conf.d]# systemctl start mariadb.service
[root@serverb conf.d]# mysqladmin -u root password "uplooking"
[root@serverb php]# cp Discuz_X3.2_SC_UTF8.zip /tmp/
[root@serverb php]# cd /tmp/
[root@serverb tmp]# unzip Discuz_X3.2_SC_UTF8.zip
[root@serverb tmp]# cp -r upload/* /usr/share/nginx/bbs.com/
[root@serverb tmp]# chown nginx /usr/share/nginx/bbs.com/ -R
[root@workstation ~]# echo 172.25.15.10 www.bbs.com >> /etc/hosts
}

项目迁移
{
    迁移优先级    #数据库>其他软件
    迁移的流程{
            .程序的迁移
            .配置文件的迁移
            .数据文件的备份与迁移
            .地址的修改
            .权限的修改
    }
}

LNMP项目迁移
{
    迁移优先级    #数据库>php php-mysql spawn-fcgi
    迁移的流程{
            .程序的迁移
            .配置文件的迁移
            .数据文件的备份与迁移
            .地址的修改
            .权限的修改
    }
    数据库迁移
    php相关程序的迁移    

}

数据库迁移
{
旧机器上的操作{
        >备份数据文件并拷贝至新机器
        >修改配置文件中的地址 (此处的配置文件不是数据库配置文件,而是使用数据库的程序的配置文件)

            }
新机器上的操作{
        >安装程序并启动服务
        >导入旧机器上的数据文件
        >修改程序的权限
        }
}

项目迁移实验
{
    .数据库迁移实验         #实验目的:随着网站用户的增多,数据量越来越大,数据库需要扩容,现在想将数据库单独放在一台服务器上来解决数据库容量不足的问题
                #实验要求:将数据库从serverb-->serverj
    .LNMP项目迁移实验    #实验目的:原本的LNMP服务所在的服务器老化了,现在公司新买了两台服务器,要将LNMP服务迁移到新服务器上;数据库单独放在一台服务器上;php相关程序放在一台服务器上
                #实验要求:数据库serverb-->serverj;php相关程序serverb-->serverc
    .LNMP项目迁移并配置第二个php服务实验
                #实验要求:原本的LNMP服务所在的服务器老化了,现在公司新买了三台服务器,要将LNMP服务迁移到新服务器上;数据库单独放在一台服务器上;还有两台,配置两个php服务

}
具体实验请去实验论坛
数据库迁移详 实验
{
#实验目的:随着网站用户的增多,数据量越来越大,数据库需要扩容,现在想将数据库单独放在一台服务器上来解决数据库容量不足的问题
#实验要求:将数据库从serverb-->serverj
#实验步骤:
========================================================================
serverb{
    #数据库备份
    mysqldump --all-databases -uroot -puplooking > /tmp/mariadb.all.sql <--将数据库文件备份并导出到/tmp/mariadb.all.sql文件中
    #复制到serveri中
    scp /tmp/mariadb.all.sql serveri:/tmp
    #地址的修改<==在/usr/share/nginx/bbs.com/目录中循环找到以.php结尾的文件,在文件中找到uplooking关键字的所在行,但是不输出(-q),而是输出该文件的文件名。此处uplooking是数据库的密码,请根据实际情况做修改。
    cd /usr/share/nginx/bbs.com;for i in $(find ./ -name "*.php");do grep -q "uplooking" $i && echo $i;done
    vim xxx.php
    #将找到的文件进行修改,将localhost改为数据库所在的服务器的ip地址
    #define('UC_DBHOST', 'localhost');         

    }

serverj{
    #安装mariadb-server 注意版本 安装相同版本的数据包
    yum install -y mariadb-server
    #开启服务,并设置开机服务自启
    systemctl enable mariadb;systemctl start mariadb
    #查看数据库文件是否复制成功
    ll /tmp/mariadb.all.sql
    #导入数据库文件
    mysql < /tmp/mariadb.all.sql
    #授权serverb的spawn-fcgi访问数据库
    #>授权ip地址
    echo "grant all on bbs.* to root@'192.168.0.11' identified by 'uplooking';" | mysql-u root -p uplooking
    #>授权主机名
    echo "grant all on bbs.* to root@'serverb.pod15.example.com' identified by 'uplooking';" | mysql -uuroot -puplooking
    #更新授权表 mysqladmin -uroot -puplooking flush-privileges
    }
--------------------------------------------------------------------------
#测试
serverb{
    #关闭数据库服务
    systemctl stop mariadb
}
workstation{
    #通过浏览器登陆www.bbs.com
    firefox
}
#问题和答案
#-u root 不能有空格;-p uplooking 不能有空格
    mysqldump --all-databases -uroot -puplooking > /tmp/mariadb.all.sql
#find搜索*.php必须用双引号
find ./ -name "*.php"

#mysql登陆方式
    mysql -uroot -puplooking
    mysql -u root -p 回车
    输入密码
#*.*是指什么目录下的所有文件呢?
    echo "grant all on *.* to root@'192.168.0.11' identifide by 'uplooking';" | mysql -uroot -puplooking
    /var/lib/mysql

}

LNMP项目迁移实验
{
#实验目的:原本的LNMP服务所在的服务器老化了,现在公司新买了两台服务器,要将LNMP服务迁移到新服务器上;数据库单独放在一台服务器上;php相关程序放在一台服务器上
#实验要求:数据库serverb-->serverj;php相关程序serverb-->serverc
#实验步骤:
===============================================================
#第一步——数据库迁移(serverb-->serverj)
serverb{
    #数据库备份
    mysqldump --all-databases -uroot -puplooking > /tmp/mariadb.all.sql <--将数据库文件备份并导出到/tmp/mariadb.all.sql文件中
    #复制到serveri中
    scp /tmp/mariadb.all.sql serveri:/tmp
    #地址的修改<==在/usr/share/nginx/bbs.com/目录中循环找到以.php结尾的文件,在文件中找到uplooking关键字的所在行,但是不输出(-q),而是输出该文件的文件名。此处uplooking是数据库的密码,请根据实际情况做修改。
    cd /usr/share/nginx/bbs.com;for i in $(find ./ -name "*.php");do grep -q "uplooking" $i && echo $i;done
    #将找到的文件进行修改,修改server_name,为数据库所在的服务器的ip地址
    vim xxx.php
    }

serverj{
    #安装mariadb-server 注意版本 安装相同版本的数据包
    yum install -y mariadb-server
    #开启服务,并设置开机服务自启
    systemctl enable mariadb;systemctl start mariadb
    #设置数据库密码
    mysqladmin -u root password 'uplooking'
    #查看数据库文件是否复制成功
    ll /tmp/mariadb.all.sql
    #导入数据库文件
    mysql < /tmp/mariadb.all.sql
    #授权serverb的spawn-fcgi访问数据库
    #>授权ip地址
    echo "grant all on *.* to root@'192.168.0.11' identified by 'uplooking';" | mysql -uroot -puplooking
    #>授权主机名
    echo "grant all on *.* to root@'serverb.pod15.example.com' identified by 'uplooking';" | mysql -uroot -puplooking
    #更新授权表 mysqladmin -uroot -puplooking flush-privileges
    }
}
---------------------------------------------------------------------------
#第二步——php相关程序的迁移 (serverb-->serverc)

serverb{
    #操作数据(偷懒的做法,直接将文件复制过去即可)
    scp /etc/sysconfig/spawn-fcgi serverc:/etc/sysconfig/spawn-fcgi
     #将serverb中的php相关文件转移到 serverc中 (需要相同的目录,最好用tar命令打包复制到serverc中)
    tar -cjf bbs.tar.bz2 /usr/share/nginx/bbs.com; scp bbs.tar.bz2 serverc:/usr/share/nginx/bbs.com
    #地址修改
     serverb 中的/etc/nginx/conf.d 目录下配置文件中关于php的配置的php指向改为 serverc的地址
       location ~ \.php$ {
            fastcgi_pass   ;(改为servec的地址)
            fastcgi_index  index.php;
            fastcgi_param  SCRIPT_FILENAME  /usr/share/nginx/yeliangcheng.com$fastcgi_script_name;
            include        fastcgi_params;
                   }

    }

serverc{
    #迁移程序--安装相同的软件包
    php php-mysql /mnt/item/nginx/epel/spawn-fcgi--.el7.x86_64.rpm
    #启动服务并设置开机自启
    systemctl start spawn-fcgi; /sbin/chkconfig spawn-fcgi on
    #php相关文件
    tar -jxf /usr/share/nginx/bbs.com/bbs.tar.bz2
    }
===================================================================================
#测试
serverb{
    #关闭数据库服务
    systemctl stop mariadb
    #关闭spawn-fcgi服务
    systemctl stop spawn-fcgi
    /sbin/chkconfig spawn-fcgi off
    }
workstation{
    #通过浏览器登陆www.bbs.com
    firefox
    }
#问题和解决

}

零基础学习云计算及大数据DBA集群架构师【企业级运维技术及实践项目2015年1月29日周五】的更多相关文章

  1. 零基础学习云计算及大数据DBA集群架构师【Linux系统环境及权限管理12.21-12.25】

    从这周开始Linux的学习,老师是一位女老师,这到给了更多的信心,老师讲得很快,如果说只谈记命令的话是不多,但是要真正去理解,其实内容还是挺多的,我都是以老师讲的内容为主线,然后自己再看鸟哥的书做加深 ...

  2. 零基础学习云计算及大数据DBA集群架构师【Linux系统配置及网络配置2015年12月30日周三】

    /Mon *************摘要************** 计划任务 )一次性计划任务 服务:atd 命令:at 服务存放文件:/etc/init.d/atd 系统配置文件:/etc/at. ...

  3. 零基础学习云计算及大数据DBA集群架构师【Linux Bash Shell编程及系统自动化2015年1月21日周四】

    lvy老师教项目课程,以及代课了shell部分课程,大家都觉得这位老师不行,上课时做的操作很多都是错误的,觉得她基础不好.而且,她不能解释原因,学生问为什么,她不知道.崩溃啊.向xx培训机构反应后,说 ...

  4. 零基础学习云计算及大数据DBA集群架构师【预科2015年12月14日周一】

    1.第一天比较轻松,上午填表格,录指纹,拍照片,做自我介绍. 2.下午老师简单介绍了一下PC\交换机\路由器\塔式服务器\机架式服务器(1U\2U)\刀片服务器\磁带机 3.班主任陈老师朱老师,预科秦 ...

  5. 零基础学习云计算及大数据DBA集群架构师【Linux系统\网络服务及安全配置2015年1月8日周五】

    考试考一天,得分94,最后一题防火墙当时还没搞明白 考题如下: 注意事项: .确保在重启主机后所有配置仍然生效. .selinux 必须为Enforing 模式,防火墙必须开始.默认策略必须清空. . ...

  6. 大数据Hadoop-Spark集群部署知识总结(一)

    大数据Hadoop-Spark集群部署知识总结 一.启动/关闭 hadoop myhadoop.sh start/stop 分步启动: 第一步:在hadoop102主机上 sbin/start-dfs ...

  7. 入门大数据---Redis集群分布式学习

    Redis是什么? 官方介绍: Redis 是一个开源(BSD许可)的,内存中的数据结构存储系统,它可以用作数据库.缓存和消息中间件. 它支持多种类型的数据结构,如 字符串(strings), 散列( ...

  8. 一台虚拟机,基于docker搭建大数据HDP集群

    前言 好多人问我,这种基于大数据平台的xxxx的毕业设计要怎么做.这个可以参考之前写得关于我大数据毕业设计的文章.这篇文章是将对之前的毕设进行优化. 个人觉得可以分为两个部分.第一个部分就是基础的平台 ...

  9. 大数据——Hadoop集群坏境CentOS安装

    前言 前面我们主要分析了搭建Hadoop集群所需要准备的内容和一些提前规划好的项,本篇我们主要来分析如何安装CentOS操作系统,以及一些基础的设置,闲言少叙,我们进入本篇的正题. 技术准备 VMwa ...

随机推荐

  1. 织梦 dedecms 中LOOP 万能标签循环 调用 arcurl标签(获取链接)

    在DEDECMS中,提供了loop万能循环标签,但是此循环标签只能循环出该表中的字段,而“[field:arcurl/]”链接标签并不能被解析出来,而DEDECMS官方论坛上也没有找到相关的解决办法, ...

  2. php 钩子函数原理 解析

    目前对钩子的理解:<转载:http://www.cnblogs.com/del/archive/2008/02/25/1080825.html> 譬如我们用鼠标在某个窗口上双击了一次, 或 ...

  3. Android App 性能评测与调优

    要点: 1. 内存优化的目的以及工具介绍 2. Android APP 内存的主要问题分析与总结 3. UI 绘制原理以及量化工具 - UI 流畅度的主要问题分析以及 UI 绘制原理. 4. 如何获取 ...

  4. python 编程之计算器

    作业: 使用正则表达式和递归实现计算器功能. 实现: 1.实现带括号的计算 2.实现指数.加减乘除求余等功能 一.实例说明: 本实例自己写了个版本,但依旧存在一点bug,例:-2-2等计算问题,故最后 ...

  5. elasticsearch 性能优化

    #系统默认的最大打开文件数的限制 vi /etc/security/limits.conf   *     -       nproc          50240    *     -       ...

  6. UBOOT的多支持性与可裁剪性

    UBOOT功能强大,适用于多种操作系统,多种处理器架构. 在阅读它的源码时,可以看到cpu目录有各种处理器,而board目录有各种开发板.但是,对于一个特定的实验平台,例如TQ2440开发板,它用到的 ...

  7. Ruby自学笔记(二)— Ruby的一些基础知识

    Ruby安装好之后,我们就可以来实践Ruby语言了. 以下是一些学习到的简单基础知识: 1. 如何执行Ruby文件? 我们编写的Ruby文件是以rb为后缀名的,例如:XXX.rb.当要执行ruby文件 ...

  8. DEDECMS-helper小助手扩展

    今天在做DEDE动态调用模板的时候卡住了,后终被强大的互联网解决,记录解决问题的过程,以备后用 可以在/data/helper.inc.php中进行默认小助手初始化的设置,系统默认载入小助手 例如创建 ...

  9. Node.js npm

    Node程序包管理器(NPM)提供了以下两个主要功能: 在线存储库的Node.js包/模块,可搜索 search.nodejs.org 命令行实用程序来安装Node.js的包,做版本管理和Node.j ...

  10. cognos启动报错

    [ ERROR ] Content Manager is unable to process your request because an unexpected event occurred in ...