+++++++LAMP布署Wordpress、phpMyadmin

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,高可用系列 2核4GB
简介:

常见动态资源服务模型

  • LAMP Linux Apache Mariadb|Mysql|Mongdb Php|Perl|Python

  • LAMMP Linux Apache Mariadb|Mysql|Mongdb Memocache Php|Perl|Python

  • LNMP Linux Nginx Mariadb|Mysql|Mongodb Php|Perl|Python

  • LNMMP Linux Nginx Mariadb|Mysql|Mongodb Memocache Php|Perl|Python

  • LAMT Linux Apache Mariadb|Mysql|Mongdb Tomcat

  • LNMT Linux Nginx Mariadb|Mysql|Mongdb Tomcat

httpd静态资源的响应模型

客户端通过http协议连接静态资源服务器

httpd动态态资源的响应模型

程序文件需要在虚拟机(PHP, Perl, Tomcat, Python)中运行后响应。

如果虚拟中的程序运行过程中需要数据库时,就通过连接数据库的驱动,驱动内提供的函数库完成封装报文、解封装报文和与mysql服务器交互。

  • CGI 

    • 静态资源: fork自身用子进程响应。

    • 动态资源:CGI调用对应程序,fork自身,程序作为子进程运行

    • 在同一个主机上通信IPC:

        消息队列、共享内存、旗语、套接字
        message queue, shared memor, semaphores, unix socket
    • 缺陷: **httpd处理的请求过多**

  • FastCGI 

    • 跨主机通信IPC:

        套接字、远程过程调用
        socket, rpc
  • 动态网站特性

    • 静态资源>动态资源(一个PV内1/10个为动态)

    • 1/100个需要mysql的数据[在应用程序服务器中]

    • 加强后端服务器的性能

  • httpd与php结合的方式

    • CGI: 作为HTTPD子进程<与tomcat, perl, python整合>

    • Modules: php作为httpd的模块, httpd调用模块不用生成子进程

    • FastCGI: 独立的服务器

文件查询和数据库查询的区别

  • 操作文件时都需要将数据载入内存中

    • 将文件中的所有数据块加载至内存进行查找

  • 数据库管理系统:[可以将数据存储为较小的数据集],查询时只用装载较小的数据集

    • 将部分字段抽取<复制>出来,做为一个较小的数据集,存储的位置有指向原位置的指针

    • 将抽取出的字段按特定的逻辑,再抽取一份,做为一个小的数据集

    • 查找到的key对应的指针会指向原位置所在的行[每行或多行为一个数据块] 

php解释器与mysql交互

php解释器中运行的php代码/程序,需要用到mariadb时,用驱动,连接mariadb

php

服务器端脚本编程语言,动态网站开发语言:php, asp, ruby, c, bash<解释器,提供程序功能>

  • 代码执行过程

    扫描(词法分析) --> parsing(语义分析-->表达式) --> compilation(表达式-->opcode) --> exec(opcode-->机器指令)

php加速方式

请求相同的动态资源时,之前缓存在内存中的opcode相同代码可以重复利用

即使是prefork,进程间也可以共用opcode

注意:prefork每个进程独立的,进程有自己的内存空间,不能使用其他进程内资源

存储系统

  • 文件系统: 文件 操作文件时,需要内核的系统调用

  • SQL数据库: mariadb, mysql, oracle, ms_sql 交互时,用驱动[函数库]连接

  • no_sql: redis, mongodb, hbase

  • new_sql: <存储,基于分布式模式,管理的存储的系统>

rpm提供LAMP组合布署开源程序

wordpress, phpMyadmin, discuss

