Centos yum安装PHP+MysqL(mariadb)+httpd(apache)环境

本文使用CentOS 6 x64版本,Centos7通用,安装PHP+mariadb+httpd环境,有机会会介绍windows版本安装与linux下二级制源码安装。
一、环境介绍
新入手一个美国老牌主机商vultr.com的$5/month的主机,一直用作ss使用,有近5年没有使用过PHP了,今日计划使用期安装下zblog系统和wordpress,自己动手制作个主题模板,做个bolg。

环境 命令 参数
OS cat /etc/redhat-release CentOS release 6.8 (Final)
host uname -a Linux 2.6.32-642.15.1.el6.x86_64 #1 SMP Fri Feb 24 14:31:22 UTC 2017 x86_64 x86_64 x86_64 GNU/Linux

二、MysqL(mariadb)安装
MariaDB数据库管理系统是MysqL的一个分支,主要由开源社区在维护,采用GPL授权许可 MariaDB的目的是完全兼容MysqL,包括API和命令行,使之能轻松成为MysqL的代替品。在存储引擎方面,使用XTradB(英语:XTradB)来代替MysqL的InnoDB。 MariaDB由MysqL的创始人Michael Widenius(英语:Michael Widenius)主导开发,他早前曾以10亿美元的价格,将自己创建的公司MysqL AB卖给了SUN,此后,随着SUN被甲骨文收购,MysqL的所有权也落入Oracle的手中。MariaDB名称来自Michael Widenius的女儿Maria的名字。
安装MysqL:yum install -y MysqL-server MysqL MysqL-devel

这里MysqL-server为MysqL服务端软件,MysqL 为MysqL客户端软件,用于本地命令行方式连接操作MysqL,这两个都比较好理解。MysqL-devel为MysqL开发者工具包,里面主要提供C/C++开发MysqL应用软件时使用的头文件等信息,同时例如Python,PHP等其他解释型脚本语言底层使用的都是C语言库,故在安装其MysqL扩展插件时有可能需要MysqL-devel开发环境。这里使用的是yum的方式安装MysqL服务,若在没有网络的情况下可以使用rpm安装,centos自带光盘或ISO文件下Packages下面的rpm安装包。若是机器不是X86体系的处理器,而是例如国产化一些处理器如龙芯,飞腾等,运气好可以找到rpm包,找不到就只能源码安装,这里安装过程就不多说了,曾经在龙芯2B上安装一个MysqL5.1,编译就耗时了近3个小时。
三、HTTPD(apache)安装
httpd安装:yum install -y httpd

这里安装很简单,同理没有网络或芯片级差异请找rpm包或源码编译。

PS:这里主要说两点题外话,第一,rpm包其实是在这个平台上通过源码编译完成之后生成的二级制文件包,就是一个压缩包,其中有一些脚本,通过rpmbuild工具打包成当前平台向的rpm安装包或软件补丁包,具体可自行百度Google。第二,例如很多软件名称如下httpd、sshd、MysqLd、pptpd后面都带个d,这个d的意思简单说下,d是daemon名称是守护神的意思,计算机术语是守护进程,没错,这些都是守护进程的意思,守护进程是一类在后台运行的特殊进程,确保其守护的服务正常运行。

四、PHP安装
PHP安装:yum install -y PHP PHP–devel
PHP扩展插件安装:yum install PHP-MysqL PHP-gd PHP-imap PHP-ldap PHP-odbc PHP-pear PHP-xml PHP-xmlrpc
安装成功测试:
httpd安装后未修改配置文件/etc/httpd/conf/httpd.conf的情况下,默认web跟目录在/var/www/html,故在目录下建议一个info.PHP的文件,文件内容如下:

这时候我们启动httpd服务查看效果,service httpd start

PS:不好意思,这里又要废话了,这里简单说下httpd这些服务,其实是存在于/etc/目录下的脚本文件,具体可了解linux服务。

这里httpd其实是一个bash脚本文件,其中而有start,stop,restart,status等函数,感兴趣的可以了解下,这里不啰嗦了,结果如下图所示,即安装成功。

在安装完成后,安装其他开源程序时,例如wordpress,PHPwind,zblog等程序时,若出现上传失败,(即创建新文件失败),请从两方面考虑,用户权限问题,系统权限认证问题。用户权限问题主要体现在文件权限上,这里建议不要不管三七二十一就chmod 777 *来赋权,这样第一即使解决了也存在巨大问题如安全问题。第二在selinux MAC认证下,即使777也解决不了问题。

我们分析下这个问题,首先创建文件失败,除了磁盘满了,坏了等特殊情况下,肯定是权限出问题了,首先我们来看下,运行httpd服务的用户是谁,首先我们找到是那个进程在监听80端口,这里由于安全考虑,不想被来回扫到,我机器修改了httpd.conf文件,监听端口888。netstat -anp |grep 888 如下图:

