LAMP平台搭建-Centos7

LAMP平台搭建-Centos7

准备工作:

  • 系统:centos7以上
  • 关闭对应的firewalld和selinux
#关闭selinux和防火墙
[root@node0 ~]# systemctl disable firewalld
Removed symlink /etc/systemd/system/multi-user.target.wants/firewalld.service.
Removed symlink /etc/systemd/system/dbus-org.fedoraproject.FirewallD1.service.
[root@node0 ~]# systemctl stop firewalld
[root@node0 ~]# getenforce 
Disabled
#准备好本地yum源
[root@node0 ~]# cd /etc/yum.repos.d/
[root@node0 yum.repos.d]# vim local.repo 
[local]
name=local-epel
baseurl=file:///mnt/cdrom
enabled=1
gpgcheck=0
[root@node0 ~]# mount /dev/cdrom /mnt/cdrom/
mount: /dev/sr0 写保护,将以只读方式挂载

0.安装gcc、gcc-c++等工具

[root@node0 ~]# yum -y install gcc gcc-c++

#准备好源码包
root@node0 ~]# mkdir /lamp
[root@node0 lamp]# ls
anaconda-ks.cfg        jpegsrc.v6b.tar.gz      ncurses-5.6.tar.gz
autoconf-2.61.tar.gz   libmcrypt-2.5.8.tar.gz  php-5.2.6.tar.gz
freetype-2.3.5.tar.gz  libpng-1.2.31.tar.gz    phpMyAdmin-3.0.0-rc1-all-languages.tar.gz
gd-2.0.35.tar.gz       libxml2-2.6.30.tar.gz   ZendOptimizer-3.2.6-linux-glibc21-i386.tar.gz
httpd-2.2.9.tar.gz     mysql-5.0.41.tar.gz     zlib-1.2.3.tar.gz

#创建一个脚本-->用于解压这么多的包
[root@node0 lamp]# vim tar.sh
#!/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

#执行脚本
[root@node0 lamp]# bash tar.sh 

编译安装从这里开始

1、安装libxml2

#安装对应的依赖包
[root@node0 lamp]# yum -y install libxml2-devel python-devel
#编译安装
[root@node0 lamp]# cd /lamp/libxml2-2.6.30/
[root@node0 libxml2-2.6.30]# ./configure --prefix=/usr/local/libxml2/ && make && make install

2、安装libmcrypt

[root@node0 libxml2-2.6.30]# cd /lamp/libmcrypt-2.5.8/
[root@node0 libmcrypt-2.5.8]# ./configure --prefix=/usr/local/libmcrypt && make && make install

#需要安装一个libltdl,也在libmcrypt源码目录当中
[root@node0 libmcrypt-2.5.8]# cd /lamp/libmcrypt-2.5.8/libltdl/
[root@node0 libltdl]# ./configure --enable-ltdl-install && make && make install

3、安装mhash

[root@node0 lamp]# cd /lamp/mhash-0.9.9.9/ 
[root@node0 mhash-0.9.9.9]# ./configure  && make && make install

4、安装mcrypt

[root@node0 mhash-0.9.9.9]# cd /lamp/mcrypt-2.6.8/
#调整一下环境变量,变量:LD_LIBRARY_PATH 用于指定 libmcrypt 和 mhash 的库的位置
[root@node0 mcrypt-2.6.8]# export LD_LIBRARY_PATH=/usr/local/libmcrypt/lib:/usr/local/lib
[root@node0 mcrypt-2.6.8]#  ./configure --with-libmcrypt-prefix=/usr/local/libmcrypt && make && make install
#编译安装
[root@node0 mcrypt-2.6.8]#  ./configure --with-libmcrypt-prefix=/usr/local/libmcrypt && make && make install

5、安装zlib

#进入目录
[root@node0 lamp]# cd /lamp/zlib-1.2.3.1/

#检测编译环境
[root@node0 zlib-1.2.3.1]# ./configure 

#修改Makefile文件--否则无法正常安装
	#找到 CFLAGS=-O3 -DUSE_MMAP,在后面加入 -fPIC 变成(注意:小 f 大 PIC,空格)
[root@node0 zlib-1.2.3.1]# vim Makefile
...............
CFLAGS=-O3 -DUSE_MMAP -fPIC
..........
[root@node0 zlib-1.2.3.1]# make && make install

6、安装libpng

[root@node0 zlib-1.2.3.1]# cd /lamp/libpng-1.2.31/
[root@node0 libpng-1.2.31]# ./configure --prefix=/usr/local/libpng && make && make install

7、安装jpeg6