CentOS 6rpm安装LAMP

  • 配置yum源

      # install -d /media/cdrom
      # mount -r /dev/cdrom /media/cdrom
      # mv -v /etc/yum.repos.d/CentOS-Base.repo{,.bak}
      # vim /etc/yum.repos.d/CentOS-Base.repo
          [C6CentOS]
          name=CentOS 6
          failovermethod=priority
          baseurl=file:///media/cdrom
                  http://mirrors.aliyun.com/centos/6/os/i386/
          gpgcheck=0
          enabled=1
          [EPEL]
          name=Fedora EPEL
          failovermethod=priority
          baseurl=http://mirrors.aliyun.com/epel/6/i386/
                  http://mirrors.sohu.com/fedora-epel/6/i386/
          gpgcheck=1
          gpgkey=http://mirrors.aliyun.com/epel/RPM-GPG-KEY-EPEL-6
          enabled=1
  • 安装

      # yum -y install httpd php php-mysql mysql-server
  • 配置

      # rpm -ql php    
      /etc/httpd/conf.d/php.conf              //提供httpd的配置文件
      /usr/lib/httpd/modules/libphp5.so       //提供给httpd的模块
      PS:此模块仅能运行prefork模型, worker|event模型:libphp5-zts.so模块
      # httpd -M
       php5_module (shared)                   //模块已经被装载
  • 启用httpd, mysql

      # service httpd start
      # service mysqld start
    • 测试httpd

        # ss -tnl
        在Windows浏览器中键入IP地址测试
        http://
    • 测试mysql

        # ss -tnl
        # mysql
        mysql>
  • 测试

    • php程序执行环境

        # vim /var/www/html/index.php
        <?php 
            phpinfo();
        ?>

    • 测试php程序通过驱动连接mysql服务器

      php-mysql驱动所提供的调用: mysql_connect, mysql_close php代码以';'结尾

         # vim /var/www/html/index.php
         <?php
         $link=mysql_connect('localhost','root','');
         if($link)
            echo "Success";
        else
            echo "Failure";
        mysql_close();
        ?>

        停止服务
        # service mysqld stop

布署wordpress[个人博客站点]

  • 获取wordpress wordpress中文站点

  • 服务器环境要求

    PHP 5.2.4或更新版本

    MySQL 5.0或更新版本

    Apache mod_rewrite模块(可选,用于支持“固定链接”和“站点网络”功能)

  • 下载链接: wordpress-4.8.1-zh_CN.zip

  • 展开并配置

      # unzip wordpress-4.8.1-zh_CN.zip
      # cp -a wordpress /var/www/html/
      # cd /var/www/html/
      # ln -sv wordpress wp            //便于升级
      # cd wp
      # cp wp-config-sample.php wp-config.php
      # vim  wp-config.php 
          define('DB_NAME', 'wpdb');
          define('DB_USER', 'wpuser');
          define('DB_PASSWORD', 'wppass');
  • mysql中添加用户

      # mysql
      mysql> GRANT ALL ON *.* TO 'wpuser'@'localhost' IDENTIFIED BY 'wppass';
      mysql> GRANT ALL ON *.* TO 'wpuser'@'127.0.0.1' IDENTIFIED BY 'wppass';
      mysql> FLUSH PRIVILEGES;
      mysql> CREATE DATABASE wpdb;
      mysql> \q
  • 在Windows主机中,输入CentOS虚拟主机的IP测试

    http://172.16.100.1/wp

布署phpMyadmin[mysql Web GUI]

  • 获取phpMyadminphpMyadmin官网

    • 旧版本与PHP 5.2和MySQL 5兼容。不支持PHP 5.5或更新版本。至2017年4月1日为止。

    • 当前版本与PHP 5.5至7.1和MySQL 5.5及更高版本兼容。

    • 下载链接: phpMyAdmin-4.7.4-all-languages.zip

    • 下载链接: phpMyAdmin-4.0.10.20-all-languages.zip

    • 获取版本

        # rpm -q php
        # rpm -q mysql
        # rpm -q httpd
    • 展开并配置

        # unzip phpMyAdmin-4.0.10.20-all-languages.zip
        # cp -a phpMyAdmin-4.0.10.20-all-languages.zip /var/www/html
        # cd /var/www/html/
        # ln -sv phpMyAdmin-4.0.10.20-all-languages pma
        # cd pma
        # cp config.sample.inc.php config.inc.php
        # openssl rand -hex 16
        e870cf5bb5e30295ca0389f77b469919
        # vim config.inc.php 
        $cfg['blowfish_secret'] = ' e870cf5bb5e30295ca0389f77b469919'; /* YOU MUST FILL IN THIS FOR COOKIE AUTH! */
        ['AllowNoPassword'] = false; //拒绝空密码登陆
    • mysql中给root用户添加密码

        # mysql
        mysql> SET PASSWORD FOR 'root'@'localhost'=PASSWORD('magedu');
        mysql> SET PASSWORD FOR 'root'@'127.0.0.1'=PASSWORD('magedu'); 
        mysql> FLUSH PRIVILEGES;
        mysql> \q
    • 在Windows主机中,输入CentOS虚拟主机的IP测试

      http://172.16.100.3/pma

    • 安装php扩展: php-mbstring

        # yum install php-mbstring   //A module for PHP applications which need multi-byte string handling
        [root@localhost pma]# rpm -ql php-mbstring
        /etc/php.d/mbstring.ini
        /usr/lib/php/modules/mbstring.so   //提供了php的扩展模块或库
    • 重载httpd,因为php是httpd的模块

        # rpm -ql php
        /etc/httpd/conf.d/php.conf
        /usr/lib/httpd/modules/libphp5.so  //php是httpd的模块
      
        # service httpd reload
    • 再次测试 