888端口监听的进程PID是10283,我们查找其与其相关的进程,ps -ef|grep 10283

大家可以发现10283是由root用户启动,它创建了一些子进程,子进程的用户是apache,这里我们可以简单理解,httpd的业务处理服务进程是由apache用户启动的,所以需要对上传文件的目录给apache用户赋权限,可以通过 chown -R path path为具体路径。
此外,由于red hat体系(centos属于redhat的社区版)默认是运行selinux认证机制的,所以需要关闭其selinux,通过命令setenforce 0 暂时关闭,具体selinux认证是什么可以自行百度。

Centos yum安装php+mysql(mariadb)+httpd(apache)环境的更多相关文章

  1. 从iOS应用程序发送帖子到PHP脚本不工作…简单的解决方案就像

    我之前已经做了好几次了但是由于某些原因我无法通过这个帖子…我尝试了设置为_POST且没有的变量的PHP脚本……当它们未设置为发布时它工作精细.这是我的iOS代码:这里是PHP的一大块,POST变量不在正确的位置?我想这对于更有经验的开发人员来说是一个相当简单的答案,感谢您的帮助!解决方法$_POST是一个数组,而不是一个函数.您需要使用方括号来访问数组索引:

  2. IOs Cordova长按显示文本选择放大镜即使禁用文本选择,如何删除?

    是否有任何可能导致此问题的插件?任何帮助深表感谢.Cordova插件:>com.mbppower.camerapreview>cordova-plugin-statusbar>cordova-plugin-whitelist>离子插件键盘>org.apache.cordova.camera>org.apache.cordova.console>org.apache.cordova.device>org.apache.cordova.dialogs>org.apache.cordova.file>org.a

  3. android – org.apache.cordova.api不存在. PhoneGap 3.0

    我正在尝试将VideoPlayer插件(https://github.com/macdonst/VideoPlayer)添加到我的phonegapAndroid应用程序中.在编译时遇到问题:第25行:解决方法将您的导入更改为:

  4. 如何将android客户端连接到我的笔记本电脑内的Apache服务器(php)的localhost?

    我的笔记本电脑中的localhost-127.0.0.1或android10.0.0.1中的localhost?>那么,如果我想从android访问localhost来调用PHP来运行?哪个ip地址/url我需要放在Android应用程序?我需要在httpconfig中为XAMPP修改任何内容吗?解决方法使用ipconfig在笔记本电脑中找到您的IP地址.在手机中使用该地址而不是127.0.0.1.

  5. android – 在android工作室中的proguard错误

    我想在我的应用程序中使用proguard,我启用它但是当我想生成apk文件时,它给了我这个错误:我正在使用最新版本的sdk23,这是我的gradle文件:怎么了?我在这段代码中做错了什么?谢谢解决方法只需在proguard上添加:

  6. 无法修复Android Proguard返回错误代码1错误

    当我尝试在我的Android应用程序中使用proguard时只需添加到我的project.properties文件,APK导出失败并显示消息Proguard返回错误代码1这是我的project.properties文件这是错误堆栈:解决方法将这些行添加到proguard配置文件(proguard-android.txt)见ProguardTroubleshooting请注意,如果您使用您的配置文件

  7. Phonegap 2.4 Android Proguard配置

    有人有主意吗???

  8. android – 如何在sharedPreferences中分析ANR

    在sharedPreferences中遇到ANR,不知道如何定位问题.以下是trace的三个部分,其他大多数线程都是“WAIT”或“TIMED_WAIT”.由于countdownlatch.await(),“主”线程被阻止.第二个线程“pool-1-thread-1”等待fsync.最后一个是试图读一些东西.我认为第二个线程已经阻塞了主线程,因为如果这个无法完成,它将不会调用countdownla

  9. Android – 将SQLite与MySQL同步的最佳方式

    参见英文答案>Synchronizingclient-serverdatabases5个我正在开发一个包含网络应用和移动应用程序的项目,该应用程序记录每日用户的数据.用户可以删除,更新他们的数据,他们可以使用许多设备插入数据.我打算这样开发:用户输入他们的数据然后插入sqlite.服务将定期启动(每5小时或每小时)以使用时间戳与MysqL同步.我确实在互联网上使用服务和时间戳搜索了一个样本,但我一

  10. Android无法访问org.apache.http.client.HttpClient

    我正在使用androidstudio创建一个向服务器发出GET请求的应用程序.我的代码是这样的:问题是AndroidStudio标记了这一行有错误:说“无法访问org.apache.http.client.HttpClient”这是我的gradle文件:解决方法在AndroidSDK23中不推荐使用HttpClient,因为它推断,您可以在HttpURLConnection中迁移代码https:/

随机推荐

  1. 在airgapped(离线)CentOS 6系统上安装yum软件包

    我有一个CentOS6系统,出于安全考虑,它已经被空气泄漏.它可能从未连接到互联网,如果有,它很长时间没有更新.我想将所有.rpm软件包放在一个驱动器上,这样它们就可以脱机安装而无需查询互联网.但是,我在测试VM上遇到的问题是,即使指定了本地路径,yum仍然会挂起并尝试从在线存储库进行更新.另外,有没有办法使用yum-utils/yumdownloader轻松获取该包的所有依赖项和所有依赖项?目前

  2. centos – 命名在日志旋转后停止记录到rsyslog

    CentOS6.2,绑定9.7.3,rsyslog4.6.2我最近设置了一个服务器,我注意到在日志轮换后,named已停止记录到/var/log/messages.我认为这很奇怪,因为所有日志记录都是通过rsyslog进行的,并且named不会直接写入日志文件.这更奇怪,因为我在更新区域文件后命名了HUPed,但它仍然没有记录.在我停止并重新启动命名后,记录恢复.这里发生了什么?

  3. centos – 显示错误的磁盘大小

    对于其中一个磁盘,Df-h在我的服务器上显示错误的空白区域:Cpanel表明它只有34GB免费,但还有更多.几分钟前,我删除了超过80GB的日志文件.所以,我确信它完全错了.fdisk-l/dev/sda2也显示错误:如果没有格式化,我该怎么做才能解决这个问题?并且打开文件描述符就是它需要使用才能做到这一点.所以…使用“lsof”并查找已删除的文件.重新启动写入日志文件的服务,你很可能会看到空间可用.

  4. 如何在centos 6.9上安装docker-ce 17?

    我目前正在尝试在centOS6.9服务器上安装docker-ce17,但是,当运行yuminstalldocker-ce时,我收到以下错误:如果我用跳过的标志运行它我仍然得到相同的消息,有没有人知道这方面的方法?

  5. centos – 闲置工作站的异常负载平均值

    我有一个新的工作站,具有不寻常的高负载平均值.机器规格是:>至强cpu>256GB的RAM>4x512GBSSD连接到LSI2108RAID控制器我从livecd安装了CentOS6.564位,配置了分区,网络,用户/组,并安装了一些软件,如开发工具和MATLAB.在启动几分钟后,工作站负载平均值的值介于0.5到0.9之间.但它没有做任何事情.因此我无法理解为什么负载平均值如此之高.你能帮我诊断一下这个问题吗?

  6. centos – Cryptsetup luks – 检查内核是否支持aes-xts-plain64密码

    我在CentOS5上使用cryptsetupluks加密加密了一堆硬盘.一切都很好,直到我将系统升级到CentOS6.现在我再也无法安装磁盘了.使用我的关键短语装载:我收到此错误:在/var/log/messages中:有关如何装载的任何想法?找到解决方案问题是驱动器使用大约512个字符长的交互式关键短语加密.出于某种原因,CentOS6中的新内核模块在由旧版本创建时无法正确读取512个字符的加密密钥.似乎只会影响内核或cryptsetup的不同版本,因为在同一系统上创建和打开时,512字符的密钥将起作用

  7. centos – 大量ssh登录尝试

    22个我今天登录CentOS盒找到以下内容这是过去3天内的11次登录尝试.WTF?请注意,这是我从我的提供商处获得的全新IP,该盒子是全新的.我还没有发布任何关于此框的内容.为什么我会进行如此大量的登录尝试?是某种IP/端口扫描?基本上有4名匪徒,其中2名来自中国,1名来自香港,1名来自Verizon.这只发生在SSH上.HTTP上没有问题.我应该将罪魁祸首子网路由吗?你们有什么建议?

  8. centos – kswap使用100%的CPU,即使有100GB的RAM也可用

    >Linux内核是否应该足够智能,只需从内存中清除旧缓存页而不是启动kswap?

  9. centos – Azure将VM从A2 / 3调整为DS2 v2

    我正在尝试调整前一段时间创建的几个AzureVM,从基本的A3和标准A3到标准的DS2v2.我似乎没有能力调整到这个大小的VM.必须从头开始重建服务器会有点痛苦.如果它有所不同我在VM中运行CentOS,每个都有一个带有应用程序和操作系统的磁盘.任何人都可以告诉我是否可以在不删除磁盘的情况下删除VM,创建新VM然后将磁盘附加到新VM?

  10. centos – 广泛使用RAM时服务器计算速度减慢

    我在非常具体的情况下遇到服务器速度下降的问题.事实是:>1)我使用计算应用WRF>2)我使用双XeonE5-2620v3和128GBRAM(NUMA架构–可能与问题有关!

返回
顶部