九.LNMP网站架构实践部署

期中集群架构-第九章-期中架构LNMP章节
======================================================================php

01. LNMP架构说明
   1)使前端web服务和后端存储服务进行串联
   2)主要实现处理PHP程序动态请求

02. LNMP架构工做原理
    L--Linux  N--nginx  M--mysql  P--php
 html

03. LNMP架构部署前端


1)安装LNMP相关软件
   ①. 部署Linux系统
      基础优化操做要完成(防火墙关闭 关闭selinux /tmp权限为1777)mysql

   . 部署nginx服务
      暂时忽略 
  ③. 部署mysql服务
yum部署软件 linux

编译安装软件 nginx

二进制包方式部署mysql服务
第一个里程:下载并解压mysql软件程序
   mysql官方下载连接地址:ftp://ftp.jaist.ac.jp/pub/mysql/Downloads/MySQL-5.6/
   上传mysql软件程序,进行利用xftp软件进行上传
   tar xf mysql-5.6.34-linux-glibc2.5-x86_64.tar.gz
   mv mysql-5.6.34-linux-glibc2.5-x86_64 /application/mysql-5.6.34

第二个里程:建立软件程序软连接
   ln -sf /application/mysql-5.6.34/ /application/mysql
   若是软连接已经存在  -f 强制建立
第三个里程:建立数据库管理用户,并受权数据目录
   useradd mysql -M -s /sbin/nologin
   chown -R mysql.mysql /application/mysql/data/

第四个里程:对数据库服务进行初始化
   /application/mysql/scripts/mysql_install_db --basedir=/application/mysql --datadir=/application/mysql/data/ --user=mysql
   basedir对哪个数据库进行初始化,后期学习一个系统中部署几个数据库因此须要指定web

   datadir指定数据目录  user指定数据库目录管理帐户sql

第五个里程:启动mysql服务
   cp /application/mysql/support-files/mysql.server /etc/init.d/mysqld数据库

    mysql.server 启动脚本文件  把文件复制到 开机启动文件夹中vim

sed -ri 's#/usr/local#/application#g' /etc/init.d/mysqld /application/mysql/bin/mysqld_safe

  vim mysql.server看到默认的basedir不在咱们建立的application中,须要修改

vim mysqld_safe控制mysql服务是否可以正常启动的命令看到默认识别的程序目录

也不是/applicastion 须要修改

   cp /application/mysql/support-files/my-default.cnf /etc/my.cnf

  /etc/my.cnf系统自带的mysql 配置文件 跟咱们的版本可能不匹配

  cp  mysql里的配置文件过去

最后启动 mysql
   /etc/init.d/mysqld start

 

第六个里程:设置数据库root用户登陆密码
   设置密码/application/mysql/bin/mysqladmin -uroot password "oldboy123"
   登录/application/mysql/bin/mysql -uroot -poldboy123
   进入数据库全部的操做都是用的sql语句

   show databases;   显示全部的数据库内容

④. PHP软件安装部署过程
第一里程:解决PHP软件的依赖关系
   yum install -y zlib-devel libxml2-devel libjpeg-devel libjpeg-turbo-devel libiconv-devel freetype-devel libpng-devel gd-devel libcurl-devel libxslt-devel

   libiconv软件安装---字符集转换库(默承认以不进行安装了)
   cd /server/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 ../

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

   部署repo源以前已经操做过了
   yum -y install libmcrypt-devel mhash mcrypt  加密相关软件
   rpm -qa libmcrypt-devel mhash mcrypt

第二个里程:下载解压PHP软件
   php官方网站下载:php.net
   cd /server/tools/
   tar xf php-5.5.32.tar.gz
   cd php-5.5.32 进入目录配置php 不须要区了解每一个配置的类容

如下配置方法是汇总实际工做的一个配置
   ./configure \
   --prefix=/application/php-5.5.32 \
   --with-mysql=/application/mysql-5.6.34 \
   --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

   /server/tools/php-5.5.32/ext/phar/phar.phar
   make
   make install
   ln -s /application/php-5.5.32/ /application/php

 

