Processing math: 100%

CentOS 7下搭建LAMP并把MySQL单独分离

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
简介:

CentOS 7下搭建LAMP并把MySQL单独分离

原文:http://www.linuxidc.com/Linux/2017-05/144037.htm

环境:
系统:CentOS-7-x86_64-Minimal-1611
Apache:httpd-2.4.25.tar
MySQL:mysql-5.7.16.tar
php:php-5.6.30.tar
192.168.57.144:安装MySQL
192.168.57.143:安装Apache+php
 
搭建LAMP平台并实现PHP和MySQL读写分离 见  http://www.linuxidc.com/Linux/2017-05/144029.htm
创建相关目录
创建用户
解压安装包
编译安装
(初始化)
链接bin目录
拷贝脚本文件,主配置文件
配置主配置文件
脚本自启动
验证服务
验证对接服务
 
 
一·编译安装Apache
 
yum install lrzsz
cd /usr/local/
tar -zxf httpd-2.4.25.tar.gz
 
yum install gcc*  gcc-c++*
yum install apr* apr-util apr-devel pcre* pcre-devel openssl* openssl-devel -y
 
编译安装
./configure --prefix=/apps/svr/httpd --enable-so --enable-rewrite --enable-charset-list  --enable-cgi
或者:
./configure                          \
        --prefix=/apps/svr/httpd  \
--sysconfdir=/apps/conf/\
        --enable-so                \
        --enable-ssl              \
        --enable-cgi              \
        --enable-rewrite          \
        --with-zlib                \
        --with-pcre                \
        --with-mpm=prefork        \
        --enable-modules=most      \
        --enable-mpms-shared=all 
echo ?makemakeinstallhttplns/apps/svr/httpd/bin//usr/local/bin/cat>exportPATH=PATH:/apps/svr/httpd/bin >>/etc/profile
检查配置文件
apachectl -t
 
 
设置apache为Linux服务并实现开机自启动
cp /apps/svr/httpd/bin/apachectl /etc/init.d/httpd
或者:设置Apache为Linux服务并实现开机自启动 
mv /etc/rc.d/init.d/apachectl /etc/rc.d/init.d/httpd
chmod +x /etc/init.d/httpd
 
vim /etc/init.d/httpd
#!/bin/sh
#chkconfig:2345 80 80
#description:httpd
#
 
chkconfig:2345 80 80
2345:是服务识别参数,在级别2345中启动
第一个80:是该服务在第80个启动
第二个80:是该服务在第80个关闭
description:httpd      :服务描述信息
 
chkconfig --add httpd
chkconfig httpd on
chkconfig --list httpd
 
 
cat /etc/hosts
127.0.0.1  localhost localhost.localdomain localhost4 localhost4.localdomain4
::1        localhost localhost.localdomain localhost6 localhost6.localdomain6
192.168.57.141 www.a.org
 
 
cat  /apps/svr/httpd/conf/httpd.conf
#ServerName www.example.com:80
ServerName www.a.org
 
 
service  httpd restart
netstat -anpt |grep httpd
 
关闭数据库
systemctl stop firewalld
 
 
http://www.linuxidc.com/Linux/2017-05/144038.htm

编译安装mysql-5.7.16
 
groupadd -r mysql
useradd -r -g mysql -s /bin/false -M mysql
 
创建mysql安装文件、数据库存储文件、my.cnf文件
mkdir -p /apps/svr/mysql
mkdir -p /apps/mysqldb/data
mkdir -p /apps/conf
 
 
yum install -y gcc wget make cmake zlib-devel ncurses-devel bison gcc-c++ automake autoconf  imake libxml2-devel expat-devel cmake gcc gcc-c++ libaio libaio-devel bzr bison libtool ncurses-devel libxml2-devel expat-devel openssl openssl-devel
 
下载Boost_1_59_0.tar.gz
wget  http://nchc.dl.sourceforge.net/project/boost/boost/1.59.0/boost_1_59_0.tar.gz
wget http://sourceforge.net/projects/boost/files/boost/1.59.0/boost_1_59_0.tar.gz
tar zxvf boost_1_59_0.tar.gz
 
