部署 LAMP (CentOS 7.2)

来源:互联网 发布:资生堂淘宝旗舰店真吗 编辑:程序博客网 时间:2024/06/05 14:59

1、系统版本说明

  1. # cat /etc/redhat-release
  2. CentOS Linux release 7.2.1511 (Core)

注:这是本文档实施时参考的系统版本。您的实际使用版本可能与此不同,下文中的nginx,mysql,及php版本,您也可以根据实际情况选择相应版本。

2、关闭SELINUX

修改配置文件,重启服务后永久生效。

# sed -i 's/SELINUX=.*/SELINUX=disabled/g' /etc/selinux/config

命令行设置立即生效。

# setenforce 0

3、安全组设置

在ECS安全组放行需访问的端口和访问白名单,下面的示例表示允许所有IP访问服务器的80端口。您可以根据实际情况放行允许访问的客户端IP。

图片1



简介

LAMP指Linux+Apache+Mysql/MariaDB+Perl/PHP/Python是一组常用来搭建动态网站或者服务器的开源软件,本身都是各自独立的程序,但是因为常被放在一起使用,拥有了越来越高的兼容度,共同组成了一个强大的Web应用程序平台。

部署方式

在阿里云服务器下部署LAMP提供三种部署方式,镜像部署、一键安装包部署和手动部署(源码编译安装/YUM安装),一般推荐镜像部署适合新手使用更加快捷方便,安装包部署以及手动部署适合对Linux命令有基本了解的用户,可以满足用户个性化部署的要求。本教程主要介绍手动部署的方式。

手动部署

系统平台:CentOS 7.2

Apache版本:2.4.23

Mysql 版本:5.7.17

Php版本:7.0.12

安装前准备

A.
让VIM 自动显示行号

  输入命令:vim   ~/.vimrc

 打开后是一个空文件,我们添加 set nu,保存退出[Ecs ,  :wq ],再次进入vim编辑器,就会自动显示出行号了。



B.

CentOS 7.2系统默认开启了防火墙,需关闭后外部才可访问本机的80、21等端口,如需做安全类配置可自行参考官方文档。

关闭防火墙:

  1. systemctl stop firewalld.service

关闭防火墙开机自启动:

  1. systemctl disable firewalld.service

安装vim及unzip:

  1. yum install -y vim unzip

编译安装apache准备

编译安装apache前需要安装apr、apr-util和pcre软件包和相关依赖包。

  1. yum install -y gcc gcc-c++ autoconf libtool
安装apr

http://archive.apache.org/dist/apr/

http://archive.apache.org/dist/apr/apr-1.5.2.tar.gz


  1. cd /usr/local/src/
  2. wget http://oss.aliyuncs.com/aliyunecs/onekey/apache/apr-1.5.0.tar.gz
  3. tar zxvf apr-1.5.0.tar.gz
  4. cd apr-1.5.0
  5. ./configure --prefix=/usr/local/apr
  6. make && make install
安装apr-util
  1. cd /usr/local/src/
  2. wget http://oss.aliyuncs.com/aliyunecs/onekey/apache/apr-util-1.5.3.tar.gz
  3. tar zxvf apr-util-1.5.3.tar.gz
  4. cd apr-util-1.5.3
  5. ./configure --prefix=/usr/local/apr-util --with-apr=/usr/local/apr
  6. make && make install
安装pcre
  1. cd /usr/local/src/
  2. wget http://zy-res.oss-cn-hangzhou.aliyuncs.com/pcre/pcre-8.38.tar.gz
  3. tar zxvf pcre-8.38.tar.gz
  4. cd pcre-8.38
  5. ./configure --prefix=/usr/local/pcre
  6. make && make install
编译安装Apache, 开启 ssl

编译安装openssl

# cd /tmp# wget http://www.openssl.org/source/openssl-1.0.1.tar.gz# tar xzvf openssl-1.0.1.tar.gz# cd openssl-1.0.1# ./config --prefix=/usr/local/openssl -fPIC no-gost no-shared no-zlib # make && make install


乐意黎注: 

./config --prefix=/usr/local/openssl (注: )
install apache 在 加载openssl 模块时出现 “/usr/local/ssl/lib/libssl.a: could not read symbols: Bad value”错误解决方案.所以改用 
./config --prefix=/usr/local/openssl -fPIC no-gost no-shared no-zlib 

安装openssl这里设置路径为/usr/local/openssl,下文已经后续安装其它软件,凡是涉及到ssl的,也同样需要指定这个路径,因为我们没有按照系统默认的路径安装。

64位下成功解决方法:
openssl编译:
./config --prefix=${destination_dir} -fPIC no-gost no-shared no-zlib 
make depend ; make install
apache 编译方法照旧。


