LAMP网站服务器部署

源码编译安装LAMP

一.编译安装HTTP服务

(1)将这三个软件包传到opt目录下
apr-1.6.2.tar.gz
apr-util-1.6.0.tar.gz
httpd-2.4.29.tar.gz

(2)对压缩包进行解压
[root@localhost ~]# cd /opt
[root@localhost opt]# ll
总用量 8020
-rw-r--r--  1 root root 1071074 8月   4 17:33 apr-1.6.2.tar.gz
-rw-r--r--  1 root root  565507 8月   4 17:33 apr-util-1.6.0.tar.gz
-rw-r--r--  1 root root 6567926 8月   4 17:33 httpd-2.4.29.tar.bz2
drwxr-xr-x. 2 root root       6 3月  26 2015 rh
[root@localhost opt] tar zxvf apr-1.6.2.tar.gz   
[root@localhost opt] tar zxvf apr-util-1.6.0.tar.gz
[root@localhost opt] yum -y install bzip2  ## 如果是最小化安装需要安装bzip2
[root@localhost opt] tar jxvf httpd-2.4.29.tar.bz2
[root@localhost opt] mv apr-1.6.2 httpd-2.4.29/srclib/apr ##放到srclib才能支持这个模块工作,实现跨平台工作,并重命名apr 
[root@localhost opt] mv apr-util-1.6.0 httpd-2.4.29/srclib/apr-util  ##放到srclib才能支持这个模块工作,实现跨平台工作,并重命名apr-util

(3)安装环境编译HTTP的环境
[root@localhost opt]# 
yum -y install \
gcc \         ##  源码--编译器(gcc,gcc-c++)--->>二进制文件(执行文件)
gcc-c++ \
make \                 ## 让普通文件变成二进制文件
pcre-devel \        ## pcre-devel:让apache支持正则表达式
expat-devel \
perl

(4)安装配置模块
[root@localhost opt]# cd /opt/httpd-2.4.29/  ## 安装模块
./configure \
--prefix=/usr/local/httpd \
--enable-so \
--enable-rewrite \
--enable-charset-lite \
--enable-cgi

####配置模块解释####
–prefix:指定将 httpd 服务程序安装到哪个目录下,如/usr/local/httpd。便于系统直接使用
–enable-so:开启apache核心功能模块,启用动态加载模块支持,使 httpd 具备进一步扩展功能的能力。
–enable-rewrite:启用网页地址重写功能,用于网站优化及目录迁移维护。
–enable-charset-lite:启动字符集支持,以便支持使用各种字符集编码的网
–enable-cgi:启用 CGI 脚本程序支持,便于扩展网站的应用访问能力。cgi:通用网关接口,时weib服务器运行时外部程序的规范

(5) 编译安装


make && make install 

(6)优化执行路径