下载mysql-5.7.13.tar.gz
wget http://cdn.mysql.com/Downloads/MySQL-5.7/mysql-5.7.13.tar.gz
wget https://dev.mysql.com/get/Downloads/MySQL-5.7/mysql-5.7.17.tar.gz
tar zxvf mysql-5.7.17.tar.gz
 
cd mysql-5.7.17
cmake . -DCMAKE_INSTALL_PREFIX=/apps/svr/mysql \
-DMYSQL_DATADIR=/apps/mysqldb/data \
-DSYSCONFDIR=/apps/conf/my.cnf \
-DWITH_INNOBASE_STORAGE_ENGINE=1 \
-DWITH_ARCHIVE_STORAGE_ENGINE=1 \
-DWITH_BLACKHOLE_STORAGE_ENGINE=1 \
-DWITH_READLINE=1 \
-DWITH_LIBWRAP=0 \
-DMYSQL_UNIX_ADDR=/tmp/mysql.sock \
-DWITH_SSL=system \
-DWITH_ZLIB=system \
-DDOWNLOAD_BOOST=1 \
-DWITH_BOOST=../boost_1_59_0 \
-DDEFAULT_CHARSET=utf8 \
-DDEFAULT_COLLATION=utf8_general_ci
 
 
boost_1_59_0 解压放到mysql上层目录
 
---------------------------------------------------------------------------------------------------------------------------------
-DCMAKE_INSTALL_PREFIX= 安装根目录
-DCMAKE_INSTALL_PREFIX=  unix套接字目录
-DDEFAULT_CHARSET= 默认字符集
-DDEFAULT_COLLATION=默认编码
-DWITH_EXTRA_CHARSETS= 额外的编码,请使用ALL来编译。
-DWITH_MYISAM_STORAGE_ENGINE=1  编译myisam存储引擎,默认的存储引擎,不加也可以
-DWITH_INNOBASE_STORAGE_ENGINE=1 支持InnoDB存储引擎,这个也是默认安装的
-DWITH_READLINE=1 使用readline功能
-DENABLED_LOCAL_INFILE=1 可以使用load data infile命令从本地导入文件
-DMYSQL_DATADIR=数据库 数据目录
---------------------------------------------------------------------------------------------------------------------------------
 
grep processor /proc/cpuinfo 个数x2
 
make或者:make -j (grepprocessor/proc/cpuinfo|wcl)makeinstallcat>exportPATH=PATH:/apps/svr/mysql/bin >>/etc/profile
Source /etc/profile
或者:ln -s /apps/svr/mysql/bin /usr/local/bin
 
chown  -R mysql:mysql /apps/svr/mysql
chown -R mysql:mysql /apps/conf
chown -R mysql:mysql /apps/mysqldb
 
rm -rf /etc/my.cnf
 
导出配置文件 
cd mysql-5.7.16
cp support-files/my-default.cnf /apps/conf/my.cnf
cp support-files/my-default.cnf /etc/
 
 
初始化数据库
注:
1 之前版本mysql_install_db是在mysql_basedir/script下,5.7放在了mysql_install_db/bin目录下,且已被废弃
2  "--initialize"会生成一个随机密码(~/.mysql_secret),而"--initialize-insecure"不会生成密码
3  --datadir目标目录下不能有数据文件


初始化(测试OK):/apps/svr/mysql/scripts/mysql_install_db  --user=mysql --basedir=/apps/svr/mysql/ --datadir=/apps/mysqldb/data/

查看初始化数据文件:ls  /apps/mysqldb/data    文件列表如下

auto.cnf  ib_logfile0  localhost.uplook.com.err  mysql               test
ibdata1   ib_logfile1  localhost.uplook.com.pid  performance_schema

原文(有问题):/apps/svr/mysql/bin/mysqld --initialize --user=mysql --basedir=/apps/svr/mysql/ --datadir=/apps/mysqldb/data/
 
初始化密码
 #root@localhost: Ml-&jsWy(7j)
 
 