2017-06-05 测试通过

  1. cd /usr/local/src/
  2. wget http://zy-res.oss-cn-hangzhou.aliyuncs.com/apache/httpd-2.4.23.tar.gz
  3. tar zxvf httpd-2.4.23.tar.gz
  4. cd httpd-2.4.23//(不带SSL 的配置文件)
  5. ./configure \
  6. --prefix=/usr/local/apache --sysconfdir=/etc/httpd \
  7. --enable-so --enable-cgi --enable-rewrite \
  8. --with-zlib --with-pcre=/usr/local/pcre \
  9. --with-apr=/usr/local/apr \
  10. --with-apr-util=/usr/local/apr-util \
  11. --enable-mods-shared=most --enable-mpms-shared=all \
  12. --with-mpm=event
  13. //(乐意黎所用的带SSL配置文件)./configure --prefix=/usr/local/apache --sysconfdir=/etc/httpd \--enable-so --enable-cgi --enable-rewrite \--with-zlib --with-pcre=/usr/local/pcre \--enable-mods-shared=most --enable-mpms-shared=all \--with-apr=/usr/local/apr \--with-apr-util=/usr/local/apr-util --with-pcre=/usr/local/pcre \--enable-ssl --with-ssl=/usr/local/openssl \--with-mpm=event
  14. make && make install
修改httpd.conf配置文件参数
  1. cd /etc/httpd/
  2. vim httpd.conf

1.找到Directory参数,注释掉Require all denied添加Require all granted。

1

2.找到ServerName参数,添加ServerName localhost:80 然后,按Esc键后输入:wq保存退出。

2

设置PidFile路径
  1. vim /etc/httpd/httpd.conf

在配置文件最后添加以下内容:

  1. PidFile "/var/run/httpd.pid"
启动Apache服务并验证
  1. cd /usr/local/apache/bin/
  2. ./apachectl start
  3. netstat -tnlp #查看服务是否开启

3

在本地浏览器中输入云服务器的公网IP地址验证,出现下图表示安装成功。

4


配置rewrite规则实现访问http自动跳转到https

实现方法是定义一个.htaccess放在httdocs中,内容为:

[plain] view plain copy
 print?
  1. <IfModule mod_rewrite.c>  
  2.   Options +FollowSymlinks  
  3.   RewriteEngine On  
  4.   
  5.   RewriteCond %{SERVER_PORT} !^443$  
  6.   RewriteRule ^.*$ https://%{SERVER_NAME}%{REQUEST_URI} [L,R]  
  7.   
  8.   RewriteCond %{REQUEST_FILENAME} !-d  
  9.   RewriteCond %{REQUEST_FILENAME} !-f  
  10.   RewriteRule ^(.*)$ index.php/$1 [QSA,PT,L]  
  11.    
  12.   ErrorDocument 404 /404.html  
  13.   ErrorDocument 403 /404.html  
  14. </IfModule>  

特别说明:

     apache重新编译不会覆盖原有的httpd.conf文件,因此如果原有没有编译ssl的话,httpd.conf中必须手工加上mod_ssl.so模块配置



设置开机自启

在rc.local文件中添加/usr/local/apache/bin/apachectl start,然后输入:wq保存退出。

  1. vim /etc/rc.d/rc.local

5

设置环境变量
  1. vi /root/.bash_profile

在PATH=$PATH:$HOME/bin添加参数为:

  1. PATH=$PATH:$HOME/bin:/usr/local/apache/bin

然后输入:wq保存退出,执行:

  1. source /root/.bash_profile

编译安装MySQL前预准备

首先检查系统中是否存在使用rpm安装的mysql或者mariadb,如果有需要先删除后再编译安装。

  1. rpm -qa | grep mysql #由下至上依次卸载
  2. rpm -qa | grep mariadb
  3. rpm -e xxx #一般使用此命令即可卸载成功
  4. rpm -e --nodeps xxx #卸载不成功时使用此命令强制卸载

卸载完以后用 rpm -qa|grep mariadb 或者 rpm -qa|grep mysql 查看结果。

rpm -e --nodeps mariadb-libs-5.5.37-1.el7_0.x86_64

rpm -e mariadb-libs-5.5.52-1.el7.x86_64

rpm -e --nodeps mariadb-devel-5.5.52-1.el7.x86


  1. [root@localhost~]# rpm -aq|grep mariadb  
  2. mariadb-libs-5.5.50-1.e17_2.x86_64  
  3. mariadb-5.5.50-1.e17_2.x86_64  
  4. mariadb-server-5.5.50-1.e17_2.x86_64  
  5. [root@localhost~]# yum -y remove mariadb* 