CentOS 7rpm安装LAMP

  • 安装

      # yum -y install httpd php php-mysql mariadb-server
  • 启动

     # systemctl start httpd.service
     # systemctl start mariadb.service

给php添加xcache模块,实现缓存加速

  • 安装前测试

      # ulimit -n 65535
      # php -m
      [Zend Modules]
      [root@localhost pma]# ab -c 1000 -n 4000 172.16.100.3/pma
      Server Software:        Apache/2.2.15
      Server Hostname:        172.16.100.3
      Server Port:            80
    
      Document Path:          /pma
      Document Length:        310 bytes
    
      Concurrency Level:      1000                   //并发数  
      Time taken for tests:   5.968 seconds
      Complete requests:      4000                   //请求数
      Failed requests:        0
      Write errors:           0
      Non-2xx responses:      4003
      Total transferred:      2137602 bytes
      HTML transferred:       1240930 bytes
      Requests per second:    670.23 [#/sec] (mean)  //每秒请求数
      Time per request:       1492.033 [ms] (mean)   //每批请求所需要的时间
      Time per request:       1.492 [ms] (mean,      //每个请求所需要的时间
      Transfer rate:          349.77 [Kbytes/sec]    //3MiB带宽
    
      Connection Times (ms)
                    min  mean[+/-sd] median   max
      Connect:        0  338 613.4    157    3130   //客户端建立连接
      Processing:     1  379 771.3    168    4759   //服务器处理请求
      Waiting:        0  322 700.7    133    4505   //服务器响应
      Total:        187  716 1088.9    329    5798  //一次完整的事务
  • 安装xcache

      # yum -y install php-xcache // Fast, stable PHP opcode cacher
    
      查看安装所提供的模块:
      # rpm -ql php-xcache
      /etc/php.d/xcache.ini
      /usr/lib/php/modules/xcache.so      //为php提供的模块
  • 重载httpd

      # service httpd reload
      # php -m
      [Zend Modules]
      XCache
      XCache Cacher
      XCache Coverager
      XCache Optimizer
  • 测试

    • 预热

        # ab -c 10 -n 100 www.mykernel.cn/pma
        # ab -c 10 -n 100 www.mykernel.cn/pma
        # ab -c 10 -n 100 www.mykernel.cn/pma
    • 测试

        [root@localhost pma]# ab -c 1000 -n 4000 172.16.100.3/pma
        Server Software:        Apache/2.2.15
        Server Hostname:        172.16.100.3
        Server Port:            80
      
        Document Path:          /pma
        Document Length:        310 bytes
      
        Concurrency Level:      1000
        Time taken for tests:   6.510 seconds
        Complete requests:      4000
        Failed requests:        0
        Write errors:           0
        Non-2xx responses:      4006
        Total transferred:      2139204 bytes
        HTML transferred:       1241860 bytes
        Requests per second:    614.46 [#/sec] (mean)     //每秒请求
        Time per request:       1627.457 [ms] (mean)      
        Time per request:       1.627 [ms] (mean, across all concurrent requests)
        Transfer rate:          320.91 [Kbytes/sec] received
      
        Connection Times (ms)
                      min  mean[+/-sd] median   max
        Connect:        0  180 590.6      4    3014
        Processing:     0  531 1086.5    101    6376
        Waiting:        0  527 1086.1     97    6372
        Total:         75  711 1431.8    106    6477
      
        Percentage of the requests served within a certain time (ms)
          50%    106
          66%    114
          75%    145
          80%    542
          90%   3210
          95%   4408
          98%   5325
          99%   6081
         100%   6477 (longest request)
         ...

有问题反馈

在使用中有任何问题,欢迎反馈给我,可以用以下联系方式跟我交流

  • 邮件:lccnx@foxmail.cn

  • QQ: 2192383945

感激










本文转自 lccnx 51CTO博客,原文链接:http://blog.51cto.com/sonlich/1969713,如需转载请自行联系原作者
相关实践学习
如何快速连接云数据库RDS MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
弹性计算 关系型数据库 MySQL
基于 ECS+ CentOS,部署 LAMP环境并安装 WordPress 快速搭建个人博客
基于 ECS+ CentOS,部署 LAMP环境并安装 WordPress 快速搭建个人博客
544 0
|
SQL 开发框架 搜索推荐
lamp源码搭建详解及wordpress搭建
Linux下LAMP( Linux+ Apache+My SQL/ MariaDB+PerI /PHP/ Python)是一组用来搭建动态网站的开源软件架构,本身是各自独立的软件服务,放在一起使用,拥有了越来越兼容成大的Web应用程序平台。
362 0
lamp源码搭建详解及wordpress搭建
|
关系型数据库 MySQL Linux
CentOS7.2基于LAMP搭建WordPress,并自定义Logo和名称
CentOS7.2基于LAMP搭建WordPress,并自定义Logo和名称
761 0
CentOS7.2基于LAMP搭建WordPress,并自定义Logo和名称
|
关系型数据库 MySQL Linux
RedHat7.4 Yum环境下搭建LAMP实现库站分离(部署wordpress博客)
RedHat7.4 Yum环境下搭建LAMP实现库站分离(部署wordpress博客)
205 0
RedHat7.4 Yum环境下搭建LAMP实现库站分离(部署wordpress博客)
|
前端开发 关系型数据库 MySQL
Linux7通过LAMP环境构搭建WordPress论坛
WordPress是什么? WordPress是使用PHP语言开发的博客平台,用户可以在支持PHP和MySQL数据库的服务器上架设属于自己的网站。也可以把 WordPress当作一个内容管理系统(CMS)来使用。 WordPress是一款个人博客系统,并逐步演化成一款内容管理系统软件,它是使用PHP语言和MySQL数据库开发的,用户可以在支持 PHP 和 MySQL数据库的服务器上使用自己的博客。 WordPress有许多第三方开发的免费模板,安装方式简单易用。不过要做一个自己的模板,则需要你有一定的专业知识。比如你至少要懂的标准通用标记语言下的一个应用HTML代码、CSS、PHP等相关知识
168 0
|
缓存 应用服务中间件 Linux
WordPress网站选择LNMP环境和LAMP环境哪个好?
WordPress建网站选择LNMP环境还是LAMP环境服务更好呢?现在建站常用的两大环境服务是 LNMP和LAMP,因为这两种环境易用,好上手,所以普及率一直很高。比如我们常用的宝塔面板,在初次登陆界面就会提示二选一。要想知道哪个好用,我们先来详细了解这两款环境服务。
1571 0
WordPress网站选择LNMP环境和LAMP环境哪个好?
|
弹性计算 缓存 应用服务中间件
WordPress建站选择LNMP环境还是LAMP环境?
WordPress建网站选择LNMP环境还是LAMP环境服务更好呢?现在建站常用的两大环境服务是 LNMP和LAMP,因为这两种环境易用,好上手,所以普及率一直很高。比如我们常用的宝塔面板,在初次登陆界面就会提示二选一。要想知道哪个好用,我们先来详细了解这两款环境服务。
|
Web App开发 Ubuntu 关系型数据库
Ubuntu LAMP下搭建wordpress
在Ubuntu安装完LAMP环境的基础上搭建我们搭建wordpress 1.png 一、wordpress网站文件放置 step1.下载源码 zzq@ubuntu:/var/www/html$ sudo wget https://wordpress.
2238 0
|
Web App开发 应用服务中间件 Apache
Web服务(Apache、Nginx、Tomcat、Jetty)与应用(LAMP、CMS-WordPress&Ghost、Jenkins、Gitlab)
Web服务和应用是目前信息技术领域的热门技术。如何使用Docker来运行常见的Web服务器(包括Apache、Nginx、Tomcat等),以及一些常用应用(LAMP、CMS等)。包括具体的镜像构建方法与使用步骤。
2327 0