第三个里程:设置PHP程序配置文件
   php.ini   php-fpm.ini两个配置文件

   php.ini 放在安装包里面
   cp php.ini-production /application/php-5.5.32/lib/

一下命令是由于建立了软连接

   cd /application/php/etc/

里面有个php-fpm.conf.default 备份文件程序不能加载

因此备份重命名
   cp php-fpm.conf.default php-fpm.conf

第四个里程:启动php程序服务
   /application/php/sbin/php-fpm
   netstat -lntup|grep php

   添加到、vim /etc/rc.local 开机自动开启
   tcp 0 0 127.0.0.1:9000 0.0.0.0:* LISTEN 6251/php-fpm


2)进行软件直接的结合
   nginx与php结合:编写nginx配置文件
   location ~* .*\.(php|php5)?$ {
      fastcgi_pass 127.0.0.1:9000;
      fastcgi_index index.php;
      include fastcgi.conf;
   }
以上匹配到php或php5的都给9000端口,默认使用这个配置便可不用过多关注

而后重启

测试

cd /application/nginx/html/blog/ 进入blog站点目录

\rm ./* -fr清空里面的类容

vim test_info.php编写php的测试网页

http://blog.etiantian.org/test_info.php  浏览器打开

动态解析成功!

php与mysql结合:编写php程序代码

编写生成到相应站点目录下如 /application/nginx/html/blog

# vim test_mysql.php
   <?php
      //$link_id=mysql_connect('主机名','用户','密码');
      //mysql -u用户 -p密码 -h 主机
      $link_id=mysql_connect('localhost','root','oldboy123') or mysql_error();
      if($link_id){
                    echo "mysql successful by oldboy !\n";
         }else{
                    echo mysql_error();
      }
   ?>

解释:

$link_id=mysql_connect 设置变量=调用了一个php调用mysql的函数

localhost---mysql服务器在哪 哪儿登录过去的 这里设置的本地

root---登录数据库的用户 后面为密码

if判断若是成功 则显示 echo " "

若是失败echo  就调用or后面的mysql_error()函数

==========================================
测试浏览器打开http://blog.etiantian.org/test_mysql.php

显示 

结合成功!


3)部署一个真的网站
第一个里程:下载与上传网站代码

wordpress-4.7.3-zh_CN.tar.gz 一个开源的博客网站代码

第二个里程:解压程序代码,将程序代码保存到站点目录并进行受权
   tar xf wordpress-4.7.3-zh_CN.tar.gz
   mv wordpress/* /application/nginx/html/blog/

   移动过去的文件不少都是nobody的权限,须要修改

   修改为nginx: worker进程的用户

   chown -R www.www /application/nginx/html/blog/
无论客户端是什么身份访问网站都会作一个映射,转换成www用户


第三个里程:直接访问blog网站,进行初始化操做

http://blog.etiantian.org/ 出错

配置文件里默认没有请求指定文件时返回的是index.html

但此时在/application/nginx/html/blog里并无index.html首页存在

因此报错403 

 咱们如今不是默认访问静态资源 ,如今是动态资源因此加上index.php

重启reload 再次进入网站

 

建立数据库:

进入mysql

# /application/mysql/bin/mysql -uroot -poldboy123
   create database wordpress; 建立一个数据库
   show databases; 检查 WordPress数据库是否建立好了



grant all on wordpress.* to 'wordpress'@'localhost' identified by 'oldboy123';

建立连接数据库用户 和密码
select user,host from mysql.user;
检查mysql自带的用户表看有没有建立的信息

接着安装

 

提示"要执行请求的操做,WordPress须要访问您网页服务器的权限。 请输入您的FTP登陆凭据以继续。 若是您忘记了您的登陆凭据(如用户名、密码),请联系您的网站托管商。"

添加好网站目录权限与nginx进程权限一致
下一个章节:
01. LNMP架构数据库服务的迁移
02. LNMP架构数据资源迁移到NFS服务器存储
03. nginx反向代理与负载均衡功能

相关文章
相关标签/搜索