#创建所需要的目录
[root@node0 libpng-1.2.31]# mkdir  /usr/local/jpeg6
[root@node0 libpng-1.2.31]# mkdir  /usr/local/jpeg6/bin
[root@node0 libpng-1.2.31]# mkdir  /usr/local/jpeg6/lib
[root@node0 libpng-1.2.31]# mkdir  /usr/local/jpeg6/include
[root@node0 libpng-1.2.31]# mkdir -p /usr/local/jpeg6/man/man1

#安装必要的依赖
[root@node0 libpng-1.2.31]# yum -y install libtool*
[root@node0 libpng-1.2.31]# cd /lamp/jpeg-6b/
#复制 libtool 中的文件,覆盖 jpeg-6b 中的文件(64 位中的问题)
[root@node0 jpeg-6b]# cp -a /usr/share/libtool/config/config.sub ./
cp:是否覆盖"./config.sub"? y
[root@node0 jpeg-6b]# cp -a /usr/share/libtool/config/config.guess ./
cp:是否覆盖"./config.guess"? y

#编译安装
	#--enable-shared 与--enable-static 参数分别为建立共享库和静态库使用的 libtool
[root@node0 jpeg-6b]#  ./configure --prefix=/usr/local/jpeg6/ --enable-shared --enable-static && make && make install

8、安装freetype

[root@node0 jpeg-6b]# cd /lamp/freetype-2.3.5/
[root@node0 freetype-2.3.5]# 
[root@node0 freetype-2.3.5]#  ./configure --prefix=/usr/local/freetype/ && make && make install

9、安装apache

#首先解决一下依赖apr的依赖包
[root@node0 freetype-2.3.5]# cp -a /lamp/apr-1.4.6 /lamp/httpd-2.4.7/srclib/apr
[root@node0 freetype-2.3.5]# cp -a /lamp/apr-util-1.4.1 /lamp/httpd-2.4.7/srclib/apr-util

#安装pcre依赖包
[root@node0 lamp]# cd pcre-8.34/
[root@node0 pcre-8.34]# 
[root@node0 pcre-8.34]# ./configure &&make  && make install

#安装一下openssl-->提供mod_ssl模块-->用于加密使用
[root@node0 pcre-8.34]# yum -y install openssl-devel

#开始安装apache
[root@node0 pcre-8.34]# cd /lamp/
[root@node0 lamp]# ./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
[root@node0 httpd-2.4.7]# make && make install

#apache简单调优
	#指定监听端口
	[root@node0 httpd-2.4.7]# vim /usr/local/apache2/etc/httpd.conf
.........
Listen 0.0.0.0:80

	#调整servername
[root@node0 httpd-2.4.7]# vim /usr/local/apache2/etc/httpd.conf
ServerName localhost:80

##启动apache
[root@node0 httpd-2.4.7]#  /usr/local/apache2/bin/apachectl start
[root@node0 httpd-2.4.7]# ps -aux | grep httpd
	#浏览器输入网址查看

10、安装ncurses

[root@node0 lamp]# cd /lamp/ncurses-5.9/
[root@node0 ncurses-5.9]# 
#安装对应的依赖包
[root@node0 ncurses-5.9]# yum -y install ncurses-devel
[root@node0 ncurses-5.9]# ./configure --with-shared --without-debug --without-ada --enable-overwrite &&make &&make install

11、安装cmake和bison

[root@node0 ncurses-5.9]# yum -y install cmake bison

12、安装mysql

#创建mysql的用户
[root@node0 ncurses-5.9]# cd /lamp/mysql-5.5.48/
[root@node0 mysql-5.5.48]# useradd -r -s /sbin/nologin mysql