安装mysql
  1. yum install -y libaio-* #安装依赖
  2. mkdir -p /usr/local/mysql
  3. cd /usr/local/src
  4. wget http://zy-res.oss-cn-hangzhou.aliyuncs.com/mysql/mysql-5.7.17-linux-glibc2.5-x86_64.tar.gz
  5. tar -xzvf mysql-5.7.17-linux-glibc2.5-x86_64.tar.gz
  6. mv mysql-5.7.17-linux-glibc2.5-x86_64/* /usr/local/mysql/
建立mysql组和用户,并将mysql用户添加到mysql组
  1. groupadd mysql
  2. useradd -g mysql -s /sbin/nologin mysql
初始化mysql数据库
  1. /usr/local/mysql/bin/mysqld --initialize-insecure --datadir=/usr/local/mysql/data/ --user=mysql
更改mysql安装目录的属主属组
  1. chown -R mysql:mysql /usr/local/mysql
  2. chown -R mysql:mysql /usr/local/mysql/data/
  3. chown -R mysql:mysql /usr/local/mysql
设置开机自启
  1. cd /usr/local/mysql/support-files/
  2. cp mysql.server /etc/init.d/mysqld
  3. chmod +x /etc/init.d/mysqld # 添加执行权限
  4. vim /etc/rc.d/rc.local

添加/etc/init.d/mysqld start到rc.local文件中,然后输入:wq保存退出。

设置环境变量
  1. vi /root/.bash_profile

在PATH=$PATH:$HOME/bin添加参数为:

  1. PATH=$PATH:$HOME/bin:/usr/local/mysql/bin:/usr/local/mysql/lib

然后输入:wq保存退出,输入:

  1. source /root/.bash_profile
启动MySQL数据库
  1. /etc/init.d/mysqld start

7

修改Mysql的root用户密码

初始化后mysql为空密码可直接登录,为了保证安全性需要修改mysql的root用户密码。

  1. mysqladmin -u root password 'xxxx'
测试登录MySQL数据库
  1. mysql -uroot -p密码 #-p和密码之间无空格

8

编译安装php

依赖安装:

//注: 开通 SSL 及 CURL (2017-06-07 测试)

  1. yum install php-mcrypt libmcrypt libmcrypt-devel libxml2-devel openssl-devel libcurl-devel libjpeg.x86_64 libpng.x86_64 freetype.x86_64 libjpeg-devel.x86_64 libpng-devel.x86_64 freetype-devel.x86_64 libjpeg-turbo-devel libmcrypt-devel mysql-devel -y
  2. wget http://zy-res.oss-cn-hangzhou.aliyuncs.com/php/php-7.0.12.tar.gz
  3. tar zxvf php-7.0.12.tar.gz
  4. cd php-7.0.12
  5. ./configure \
  6. --prefix=/usr/local/php \
  7. --with-pdo-mysql=mysqlnd --with-openssl \
  8. --with-mysqli=mysqlnd \
  9. --enable-mbstring \
  10. --enable-mbregex \
  11. --enable-mbregex-backtrack \
  12. --with-freetype-dir \
  13. --with-jpeg-dir \
  14. --with-png-dir \
  15. --with-zlib --with-libxml-dir=/usr \
  16. --enable-xml --enable-sockets \
  17. --with-apxs2=/usr/local/apache/bin/apxs \
  18. --with-mcrypt --with-config-file-path=/etc \
  19. --with-config-file-scan-dir=/etc/php.d \
  20. --enable-maintainer-zts \
  21. --enable-session \
  22. --disable-fileinfo \
  23. --enable-bcmath \
  24. --with-curl \
  25. --with-pear \--with-zip \--with-xls \--with-readline \--with-libmbfl \--enable-mbstring \--enable-mbregex \--enable-mbregex-backtrack \--with-xmlrpc \--enable-exif \--enable-filter \--enable-dom \--with-gettext \
  1. make && make install
 ------------------------------------------------------------------------------------------------------------------------------------------
若安装时抛,WARNING: You will need re2c 0.13.4 or later if you want to regenerate PHP parsers.看了下说是要re2c这个东西.
解决办法:
yum install re2c
然后再去编译安装Fileinfo,就不会报re2c的错误了.

若抛 readline错, 请执行:

configure: error: Please reinstall readline - I cannot find readline.h

yum install readline-devel

 2017-06-11日添加 

----------------------------------------------------------------------------------------------------------


复制配置文件
  1. cd php-7.0.12
  2. cp php.ini-production /etc/php.ini
编辑apache配置文件httpd.conf,以apache支持php
  1. vim /etc/httpd/httpd.conf

在配置文件最后添加如下二行:

  1. AddType application/x-httpd-php .php
  2. AddType application/x-httpd-php-source .phps

定位到 DirectoryIndex index.html

修改为:

  1. DirectoryIndex index.php index.html
重启apache服务
  1. /usr/local/apache/bin/apachectl restart
测试是否能够正常解析PHP
  1. cd /usr/local/apache/htdocs/
  2. vim index.php #添加如下内容
  3. <?php
  4. phpinfo();
  5. ?>

访问云服务器的公网IP/index.php,出现如下页面表示解析成功。

9

安装phpmyadmin

  1. mkdir -p /usr/local/apache/htdocs/phpmyadmin
  2. cd /usr/local/src/
  3. wget http://oss.aliyuncs.com/aliyunecs/onekey/phpMyAdmin-4.1.8-all-languages.zip
  4. unzip phpMyAdmin-4.1.8-all-languages.zip
  5. mv phpMyAdmin-4.1.8-all-languages/* /usr/local/apache/htdocs/phpmyadmin

访问ip/phpmyadmin即可访问到phpmyadmin登录页面,输入mysql的用户名以及密码即可登录。10

原创粉丝点击