百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 编程网 > 正文

centos7 源码安装 apache+mysql+php

yuyutoo 2024-10-17 17:00 10 浏览 0 评论

安装 apache

cd /usr/local/src/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 -with-zlib-1.2.3=/usr/local/zlib-1.2.3 --enable-so

make

make install

*若前面配置 zlib 时没有指定安装目录, Apache 配置时不要添加

--with-z=/usr/local/zlib/参数

启动apache遇到错误:httpd: Could not reliably determine the server's fully qualified domain name

编辑 /usr/local/apache2/etc/httpd.conf

把 #ServerName www.example.com:80 前面的#去掉


ps:

configure: error: Bundled APR requested but not found at ./srclib/. Download and unpack the corresponding apr and apr-util packages to ./srclib/. #如果报错,则:

cp -r /usr/local/src/apr-1.4.6 /usr/local/src/httpd-2.4.7/srclib/apr

cp -r /usr/local/src/apr-util-1.4.1 /usr/local/src/httpd-2.4.7/srclib/apr-util

#解压 apr 和 apr-util,复制并取消版本号

configure: error: pcre-config for libpcre not found. PCRE is required and available from

#如果报错,则:

tar zxvf pcre-8.34.tar.gz

cd pcre-8.34

./configure && make && make install

checking whether to enable mod_ssl... configure: error: mod_ssl has been requested but can not be built due to prerequisite failures #如果报错,则:

yum install openssl-devel

/usr/local/apache2/conf/

cd zlib-1.2.3

./configure

vi Makefile

找到 CFLAGS=-O3 -DUSE_MMAP

在后面加入-fPIC,即变成CFLAGS=-O3 -DUSE_MMAP -fPIC

make && make install**



启动 Apache 测试:

/usr/local/apache2/bin/apachectl start

ps –aux | grep httpd

netstat –tlun | grep :80

*若启动时提示/usr/local/apache2/modules/mod_deflate.so 无权限,可关闭 SELinux 或者执行命令 chcon -t texrel_shlib_t /usr/local/apache2/modules/mod_deflate.so ,

类似此类.so 文件不能载入或没有权限的问题,都是 SELinux 问题,使用命令:“chcon -t texrel_shlib_t 文件名”即可解决,MySQL 和 Apache 也可能有类似问题。

通过浏览器输入地址访问:http://Apache 服务器地址,若显示“It works”即表明 Apache 正常工作


设置apache开机自启动

1、将apache的启动脚本复制到 /etc/rc.d/init.d这个目录下,如下:

cp /usr/local/apache2/bin/apachectl /etc/init.d/httpd

2、编辑/etc/init.d/httpd文件,在第1行#!/bin/sh的后面添加如下两行

# chkconfig: 2345 70 30 //注意:前面的#号是要保留的

# description: Apache //注意:前面的#号是要保留的

保存,退出

3、

chkconfig --add httpd

Chkconfig httpd on

chkconfig --list httpd

重启reboot,查看是否会自动运行该服务!


# 安装 ncurses

Ncurses 提供字符终端处理库,包括面板和菜单。它提供了一套控制光标,建立窗口,改变前景背景颜色以及处理鼠标操作的函数。使用户在字符终端下编写应用程序时绕过了那些恼人的底层机制。简而言之,他是一个可以使应用程序直接控制终端屏幕显示的函数库。

1、

yum -y install ncurses-devel

注:如果报错,包找不到,是*通配符没有识别,给文件名加双引号 “ncurses*”

2、源代码编译:

cd /lamp/ncurses-5.9

./configure --with-shared --without-debug --without-ada --enable-overwrite make

make install

*若不安装 ncurses 编译 MySQL 时会报错

*--without-ada 参数为设定不编译为 ada 绑定,因进入 chroot 环境不能使用 ada ; --enable-overwrite 参数为定义把头文件安装到/tools/include 下而不是 /tools/include/ncurses 目录

*--with-shared生成共享库

#安装 cmake 和 bison

mysql 在 5.5 以后,不再使用./configure 工具,进行编译安装。而使用 cmake 工具替代了./configure 工具。cmake 的具体用法参考文档 cmake 说明。

bison 是一个自由软件,用于自动生成语法分析器程序,可用于所有常见的操作系统

yum -y install cmake

yum -y install bison

伪用户


# 安装 MySQL

1、添加用户组 mysql ,将 mysql 用户默认组设置为 mysql 用户组

groupadd mysql

useradd -g mysql mysql

2、编译环境,安装

cd /lamp/mysql-5.5.23

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

安装位置

指定 socket(套接字)文件位置

扩展字符支持

默认字符集

默认字符校对

安装 myisam 存储引擎

安装 innodb 存储引擎

安装 memory 存储引擎

支持 readline 库

启用加载本地数据

指定 mysql 运行用户

指定 mysql 端口

make

make install

make clean

rm -rf CMakeCache.txt

