• 欢迎访问VPS岛网站,国外VPS,国内VPS,国外服务器,国内服务器,服务器主机,测评及优惠码,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站 QQ群

在 CentOS 上部署 PHP7 开发测试环境

Centos技术 mb5fe94cbf99977 15次浏览 已收录 0个评论

最近公司增加了一台测试用的服务器,当然因为只是测试用,所以决定所有东西都装到一个服务器上,用来我们自己撸代码,发测试版功能,做点小实验神码的,等等等等……反正就是方便用吧,所以自己来试了下搭建一台完全的 LAMP 开发/测试环境,当然同样踩到了无数的坑。

准备开始吧!

Step.1 准备服务器

那第一步,我们先搞个服务器吧,搞啥服务器呢,既然是测试用那就搞点不要钱的,或者方便的吧,这里就推荐大家试试用 AWS 或者自己机器上搭建虚拟机,比如 Vagrant 这样的开发平台也是可以的,这里,我们就用 AWS 了,反正可以免费一年, AWS 的优点是访问国外网站超快,缺点自然是国内访问超慢,当然大家用啥都可以的啦,这里假设我们已经有一台 CentOS 7 的服务器了,并且假设你可以远程链接到这台服务器(比如 ssh )。

Setp.2 安装配置 LAMP

安装 Apache 很简单,只需要通过 yum 安装就可以了。

1

2

yum install httpd

 

安装完成后,使用 systemctl 命令启动,并设置为开机自动启动。

1

2

3

systemctl start httpd.service

systemctl enable httpd.service

 

出现问题时可以通过 systemctl status 来查看服务是否正确的启动了,也可以到/var/log/httpd 路径下看访问日志和错误日志来排查问题。

新的 CentOS 已经装了 FirewallD 了,所以如果装了这个,我们还需要告诉 FirewallD 打开防火墙。

1

2

3

4

firewallcmd permanent zone=public addservice=http

firewallcmd permanent zone=public addservice=https

firewallcmd reload

 

  • 接下来装 MySQL

首先,我们要知道的是, MySQL 没有在 CentOS 7 的软件源库里面, CentOS 7 里面有对应的替代品 MariaDB ,因为龟壳公司收购了 MySQL ,大家怕万一将来 MySQL 闭源了,那不都跪了,于是就开了个分支自己开始做起 MariaDB 来了,这里我们还是手工添加 MySQL 的软件源来安装 MySQL 保证还是那个味道。

首先添加 MySQL 的软件源。

1

2

yum install http://dev.mysql.com/get/mysql-community-release-el7-5.noarch.rpm

 

接下来安装 MySQL 的客户端和服务端。

1

2

yum install mysqlserver mysqlclient

 

安装完成后,使用 mysql_secure_installation 来完成 MySQL 的安装配置。

同样需要为 MySQL 配置防火墙。

1

2

3

firewallcmd permanent zone=public addservice=mysql

firewallcmd reload

 

  • 接下来我们安装 PHP 7

跟 MySQL 类似,目前发行包的软件源里面是不包含 PHP 7 ,只包含了 PHP 5.x ,所以为了安装 PHP 7 我们同样需要添加 PHP 7 的软件源,根据这几天的实验情况看, Remi 的 PHP 7 的软件包和插件比较完善,所以我们就先添加 Remi 的软件源。

1

2

3

4

yum install sclutils

yum install https://dl.fedoraproject.org/pub/epel/epel-release-latest-7.noarch.rpm

yum install http://rpms.remirepo.net/enterprise/remi-release-7.rpm

 

添加完成软件源后,我们就可以安装 PHP 7 和各种常用的包了。

1

2

3

4

5

6

7

8

yum install php70 php70phpmysqlnd php70phpcurl php70phpsimplexml

yum install php70phpdevel php70phpgd php70phpjson php70phpmcrypt

yum install php70phpmbstring php70phpopcachephp70phppear

yum install php70phppeclapcu php70phppeclgeoip php70phppeclimagick

yum install php70phppecljsonpost php70phppeclmemcache php70phppeclmemcached

