LAMP(Linux+Apache+MySQL+PHP)环境介绍、配置、搭建
文章目录
这里是一段防爬虫文本,请读者忽略。
本文原创首发于CSDN,作者IDYS
博客首页:https://blog.csdn.net/weixin_41633902/
本文链接:https://blog.csdn.net/weixin_41633902/article/details/106303965
写在开头的话
- 请记住:实践是掌握知识的最快方法
- 如果你只是怀着看看的态度去快速浏览文章,而不去认认真真的把文章里面讲的任何一个知识点去实践一遍,那么你永远也掌握不了它
- 生命不息,折腾不止!
LAMP的简要介绍
- web网站平台-LAMP的搭建方式
Linux+Apache+MySQL+PHP
-
Apache
:
实现网页共享传输
-
MySQL
:
实现数据存储(数据库)
-
PHP
:
实现页面解析的解析器
- 浏览器:
仅能解析简单的HTML语言,无法直接解析PHP语言
部署方式
- yum安装:
- 优点:安装部署便捷,快速
- 缺点:软件版本固定,且版本较低
- 源码安装:
- 优点:版本可自选,可自定义性强
- 缺点:难度较大,维护相对困难
LAMP环境搭建
环境准备
准备本地yum源
这个不是必须选项,就是如果你是断网的状态,没有和外界进行联网时,那么你肯定是无法用yum联网安装软件包的,所以你只能配置本地yum源来安装软件包
- 插入两张CD光盘
- 挂载光盘
[aaa@qq.com media]# mkdir /media/cdrom{1..2}
[aaa@qq.com media]# ls
cdrom1 cdrom2
# 挂载光盘
[aaa@qq.com /]# mount /dev/sr0 /media/cdrom1
mount: block device /dev/sr0 is write-protected, mounting read-only
[aaa@qq.com /]# mount /dev/sr1 /media/cdrom2
mount: block device /dev/sr1 is write-protected, mounting read-only
- 配置yum源
# 编辑 CentOS-Media.repo 文件
[aaa@qq.com ~]vim /etc/yum.repos.d/CentOS-Media.repo
# 做出如下修改
[c6-media]
name=CentOS-$releasever - Media
# 将yum源的本地路径修改为刚才挂载软件包的挂载点位置
baseurl=file:///media/cdrom1
file:///media/cdrom2
# file:///media/cdrecorder/
# 不检查gpgkey
gpgcheck=0
# 此yum源生效
enabled=1
- 调整yum源配置文件引导优先级
mv CentOS-Base.repo CentOS-Base.repo.bak
安装编译文件
[aaa@qq.com yum.repos.d]yum -y install gcc gcc-c++ make
关闭防火墙和SElinux
# 查看防火墙当前状态
[aaa@qq.com yum.repos.d]service iptables status
iptables:未运行防火墙。
# 查看防火墙自启动状态
[aaa@qq.com yum.repos.d]chkconfig --list iptables
iptables 0:关闭 1:关闭 2:启用 3:启用 4:启用 5:启用 6:关闭
# 关闭防火墙,再次查看防火墙自启动状态
[aaa@qq.com yum.repos.d]chkconfig iptables off
[aaa@qq.com yum.repos.d]chkconfig --list iptables
iptables 0:关闭 1:关闭 2:关闭 3:关闭 4:关闭 5:关闭 6:关闭
# 临时关闭SElinux
[aaa@qq.com yum.repos.d]setenforce 0
[aaa@qq.com /]getenforce
Permissive
# 编辑SELinux配置文件
[aaa@qq.com /]vim /etc/selinux/config
# 修改的配置如下
SELINUX=disabled
环境搭建
安装依赖包
-
上传
php7.x
的软件包到Linux上 -
解压
PHP
的软件包
# 载根目录下创建lamp目录
mkdir /lamp
# lamp软件包移动到/lamp下面
mv root/LAMP-php7.zip lamp/
# 安装unzip软件包
yum -y install unzip
# 解压lamp软件包
uzip LAMP-php7.zip
# 解压所有的以.tar.gz结尾的压缩文件
ls *.tar.gz | xargs -n1 -I {} tar -zxf {}
# 解压zip文件
unzip pecl-memcache-php7.zip
- 安装
libxml2-devl
、python-devl
yum -y install libxml2-devel python-devel
- 安装编译
libxml2
Libxml2 是一个 xml c 语言版的解析器,本来是为 Gnome 项目开发的工具,是一个基于 MIT License 的免费开源软件。它除了支持 c 语言版以外,还支持 c++、PHP、Pascal、Ruby、Tcl 等语言的绑定,能在 Windows、 Linux、Solaris、MacOsX 等平台上运行。功能还是相当强大的,相信满足一般用户需求没有任何问题。
./configure --prefix=/usr/local/libxml2
make
make install
# 现在可以看到/usr/local/libxml2文件夹存在
[aaa@qq.com libxml2-2.9.1] ls /usr/local/libxml2/
bin include lib share
- 安装
libmcrypt
libmcrypt 是加密算法扩展库。支持 DES, 3DES, RIJNDAEL, Twofish, IDEA, GOST, CAST-256, ARCFOUR, SERPENT, SAFER+等算法。
./configure --prefix=/usr/local/libmcrypt
echo $?
make
make install
安装libmcrypt的子模块:ltdl
./configure --enable-ltdl-install
make
make install
libmcrypt依赖着
mhash
和mcrypt
- 安装编译
mhash
mhash 是基于离散数学原理的不可逆向的 php 加密方式扩展库,其在默认情况下不开启。mhash 的可 以用于创建校验数值,消息摘要,消息认证码,以及无需原文的关键信息保存(如密码)等。
[aaa@qq.com mhash-0.9.9.9] ./configure && make && make install
- 安装
mcrypt
(提供加密的函数库)
mcrypt 是 php 里面重要的加密支持扩展库。mcrypt 库支持 20 多种加密算法和 8 种加密模式
[aaa@qq.com mcrypt-2.6.8] export LD_LIBRARY_PATH=/usr/local/libmcrypt/lib:/usr/local/lib
[aaa@qq.com mcrypt-2.6.8] ./configure --with-libmcrypt-prefix=/usr/local/libmcrypt
- 安装
zlib
zlib 是提供数据压缩用的函式库,由 Jean-loup Gailly 与 Mark Adler 所开发,初版 0.9 版在 1995 年 5 月 1 日发表。zlib 使用 DEFLATE 算法,最初是为 libpng 函式库所写的,后来普遍为许多软件所使用。此函式库为*软件,使用 zlib 授权
[aaa@qq.com lamp] cd /lamp/zlib-1.2.3
[aaa@qq.com zlib-1.2.3] ./configure
# 修改Makefile文件,加入修改如下
[aaa@qq.com zlib-1.2.3] vim Makefile
CFLAGS=-O3 -DUSE_MMAP -fPIC
[aaa@qq.com zlib-1.2.3] make
[aaa@qq.com zlib-1.2.3] make install
- 安装 libpng
libpng 软件包包含 libpng 库.这些库被其他程式用于解码 png 图片
[aaa@qq.com libpng-1.2.31] ./configure --prefix=/usr/local/libpng
[aaa@qq.com libpng-1.2.31] make
[aaa@qq.com libpng-1.2.31] make install
- 安装 jpeg6
jpeg6 提供用于解码.jpg 和.jpeg 图片的库文件
# 创建如下目录
[aaa@qq.com /] mkdir -p /usr/local/jpeg6/{bin,lib,include,man/man1}
# 查看目录情况
[aaa@qq.com /] tree /usr/local/jpeg6/
/usr/local/jpeg6/
├── bin
├── include
├── lib
└── man
└── man1
cd /lamp/jpeg-6b/
yum -y install libtool*
[aaa@qq.com jpeg-6b] cp -a /usr/share/libtool/config/config.* ./
cp:是否覆盖"./config.guess"? y
cp:是否覆盖"./config.sub"? y
[aaa@qq.com jpeg-6b] ./configure --prefix=/usr/local/jpeg6/ --enable-shared --enable-static && make && make install
- 安装 freetype
FreeType 库是一个完全免费(开源)的、高质量的且可移植的字体引擎,它提供统一的接口来访问多种 字体格式文件,支持单色位图、反走样位图的渲染。
[aaa@qq.com freetype-2.3.5] ./configure --prefix=/usr/local/freetype/
[aaa@qq.com freetype-2.3.5] make
[aaa@qq.com freetype-2.3.5] make install
安装 Apache
- 源码包
2.4.*
版本中默认没有集成apr
的依赖包,所以需要提前解决依赖问题
cd /lamp/httpd-2.4.7/srclib/
[aaa@qq.com srclib] cp -a /lamp/apr-1.4.6 ./apr
[aaa@qq.com srclib] cp -a /lamp/apr-util-1.4.1 ./apr-util
[aaa@qq.com srclib] ls
apr apr-util Makefile.in
- Apache 默认需要依赖
pcre
软件,但由于 Apache 软件版本较高,则系统预安装的pcre
无法使用, 所以需要人为手动安装适合版本
[aaa@qq.com pcre-8.34] cd /lamp/pcre-8.34
[aaa@qq.com pcre-8.34] ./configure && make && make install
- Apache 的加密传输模块
mod_ssl
,需要安装此软件产生
[aaa@qq.com pcre-8.34] yum install openssl-devel
-
httpd
软件安装
[aaa@qq.com httpd-2.4.7] cd /lamp/httpd-2.4.7
[aaa@qq.com 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
[aaa@qq.com httpd-2.4.7] make && make install
若前面配置 zlib 时没有指定安装目录,Apache 配置时不要添加–with-z=/usr/local/zlib/参数, --enable-ssl 选项是为了后期实现 https 提前设置的参数
- 启动
Apache
测试
- 在开始启动的过程中发现了一个报错
# 报错如下
[aaa@qq.com httpd-2.4.7] /usr/local/apache2/bin/apachectl start
AH00557: httpd: apr_sockaddr_info_get() failed for idyslamp
AH00558: httpd: Could not reliably determine the server's fully qualified domain name, using 127.0.0.1. Set the 'ServerName' directive globally to suppress this message
- 修改apache的配置文件
/usr/local/apache2/etc/httpd.conf
,修改190行的配置文件
[aaa@qq.com httpd-2.4.7] vim /usr/local/apache2/etc/httpd.conf
# 修改如下
ServerName localhost:80
- 再次启动apache
[aaa@qq.com httpd-2.4.7] /usr/local/apache2/bin/apachectl start
httpd (pid 98752) already running
# 现在80端口,已经运行
[aaa@qq.com httpd-2.4.7] netstat -lntp
Active Internet connections (only servers)
Proto Recv-Q Send-Q Local Address Foreign Address State PID/Program name
tcp 0 0 0.0.0.0:22 0.0.0.0:* LISTEN 1384/sshd
tcp 0 0 127.0.0.1:25 0.0.0.0:* LISTEN 1463/master
tcp 0 0 :::80 :::* LISTEN 98752/http
# 查看apache 进程是否正在运行
[aaa@qq.com httpd-2.4.7] ps aux | grep httpd
root 98752 0.0 0.1 75216 2804 ? Ss 21:13 0:00 /usr/local/apache2/bin/httpd -k start
daemon 98753 0.0 0.2 419476 4584 ? Sl 21:13 0:00 /usr/local/apache2/bin/httpd -k start
daemon 98754 0.0 0.2 419476 4588 ? Sl 21:13 0:00 /usr/local/apache2/bin/httpd -k start
daemon 98755 0.0 0.2 485012 4596 ? Sl 21:13 0:00 /usr/local/apache2/bin/httpd -k start
root 98843 0.0 0.0 103332 896 pts/2 S+ 21:20 0:00 grep httpd
- 在客户端浏览器的URL上输入
192.168.200.138:80
,你的话就是这样YOURSERVICEIP:80
,把IP改为你的服务器IP - 检查
apachectl
语法错误
[aaa@qq.com httpd-2.4.7] /usr/local/apache2/bin/apachectl -t
Syntax OK
# 关闭apache服务
[aaa@qq.com httpd-2.4.7] /usr/local/apache2/bin/apachectl stop
- 关于报错:
报错提示:若启动时提示/usr/local/apache2/modules/mod_deflate.so
无权限,可关闭 SELinux
解 决,类似此类.so
文件不能载入或没有权限的问题,都是 SELinux 问题,MySQL
和 Apache
都可能有类 似问题。
安装mysql
安装依赖包
- 安装 ncurses
Ncurses 提供字符终端处理库,包括面板和菜单。它提供了一套控制光标,建立窗口,改变前景背景颜色以及处理鼠标操作的函数。使用户在字符终端下编写应用程序时绕过了那些恼人的底层机制。简而言之,他是一个可以使应用程序直接控制终端屏幕显示的函数库。
[aaa@qq.com httpd-2.4.7] cd /lamp/ncurses-5.9
[aaa@qq.com ncurses-5.9] yum -y install ncurses-devel
# 检测
[aaa@qq.com ncurses-5.9] ./configure --with-shared --without-debug --without-ada --enable-overwrite
# 编译,安装
[aaa@qq.com ncurses-5.9] make && make install;echo $?
- 安装cmake 和 bison
mysql 在 5.5 以后,不再使用./configure 工具,进行编译安装。而使用cmake 工具替代了./configure 工具。bison 是一个*软件,用于自动生成语法分析器程序,可用于所有常见的操作系统
# 安装cmake
[aaa@qq.com ncurses-5.9] yum -y install cmake bison;echo $?
安装mysql
- 创建Mysql系统用户
[aaa@qq.com ~] useradd -r -s /sbin/nologin mysql
[aaa@qq.com ~] cat /etc/passwd | grep mysql
mysql:x:498:498::/home/mysql:/sbin/nologin
- 检查、编译、并且安装mysql
# 检查
[aaa@qq.com mysql] 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
# 编译安装,然后查看是否允许
[aaa@qq.com mysql] make && make install && echo $?
- 更改Mysql目录的用户归属
[aaa@qq.com mysql] cd /usr/local/mysql/
[aaa@qq.com mysql] chown -R root .
[aaa@qq.com mysql] chown -R mysql data
- 复制Mysql配置文件,并且初始化授权表
# 生成配置文件
[aaa@qq.com mysql] cp -a /lamp/mysql-5.5.48/support-files/my-medium.cnf /etc/my.cnf
# 创建数据库授权表
[aaa@qq.com mysql] ./scripts/mysql_install_db --user=mysql
- 启动Mysql服务
[aaa@qq.com mysql] ./bin/mysqld_safe --user=mysql
- 添加Mysq用户名密码
[aaa@qq.com ~] /usr/local/mysql/bin/mysqladmin -uroot password root
- 登录Mysql
[aaa@qq.com ~] /usr/local/mysql/bin/mysql -uroot -proot
- mysql的一些基本操作
# 使用mysql这个数据库
use mysql;
# 展示mysql下有几个数据库
show databases;
# 查看有所有的表
show tables
# 查询mysql
mysql> select User,Password from user;
安装PHP
PHP基本安装
- 检查、编译、安装
[aaa@qq.comidyslamp 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 && echo $?
- 复制php配置文件
[aaa@qq.com php-7.0.7] mkdir /usr/local/php/etc
[aaa@qq.com php-7.0.7] cp php.ini-production /usr/local/php/etc/php.ini
- 修改Apache配置文件,使其识别
*.php
文件,并能通过 php 模块调用 php 进行页面解析
[aaa@qq.com /] vim /usr/local/apache2/etc/httpd.conf
# 添加如下代码
AddType application/x-httpd-php .php .phtml
AddType application/x-httpd-php-source .phps
- 开启Apache服务
[aaa@qq.com /] /usr/local/apache2/bin/apachectl start
- 在目录下编写
php
文件,然后在浏览器访问,看其是否可以解析
[aaa@qq.com /] cd /usr/local/apache2/htdocs/
[aaa@qq.com htdocs] vim test.php
<?php
phpinfo();
?>
php附加扩展安装
- 安装openssl,为其提供加密
# 将某个配置文件改名
[aaa@qq.com openssl] mv config0.m4 config.m4
# 生成编译文件
[aaa@qq.com openssl] /usr/local/php/bin/phpize
# 检查、编译、安装
[aaa@qq.com openssl] ./configure --with-openssl --with-php-config=/usr/local/php/bin/php-config && make && make install && echo $?
- 为php安装
memcache
模块
# 进入目录
[aaa@qq.com openssl] cd /lamp/pecl-memcache-php7
# 生成configure文件
[aaa@qq.com pecl-memcache-php7] /usr/local/php/bin/phpize
# 检查、编译、安装
[aaa@qq.com pecl-memcache-php7] ./configure --with-php-config=/usr/local/php/bin/php-config && make && make install && echo $?
- 修改
php
配置文件,使其识别并调用openssl
和memcache
两个模块
# 编译php配置文件
[aaa@qq.com pecl-memcache-php7] vim /usr/local/php/etc/php.ini
# 添加如下内容
extension_dir="/usr/local/php/lib/php/extensions/no-debug-zts-20151012/"
# 取消分号注释,并添加以上路径(此路径来自于模块安装命令的结果)
extension="openssl.so";
extension="memcache.so";
# 添加以上两个库文件的调用
- 安装
memcached
服务
# yum 安装libevent-devel
[aaa@qq.com pecl-memcache-php7] yum -y install libevent-devel
# 检查、安装、编译
[aaa@qq.com memcached-1.4.17] ./configure --prefix=/usr/local/memcache && make && make install && echo $?
# 添加memcache用户
[aaa@qq.com memcached-1.4.17] useradd -r -s /sbin/nologin memcache
# 后台启动memcache服务
[aaa@qq.com memcached-1.4.17] /usr/local/memcache/bin/memcached -umemcache &
# 查询memcache是否安装成功
[aaa@qq.com memcached-1.4.17] netstat -an | grep :11211
- 部署
phpmyadmin
# 复制文件夹
[aaa@qq.com lamp] cp -a phpMyAdmin-4.1.4-all-languages /usr/local/apache2/htdocs/phpmyadmin
# 进入安装目录
[aaa@qq.com lamp] cd /usr/local/apache2/htdocs/phpmyadmin/
# 修改配置文件
[aaa@qq.com phpmyadmin] cp -a config.sample.inc.php config.inc.php
[aaa@qq.com phpmyadmin] vim config.inc.php
#做出如下修改
$cfg['Servers'][$i]['auth_type'] = 'http';
$cfg['Servers'][$i]['auth_type'] = 'cookie';
- 设置
Apache、MySQL、Memcache
开机自启
借助系统自带脚本/etc/rc.local
,此脚本开机后会自动加载,我们可以将源码安装的服务启动命令 写入该脚本,间接实现开机自启动
[aaa@qq.com htdocs] vim /etc/rc.local
#!/bin/sh
#
# This script will be executed *after* all the other init scripts.
# You can put your own initialization stuff in here if you don't
# want to do the full Sys V style init stuff.
touch /var/lock/subsys/local
/usr/local/apache2/bin/apachectl start
/usr/local/mysql/bin/mysqld_safe --user=mysql &
/usr/local/memcache/bin/memcached -umemcache &
CentOS7上搭建LAMP
环境准备
- 首先关闭防火墙
[aaa@qq.com ~] systemctl stop firewalld
[aaa@qq.com ~] systemctl disable firewalld
Removed symlink /etc/systemd/system/multi-user.target.wants/firewalld.service.
Removed symlink /etc/systemd/system/dbus-org.fedoraproject.FirewallD1.service.
# 查看防火墙规则,可以显示防火墙已经全部关闭了
[aaa@qq.com ~] iptables -F
- 关闭
SElinux
# 查看SELinux状态
[aaa@qq.com ~] getenforce
Enforcing
[aaa@qq.com ~] setenforce 0
Permissive
[aaa@qq.com ~] vi /etc/selinux/config
SELINUX=disabled
- 挂载光驱文件
[aaa@qq.com ~] vim /etc/fstab
# 添加以下行
UUID=2019-09-09-19-08-41-00 /media/cdrom iso9660 defaults 0 0
# 然后依据配置文件全部挂载
[aaa@qq.com ~] mount -a
- 配置本地
yum
源,做出如下修改
[aaa@qq.com yum.repos.d] vi CentOS-Media.repo
[c7-media]
name=CentOS-$releasever - Media
baseurl=file:///media/cdrom/
#baseurl=file:///media/CentOS/
# file:///media/cdrom/
# file:///media/cdrecorder/
gpgcheck=1
enabled=1
gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-CentOS-7
- 将
CentOS-Base.repo
改名
[aaa@qq.com yum.repos.d] mv CentOS-Base.repo CentOS-Base.repo.bak
- 安装
gcc
、gcc-c++
、make
等编译工具
[aaa@qq.com yum.repos.d] yum -y install gcc gcc-c++ make;echo $? #使用echo $? 是为了查看是否执行成功
- 查看是否有安装
Apache
和mysql
服务
[aaa@qq.com /] systemctl list-unit-files | grep -E "httpd|mysqld"
-
上传
lamp
环境所必备的源码包 -
安装unzip,然后解压
LAMP
环境源码包到指定路径
[aaa@qq.com tmp] yum -y install unzip
# 将其解压到/lamp目录下
unzip LAMP-php7.zip -d /lamp/
10 .解压lamp目录下所有压缩文件
cd /lamp/
mv LAMP-php7/* ./
rmdir LAMP-php7/
ls ./*.gz | xargs -n1 -i tar -xvf {} # 解压所有以.gz结尾的压缩文件
unzip pecl-memcache-php7.zip # 再解压这个文件
编译安装
- 安装
libxml2
- 安装编译安装依赖的包
[aaa@qq.com lamp] yum -y install libxml2-devel python-devel;echo $?
- 检查
[aaa@qq.com libxml2-2.9.1] ./configure --prefix=/usr/local/libxml2
- 编译、安装
[aaa@qq.com libxml2-2.9.1] make && make install;echo $?
- 安装
libcrypt
- 检查环境
[aaa@qq.com libmcrypt-2.5.8] ./configure --prefix=/usr/local/libmcrypt;echo $?
- 编译安装
[aaa@qq.com libmcrypt-2.5.8] make && make install;echo $?
- 安装
libltdl
,在libmcrypt
目录下
- 进入目录
[aaa@qq.com libmcrypt-2.5.8] cd /lamp/libmcrypt-2.5.8/libltdl/
- 检查
[aaa@qq.com libltdl] ./configure --enable-ltdl-install;echo $?
- 编译安装
[aaa@qq.com libltdl] make && make install;echo $?
- 编译安装mhash
- 进入目录
[aaa@qq.com libltdl] cd /lamp/mhash-0.9.9.9
- 检查
[aaa@qq.com mhash-0.9.9.9] ./configure;echo $?
- 编译安装
[aaa@qq.com mhash-0.9.9.9] make && make install;echo $?
- 安装
mcrypt
- 定义
LD_LIBRARY_PATH
用于指定libmcrypt
和mhash
的位置
[aaa@qq.com mcrypt-2.6.8] export LD_LIBRARY_PATH=/usr/local/libmcrypt/lib:/usr/local/lib
- 检查
[aaa@qq.com mcrypt-2.6.8] ./configure --with-libmcrypt-prefix=/usr/local/libmcrypt/
- 编译安装
[aaa@qq.com mcrypt-2.6.8] make && make install;echo $?
- 安装
zlib
- 进入目录
[aaa@qq.com mcrypt-2.6.8] cd /lamp/zlib-1.2.3
- 检查
[aaa@qq.com zlib-1.2.3] ./configure;echo $?
- 编辑该目录下的
MakeFile
文件 在CFLAGS最后上加上-fPIC
注意是小f
大PIC
[aaa@qq.com zlib-1.2.3] vi Makefile
CFLAGS=-O3 -DUSE_MMAP -fPIC #隔一个空格然后加上-fPIC
- 编译安装
[aaa@qq.com zlib-1.2.3] make && make install;echo $?
- 安装
libpng
- 进入目录
[aaa@qq.com zlib-1.2.3] cd /lamp/libpng-1.2.31
- 检查
[aaa@qq.com libpng-1.2.31] ./configure --prefix=/usr/local/libpng
- 编译安装
[aaa@qq.com libpng-1.2.31] make && make install;echo $?
- 安装
jpeg6
- 创建目录
[aaa@qq.com libpng-1.2.31] mkdir -p /usr/local/jpeg6/{bin,lib,include,man/man1}
- 查看目录创建情况
[aaa@qq.com libpng-1.2.31] tree /usr/local/jpeg6/
/usr/local/jpeg6/
├── bin
├── include
├── lib
└── man
└── man1
5 directories, 0 files
- 查看
libtool
软件包
[aaa@qq.com libpng-1.2.31] yum list | grep libtool
libtool-ltdl.x86_64 2.4.2-22.el7_3 @anaconda
libtool.x86_64 2.4.2-22.el7_3 c7-media
libtool-ltdl.i686 2.4.2-22.el7_3 c7-media
libtool-ltdl-devel.i686 2.4.2-22.el7_3 c7-media
libtool-ltdl-devel.x86_64 2.4.2-22.el7_3 c7-media
- 安装依赖软件包
[aaa@qq.com libpng-1.2.31] yum -y install libtool*
- 赋值模板文件到源码包目录下
[aaa@qq.com jpeg-6b] cp -ai /usr/share/libtool/config/{config.sub , config.guess} ./
- 检查
[aaa@qq.com jpeg-6b] ./configure --prefix=/usr/local/jpeg6/ --enable-shared --enable-static
–enable-shared 与–enable-static 参数分别为建立共享库和静态库使用的 libtool
- 编译安装
[aaa@qq.com jpeg-6b] make && make install;echo $?
- 安装
freetype
- 检查
[aaa@qq.com jpeg-6b] cd /lamp/freetype-2.3.5
[aaa@qq.com freetype-2.3.5] ./configure --prefix=/usr/local/freetype;echo $?
- 编译、安装
[aaa@qq.com freetype-2.3.5] make && make install;echo $?
- 安装
Apache
- 源码包
2.4.*
版本中默认没有集成 apr 的依赖包,所以需要提前解决依赖问题
[aaa@qq.com httpd-2.4.7] cp -a /lamp/apr-1.4.6 /lamp/httpd-2.4.7/srclib/apr
[aaa@qq.com httpd-2.4.7] cp -a /lamp/apr-util-1.4.1 /lamp/httpd-2.4.7/srclib/apr-util
解压 apr 和 apr-util,复制整个目录并取消目录上的版本号到指定位置,./configure 时会检测
- .Apache 默认需要依赖 pcre 软件,但由于 Apache 软件版本较高,则系统预安装的 pcre 无法使用, 所以需要人为手动安装适合版本
[aaa@qq.com httpd-2.4.7] cd /lamp/pcre-8.34
[aaa@qq.com pcre-8.34] ./configure;echo $?
make && make install;echo $?
-
Apache
的加密传输模块mod_ssl
,需要安装此软件产生
[aaa@qq.com pcre-8.34] yum -y install openssl-devel
-
httpd
软件安装
# 检查
[aaa@qq.com 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
# 编译安装
[aaa@qq.com httpd-2.4.7] make && make install;echo $?
若前面配置 zlib 时没有指定安装目录,Apache 配置时不要添加
--with-z=/usr/local/zlib/
参数,--enable-ssl
选项是为了后期实现https
提前设置的参数
- 启动
Apache
测试
# 修改Apache的配置文件httpd.conf
[aaa@qq.com httpd-2.4.7] vim /usr/local/apache2/etc/httpd.conf
# 在190行左右,修改Servername的配置为 localhost:80
ServerName localhost:80
# 启动Apache
[aaa@qq.com httpd-2.4.7] /usr/local/apache2/bin/apachectl start
# 查看Apache启动状态
[aaa@qq.com httpd-2.4.7] ps aun | grep httpd
0 84129 0.0 0.0 110276 884 pts/0 S+ 10:34 0:00 grep --color=auto httpd
[aaa@qq.com httpd-2.4.7] netstat -tlun | grep 80
tcp6 0 0 :::80 :::* LISTEN
注意事项:在 CentOS 7 操作系统上 Apache 默认监听了 Ipv6 地址的 80 端口,没有监听 Ipv4 的地址, 所以需要修改下配置文件使其监听。 Listen 0.0.0.0:80,但是我发现其实没有修改这个选项,也可以访问Apache,只不过监听端口为tcp6的监听端口
- 安装
ncurses
[aaa@qq.com httpd-2.4.7] yum -y install ncurses-devel
- 检查
[aaa@qq.com ncurses-5.9] ./configure --with-shared --without-debug --without-ada --enable-overwrite
[aaa@qq.com ncurses-5.9] echo $?
0
- 安装编译
[aaa@qq.com ncurses-5.9] make && make install;echo $?
若不安装 ncurses 编译 MySQL 时会报错
- 安装
cmake
和bison
[aaa@qq.com ncurses-5.9] yum -y install bison
- 安装Mysql
- 创建用户
[aaa@qq.com ncurses-5.9] adduser -r -s /sbin/nologin mysql
cmake
[aaa@qq.com 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;echo $?
- 编译安装
[aaa@qq.com mysql-5.5.48] make && make install;echo $?
- 选项说明
选项 | 作用 |
---|---|
-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 目录的用户归属
[aaa@qq.com mysql-5.5.48] cd /usr/local/mysql/
[aaa@qq.com mysql] chown -R root .
[aaa@qq.com mysql] chown -R mysql data
- 生成配置文件,并初始化授权表
[aaa@qq.com mysql] cp -a /lamp/mysql-5.5.48/support-files/my-medium.cnf /etc/my.cnf
cp: overwrite ‘/etc/my.cnf’? y
# 复制 MySQL 配置文件到指定位置,覆盖掉系统自带文件
- 创建数据库授权表,初始化数据库,相当于安装完操作系统后的引导设置(添加第一个用户)
[aaa@qq.com mysql] ./scripts/mysql_install_db --user=mysql
- 启动
mysql
[aaa@qq.com mysql] /usr/local/mysql/bin/mysqld_safe --user=mysql
- 设定
mysql
用户名密码
[aaa@qq.com mysql] bin/mysqladmin -uroot -password 123456
- 登录mysql
[aaa@qq.com mysql] bin/mysql -u root -p123456
- 安装PHP
[aaa@qq.com mysql] cd /lamp/php-7.0.7
[aaa@qq.com 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
[aaa@qq.com php-7.0.7] echo $?
0
[aaa@qq.com php-7.0.7] make && make install;echo $?
- 配置参数说明
选项 | 作用 |
---|---|
–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
安装后需要调整相应配置文件和参数才能正常运行
- 生成 php 配置文件
[aaa@qq.com php-7.0.7] cd /usr/local/php/
[aaa@qq.com php] mkdir etc
[aaa@qq.com php] cp /lamp/php-7.0.7/php.ini-production ./etc/php.ini
- 修改
Apache
配置文件,使其识别*.php
文件,并能通过 php 模块调用 php 进行页面解析
[aaa@qq.com php] vim /usr/local/apache2/etc/httpd.conf
# 在最后一行添加以下内容
AddType application/x-httpd-php .php .phtml
AddType application/x-httpd-php-source .phps
- 重启
Apache
服务
[aaa@qq.com htdocs] ../bin/apachectl stop
[aaa@qq.com htdocs] ../bin/apachectl start
- 测试 php 页面是否能正常解析(即 apache 和 php 连通性)
[aaa@qq.com htdocs] vim test.php
# 添加如下内容
<?php
phpinfo();
?>
通过浏览器输入地址访问:
http://Apache 服务器地址/test.php
- 为 PHP 安装 openssl 模块
[aaa@qq.com ~] cd /lamp/php-7.0.7
[aaa@qq.com php-7.0.7] cd ext/openssl/
[aaa@qq.com openssl] mv config0.m4 config.m4
# 生成编译工具
[aaa@qq.com openssl] /usr/local/php/bin/phpize
Configuring for:
PHP Api Version: 20151012
Zend Module Api No: 20151012
Zend Extension Api No: 320151012
[aaa@qq.com openssl] ./configure --with-openssl --with-php-config=/usr/local/php/bin/php-config
[aaa@qq.com openssl] echo $?
0
[aaa@qq.com openssl] make && make install;echo $?
- 为
PHP
安装memcache
模块
[aaa@qq.com openssl] cd /lamp/pecl-memcache-php7
# 生成编译工具
[aaa@qq.com pecl-memcache-php7] /usr/local/php/bin/phpize
[aaa@qq.com pecl-memcache-php7] ./configure --with-php-config=/usr/local/php/bin/php-config;echo $?
[aaa@qq.com pecl-memcache-php7] make && make install;echo $?
- 修改
php
配置文件,使其识别并调用openssl
和memcache
两个模块
[aaa@qq.com pecl-memcache-php7] cd /usr/local/php/etc/
[aaa@qq.com etc] vim php.ini
# 添加如下内容,此路径来自模块安装命令的结果
extension_dir="/usr/local/php/lib/php/extensions/no-debug-zts-20151012/"
# (添加两个库文件的调用)
extension="openssl.so";
extension="memcache.so";
- 重启
apache
,刷新phpinfo
页面,并查看是否有两个新增的模块
- 安装
memcached
服务
# 下载安装包
[aaa@qq.com tmp] wget http://mirror.centos.org/centos/7/os/x86_64/Packages/libevent-devel-2.0.21-4.el7.x86_64.rpm
[aaa@qq.com tmp] yum -y install libevent-devel
[aaa@qq.com lamp] cd /lamp/memcached-1.4.17
[aaa@qq.com memcached-1.4.17] ./configure --prefix=/usr/local/memcache
[aaa@qq.com memcached-1.4.17] make && make install;echo $?
- 添加
memcache
用户,同时开启memcache
服务
[aaa@qq.com memcached-1.4.17] useradd -r -s /sbin/nologin memcache
# 添加 memcache 用户,此用户不用登录,不设置密码
/usr/local/memcache/bin/memcached -umemcache &
#启动 memcache 服务,并设置为后台运行
[aaa@qq.com memcached-1.4.17] netstat -an | grep :11211
tcp 0 0 0.0.0.0:11211 0.0.0.0:* LISTEN
tcp6 0 0 :::11211 :::* LISTEN
udp 0 0 0.0.0.0:11211 0.0.0.0:*
udp6 0 0 :::11211 :::*
检查 memcache 是否正常启动,并监听了 11211 端口
- 安装
phpMyAdmin
# 复制文件
[aaa@qq.com memcached-1.4.17] cp -a /lamp/phpMyAdmin-4.1.4-all-languages /usr/local/apache2/htdocs/phpmyadmin
[aaa@qq.com memcached-1.4.17] cd /usr/local/apache2/htdocs/phpmyadmin/
[aaa@qq.com phpmyadmin] cp -a config.sample.inc.php config.inc.php
$cfg['Servers'][$i]['auth_type'] = 'cookie'; #在这行下面添加$cfg['Servers'][$i]['auth_type'] = 'http'; 含义设置 auth_type 为 http ,即设置为 HTTP 身份认证模式
$cfg['Servers'][$i]['auth_type'] = 'http';
- 输入
http://YOURIPADDR/phpmyadmin/index.php
- 然后输入你设置的
mysql
用户名和密码
- 设置
Apache、MySQL、Memcache
开机自启
- 借助系统自带脚本
/etc/rc.local
,此脚本开机后会自动加载,我们可以将源码安装的服务启动命令写入该脚本,间接实现开机自启动
# 编辑rc.local文件,添加如下3行
[aaa@qq.com phpmyadmin] vim /etc/rc.local
/usr/local/apache2/bin/apachectl start
/usr/local/mysql/bin/mysqld_safe --user=mysql &
/usr/local/memcache/bin/memcached -umemcache &
- 项目发布
- 把 php 项目拷贝到网站默认目录下:
/usr/local/apache2/htdocs/**
- 使用
phpMyAdmin
创建网站所需数据库
注意事项:注意目录权限和归属,防止权限过大或者权限过小
# 下载一个blog项目
[aaa@qq.com lamp] wget http://typecho.org/downloads/1.1-17.10.30-release.tar.gz
[aaa@qq.com lamp] tar -zxvf 1.1-17.10.30-release.tar.gz 解压项目
将项目移动到Apache的htdocs下,并且改名为blog
[aaa@qq.com lamp] cp -a build /usr/local/apache2/htdocs/blog
# 查看Apache运行的用户实例
[aaa@qq.com lamp] ps aux | grep httpd
root 101685 0.0 0.5 263632 11400 ? Ss 17:10 0:00 /usr/local/apache2/bin/httpd -k start
daemon 101687 0.0 1.1 815796 23728 ? Sl 17:10 0:00 /usr/local/apache2/bin/httpd -k start
daemon 101688 0.0 1.6 890220 32496 ? Sl 17:10 0:00 /usr/local/apache2/bin/httpd -k start
daemon 101689 0.0 1.7 890112 34500 ? Sl 17:10 0:00 /usr/local/apache2/bin/httpd -k start
daemon 101771 0.0 1.3 817764 26860 ? Sl 17:10 0:00 /usr/local/apache2/bin/httpd -k start
root 103233 0.0 0.0 112716 960 pts/0 S+ 17:57 0:00 grep --color=auto httpd
# 给运行apache的用户赋予对博客目录的权限
[aaa@qq.com lamp] setfacl -m u:daemon:rwx /usr/local/apache2/htdocs/blog/
写在最后的话:
- 无论每个知识点的难易程度如何,我都会尽力将它描绘得足够细致
- 欢迎关注我的CSDN博客,IDYS’BLOG
-
持续更新内容:
linux基础 | 数据通信(路由交换,WLAN) | Python基础 | 云计算 - 如果你有什么疑问,或者是难题。欢迎评论或者私信我。你若留言,我必回复!
- 虽然我现在还很渺小,但我会做好每一篇内容。谢谢关注!
推荐阅读
-
j2ee 简单网站搭建:(二)添加和配置 spring + spring-mvc 的 mvc 开发环境
-
LAMP(Linux+Apache+MySQL+PHP)环境介绍、配置、搭建
-
深入理解Maven环境搭建和介绍
-
第二十二记·Spark Standalone环境搭建 监听历史服务配置
-
LAMP环境搭建与配置(三)
-
Java 开发环境配置步骤(介绍)
-
Mac系统下使用brew搭建PHP(LNMP/LAMP)开发环境_PHP
-
WindowsXP搭建PHP环境 博客分类: 技术简介 PHPApacheIIS配置管理ASP.net
-
快应用配置环境(简单搭建一个helloworld)注意事项
-
windows下zendframework项目环境搭建(通过命令行配置)