#如果报错,清除缓存,请使用以上命令

3、修改 mysql 目录权限

cd /usr/local/mysql/

chown -R mysql .

chgrp -R mysql .

4、创建数据库授权表,初始化数据库

/usr/local/mysql/scripts/mysql_install_db --user=mysql

5、再次修改 mysql 目录权限

chown -R root .

chown -R mysql data

6、#复制 mysql 配置文件,再次初始化数据库

启动 MySQL 服务

cp support-files/my-medium.cnf /etc/my.cnf

/usr/local/mysql/scripts/mysql_install_db --user=mysql

7、设置mysqld开机自启动

将mysql的启动脚本 /usr/local/mysql/bin/support-files/mysql.service

复制到 /etc/rc.d/init.d

cp /usr/local/mysql/bin/support-files/mysql.service /etc/rc.d/init.d/mysqld

chkconfig --add mysqld # 添加到系统服务
 

chkconfig mysql on # 开机启动

8、手动启动mysql

/etc/rc.d/init.d/mysql start

9、设定 mysql 密码

/usr/local/mysql/bin/mysqladmin -uroot password 123

清空历史记录 history -c

*给 mysql 用户 root 加密码 123

*注意密码不能写成 “123”

*

10、运行数据库,输入密码

/usr/local/mysql/bin/mysql -u root -p

操作数据库:

mysql>show databases;

mysql>use test; mysql>show tables;

mysql>\s #查看字符集是否改为 utf8

*进入 mysql 以后用 set 来改密码 mysql> exit

*登录 MySQL 客户端控制台设置指定 root 密码

重启,reboot

#安装 PHP

编译前确保系统已经安装了 libtool 和 libtool-ltdl 软件包,安装:

yum -y install “libtool*”

yum -y install “libtool-ltdl*”

vi/usr/local/gd2/include/gd_io.h typedef struct gdIOCtx

{

……

void (*data);

#加入此句

}

#php 5.4 的 bug,检测 gd 库有问题,需要手工修改

cd /lamp/ php-5.4.25

./configure --prefix=/usr/local/php/

--with-config-file-path=/usr/local/php/etc/

--with-apxs2=/usr/local/apache2/bin/apxs --with-mysql=/usr/local/mysql/ --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-gd=/usr/local/gd2/ --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 --without-pear

l若前面配置 zlib 时没有指定安装目录,PHP 配置时不要添加

--with-zlib-dir=/usr/local/zlib/参数选项:

--with-config-file-path=/usr/local/php/etc/ 指定配置文件目录

--with-apxs2=/usr/local/apache2/bin/apxs 指定 apache 动态模块位置

--with-mysql=/usr/local/mysql/ 指定 mysql 位置

--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-gd=/usr/local/gd2/ 指定 gd 位置

--with-mcrypt=/usr/local/libmcrypt/ 指定 libmcrypt 位置

--with-mysqli=/usr/local/mysql/bin/mysql_config 指定 mysqli 位置

--enable-soap 支持 soap 服务

--enable-mbstring=all 支持多字节,字符串

--enable-sockets 支持套接字

--with-pdo-mysql=/usr/local/mysql 启用 mysql 的 pdo 模块支持

--without-pear 不安装 pear(安装 pear 需要连接互

联网。 PEAR 是PHP 扩展与应用库)

make

make install

生成 php.ini

cp /usr/local/src/php-5.4.25/php.ini-production /usr/local/php/etc/php.ini

测试 Apache 与 PHP 的连通性,看 Apache 是否能解析 php 文件

vi /usr/local/apache2/etc/httpd.conf

AddType application/x-httpd-php .php .phtml

AddType application/x-httpd-php .php .php4 .php5

*.phtml 为将.phps 做为 PHP 源文件进行语法高亮显示

重启 Apache 服务:systemctl restart httpd

* Apache 无法启动,提示 cannot restore segment prot after reloc: Permission denied

错误,为 SELinux 问题,可关闭 SELinux 或者执行命令

chcon -t texrel_shlib_t /usr/local/apache2/modules/libphp5.so

测试:vim /usr/local/apache2/htdocs/test.php <?php

phpinfo();

?>

通过浏览器输入地址访问:http://Apache 服务器地/test.php

yum安装方式的网页默认目录 /var/www/html/

有时第一次浏览器测试会失败,关闭浏览器重启再尝试即可,非编译错误

# 编译安装 memcache

Memcache 是一个高性能的分布式的内存对象缓存系统,通过在内存里维护一个统一的巨大的 hash 表,它能够用来存储各种格式的数据,包括图像、视频、文件以及数据库检索的结果等。简单的说就是将数据调用到内存中,然后从内存中读取,从而大大提高读取速度。

yum -y install zlib-devel

cd memcache-3.0.8

/usr/local/php/bin/phpize

./configure --with-php-config=/usr/local/php/bin/php-config make && make install