配置mysql自动启动
cp /apps/svr/mysql/usr/lib/systemd/system/mysqld.service /usr/lib/systemd/system
systemctl enable mysqld.service
或者
cp /apps/svr/mysql/support-files/mysql.server /etc/init.d/mysqld
chmod +x /etc/init.d/mysqld
chkconfig --add mysqld
chkconfig mysqld on
 
 
 
* Mysqld.pid文件让mysql用户有权限访问。
Vi /usr/lib/systemd/system/mysqld.service
改:PIDFile=/apps/svr/mysql/mysqld.pid
# Start main service
ExecStart=/apps/svr/mysql/bin/mysqld--daemonize--pid-file=/apps/conf/mysql5.7/mysqld.pid MYSQLD_OPTS     dbrootpwd=oneinstack #数据库root密码  /usr/local/mysql/bin/mysql -e "grant all privileges on *.* to root@'127.0.0.1' identified by \"dbrootpwd\" with grant option;"
/usr/local/mysql/bin/mysql -e "grant all privileges on *.* to root@'localhost' identified by \"dbrootpwd\" with grant option;"     更改mysql登录root用户密码  mysqladmin -u root -p'Ml-&jsWy(7j)' password '2Zs63oQbPxpKYFjn6tyj'        创建用户允许143远程(允许php链接)  grant all on *.* to root@192.168.57.143 identified by '123456';  flush privileges;     show grants for root@192.168.57.143;  select user,host from mysql.user;     安装数据加密等扩展工具(如libmcrypt、mhash、mcrypt)        注意:这三个包mcrypt要最后安装  yum install libxml2 libxml2-devel bzip2-devel libcurl-devel -y  yum install php-mcrypt libmcrypt libmcrypt-devel mhash mhash-devel libevent libevent-devel     ./configure --prefix=/apps/svr/php/  \  --with-openssl \  --enable-mbstring \  --with-freetype-dir \  --with-jpeg-dir \  --with-png-dir \  --with-mysql \  --with-zlib \  --enable-xml \  --enable-sockets \  --with-apxs2=/apps/svr/httpd/bin/apxs \  --with-config-file-path=/apps/conf \  --with-bz2  \  --enable-maintainer-zts     make  make install        #--with-config-file-scan-dir=/apps/conf  \  #--with-libxml-dir=/usr \  #--with-mysqli=/usr/local/mysql/bin/mysql_config \  #--with-mysql添加mysql模块  #  --with-apxs2=/usr/local/apache24/bin/apxs 表示编译成模块  #--enable-fpm 编译成fastCGI  #  --enable-maintainer-zts  编译fastCGI不需要选项      配置php.ini文件:解压的安装包下  cp php.ini-development /apps/conf/php.ini    设置配置文件路径 --with-config-file-path=/apps/conf \  short_open_tag = On  asp_tags = On     *解析  short_open_tag  决定是否允许使用 PHP 代码开始标志的缩写形式(<? ?> )。如果要和 XML 结合使用 PHP,可以禁用此选项以便于嵌入使用 <?xml ?> 。否则还可以通过 PHP 来输出,例如:<?php echo '<?xml version="1.0"'; ?> 。如果禁用了,必须使用 PHP 代码开始标志的完整形式(<?php ?> )。  注意: 本指令也会影响到缩写形式 <?= ,它和 <? echo 等价。使用此缩写需要 short_open_tag 的值为 On。  asp_tags  除了通常的 <?php ?> 标志之外还允许使用 ASP 风格的标志 <% %>。这也包括了输出变量值的缩写 <%=value %>。
注意: ASP 风格标志的支持是 3.0.4 版新加的
 
 
整合apache和php
 
编译Apache配置文件httpd.conf,以Apache支持php。以及访问的主页面index.php
vim /apps/conf/httpd.conf
 
添加支持php的主页
<IfModule dir_module>
    DirectoryIndex index.php index.html
</IfModule>
 
加载php程序模块文件
LoadModule php5_module        modules/libphp5.so
添加如下二行apache能识别php格式页面
    AddType application/x-httpd-php .php
    AddType application/x-httpd-php-source .phps
 
 
