Centos6.7下搭建lnmp

十度 linux 2017年03月27日 收藏

之前搭建lnmp,一直是寻找的网上的一键安装的脚本,这个有很大的缺点。很多的脚本,安装出来的 php版本 以及 nginx的版本和mysql的版本,可能并不是自己想要的。而且,安装的目录,也不是可见的,导致安装好之后,并不知道这些文件安装到哪里去了。使用起来很是麻烦。所以,求人不如求己。算了,自己来吧。一个一个的安装,可以自己随意的定义版本。好了,开始吧!

一 、 编译安装 php

编译 php 需要一些依赖:

  1. yum install gd zlib zlib-devel openssl openssl-devel libxml2 libxml2-devel libjpeg libjpeg-devel libpng libpng-devel

记住:这些软件都是安装两个 比如 zlib和zlib-devel都要安装。

运行安装这些依赖之后,我们就可以去寻找需要的php版本了。下载的地方,就在php的官网,地址:http://www.php.net/downloads.php

打开我们会看到很多的php版本,我就选择一个 php-5.6.30版本的吧。7以上的版本,有些扩展支持的还有些问题,我们就编译老的版本吧。

复制下面的地址,我们在 /usr/local/src 下,下载这个安装包。  记住: /usr/local/src 是我规定的放所有的安装包源码的地方。

  1. cd /usr/local/src
  2. wget http://cn2.php.net/get/php-5.6.30.tar.bz2/from/this/mirror

我们下载的地址链接的结尾是 mirror 。当然,这个文件下载完毕之后,会在 /usr/local/src下面有一个 mirror 文件。我们将它重命名,便于我们查看,操作。

  1. mv mirror php-5.6.30.tar.bz2

然后,对 php-5.6.30.tar.bz2 进行解压:

  1. tar jxf php-5.6.30.tar.bz2

解压完毕之后,进入加压后的文件内

  1. cd php-5.6.30

接下来,进行 configure的操作:

  1. ./configure --prefix=/usr/local/php \
  2. --with-gd \
  3. --enable-gd-native-ttf \
  4. --enable-mysqlnd \
  5. --with-mysql=mysqlnd \
  6. --with-pdo-mysql=mysqlnd \
  7. --with-openssl \
  8. --enable-mbstring \
  9. --enable-fpm

--prefix 这项配置表示,我们会将php安装到哪里。我们就可以根据自己的喜好,规定php的存放地方。

--with-gd 和 --enable-gd-native-ttf 这两个命令是允许 gd库和一些简单的字体

--enable-mysqlnd 和 --with-mysql=mysqlnd 和 --with-pdo-mysql=mysqlnd 这三条命令,是关于,mysql的扩展操作。如果 你编译安装的是 7.*以上的版本,那么--with-mysql=mysqlnd指令可以不要。

--with-openssl开启openssl

--enable-mbstring允许mbstring

--enable-fpm 允许 php-fpm (和nginx配合,这个是重点)

输入之后,等待系统的检测吧,当你看到  Thank you for using PHP. 那么恭喜你,证明你的系统符合安装要求了。

然后输入:

  1. make && make install

此后需要等待 几分钟。等待完毕之后,执行:

  1. cd /usr/local/php

php-fpm这个文件,在php文件夹下的 sbin下。那么,我们来启动 php-fpm吧:

  1. ./sbin/php-fpm

然而,不幸的是,错误来了:

  1. failed to open configuration file '/usr/local/php/etc/php-fpm.conf': No such file or directory (2)
  2. failed to load configuration file '/usr/local/php/etc/php-fpm.conf'
  3. FPM initialization failed

从错误的信息可以看出,打开配置文件出错了。没有在/usr/local/php/etc/ 下面发现 php-fpm.conf。通过查看,这个目录下,确实没有这个文件。那这个文件到底在哪里呢?

其实在 /usr/local/php/etc/ 下面有一个php-fpm.conf.default 文件,这个是系统给的默认配置文件,我们只要将这个文件改个名字即可:

  1. cp etc/php-fpm.conf.default etc/php-fpm.conf

我们再次启动 php-fpm 看看

  1. ./sbin/php-fpm

没有报错,那么恭喜你,php安装完成!查看一下,是否真的启动了吧

  1. ps aux|grep php

能看到 php-fpm 启动的进程号。

二 、编译安装 nginx 并 整合 php

从nginx的官网,http://nginx.org/en/download.html下载你需要的版本,我们选择一个stable稳定版本。我这里选择的是 1.10.3版本的

  1. cd /usr/local/src
  2. wget http://nginx.org/download/nginx-1.10.3.tar.gz
  3. tar zxf nginx-1.10.3.tar.gz
  4. cd nginx-1.10.3
  5. ./configure --prefix=/usr/local/nginx

这一步之后,系统会抛出一个错误:

  1. ./configure: error: the HTTP rewrite module requires the PCRE library.
  2. You can either disable the module by using --without-http_rewrite_module
  3. option, or install the PCRE library into the system, or build the PCRE library
  4. statically from the source with nginx by using --with-pcre=<path> option.

他提示我们,nginx的 http rewrite模块,需要 pcre的支持。又给了我们3中解决方案,我们现在选择第三个,自己找一个pcre库,然后编译的时候,告诉他库在哪里。

pcre的官网地址是 www.pcre.org ,选择一个合适的版本,这里,我们不要选择 pcre2开头的版本,这个版本虽然在坚持的时候能通过,但是make的时候,还是会报错终止。我们选择一个pcre-8.38

  1. cd /usr/local/src
  2. wget https://ftp.pcre.org/pub/pcre/pcre-8.38.tar.bz2
  3. tar jxf pcre-8.38.tar.bz2

