05.22 LNMP组合架构

第一章 LNMP组合工作流程

在LNMP组合工作时,首先是用户通过浏览器输入域名请求Nginx Web服务,如果请求时静态资源,则由Nginx解析返回给用户;如果是动态请求(.php结尾),那么Nginx就会把它通过Fast CGI接口发送给PHP引擎服务(FastCGI进程php-fpm)进行解析,如果这个动态请求要读取数据库数据,那么PHP就会继续向后请求MYSQL数据库,一度去需要的数据,并最终通过Nginx服务把获取的数据返回给用户,这就是LNMP环境的基本请求顺序流程。
这里写图片描述


第二章 MySQL数据库优势和特点

  1. 性能卓越、服务稳定,很少出现异常宕机。
  2. 开放源代码且无版权制约,自主性强,使用成本低。
  3. 历史悠久,社区及用户非常活跃,遇到问题,可以很快获取到帮助。
  4. 软件体积小,安装使用简单,并且易于维护,安全及维护成本低。
  5. 支持多种操作系统,提供多种API接口,支持多种开发语言,特别是对流行的PHP语言无缝支持。

第三章 MYSQL安装方式

序号MySQL安装方式特点说明
1yum/rpm包安装特点是简单、速度快、但是没法定制安装,入门新手常用这种方式
2二进制安装解压软件,简单配置后就可以使用,不用安装,速度较快,专业DBA喜欢这种方式
3源码编译安装特点是可以定制安装,但是安装时间长,例如:字符集安装路径,等
4源码软件结合yum/rpm安装把源码软件制作成符合要求的rpm,放到yum仓库里,然后通过yum来安装,结合了1和3有点,即安装快捷,可任意制定参数,但是安装着也许要更深能力

第四章 MYSQL安装步骤

1. 安装包放入指定路径

cd /home/oldboy/tools/
wget http://ftp.iij.ad.jp/pub/db/mysql/Downloads/MySQL-5.6/mysql-5.6.34-linux-glibc2.5-x86_64.tar.gz

2. 解压安装包

[root@web02 ~]$ cd /home/oldboy/tools/
[root@web02 tools]$ ll
total 307688
-rw-r--r-- 1 root root 314149697 May 22 08:38 mysql-5.6.34-linux-glibc2.5-x86_64.tar.gz
drwxr-xr-x 9 1001 1001      4096 May 18 10:36 nginx-1.10.2
-rw-r--r-- 1 root root    910812 Oct 18  2016 nginx-1.10.2.tar.gz
[root@web02 tools]$ tar xf mysql-5.6.34-linux-glibc2.5-x86_64.tar.gz

3. 创建服务用户

[root@web02 tools]$ useradd -s /sbin/nologin -M mysql
[root@web02 tools]$ id mysql
uid=502(mysql) gid=502(mysql) groups=502(mysql)

4. 查看目录大小

[root@web02 tools]$ du -sh mysql-5.6.34-linux-glibc2.5-x86_64
1.1G    mysql-5.6.34-linux-glibc2.5-x86_64

5. 移动到程序安装目录(规范)

[root@web02 tools]$ mv mysql-5.6.34-linux-glibc2.5-x86_64 /application/mysql-s.6.34
[root@web02 tools]$ ll /application/mysql-s.6.34/
total 68

6. 创建软链接

[root@web02 tools]$ ln -s /application/mysql-s.6.34/ /application/mysql
[root@web02 tools]$ ll /application/mysql
lrwxrwxrwx 1 root root 26 May 22 10:01 /application/mysql -> /application/mysql-s.6.34/

7. 初始化数据库服务

[root@web02 tools]$ /application/mysql/scripts/mysql_install_db --basedir=/application/mysql --datadir=/application/mysql/data --user=mysql

8. 复制MySQL启动程序到init.d