查看配置文件是否有语法错误
httpd -t
Syntax OK
 
重启服务
service httpd restart
 
测试PHP与Apache是否正常连接
cd /apps/svr/httpd/htdocs/
vim index.php
<?php
phpinfo();
?>
 
 
整合php和mysql
 
由于mysql和php不在同一台服务器,所以添加php的扩展模块
1、在Apache+php服务器上安装mysql-devel
yum install mysql-devel -y
 
2、进入php解压包生成配置文件
cd /root/php-5.6.30/ext/mysql
执行phpize脚本生成configure文件
[root@client mysql]# pwd
/root/php-5.6.30/ext/mysql
[root@client mysql]# /apps/svr/php/bin/phpize
Configuring for:
PHP Api Version:        20131106
Zend Module Api No:      20131226
Zend Extension Api No:  220131226
Cannot find autoconf. Please check your autoconf installation and the
PHPAUTOCONFenvironmentvariable.Then,rerunthisscript.autoconfautoconfPHP_AUTOCONF环境变量。然后,重新运行这个脚本。
(*错误缺少 m4  autoconf包* )
yum install m4
yum install autoconf
 
3、配置 编译安装(安装完成之后再扩展块路径下生成一个mysql.so模块文件)
./configure --with-mysql --with-php-config=/apps/svr/php/bin/php-config
 
--with-mysql添加mysql模块
--with-php-config=/apps/svr/php/bin/php-config添加模块所需要的脚本位置
 
make
make install
spacer.gif
 
 
4、添加mysql.so模块到php.ini配置文件(/apps/conf/php.ini)
[root@client htdocs]# cat /apps/conf/php.ini |grep mysql.so
extension=/apps/svr/php/lib/php/extensions/no-debug-zts-20131226/mysql.so wKiom1kejiDi0kTlAAAzoQvJWYU480.png
 
测试PHP与MySQL(默认root用户登录不需要密码)是否正常连接
vim index.php
<?php
conn=mysqlconnect(localhost,root,);if(conn)
echo "Success...";
else
echo "Failure!!!";
?>

下面关于LAMP相关的内容你可能也喜欢:

LAMP平台安装Xcache和Memcached加速网站运行  http://www.linuxidc.com/Linux/2015-06/118835.htm

CentOS 7下搭建LAMP平台环境  http://www.linuxidc.com/Linux/2015-06/118818.htm

CentOS 6.5系统安装配置LAMP(Apache+PHP5+MySQL)服务器环境 http://www.linuxidc.com/Linux/2014-12/111030.htm

CentOS 7.2 yum安装LAMP环境  http://www.linuxidc.com/Linux/2016-11/136766.htm

Ubuntu 14.04 配置 LAMP+phpMyAdmin PHP(5.5.9)开发环境  http://www.linuxidc.com/Linux/2014-10/107924.htm

LAMP结合NFS构建小型博客站点  http://www.linuxidc.com/Linux/2015-08/121029.htm

CentOS7下安装部署LAMP环境  http://www.linuxidc.com/Linux/2016-04/130653.htm

CentOS 7 上安装(LAMP)服务 Linux,Apache,MySQL,PHP  http://www.linuxidc.com/Linux/2017-05/143868.htm

Ubuntu Server 14.04 LTS下搭建LAMP环境图文详解  http://www.linuxidc.com/Linux/2016-12/138758.htm

Ubuntu Server 16.04下配置LAMP环境 http://www.linuxidc.com/Linux/2016-12/138757.htm

CentOS 6.7编译安装LAMP 详解 http://www.linuxidc.com/Linux/2017-03/141244.htm

Ubuntu 16.04搭建LAMP开发环境 http://www.linuxidc.com/Linux/2016-10/136327.htm

本文永久更新链接地址:http://www.linuxidc.com/Linux/2017-05/144037.htm







      本文转自rshare 51CTO博客,原文链接:http://blog.51cto.com/1364952/1979068,如需转载请自行联系原作者




