LNMP编译

一、安装数据库

创建组账号:

  groupadd mysql

创建用户:

  useradd -s /sbin/nologin -g mysql -M mysql

写入密码:

  echo "123123" >> /etc/passwd

映射:

  echo "`hostname -I` LNMP" >> /etc/hosts

查看属主和属组:

  id mysql

获取MySQL二进制软件包,解压:

  tar xf mysql-5.5.32-linux2.6-x86_64.tar.gz -C /usr/local/

移动到解压目录:

  cd /usr/local/

将文件改名:

  mv mysql-5.5.32-linux2.6-x86_64 mysql-5.5.32

创建软链接:

  ln -s mysql-5.5.32 mysql

移动到新建目录下:

  cd /usr/local/mysql

查看目录下support-files/*.cnf的文件:

  ls -l support-files/*.cnf

强制复制文件到/etc/my.cnf:

  /bin/cp support-files/my-small.cnf /etc/my.cnf

建立MySQL数据文件目录:

  mkdir -p /usr/local/mysql/data

授权MySQL用户管理MySQL的安装目录:

  chown -R mysql.mysql /usr/local/mysql

光盘源安装依赖包,否则下一步的编译会报错:

  yum -y install libaio

初始化MySQL数据库文件,会有很多提示,如果没有ERROR的显示,会有两个OK的字样,表示初始化成功,否则就要解决初始化的问题。

  /usr/local/mysql/scripts/mysql_install_db --basedir=/usr/local/mysql --basedir=/usr/local/mysql --datadir=/usr/local/mysql/data --user=mysql

  初始化故障排错:

  1.如果出现主机名未找到的错误,修改主机名,hostname=localhost或者如下:

  2.没有安装依赖包:

  3.权限问题:

二、配置并启动MySQL数据库

(1)设置MySQL启动脚本:

  cp /usr/local/mysql/support-files/mysql.server /etc/init.d/mysqld

 (2)MySQL二进制默认安装路径是/usr/local/mysql,启动脚本里是/usr/local/mysql。如果安装路径不同,那么脚本里路径等都需要替换

 (3)启动MySQL数据库:/etc/init.d/mysqld start

 (4)检查MySQL数据库是否启动:netstat -antup | grep mysql

 (5)查看MySQL数据库启动结果日志:tail -10 /usr/local/mysql/data/localhost.err

(6)设置MySQL开机自启动(也可以将启动命令/etc/init.d/myslqd start 放到/etc/rc.local里面):

  chkconfig --add mysqld

  chkconfig mysqld on

  chkconfig --list mysqld

(7)配置mysql命令的全局使用路径:

   ln -s /usr/local/mysql/bin/* /usr/local/bin/ (创建软链接)

   which mysqladmin (查看命令)

 (8)登陆MySQL测试(MySQL安装完成后,默认情况下,root账户是无密码的,这个必须要设置。)

   mysql (直接输入命令即可登录)

   show databases; (查看当前所有的数据库)

   select user(); (查看当前登录的用户)

三、MySQL安全配置

(1)为MySQL的root用户设置密码:mysqladmin -u root password '123123'

(2)进入到数据库,清理无用的MySQL用户及库:select user,host from mysql.user; (查看mysql.user库中表头user和host中的信息)

  drop user "root"@"::1"; (删除user下的“root”@“::1”)

  drop user ""@"localhost"; (删除user下的“”@“localhost”)

  select user,host from mysql.user; (查看登录用户)

  flush privileges; (刷新)

 四 、LNMP之PHP(FastCGI方式)服务的安装和准备

1.准备nginx的压缩包并解压:tar xf nginx-1.10.2.tar.gz -C /usr/src

2.移动到解压目录:cd /usr/src/nginx-1.10.2/

3.安装依赖包:yum -y install pcre-devel openssl-devel

4.执行: ./configure --user=mysql --group=mysql --prefix=/usr/local/nginx --with-http_stub_status_module --with-http_ssl_module

make && make install

5.创建软链接:ln -s /usr/local/nginx/sbin/* /usr/local/sbin/

6.修改nginx的配置文件:

  cd /usr/local/nginx/conf

  egrep -v "#|^$" nginx.conf.default > nginx.conf

7.删除文件中的最后一块脚本:vim /usr/local/nginx/conf/nginx.conf

8.修改配置文件后需要重启: /usr/local/nginx/sbin/nginx -s reload (平滑重启)

9.确认检查nginx和MySQL的安装路径:ls -ld /usr/local/nginx      ls -ld /usr/local/mysql

10.检查端口启动情况:netstat -antup | grep -E "80|3306"

11.测试访问nginx及MySQL是否OK:

 wget 127.0.0.1 (测试nginx)

 mysql -uroot -p (测试MySQL)

 

如果访问结果和上述一致,就表明nginx及MySQL的安装一切正常。

五、检查安装PHP所需的lib库

PHP程序在开发及运行时会调用一些诸如zlib,gd等函数库,因此需要确认lib库是否已经安装:

每个lib一般都会存在对应的以“*-devel”命名的包,安装lib对应的-devel包后,对应的lib包就会自动安装好,例如安装gd-devel时就会安装gd。

这些lib库不是必须安装的,但是目前的企业环境下一般都需要安装。否则,PHP程序运行时会出现问题,例如验证码无法显示等。

 安装相关的lib软件包:

安装后的结果:这里仅缺少libiconv-devel包,因为默认的yum源没有此包。

安装yum无法安装的libiconv库:

解压安装包:

移动到解压目录下:

执行: ./configure --prefix=/usr/local/libiconv && make && make install

安装libmcrypt库:

推荐使用简单的在线yum的方式安装:wget -O /etc/yum.repos.d/epel.repo http://mirrors.aliyun.com/repo/epel-6.repo

  yum -y install libmcrypt-devel

安装mhash加密扩展库:

推荐使用简单的在线yum的方式安装:wget -O /etc/yum.repos.d/epel.repo http://mirrors.aliyun.com/repo/epel-6.repo

   yum -y install mhash

安装mcrvpt加密扩展库:

推荐使用简单的在线yum的方式安装:wget -O /etc/yum.repos.d/epel.repo http://mirrors.aliyun.com/repo/epel-6.repo

  yum -y install mhash

安装mcrvpt加密扩展库:

推荐使用简单的在线yum的方式安装:wget -O /etc/yum.repos.d/epel.repo http://mirrors.aliyun.com/repo/epel-6.repo

   yum -y install mcrypt

六、开始安装PHP(FastCGI方式)服务

1.获取PHP软件包: wget http://cn2.php.net/get/php-5.3.28.tar.gz/from/this/mirror

2.解压配置PHP

解压文件:tar xf php-5.3.28.tar.gz -C /usr/src/

移动到解压文件:cd /usr/src/php-5.3.28/

执行: ./configure  --prefix=/usr/local/php5.3.28   --with-mysql=/usr/local/mysql  --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-safe-mode  --enable-bcmath  --enable-shmop  --enable-sysvsem  --enable-inline-optimization  --with-curl  --with-curlwrappers  --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-zip  --enable-soap  --enable-short-tags  --enable-zend-multibyte  --enable-static  --with-xsl  --with-fpm-user=mysql  --with-fpm-group=mysql  --enable-ftp

安装成功出现下图:

 上述命令参数详解:  

--prefix=/usr/local/php5.2.28 :表示指定PHP的安装路径为/usr/local/php5.3.28

--with-mysql=/usr/local/mysql :表示需要指定MySQL的安装路径,安装PHP需要的MySQL相关内容。当然,如果没有MySQL软件包,也可以不单独安装,这样的情况可使用--with-mysql=mysqlnd替代--with-mysql=/usr/local/mysql,因为PHP软件里已经自带了连接MySQL的客户端工具。

--with-fpm-user=mysql :nginx表示指定PHP-FPM进程管理的用户为www,此处最好和Nginx服务用户统一。

--with-fpm-group=mysql :表示指定PHP-FPM进程管理的组为www,此处最好与Nginx服务用户组统一。

--enable-fpm :表示激活PHP-FPM方式服务,即以FastCGIF方式运行PHP服务。

编译PHP:

创建软链接:ln -s /usr/local/mysql/lib/libmysqlclient.so.18 /usr/lib64/

创建文件:touch ext/phar/phar.phar

make编译:make

最后的正确提示:

 

安装PHP生成文件到系统:make install

配置PHP引擎配置文件php.ini:

(1)设置软链接以方便访问:ln -s /usr/local/php5.3.28/ /usr/local/php

(2)查看PHP配置默认模版文件:

  cd /usr/src/php-5.3.28/

  ls php.ini*

  请注意以上两文件的异同之处,可通过diff或vimdiff命令比较,如下图所示:

对比此结果可以看出,开发环境更多的是开启日志文件,调试信息,而生产环境都是关闭状态。

(3)拷贝PHP配置文件到PHP默认目录,并更改文件名称为php.ini:

  cp php.ini-production /usr/local/php/lib/php.ini

  ls -l /usr/local/php/lib/php.ini

配置PHP(FastCGI方式)的配置文件php-fpm.conf

移动:cd /usr/local/php/etc/

查看目录下文件:ls

拷贝文件:cp php-fpm.conf.default php-fpm.conf

  php-fpm.conf,暂时可用默认的配置,先把服务搭好,以后再进行优化。

启动PHP服务(FastCGI方式)

(1)启动PHP服务php-fpm: /usr/local/php/sbin/php-fpm

(2)检查PHP服务php-fpm的进程及启动端口的情况:

配置Nginx支持PHP程序请求访问:

修改Nginx配置文件:

  cd /usr/local/nginx/conf/

  cp nginx.conf nginx.conf.02

  vim nginx.conf
worker_processes  1;
error_log logs/error.log;
events {
    worker_connections  1024;
}
http {
    include       mime.types;
    default_type  application/octet-stream;
    sendfile        on;
    keepalive_timeout  65;   
 server {
        listen       80;
        server_name  blog.yunjisuan.com;
        location / {
            root   /root/www;
            index  index.html index.htm;
        }
        location ~ .*\.(php|php5)?$ {
            root    /root/www;
            fastcgi_pass    127.0.0.1:9000;
            fastcgi_index   index.php;
            include     fastcgi.conf;
        }
    }

}

检查并启动Nginx:

  /usr/local/nginx/sbin/nginx -t (检查脚本是否有语法错误)

  /usr/local/nginx/sbin/nginx -s reload (平滑重启)

这步在生产环境很关键,如不提前检查语法,重启后发现语法错误会导致Nginx无法提供服务,给用户访问体验带来不好的影响。

测试LNMP环境生效情况:

1.测试PHP解析请求是否OK

1)进入指定的默认站点目录后,编辑index.php,添加如下内容:

  cd /usr/local/nginx/html/www

  echo "<?php phpinfo(); ?>" > test_info.php

以上代码为显示PHP配置信息的简单PHP文件代码

 2)调整Windows下的host解析(192.168.0.121为当前的机器IP)

在本机影射文件里添加虚拟机的IP地址,和域名。

本机影射文件位置:C盘:windows/System32/dirvers/etc/hosts

3)打开浏览器,输入http://blog.yunjisuan.com/test_info.php 即可打开如下图所示界面:

 出现上述界面,表示Nginx配合PHP解析已经正常。

2.针对Nginx请求访问PHP,然后对PHP连接MySQL的情况进行测试

编辑/usr/local/nginx/html/www/test_mysql.php,加入如下内容:

测试结果如下:

至此,LNMP的组合以基本搭建完毕。当然,我们还没有做相关优化,因此,我们需要将虚拟机保存好。以后使用。

七、部署一个blog程序服务

1.WordPress 博客程序的搭建准备

  1)登录MySQL数据库:mysql -uroot -p123123

  2)创建一个专用的数据库WordPress,用于存放blog数据:

  create database wordpress; (创建一个数据库)

  show databases like 'wordpress'; (查看库名)

  3)创建一个专用的WordPress blog管理用户

  grant all on wordpress.* to wordpress@'localhost' identified by '123123';   (localhost为客户端地址)

  show grants for wordpress@'localhost';  (查看用户对应权限)

  select user,host from mysql.user;  (查看数据库里创建的Wordpress用户)

 

2.Nginx及PHP环境配置准备

 1)选择之前配置好的支持LNMP的blog域名对应的虚拟主机

 

2)获取WordPress博客程序,并放置到blog域名对应虚拟主机的站点目录下,即/usr/local/nginx/html/www:

  ls 浏览www.wordpress.org下载博客程序

  tar xf wordpress-4.7.4-zh_CN.tar.gz 解压

  rm -f index.html test_info.php  test_mysql.php 删除无用文件

  mv wordpress/* . 把目录里的内容移动到blogcom根目录下

  /bin/mv wordpress-4.7.4-zh_CN.tar.gz /root/ 移走源程序

  ls -l 完整的blog程序内容

  chown -R mysql.mysql ../www/ 授权用户访问

  ls -l 最终博客目录和权限

开始安装blog博客程序

很多开源程序都支持浏览器傻瓜式的界面安装,此处也用这种方法。

1)打开浏览器输入blog.yunjisuan.com(提前做好hosts或DNS解析)

2)仔细阅读页面的文字信息后,单击“现在就开始”按钮继续,然后在出现的页面表单上填写相应的内容。

至此,静态网页设置完毕。 

实现WordPress博客程序URL静态化

实现此功能时,首先要在WordPress后台依次单击设置--->固定链接--->自定义结构,然后输入下面的代码,并保存更改。

/archives/%post_id%.html%post_id%是数据库对应博文内容的唯一ID,例如423)

接着,在Nginx配置文件的server容器中添加下面的代码:

  vim /usr/local/nginx/conf/nginx.conf

worker_processes  1;
events {
    worker_connections  1024;
}
http {
    include       mime.types;
    default_type  application/octet-stream;
    sendfile        on;
    keepalive_timeout  65;
    server {
        listen       80;
        server_name  blog.yunjisuan.com;
        location / {
            root   html/www;
            index  index.php index.html index.htm;
        if (-f $request_filename/index.html){
            rewrite (.*) $1/index.html break;
        }
        if (-f $request_filename/index.php){
            rewrite (.*) $1/index.php;
        }
        if (!-f $request_filename){
            rewrite (.*) /index.php;
        }
        }
        location ~ .*\.(php|php5)?$ {
                root    html/www;
                fastcgi_pass    127.0.0.1:9000;
                fastcgi_index   index.php;
                include         fastcgi.conf;
        }
    }
}

最后检查语法并重新加载Nginx服务:

  /usr/local/nginx/sbin/nginx -t (检查脚本)

  /usr/local/nginx/sbin/nginx -s reload (平滑重启)

 

 

posted @ 2018-11-27 23:52  mashuang  阅读(167)  评论(0编辑  收藏  举报