[root@web02 tools]$ cp /application/mysql/support-files/mysql.server  /etc/init.d/mysqld
[root@web02 tools]$ ll /etc/init.d/mysqld 
-rwxr-xr-x 1 root root 10875 May 22 10:12 /etc/init.d/mysqld
[root@web02 tools]$ chmod +x /etc/init.d/mysqld

9. 更改默认目录

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

10. MYSQL默认配置文件

ll /application/mysql/support-files/my-default.cnf
[root@web02 tools]$ cp /application/mysql/support-files/my-default.cnf /etc/my.cnf

11. 启动MySQL服务

[root@web02 ~]$ /etc/init.d/mysqld  start
Starting MySQL.. SUCCESS!

#[root@web02 ~]$ /application/mysql/bin/mysql -uroot

12. 设置命令变量

echo 'export PATH=/application/mysql/bin:$PATH' >>/etc/profile
source /etc/profile
which mysql

13. 登录密码方式

[root@web02 ~]$ mysqladmin -u root password 'oldboy123'
[root@web02 ~]$ mysql -u root -p
[root@web02 ~]$ mysql -uroot -p123456

第五章 PHP安装

1. 安装软件包(依赖包)

cd /server/files
yum install zlib-devel libxml2-devel libjpeg-devel libjpeg-turbo-devel libiconv-devel freetype-devel libpng-devel gd-devel libcurl-devel libxslt-devel libxslt-devel -y

2. libiconv软件安装

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
yum -y install libmcrypt-devel mhash mcrypt
rpm -qa libmcrypt-devel mhash mcrypt

3. php编译安装

wget -O /etc/yum.repos.d/epel.repo http://mirrors.aliyun.com/repo/epel-6.repo  #注意这里是6的源,如果是7的请更换

wget http://tw1.php.net/distributions/php-5.5.32.tar.gz
tar xf php-5.5.32.tar.gz
cd php-5.5.32
./configure --prefix=/application/php-5.5.32 \
--with-mysql=mysqlnd \
--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
make && make install
echo $?

5. 创建软链接复制配置文件

[root@web02 php-5.5.32]$ ln -s /application/php-5.5.32/ /application/php
[root@web02 php-5.5.32]$ ll /application/php
lrwxrwxrwx 1 root root 24 May 22 11:35 /application/php -> /application/php-5.5.32/

cd /home/oldboy/tools/php-5.5.32 
[root@web02 php-5.5.32]$ cp php.ini-production /application/php/lib/php.ini

cd /application/php/etc/
cp php-fpm.conf.default php-fpm.conf

6. 启动

[root@web02 etc]$ /application/php/sbin/php-fpm 
[root@web02 etc]$ ps -ef |egrep php-fpm.conf

tcp    LISTEN     0      16384          127.0.0.1:9000

第六章 FastCGI网关接口

CGI的全称为“通用网关接口 (common Gateway interface)”,为HTTP服务器与其他机器上的程序服务通信交流的一种工具,CGI程序必须运行在网络服务器上。

传统CGI接口方式的主要缺点是性能较差,因为每次HTTP服务器遇到动态程序时都需要重新启动解析器来执行解析,之后结构才会被返回给HTTP服务器。这在处理高并发访问时几乎是不可用的,因此就诞生了FastCGI。;另外,传统的CGI接口安全性也很差,故而现在已经很少被使用了。


第七章 建立Nginx和php连接

[root@web02 conf]$ pwd
/application/nginx/conf
[root@web02 conf]$ cat extra/blog.conf 
    server {
        listen       80;
        server_name  blog.etiantian.org;
        # 静态请求处理的location
        location / {
            root   html/blog;
            index  index.html index.htm;
        }
        # 动态请求处理的location
        location ~* .*\.(php|php5)?$ {
            root html/blog;
            fastcgi_pass  127.0.0.1:9000;
            fastcgi_index index.php;
            include fastcgi.conf;
        }
}