然后我们可以继续安装 nginx了,以及启动它

  1. cd nginx-1.10.3
  2. ./configure --prefix=/usr/local/nginx --with-pcre=/usr/local/src/pcre-8.38
  3. cd /usr/local/nginx
  4. ./sbin/nginx

我是在虚拟机中搭建的lnmp,此时我们通过 192.168.1.226,便可以访问我的虚拟机,然后,发现并打不开。通过ping发现,宿主机和虚拟机之间是可以互相ping通的,如果还是无法访问,一般的问题就是 防火墙屏蔽了80端口。方便起见,我们可以先关闭防火墙,当然,你一可以配置 允许80端口访问。

  1. service iptables stop

关闭了防火墙之后,浏览器就能看到 欢迎使用 nginx 的页面了。好了,nginx安装完成之后,我们让他和php配合起来吧。

  1. cd /usr/local/nginx/conf
  2. vim nginx.conf

打开了,nginx的配置文件,我们找到:

  1. location ~ \.php$ {
  2. root html;
  3. fastcgi_pass 127.0.0.1:9000;
  4. fastcgi_index index.php;
  5. fastcgi_param SCRIPT_FILENAME /scripts$fastcgi_script_name;
  6. include fastcgi_params;
  7. }

将前面的分号删除,并修改:

  1. /scripts$fastcgi_script_name; $DOCUMENT_ROOT$fastcgi_script_name;

保存退出,并重新加载 nginx配置文件:

  1. ./sbin/nginx -s reload
我们在 nginx/html下新建 info.php
  1. <?php
  2. phpinfo();

保存退出,访问 192.168.1.226/info.php,就能看到熟悉的 phpinfo页面了。这时我们会发现,貌似并没有找到php.ini文件。而且系统是到/usr/local/php/lib 目录下查找的,我们通过查找发现 php.ini确实不在这里。其实这个文件在/usr/local/src/php-5.6.30这个文件夹下面:

php.ini-development
php.ini-production
两个配置我们,我们随便选择一个,复制到指定的目录即可,并重启php-fpm
  1. cp /usr/local/src/php-5.6.30/php.ini-development /usr/local/php/lib/php.ini
  2. pkill -9 php
  3. ./sbin/php-fpm

三、编译安装mysql

我是从:http://mirrors.sohu.com/mysql/MySQL-5.5/ 搜狐的镜像中下载的,选择一个相对来说小点的 版本,5.5.53

  1. cd /usr/local/src
  2. wget http://mirrors.sohu.com/mysql/MySQL-5.5/mysql-5.5.53-linux2.6-x86_64.tar.gz
  3. tar zxf mysql-5.5.53-linux2.6-x86_64.tar.gz

mysql的安装依赖于libaio,我们先通过 yum安装一下

  1. yum install libaio

一下是根据mysql官方给的方法安装的:

  1. cd /usr/local/mysql
  2.  
  3. // 添加mysql用户组
  4. groupadd mysql
  5. // 添加一个mysql用户 让其属于mysql组
  6. useradd -r -g mysql mysql
  7. // 改变mysql文件夹的拥有者为mysql
  8. chmod -R mysql .
  9. // 改变mysql文件夹下所有文件的拥有组为mysql
  10. chgrp -R mysql .
  11. // 安装基础的数据库
  12. ./scripts/mysql_install_db --user=mysql
  13.  
  14. // 将当前目录的拥有者改成root
  15. chown -R root .
  16. // 把data文件夹的属主改成mysql
  17. chown -R mysql data
  18.  
  19. // 创建,mysql运行所需的文件夹
  20. mkdir /var/run/mysqld
  21. // 将该文件夹的属主和用户组都设成,mysql
  22. chown mysql /var/run/mysqld/ -R
  23. chgrp mysql /var/run/mysqld/ -R
  24.  
  25. // 启动
  26. ./bin/mysqld_safe --user=mysql &

启动之后,我们发现 有一个提示 :mysql.sock文件的位置 /var/lib/mysql/mysql.sock,当我们试图链接 这个mysql服务器时:

  1. ./bin/mysql

会发现一个错误:

Can't connect to local MySQL server through socket '/tmp/mysql.sock' (2)
由于mysql服务器相对于客户端来说,是在本地的,因此链接mysql时候,只要通过本地的sock文件,而不是通过网卡,客户端是去 /tmp 下去寻找mysql.sock文件,然后我么前面也看到了,服务端的 mysql.sock文件放在了/var/lib/mysql/下面,因此我们只要将这两个文件关联起来就可以解决这个问题了。
  1. ln /var/lib/mysql/mysql.sock /tmp/mysql.sock

然后再去链接 ./bin/mysql ,就会进入mysql

下面是修改mysql的root密码,链接上mysql之后:

  1. show databases;
  2. use mysql;
  3. show tables;

发现 user这几个表

  1. //1、删除不相关的用户
  2. delete from user where Host != 'localhost';
  3. delete from user where user = '';
  4.  
  5. //2 、改密码
  6. update user set Password = password('root');
  7.  
  8. //3、将修改后的信息刷新到内存中
  9. flush privileges;
  10.  
  11. //退出重新登录
  12. exit;

再次链接就需要:

  1. ./bin/mysql -uroot -p

提供刚才我们设定的密码才能登陆了。好了,整个 lnmp系统搭建完毕!