#预编译安装
[root@node0 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
[root@node0 mysql-5.5.48]# 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的基础参数
	#修改mysql的目录归属
[root@node0 mysql-5.5.48]# cd /usr/local/mysql/
[root@node0 mysql]# chown -R mysql  data
	#生成配置文件
[root@node0 mysql]# cp -a /lamp/mysql-5.5.48/support-files/my-medium.cnf /etc/my.cnf
cp:是否覆盖"/etc/my.cnf"? y
	#创建数据库授权表,初始化数据库,相当于安装完操作系统后的引导设置(添加第一个用户)
[root@node0 mysql]# cd /usr/local/mysql/
[root@node0 mysql]# ./scripts/mysql_install_db --user=mysql

#启动mysql
[root@node0 mysql]# /usr/local/mysql/bin/mysqld_safe --user=mysql &

#启动后修改mysql的登陆密码
[root@node0 mysql]# /usr/local/mysql/bin/mysqladmin -uroot password 123456

#登陆查看一下
[root@node0 mysql]# /usr/local/mysql/bin/mysql -uroot -p123456
#到这里mysql安装完成

13、安装php

#进入目录
[root@node0 mysql]# cd /lamp/php-7.0.7/
[root@node0 php-7.0.7]# 

#预编译、编译安装
[root@node0 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
[root@node0 php-7.0.7]# 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的对应参数-->才能正常运行
	#生成php配置文件
[root@node0 php-7.0.7]# mkdir /usr/local/php/etc/
[root@node0 php-7.0.7]# cp /lamp/php-7.0.7/php.ini-production  /usr/local/php/etc/php.ini	
	#修改apache配置文件-->识别*.php文件,访问能够对php页面进行解析
[root@node0 php-7.0.7]# vim /usr/local/apache2/etc/httpd.conf
..........
    AddType application/x-httpd-php .php .phtml
    AddType application/x-httpd-php-source .phps
	#重启apache
[root@node0 php-7.0.7]# /usr/local/apache2/bin/apachectl stop
[root@node0 php-7.0.7]# /usr/local/apache2/bin/apachectl start

	#编写php页面
[root@node0 php-7.0.7]# vim /usr/local/apache2/htdocs/test.php
<?php   
        phpinfo();
?>

#浏览器输入地址查看-->能够解析出来证明php安装完成

14、php安装openssl模块

[root@node0 php-7.0.7]# cd /lamp/php-7.0.7/ext/openssl/
[root@node0 openssl]# mv config0.m4  config.m4
[root@node0 openssl]# /usr/local/php/bin/phpize 
[root@node0 openssl]# ./configure --with-openssl --with-php-config=/usr/local/php/bin/php-config && make && make install

15、php安装memcache模块

[root@node0 lamp]# cd /lamp/
[root@node0 lamp]# unzip pecl-memcache-php7.zip 
[root@node0 lamp]# cd /lamp/pecl-memcache-php7/
[root@node0 pecl-memcache-php7]# 
[root@node0 pecl-memcache-php7]# /usr/local/php/bin/phpize 
[root@node0 pecl-memcache-php7]# ./configure --with-php-config=/usr/local/php/bin/php-config && make && make install

16、修改php配置文件,调用openssl和memcache模块

[root@node0 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";

#重启apache,刷新phpinfo页面-->检查是有有这两个模块
[root@node0 pecl-memcache-php7]# /usr/local/apache2/bin/apachectl stop
[root@node0 pecl-memcache-php7]# /usr/local/apache2/bin/apachectl start

17、安装memcached服务

#安装依赖-libevent-devel
[root@node0 ~]# ls
libevent-devel-2.0.21-4.el7.x86_64.rpm
[root@node0 ~]# yum -y install ./libevent-devel-2.0.21-4.el7.x86_64.rpm 

#预编译、编译、安装
[root@node0 ~]# cd /lamp/memcached-1.4.17/
[root@node0 memcached-1.4.17]# ./configure --prefix=/usr/local/memcache && make && make install

#添加memcache用户
[root@node0 memcached-1.4.17]# useradd -r -s /sbin/nologin memcache

#启动查看端口
[root@node0 memcached-1.4.17]# /usr/local/memcache/bin/memcached -umemcache &
[2] 38764
[root@node0 memcached-1.4.17]# ss -antulp | grep :11211

18、安装phpMyAdmin

#把目录直接复制到apache的发布目录路径
[root@node0 memcached-1.4.17]# cp -a /lamp/phpMyAdmin-4.1.4-all-languages /usr/local/apache2/htdocs/phpmyadmin
[root@node0 memcached-1.4.17]# 

#调整一下文件-->设置 auth_type 为 http ,即设置为 HTTP 身份认证模式(新增即可)
[root@node0 memcached-1.4.17]# cd /usr/local/apache2/htdocs/phpmyadmin/
[root@node0 phpmyadmin]# cp -a config.sample.inc.php config.inc.php 
[root@node0 phpmyadmin]# vim config.inc.php 
.......
$cfg['Servers'][$i]['auth_type'] = 'cookie';
$cfg['Servers'][$i]['auth_type'] = 'http';
...........

浏览器直接访问路径

  • http://192.168.75.130//phpmyadmin/index.php
  • 用户名:root(mysql的用户名)
  • 密码:123456

最后:设置开机自启动的服务即可

[root@node0 ~]# vim /etc/rc.local 
	#添加这三行-->ok
/usr/local/apache2/bin/apachectl start
/usr/local/mysql/bin/mysqld_safe --user=mysql &
/usr/local/memcache/bin/memcached -umemcache &

到这里实验结束~!

你可能感兴趣的:(Linux-服务管理,linux,运维,服务器)