CentOS6的LAMP安装

一:环境以及软件准备

1、lsb_release -a 查看centos的环境

 

2、软件:我用的尚硅谷的LAMP-php7的包

Apache:2.4.7

Mysql:5.6

PHP:7.0

需要用到的扩展的关系图谱

 

 

 

3、因为拿到的包是zip的包,如图所示:

 

我现在本机安装rz包,yum install lrzsz。上传至/lamp目录下。

ps:zip压缩包的一些知识:.zip格式被大多数操作系统所支持。所以该压缩格式的文件可以在windows操作系统被解压,也可以在Linux操作系统被解压。Linux操作系统解压如下:

unzip LAMP-php7.zip

 

 

 5、关闭iptables以及SELinux

  关闭iptables:

    service iptables status

 

 

 防火墙是一个服务,有临时关闭和永久关闭,相关信息如下:

 #iptables -F
 #chkconfig iptables off

关闭SELinux【需重启】:getenforce

 

 

 永久关闭命令如下:

关闭SELinux(需重启)
#vim /etc/selinux/config
SELINUX=disabled

#reboot

6、安装gcc、gcc-c++、make等编译工具

# yum -y install gcc gcc-c++ make

7、关闭系统RPM安装包的Apache、MySQL等服务

 为了防止rpm安装的软件和接下来安装的源码软件包冲突

# service httpd stop
# service mysqld stop
确定rpm包安装的httpd和mysqld不能开机自启动
#chkconfig httpd off
#chkconfig mysqld off

同样的,上述的服务可以用service httpd status进行查看

8、查看安装软件的磁盘空间是否充足

df -h

 

 

 9、编写一个shell将刚才zip文件中的tar压缩包都解压到当前目录下

#!bin/bash
cd /lamp
/bin/ls *.tar.gz > ls.list
for TAR in `cat ls.list`
do
/bin/tar -xf $TAR
done
/bin/rm ls.list

10、检查目录是否都以及解压,发现一个以zip结尾的没有,手动解压

unzip

 

 

 二:yum安装和源码安装

 1、部署方式:

        yum安装:优点:安装部署便捷,快速,因为它不需要考虑依赖的问题

                         缺点:软件版本固定,且版本较低,例如CentOS自带的apache的版本很低

        源码安装:优点:版本可自选,可自定义性强

          缺点:难度较大,维护相对困难,需要自己解决依赖的问题

 2、源码安装的步骤以及详解

  参考链接:https://www.cnblogs.com/benwu/articles/8436209.html

      什么叫做源码,就是一个软件的源代码。我们拿到一个软件的源代码过后(也就是我们上述解压的命令得到的是软件的源码,未进行编译操作),需要将它编译成二进制文件才可以在Linux中运行,因为Linux,只允许二进制的文件在上面运行。

      那么源码编译生成二进制文件一共分为两步(有点像java语言的编译过程):

     a:configure命令调用gcc编译器将源码编译成目标文件

      b:make命令调用gcc将目标文件链接成二进制文件

       具体安装步骤:

        1)获取源码,并解压到一个目录,大部分在/usr/local为安装目录

         2)查看INSTALL与README文件

           该文件中详细介绍了安装方法和注意事项,但是大部分都是英文,可以边看边借助百度翻译。

         3).configure 生成MakeFile文件

             MakeFile文件会告诉我们后面的make命令怎么去编译和链接程序

    --prefix表示指定安装路径,例如:./configure --prefix=/usr/local/memcached/

      该命令有时还跟着如下的内容:

       --enable 是启用软件源码包自带 --enable-包名[=arg],但是默认不启用的功能模块。

    --with 是指定依赖的资源库的位置 --whit-依赖包名称[=依赖包目录],如果是默认位置,l路径就可以留空

   4)执行make clean;make命令将源码编译成二进制文件。 
    PS:make clean命令用来清除上一次编译生成的目标文件。这个步骤可有可无,但为了确保编译的成功,还是加上为好。防止由于软件中含有残留的目标文件导致编译失败。

        5)make install依据上述的configure开始安装软件到指定的目录

    注意事项:

  #安装软件过程中由于频繁刷屏,建议在每个步骤结束后执行此命令
  echo $?
  ./configure
  #此步骤报错多是依赖关系没解决或是编译工具未安装(注意关键词提示)
  #make
  此步骤多是编译时选项参数书写错误、不存在、漏写等问题#一般需要检查上一个步骤:./configure --help
  注意:若遇到报错,最简单的办法是,找到问题解决后重新解压软件,重新安装,步骤最简单有效