相关实践学习
如何快速连接云数据库RDS MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
打赏
0
0
0
0
347
分享
相关文章
CentOS7仅安装部署MySQL80客户端
通过上述步骤,你可以在CentOS 7上成功安装并配置MySQL 8.0客户端。这个过程确保你能够使用MySQL客户端工具连接和管理远程的MySQL数据库,而不需要在本地安装MySQL服务器。定期更新MySQL客户端可以确保你使用的是最新的功能和安全修复。
83 16
在 CentOS 7 中通过编译源码方式安装 MySQL 数据库的详细步骤,并与使用 RPM 包安装进行了对比
本文介绍了在 CentOS 7 中通过编译源码方式安装 MySQL 数据库的详细步骤,并与使用 RPM 包安装进行了对比。通过具体案例,读者可以了解如何准备环境、下载源码、编译安装、配置服务及登录 MySQL。编译源码安装虽然复杂,但提供了更高的定制性和灵活性,适用于需要高度定制的场景。
157 3
在 CentOS 7 中通过编译源码安装 MySQL 数据库的详细步骤,并与使用 RPM 包安装进行了对比。
本文介绍了在 CentOS 7 中通过编译源码安装 MySQL 数据库的详细步骤,并与使用 RPM 包安装进行了对比。内容涵盖准备工作、下载源码、编译安装、配置服务、登录设置及实践心得,帮助读者根据需求选择最适合的安装方法。
171 2
在 CentOS 7 中通过编译源码方式安装 MySQL 数据库的详细步骤,包括准备工作、下载源码、编译安装、配置 MySQL 服务、登录设置等。
本文介绍了在 CentOS 7 中通过编译源码方式安装 MySQL 数据库的详细步骤,包括准备工作、下载源码、编译安装、配置 MySQL 服务、登录设置等。同时,文章还对比了编译源码安装与使用 RPM 包安装的优缺点,帮助读者根据需求选择最合适的方法。通过具体案例,展示了编译源码安装的灵活性和定制性。
231 2
Centos7.9安装kerberos
Centos7.9安装kerberos
53 25
centos7环境下tomcat8的安装与配置
本文介绍了在Linux环境下安装和配置Tomcat 8的详细步骤。首先,通过无网络条件下的文件交互软件(如Xftp 6或MobaXterm)下载并解压Tomcat安装包至指定路径,启动Tomcat服务并测试访问。接着,修改Tomcat端口号以避免冲突,并部署Java Web应用项目至Tomcat服务器。最后,调整Linux防火墙规则,确保外部可以正常访问部署的应用。关键步骤包括关闭或配置防火墙、添加必要的端口规则,确保Tomcat服务稳定运行。
CentOS安装SeaweedFS
通过上述步骤,您应该能够在CentOS系统上成功安装并启动SeaweedFS。记住,根据实际部署规模和需求,可能还需要进一步调整配置参数和优化网络布局。SeaweedFS的灵活性和扩展性意味着随着使用深入,您可能需要探索更多高级配置和管理策略。
137 64
CentOS安装SeaweedFS
通过上述步骤,您应该能够在CentOS系统上成功安装并启动SeaweedFS。记住,根据实际部署规模和需求,可能还需要进一步调整配置参数和优化网络布局。SeaweedFS的灵活性和扩展性意味着随着使用深入,您可能需要探索更多高级配置和管理策略。
139 61
从配置源到数据库初始化一步步教你在CentOS 7.9上安装SQL Server 2019
【11月更文挑战第16天】本文介绍了在 CentOS 7.9 上安装 SQL Server 2019 的详细步骤,包括配置系统源、安装 SQL Server 2019 软件包以及数据库初始化,确保 SQL Server 正常运行。
114 4
从配置源到数据库初始化一步步教你在CentOS 7.9上安装SQL Server 2019
【11月更文挑战第8天】本文介绍了在 CentOS 7.9 上安装 SQL Server 2019 的详细步骤,包括系统准备、配置安装源、安装 SQL Server 软件包、运行安装程序、初始化数据库以及配置远程连接。通过这些步骤,您可以顺利地在 CentOS 系统上部署和使用 SQL Server 2019。
140 1

热门文章

最新文章

AI助理

你好,我是AI助理

可以解答问题、推荐解决方案等