[root@web02 conf]$ /application/nginx/sbin/nginx -t
[root@web02 conf]$ /application/nginx/sbin/nginx -s reload
echo '<?php phpinfo(); ?>' >/application/nginx/html/blog/test_info.php
[root@web02 blog]# curl -I blog.etiantian.org
HTTP/1.1 200 OK
Server: nginx/1.10.2
Date: Mon, 22 May 2017 04:10:19 GMT
Content-Type: text/html
Content-Length: 14
Last-Modified: Fri, 19 May 2017 01:53:30 GMT
Connection: keep-alive
ETag: "591e501a-e"
Accept-Ranges: bytes

[root@web02 blog]# curl -I http://blog.etiantian.org/test_info.php
HTTP/1.1 200 OK
Server: nginx/1.10.2
Date: Mon, 22 May 2017 04:10:36 GMT
Content-Type: text/html
Connection: keep-alive
X-Powered-By: PHP/5.5.32

第八章 建立MySQL和php连接

[root@web02 conf]$ mysql -uroot -poldboy123

mysql> create database wordpress;           ##mysql> drop database wordpress;

mysql> show databases;

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

mysql> flush privileges;

mysql> select user,host from mysql.user;

mysql> show databases;
+--------------------+
| Database           |
+--------------------+
| information_schema |
| test               |
| wordpress          |
+--------------------+
3 rows in set (0.00 sec)

mysql> select user();
+---------------------+
| user()              |
+---------------------+
| wordpress@localhost |
+---------------------+
1 row in set (0.00 sec)

[root@web02 conf]$ ll /application/mysql/data/
total 110620
-rw-rw---- 1 mysql mysql       56 May 22 10:33 auto.cnf
-rw-rw---- 1 mysql mysql 12582912 May 22 10:33 ibdata1
-rw-rw---- 1 mysql mysql 50331648 May 22 10:33 ib_logfile0
-rw-rw---- 1 mysql mysql 50331648 May 22 10:10 ib_logfile1
drwx------ 2 mysql mysql     4096 May 22 10:10 mysql
drwx------ 2 mysql mysql     4096 May 22 10:28 performance_schema
drwxr-xr-x 2 mysql mysql     4096 May 22 09:56 test
-rw-r----- 1 mysql root      2261 May 22 10:33 web02.err
-rw-rw---- 1 mysql mysql        5 May 22 10:33 web02.pid
drwx------ 2 mysql mysql     4096 May 22 12:16 wordpress

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

[root@web02 conf]$ vim /application/nginx/conf/nginx.conf
worker_processes  1;
events {
    worker_connections  1024;
}
http {
    include       mime.types;
    default_type  application/octet-stream;
    sendfile        on;
    keepalive_timeout  66;
    # include  extra/www.conf;
    # include  extra/bbs.conf;
    include  extra/blog.conf;

第九章 站点数据转移

1. 启动MySQL服务推送备份文件至MySQL服务器/tmp目录

[root@web02 ~]# /etc/init.d/mysqld start
[root@web02 ~]# ps -ef |egrep mysql
[root@web02 ~]# mysqldump -uroot -poldboy123 --all-databases >/tmp/mysqlbak.sql
[root@web02 ~]# scp -rp /tmp/mysqlbak.sql 172.16.1.51:/tmp

2. 备份文件导入MySQL

[root@mysql_51 tools]# mysql -uroot -poldboy123 </tmp/mysqlbak.sql
[root@mysql_51 tools]# mysql -uroot -poldboy123

[root@mysql_51 tools]# mysql -uroot -poldboy123
mysql> show databases;
mysql> select user,host from mysql.user;

mysql> grant all on wordpress.* to 'wordpress'@'172.16.1.0/255.255.255.0' identified by 'oldboy123';
mysql> select user,host from mysql.user;

[root@mysql_51 tools]# mysql -uwordpress -poldboy123 -h 172.16.1.51

[root@web02 blog]# pwd
/application/nginx/html/blog
[root@web02 blog]# vim wp-config.php 
/** MySQL主机 */
define('DB_HOST', '172.16.1.51');
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值