####优化执行路径####
## 做软链接,便于系统直接使用,可以直接使用   vi /etc/httpd.conf
ln -s /usr/local/httpd/conf/httpd.conf /etc/
ln -s /usr/local/httpd/bin/* /usr/local/bin/
httpd -v      ###查看下HTTP版本
Server version: Apache/2.4.29 (Unix)
Server built:   Aug 31 2020 02:01:04

(7)修改配置文件

vi /usr/local/httpd/conf/httpd.conf
ServerName www.test.top:80

(8)设置启动http和开机自启http,并且查看http的运行状态

[root@localhost system]# systemctl start httpd.service
[root@localhost system]# systemctl enable httpd.service         ###开机自启http
[root@localhost system]# systemctl is-enabled httpd.service   ###检查HTTP单元是否启动
[root@localhost ]# netstat -napt |grep 80  ##查看httpd 80端口,开启成功

二. 编译安装Mysql

(1) 环境准备

[root@localhost ~]# yum -y install \
                   ncurses \
                   ncurses-devel \
                   bison \
                   cmake

(2) 添加用户mysql,专门用来管理进程(程序型用户,禁止登录shell)

[root@localhost ~]# useradd -s /sbin/nologin  mysql

(3) 上传安装包到/opt目录下并解压缩

[root@localhost ~]# cd /opt
[root@localhost ~]# tar zxf mysql-boost-5.7.20.tar.gz
[root@localhost ~]# cd /optv/mysql-5.7.20/

(4) cmake 配置

[root@localhost mysql-5.7.20]# cmake \
-DCMAKE_INSTALL_PREFIX=/usr/local/mysql \
-DMYSQL_UNIX_ADDR=/usr/local/mysql/mysql.sock \
-DSYSCONFDIR=/etc \
-DSYSTEMD_PID_DIR=/usr/local/mysql \
-DDEFAULT_CHARSET=utf8  \
-DDEFAULT_COLLATION=utf8_general_ci \
-DWITH_INNOBASE_STORAGE_ENGINE=1 \
-DWITH_ARCHIVE_STORAGE_ENGINE=1 \
-DWITH_BLACKHOLE_STORAGE_ENGINE=1 \
-DWITH_PERFSCHEMA_STORAGE_ENGINE=1 \
-DMYSQL_DATADIR=/usr/local/mysql/data \
-DWITH_BOOST=boost \
-DWITH_SYSTEMD=1

配置选项含义:
1、DCMAKE_INSTALL_PREFIX:指定将 mysql 数据库程序安装到某目录下,如目录/usr/local/ mysql。
2、DMYSQL_UNIX_ADDR:指定套接字文件的存储路径,数据库连接的文件
3、DSYSCONFDIR:指定初始化参数文件目录
3、DDEFAULT_CHARSET:指定默认使用的字符集编码,如 utf8。
5、DDEFAULT_COLLATION:指定默认使用的字符集校对规则,utf8_general_ci 是适用于 UTF-8 字符集的通用规则。
6、DWITH_INNOBASE_STORAGE_ENGINE=1 :安装INNOBASE存储引擎
7、DWITH_ARCHIVE_STORAGE_ENGINE=1 :安装ARCHIVE存储引擎
8、DWITH_BLACKHOLE_STORAGE_ENGINE=1 :安装ARCHIVE存储引擎
9、DWITH_PERFSCHEMA_STORAGE_ENGINE :安装FEDERATED存储引擎

(5) 编译安装

[root@localhost mysql-5.7.20]# make  && make install

(6) 数据库目录进行权限调整

[root@localhost ~]# chown -R mysql:mysql /usr/local/mysql/

(7) 建立调整配置文件

vi /etc/my.cnf

[client]
port = 3306
default-character-set=utf8
socket = /usr/local/mysql/mysql.sock

[mysql]
port = 3306
default-character-set=utf8
socket = /usr/local/mysql/mysql.sock

[mysqld]
user = mysql
basedir = /usr/local/mysql
datadir = /usr/local/mysql/data
port = 3306
character_set_server=utf8
pid-file = /usr/local/mysql/mysqld.pid
socket = /usr/local/mysql/mysql.sock
server-id = 1

sql_mode=NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES,NO_AUTO_CREATE_USER,NO_AUTO_VALUE_ON_ZERO,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,PIPES_AS_CONCAT,ANSI_QUOTES

(8) 调整配置文件权限

[root@localhost ~]# chown mysql:mysql /etc/my.cnf 

(9) 设置环境变量

[root@localhost ~]# echo 'PATH=/usr/local/mysql/bin:/usr/local/mysql/lib:$PATH' >> /etc/profile  
[root@localhost ~]# echo 'export PATH' >> /etc/profile  ## 声明全局变量
[root@localhost ~]# source /etc/profile  ### 使加入的数据生效,使mysql的相关命令识别

(10) 初始化数据库

[root@localhost ~]# cd /usr/local/mysql/
[root@localhost mysql]# bin/mysqld \
--initialize-insecure \  ###初始化命令
--user=mysql \  ###指定用户
--basedir=/usr/local/mysql \  ###指定工作目录
--datadir=/usr/local/mysql/data  ###指定数据存放位置

(11) 编辑启动文件, 启动数据库并查看状态

[root@localhost mysql]# cp usr/lib/systemd/system/mysqld.service /usr/lib/systemd/system/
[root@localhost mysql]# systemctl start mysqld
[root@localhost mysql]# systemctl status mysqld
[root@localhost mysql]# netstat -anpt | grep 3306

(12) 设置root登陆并设置密码

[root@localhost mysql]# mysqladmin -u root -p password "abc123"	'//给root用户设置密码'
'//mysqladmin -u用户名 -p旧密码 password 新密码'
Enter password: 	'//原本密码为空,直接回车即可'
Warning: Using a password on the command line interface can be insecure.
[root@localhost mysql]# mysql -u root -p
Enter password: 	'//输入刚设置的密码abc123'
...省略内容
mysql> show databases;
+--------------------+
| Database           |
+--------------------+
| information_schema |
| mysql              |
| performance_schema |
| test               |
+--------------------+
4 rows in set (0.00 sec)

mysql> exit
Bye

三、编译安装PHP环境

(1)安装编译环境

[root@localhost ~]# yum -y install \
libjpeg \				    #jpeg图片识别
libjpeg-devel \				#jpeg开发包
libpng libpng-devel \	    #png图片识别还有开发包
freetype freetype-devel \	#freetype 识别字体
libxml2 \				    #xml文件格式识别
libxml2-devel \ 
zlib zlib-devel \			#zlib压缩
curl curl-devel \			#curl 支持文件上传下载,网页端的下载
openssl openssl-devel		#身份验证去连接网站

(2)上传文件至/opt目录下并解压缩

cd /opt
tar xjvf php-7.1.10.tar.bz2  ###解压php包

(3) configure配置属性,make编译

[root@localhost php-7.1.10]#./configure \
--prefix=/usr/local/php \							#指定安装目录
--with-mysql-sock=/usr/local/mysql/mysql.sock \		#指向mysql的sock文件,用以后台程序去连接数据库
--with-mysqli \										#客户终端工具,可以直接去访问mysql服务器,去找它进行定义存储过程,事务的处理一些功能
--with-zlib \
--with-curl \
--with-gd \											#gd是一个图像化的处理
--with-jpeg-dir \
--with-png-dir \
--with-freetype-dir \                               #字体
--with-openssl \
--enable-fpm \										#fpm 是指动态请求的模块
--enable-mbstring \									#mbstring 多节点字符串
--enable-xml \										#xml 启用xml格式支持
--enable-session \									#支持session会话
--enable-ftp \										#网页可以ftp的功能
--enable-pdo \										#pdo 类似一个通用的接口一样,下面的不同的数据库的数据,会统一接口接收
--enable-tokenizer \ 								#tokenizer 是一个函数库
--enable-zip	


[root@localhost php-7.1.10]# make -j3 && make install

(4) 复制php.ini-development开发样板,修改php.ini-development开发样板

[root@localhost php-7.1.10]# cp /php-7.1.10/php.ini-development /usr/local/php/lib/php.ini
[root@localhost php-7.1.10]# vi /usr/local/php/lib/php.ini
mysqli.default_socket = /usr/local/mysql/mysql.sock  # 搜索到mysqli.default_socket 
date.timezone = Asia/Shanghai  # 搜索到date.timezone   # 添加市区

(5)修改Apache配置文件

vi /etc/httpd.conf 
#######搜索AddType,然后在合适位置新增下面两句######
AddType application/x-httpd-php .php
AddType application/x-httpd-php-source .phps
#########搜索DirectoryIndex,然后找到这行后把下面这行代码补齐#########
DirectoryIndex index.php index.html

(6)修改主页内容

rm -f /usr/local/httpd/htdocs/index.html  ### 删除index.html文件
vi /usr/local/httpd/htdocs/index.php  ### 编辑新的index.php
#######添加下面代码###########
<?php
phpinfo();
?>

[root@localhost~]# vi /etc/httpd.conf  

#Include conf/extra/httpd-vhosts.conf  ### 关闭这个

Listen 80     ### 找到监听端口,监听端口改成这样

systemctl restart httpd   ### 重启一下httpd服务

测试一下,在真机浏览器输入服务器ip地址

在这里插入图片描述

四. 编译安装phpMyadmin

(1) 上传phpMyadmin压缩包至/opt目录下并解压缩

[root@localhost ~]# cd /opt
[root@localhost opt]# unzip phpMyAdmin-4.7.6-all-languages.zip -d /opt/

(2) 将内容拷贝至Apache服务站点主页

mv /opt/phpMyAdmin-4.7.6-all-languages /usr/local/httpd/htdocs/myadm

(3) 修改服务站点

cd /usr/local/httpd/htdocs/myadm
cp config.sample.inc.php config.inc.php

vi config.inc.php

$cfg['Servers'][$i]['host'] = '127.0.0.1'; //把localhost 改成IP

(4) 验证
在浏览器输入:http://20.0.0.10自己的IP)/myadm
使用root 以及前面为root配置的密码登录管理系统。可以对数据库进行管理操作了

在这里插入图片描述

在这里插入图片描述
我们也可以在该页面进行数据库的各种操作,如:建表,插入数据,搜索数据,修改表的结构等等。。。

在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值