yum install php70phppeclxmldiff php70phppeclzip php70phppspell php70phpsoap

yum install php70phptidy php70phpxml php70phpxmlrpc

 

接下来呢,这里其实还没装完,因为最初我是为了升级服务器 PHP 5.x 而装的 PHP 7 ,所以如果你的服务器已经装了 PHP 5.x 需要简单的升级下,那么在这里安装完成 PHP 7 的软件包以后删除 PHP 5.x 然后在安装 php70-php 这个包。

1

2

yum remove php phpcommon

 

然后

1

2

yum install php70php

 

之后修改配置文件重启 Apache 就可以了,要注意的是, PHP 7 的配置文件放到了/etc/opt/remi/php70 路径下, PHP 7 的相关文件放到了 /opt/remi/php70/root/lib64/php 路径下。

好,这样,我们一个带着 PHP 7 的服务器就装好了,大家可以在上面自由玩耍享受 PHP 7 带来的性能。

Setp.3 安装 SASL 和 Memcached

首先 Memcached 大家都知道是什么东西了,那么我来说说 SASL 是什么鬼。 SASL 全称 Simple Authentication and Security Layer 用来做安全机制验证的,说简单点,就是用这个东西,我们可以让我们的 Memcached 在访问前需要验证下用户名密码,另外 Memcached 的 Binary 接口比需要使用 SASL 验证,否则就会输出 Writing an error: Unknown command 的错误(然而在 PHP 5.x 下,却正常。。。所以这个问题研究了好会儿)。

我们先安装 SASL 。

1

2

3

4

5

6

7

yum install cyrussaslplain

yum install cyrussasldevel

yum install cyrussasl

yum install cyrussasllib

yum install cyrussaslgssapi

yum install cyrussaslmd5

 

安装完成后,通过 systemctl start saslauthd.service 命令启动这个服务,接下来,我们需要创建一个用户通过 SASL 验证来访问 Memcached 。

首先我们要修改 SASL 的配置来使用当前 /etc/shadow 中的用户账户以及密码来进行验证,所以我们修改 /etc/sysconfig/saslauthd 中的 MECH=shadow 告诉 SASL 使用系统的账户密码来验证,修改完后通过 systemctl restart saslauthd.service 重启 SASL 的进程。

可以通过下面的命令来验证用户是否可以正确的被验证了。

1

2

/usr/sbin/testsaslauthd u username p password

 

成功将会显示 0: OK “Success.” ,要注意的是这里的 username 和 password 是需要能够正常登录系统的用户名和密码,也就是需要记录在 /etc/shadow 文件中。

接下来我们安装 Memcached 需要的 libevent 。

1

2

yum install libevent libeventdevel

 

再接下来,我们需要通过源代码编译安装 Memcached ,因为默认在 yum 中的 Memcached 是没有开启 SASL 验证。

1

2

3

4

5

6

7

wget http://memcached.googlecode.com/files/memcached-1.4.15.tar.gz

tar zxvf memcached1.4.15.tgz

cd memcached1.4.15

./configure enablesasl withphpconfig=/opt/remi/php70/root/bin/phpconfig

make

make install

 

这样我们的 Memcached 也编译并安装完成了,接下来为 Memcached 的服务添加 SASL 验证和防火墙规则。

1

2

3

4

saslpasswd2 a memcached c [用来访问 memcached 用户]

firewallcmd permanent zone=public addport=11211/tcp

firewallcmd reload

 

接下来我们启动 Memcached 。

1

2

/usr/local/bin/memcached d u [用来访问 memcached 的用户] p 11211 m 512 c 1024 S

 

上面参数中 -S 就是告诉 memcached 需要开启 SASL 验证。

Step.End

到此,开发环境的配置就结束了,大家愉快的玩耍吧,欢迎掷砖


VPS岛 的文章和资源来自互联网,仅作为参考资料,如果有侵犯版权的资源请尽快联系站长,我们会在24h内删除有争议的资源。丨 转载请注明在 CentOS 上部署 PHP7 开发测试环境
喜欢 (0)
发表我的评论
取消评论
表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址