三:开始安装

  1、安装libxml2

    libxml2是xml解析器.

#yum install -y libxml2-devel python-devel
# cd /lamp/libxml2-2.9.1
#./configure --prefix=/usr/local/libxml2/
#make 
#make install

若出现了以下报错可以后面zlib的安装提前。
./.libs/libxml2.so: undefined reference to `gzopen64'
  collect2: ld returned 1 exit status

  make[2]: *** [xmllint] Error 1

  make[2]: Leaving directory `/******/libxml2-2.9.8'

  make[1]: *** [all-recursive] Error 1

  make[1]: Leaving directory `/******/libxml2-2.9.8'

  make: *** [all] Error 2       

  确认安装成功:

  使用echo $?发现没有问题。

  

2、 安装libmcrypt

   libmcrypt是加密算法扩展库。支持DES, 3DES, RIJNDAEL, Twofish, IDEA, GOST, CAST-256, ARCFOUR, SERPENT, SAFER+等算法。

# cd /lamp/libmcrypt-2.5.8
#./configure --prefix=/usr/local/libmcrypt/
#make 
#make install

 

      启动软件包自带libltdl,但是默认不启动的功能模块

# cd /lamp/libmcrypt-2.5.8/libltdl
#./configure --enable-ltdl-install
#make
#make install

3、安装mhash

  mhash是基于离散数学原理的不可逆向的php加密方式扩展库,其在默认情况下不开启。mhash的可以用于创建校验数值,消息摘要,消息认证码,以及无需原文的关键信息保存(如密码)等

# cd /lamp/mhash-0.9.9.9
# ./configure 
# make
# make install

4、安装mcrypt

 mcrypt 是php 里面重要的加密支持扩展库。mcrypt库支持20多种加密算法和8种加密模式

# cd /lamp/mcrypt-2.6.8
# export LD_LIBRARY_PATH=/usr/local/libmcrypt/lib:/usr/local/lib
变量:LD_LIBRARY_PATH用于指定libmcrypt和mhash的库的位置
# ./configure --with-libmcrypt-prefix=/usr/local/libmcrypt
# make
# make install

5、安装zlib

zlib是提供数据压缩用的函式库,由Jean-loup Gailly与Mark Adler所开发,初版0.9版在1995年5月1日发表。zlib使用DEFLATE算法,最初是为libpng函式库所写的,后来普遍为许多软件所使用。此函式库为自由软件,使用zlib授权。

#cd /lamp/zlib-1.2.3
#./configure
然后修改配置文件,否则无法正常安装此软件
#vi MakefileCFLAGS=-O3 -DUSE_MMAP -fPIC
#找到CFLAGS=-O3 -DUSE_MMAP,在后面加入-fPIC 变成(注意:小f大PIC,空格)
#make
#make install
原因:操作系统的问题,64位的操作系统,必须加上这个fPIC,而32位的操作系统则无需添加。

6、安装libpng

  libpng 软件包包含libpng 库.这些库被其他程式用于解码png图片

 

#cd /lamp/libpng-1.2.31
#./configure --prefix=/usr/local/libpng
#make
#make install

 

7、安装jpeg6

jpeg6提供用于解码.jpg和.jpeg图片的库文件

注意:此软件默认不会自动创建所需目录,所以目录必须手工建立

#mkdir /usr/local/jpeg6
#mkdir /usr/local/jpeg6/bin
#mkdir /usr/local/jpeg6/lib
#mkdir /usr/local/jpeg6/include
#mkdir -p/usr/local/jpeg6/man/man1

复制libtool中的文件,覆盖jpeg-6b中的文件(64位中的问题)

#yum -y install libtool*
#cd /lamp/jpeg-6b
# cp -a /usr/share/libtool/config/config.sub ./
# cp -a /usr/share/libtool/config/config.guess ./

#./configure --prefix=/usr/local/jpeg6/ --enable-shared --enable-static
#make
#make install

8、安装freetype

FreeType库是一个完全免费(开源)的、高质量的且可移植的字体引擎,它提供统一的接口来访问多种字体格式文件,支持单色位图、反走样位图的渲染。

#cd /lamp/freetype-2.3.5
#./configure --prefix=/usr/local/freetype/
#make
#make install

9、安装Apache

  a.源码包2.4.*版本中默认没有集成apr的依赖包,所以需要提前解决依赖问题 

解压apr和apr-util,复制整个目录并取消目录上的版本号到指定位置,./configure时会检测

#cp -a /lamp/apr-1.4.6 /lamp/httpd-2.4.7/srclib/apr
#cp -a /lamp/apr-util-1.4.1 /lamp/httpd-2.4.7/srclib/apr-util

  b.Apache默认需要依赖pcre软件,但由于Apache软件版本较高,则系统预安装的pcre无法使用,所以需要人为手动安装适合版本

# cd /lamp/pcre-8.34
# ./configure
# make
#make install

  c.Apache的加密传输模块mod_ssl,需要安装此软件产生 

因为在http转https的时候会用到
#yum install openssl-devel

  d.httpd软件安装

若前面配置zlib时没有指定安装目录,Apache配置时不要添加--with-z=/usr/local/zlib/参数,--enable-ssl选项是为了后期实现https提前设置的参数

--sysconfdir是指定配置文件的目录
#cd /lamp/httpd-2.4.7
#./configure --prefix=/usr/local/apache2 --sysconfdir=/usr/local/apache2/etc --with-included-apr --enable-so --enable-deflate=shared --enable-expires=shared --enable-rewrite=shared--enable-ssl
#make
#make install

  e.启动Apache测试

# /usr/local/apache2/bin/apachectl start
使用进程查看命令确认Apache是否启动,是否产生进程
# ps  aux | grep httpd
使用网络进程查看命令确认Apache是否启动,是否开启了80监听端口
# netstat -tlun | grep :80
检测apache是否有语法错误
#/usr/local/apache2/bin/apachectl -t

 


 

 

    报错提示:若启动时提示/usr/local/apache2/modules/mod_deflate.so无权限,可关闭SELinux解决,类似此类.so文件不能载入或没有权限的问题,都是SELinux问题,MySQL和Apache都可能有类似问题。

  警告提示:发现启动服务提示:AH00558: httpd: Could not reliably determine the server's fully qualified domain name, using localhost.localdomain. Set the 'ServerName' directive globally to suppress this message

 解决办法:打开主配置文件httpd.conf

    搜索ServerName (约在200行左右)

    改为ServerName localhost:80(并且去掉前面的#注释)

  10、安装ncurses

若不安装ncurses编译MySQL时会报错
#yum -y install ncurses-devel
#cd /lamp/ncurses-5.9
#./configure --with-shared --without-debug --without-ada --enable-overwrite
#make 
#make install

 11、安装cmake和bison

mysql在5.5以后,oracle处于安全考虑,不再使用./configure工具,进行编译安装。而使用cmake工具替代了。
而bison是一个自由软件,用于自动生成语法分析器程序,可用于所有常见的操作系统
yum -y install cmake bison

    12、安装MySQL

为MySQL软件创建运行用户,创建为系统用户,并限制此用户登录操作系统
useradd -r -s /sbin/nologin mysql
#cd /lamp/mysql-5.5.48
#cmake -DCMAKE_INSTALL_PREFIX=/usr/local/mysql-DMYSQL_UNIX_ADDR=/tmp/mysql.sock -DEXTRA_CHARSETS=all -DDEFAULT_CHARSET=utf8-DDEFAULT_COLLATION=utf8_general_ci -DWITH_MYISAM_STORAGE_ENGINE=1 -DWITH_INNOBASE_STORAGE_ENGINE=1 -DWITH_MEMORY_STORAGE_ENGINE=1 -DWITH_READLINE=1-DENABLED_LOCAL_INFILE=1 -DMYSQL_USER=mysql -DMYSQL_TCP_PORT=3306
#make
#make install
参数详解
-DCMAKE_INSTALL_PREFIX=/usr/local/mysql安装位置
-DMYSQL_UNIX_ADDR=/tmp/mysql.sock指定socket(套接字)文件位置
-DEXTRA_CHARSETS=all扩展字符支持
-DDEFAULT_CHARSET=utf8    默认字符集
-DDEFAULT_COLLATION=utf8_general_ci    默认字符校对
-DWITH_MYISAM_STORAGE_ENGINE=1  安装myisam存储引擎
-DWITH_INNOBASE_STORAGE_ENGINE=1    安装innodb存储引擎
-DWITH_MEMORY_STORAGE_ENGINE=1  安装memory存储引擎
-DWITH_READLINE=1 支持readline库 -DENABLED_LOCAL_INFILE=1 启用加载本地数据 -DMYSQL_USER=mysql 指定mysql运行用户 -DMYSQL_TCP_PORT=3306 指定mysql端口

  MySQL安装后需要调整相应配置文件和参数才能正常运行

  a.修改MySQL目录的用户归属

    关于文件权限的修改chmod、chown、chgrp是必须要掌握的,可以参考链接https://blog.csdn.net/qq_39445165/article/details/81603322 

#cd /usr/local/mysql/
#chown -R root .
#chown -R mysql data
执行结果如下:

  b.生成配置文件,并初始化授权表

复制MySQL配置文件到指定位置,覆盖掉系统自带文件
cp -a /lamp/mysql-5.5.48/support-files/my-medium.cnf /etc/my.cnf

创建数据库授权表,初始化数据库相当于安装完操作系统后的引导设置添加第一个用户
#cd/usr/local/mysql #./scripts/mysql_install_db --user=mysql

报错提示FATAL ERROR:Could not find ./bin/my_print_defaults

原因mysql_install_db初始化所调用文件使用的相对路径,路径不在/usr/local/mysql时,是无法调用my_print_defaults文件并初始化成功的。

  c.MySQL服务

用原本源代码的方式去使用和启动mysql
/usr/local/mysql/bin/mysqld_safe --user=mysql &

 


 

 

  d.设定MySQL

/usr/local/mysql/bin/mysqladmin -uroot password 123456

  e.登录MySQL

 /usr/local/mysql/bin/mysql -u root -p

 

 问:为什么不能直接使用mysql命令?

  因为系统默认会找/usr/bin底下的命令,需要将/usr/local/mysql/bin/mysql软链接到/usr/bin

  ln -s /usr/local/mysql/bin/mysql /usr/bin

  此时就可以使用mysql的命令登录了:

  mysql -h 127.0.0.1 -uroot -p

  可以使用mysqladmin关闭mysql

  /usr/local/mysql/bin/mysqladmin -u root -p123456 shutdown

13. 安装PHP

#cd /lamp/php-7.0.7
#./configure --prefix=/usr/local/php/ --with-config-file-path=/usr/local/php/etc/ --with-apxs2=/usr/local/apache2/bin/apxs --with-libxml-dir=/usr/local/libxml2/ --with-jpeg-dir=/usr/local/jpeg6/ --with-png-dir=/usr/local/libpng/ --with-freetype-dir=/usr/local/freetype/ --with-mcrypt=/usr/local/libmcrypt/ --with-mysqli=/usr/local/mysql/bin/mysql_config --enable-soap --enable-mbstring=all --enable-sockets --with-pdo-mysql=/usr/local/mysql --with-gd --without-pear
#make
#make install

选项详解: --with-config-file-path=/usr/local/php/etc/指定配置文件目录 --with-apxs2=/usr/local/apache2/bin/apxs指定apache动态模块位置 --with-libxml-dir=/usr/local/libxml2/指定libxml位置 --with-jpeg-dir=/usr/local/jpeg6/指定jpeg位置 --with-png-dir=/usr/local/libpng/指定libpng位置 --with-freetype-dir=/usr/local/freetype/指定freetype位置 --with-mcrypt=/usr/local/libmcrypt/指定libmcrypt位置 --with-mysqli=/usr/local/mysql/bin/mysql_config指定mysqli位置 --with-gd启用gd库 --enable-soap支持soap服务 --enable-mbstring=all支持多字节,字符串 --enable-sockets支持套接字 --with-pdo-mysql=/usr/local/mysql启用mysql的pdo模块支持 --without-pear不安装pear(安装pear需要连接互联网)

PHP安装后需要调整相应配置文件和参数才能正常运行

a.生成php配置文件

# mkdir /usr/local/php/etc
# cp /lamp/php-7.0.7/php.ini-production /usr/local/php/etc/php.ini

b.修改Apache配置文件,使其识别*.php文件,并能通过php模块调用php进行页面解析

#vim /usr/local/apache2/etc/httpd.conf
AddType application/x-httpd-php .php .phtml 
AddType application/x-httpd-php-source .phps

重启Apache服务 #/usr/local/apache2/bin/apachectl stop #/usr/local/apache2/bin/apachectl start

c.测试php页面是否能正常解析apachephp通性

#vim /usr/local/apache2/htdocs/test.php
<?php
phpinfo();
?>
通过浏览器输入地址访问:http://Apache服务器地址/test.php
我们运行php脚本发现运行成功

 建立软连接:

  ln -s /usr/local/php/bin/php /usr/bin/

  

 

   

 

  

 

 

 

 

 

14. PHP安装openssl模块

OpenSSL 一个强大的安全套接字层密码库,囊括主要的密码算法、常用的密钥和证书封装管理功SSL协议,并提供丰富的应用程序供测试或其它目的使用。

这里要说下phpize的作用。

phpize是用来扩展php扩展模块的,通过phpize可以建立php的外挂模块
比如你想在原来编译好的php中加入memcached或者ImageMagick等扩展模块,可以使用phpize,通过以下几步工作。

所以安装openssl扩展,需要phpize模块,执行完phpize会生成configure文件夹,

具体的操作方法可以看:https://blog.csdn.net/weixin_38674371/article/details/84714696

#cd /lamp/php-7.0.7/ext/openssl
#mv config0.m4 config.m4
#/usr/local/php/bin/phpize
#./configure --with-openssl --with-php-config=/usr/local/php/bin/php-config 
#make
#make install

15、PHP安装memcache模块

Memcache是一个高性能的分布式的内存对象缓存系统,通过在内存里维护一个统一的巨大的hash表,它能够用来存储各格式的数据,包括图像视频文件以及数据库检索的结果等。简单的说就是将数据调用到内存中,然后从内存中读取,从而大大提高读取速度。

#unzip  pecl-memcache-php7.zip
#cd pecl-memcache-php7
#/usr/local/php/bin/phpize
#./configure --with-php-config=/usr/local/php/bin/php-config
#make
# makeinstall

16. 修改php配置文件,使其识别并调用opensslmemcache两个模块

#vi/usr/local/php/etc/php.ini
extension_dir="/usr/local/php/lib/php/extensions/no-debug-zts-20151012/"
取消分号注释,并添加以上路径(此路径来自于模块安装命令的结果)extension="openssl.so";
extension="memcache.so";
添加以上两个库文件的调用重启apache,刷新phpinfo页面,并查看是否有两个新增的模块

 


 

 

 

17、安装memcached服务

memcache和MySQL类似,都是一个服务,所以需要启动这个服务

 

-DWITH_READLINE=1    支持readline库-DENABLED_LOCAL_INFILE=1   启用加载本地数据-DMYSQL_USER=mysql  指定mysql运行用户-DMYSQL_TCP_PORT=3306指定mysql端口

依赖库安装
#yum -y install libevent-devel
#cd /lamp/memcached-1.4.17
#./configure --prefix=/usr/local/memcache
#make
#make install

memcache添加memcache用户,此用户不用登录,不设置密码
#useradd -r -s /sbin/nologin memcache
启动memcache服务,并设置为后台运行
#/usr/local/memcache/bin/memcached -umemcache &

 

posted @ 2020-09-19 19:35  洛飞  阅读(337)  评论(0编辑  收藏  举报