#编译安装 mcrypt

cd /lamp/php-5.4.25/ext/mcrypt/

/usr/local/php/bin/phpize

./configure --with-php-config=/usr/local/php/bin/php-config --with-mcrypt=/usr/local/libmcrypt/

make

make install

#php 安装完成后,通过这些命令安装 mcrypt 模块

修改/usr/local/php/etc/php.ini

把 extension_dir = "." 去除

extension_dir = "/usr/local/php/lib/php/extensions/no-debug-zts-20100525/"

extension="memcache.so";

extension="mcrypt.so";

#添加

#重启 apache,在 phpinfo 中可以找到这两个模块

#安装 memcache 源代码

yum -y install “libevent*”

cd /lamp/memcached-1.4.17

./configure --prefix=/usr/local/memcache

make && make install

#添加 memcache 用户,此用户不用登录,不设置密码

useradd memcache

/usr/local/memcache/bin/memcached -umemcache &

查看端口1121是否运行:

netstat -ntl

把memcache 服务添加到开机启动项中:

vi/etc/rc.d/rc.local /usr/local/memcache/bin/memcached -umemcache

相关推荐

ETCD 故障恢复(etc常见故障)

概述Kubernetes集群外部ETCD节点故障,导致kube-apiserver无法启动。...

在Ubuntu 16.04 LTS服务器上安装FreeRADIUS和Daloradius的方法

FreeRADIUS为AAARadiusLinux下开源解决方案,DaloRadius为图形化web管理工具。...

如何排查服务器被黑客入侵的迹象(黑客 抓取服务器数据)

---排查服务器是否被黑客入侵需要系统性地检查多个关键点,以下是一份详细的排查指南,包含具体命令、工具和应对策略:---###**一、快速初步检查**####1.**检查异常登录记录**...

使用 Fail Ban 日志分析 SSH 攻击行为

通过分析`fail2ban`日志可以识别和应对SSH暴力破解等攻击行为。以下是详细的操作流程和关键分析方法:---###**一、Fail2ban日志位置**Fail2ban的日志路径因系统配置...

《5 个实用技巧,提升你的服务器安全性,避免被黑客盯上!》

服务器的安全性至关重要,特别是在如今网络攻击频繁的情况下。如果你的服务器存在漏洞,黑客可能会利用这些漏洞进行攻击,甚至窃取数据。今天我们就来聊聊5个实用技巧,帮助你提升服务器的安全性,让你的系统更...

聊聊Spring AI Alibaba的YuQueDocumentReader

序本文主要研究一下SpringAIAlibaba的YuQueDocumentReaderYuQueDocumentReader...

Mac Docker环境,利用Canal实现MySQL同步ES

Canal的使用使用docker环境安装mysql、canal、elasticsearch,基于binlog利用canal实现mysql的数据同步到elasticsearch中,并在springboo...

RustDesk:开源远程控制工具的技术架构与全场景部署实战

一、开源远程控制领域的革新者1.1行业痛点与解决方案...

长安汽车一代CS75Plus2020款安装高德地图7.5

不用破解原车机,一代CS75Plus2020款,安装车机版高德地图7.5,有红绿灯读秒!废话不多讲,安装步骤如下:一、在拨号状态输入:在电话拨号界面,输入:*#518200#*(进入安卓设置界面,...

Zookeeper使用详解之常见操作篇(zookeeper ui)

一、Zookeeper的数据结构对于ZooKeeper而言,其存储结构类似于文件系统,也是一个树形目录服务,并通过Key-Value键值对的形式进行数据存储。其中,Key由斜线间隔的路径元素构成。对...

zk源码—4.会话的实现原理一(会话层的基本功能是什么)

大纲1.创建会话...

Zookeeper 可观测性最佳实践(zookeeper能够确保)

Zookeeper介绍ZooKeeper是一个开源的分布式协调服务,用于管理和协调分布式系统中的节点。它提供了一种高效、可靠的方式来解决分布式系统中的常见问题,如数据同步、配置管理、命名服务和集群...

服务器密码错误被锁定怎么解决(服务器密码错几次锁)

#服务器密码错误被锁定解决方案当服务器因多次密码错误导致账户被锁定时,可以按照以下步骤进行排查和解决:##一、确认锁定状态###1.检查账户锁定状态(Linux)```bash#查看账户锁定...

zk基础—4.zk实现分布式功能(分布式zk的使用)

大纲1.zk实现数据发布订阅...

《死神魂魄觉醒》卡死问题终极解决方案:从原理到实战的深度解析

在《死神魂魄觉醒》的斩魄刀交锋中,游戏卡死犹如突现的虚圈屏障,阻断玩家与尸魂界的连接。本文将从技术架构、解决方案、预防策略三个维度,深度剖析卡死问题的成因与应对之策,助力玩家突破次元壁障,畅享灵魂共鸣...

取消回复欢迎 发表评论: