How to build a php7 environment with vagrant

醉折花枝作酒筹
Release: 2023-02-18 06:40:01
forward
1982 people have browsed it

This article introduces how to build a php7 development environment with vagrant. It covers the installation and configuration of nginx, the installation and configuration of composer, php7 installation and module installation, and the configuration of the firewall in centos7.

How to build a php7 environment with vagrant

I have basically gone through the basic knowledge of vagrant before. I believe that as long as you follow the tutorial, you will have set up your own basic environment. Next, let’s talk about how to set up a development environment for php7.

Let me state that the box used here is the centos7 demonstrated earlier
The address is provided:
https://github.com/tommy-muehle/puppet-vagrant-boxes/ releases/download/1.1.0/centos-7.0-x86_64.box

Installing nginx

First you need to update some ngin-related sources.

$ rpm -Uvh http://nginx.org/packages/centos/7/noarch/RPMS/nginx-release-centos-7-0.el7.ngx.noarch.rpm // 执行安装过程 $ yum install nginx
Copy after login

When you see the following interface, please wait. If you need to enter something, please press y and press Enter.

How to build a php7 environment with vagrant

Start nginx and set it to start at boot

$ systemctl start nginx $ systemctl enable nginx
Copy after login

Install epel and remi sources

Install epel. epel is a software warehouse project maintained by the Fedora team, which provides RHEL/CentOS with software packages that they do not provide by default. When installing, you must pay attention to the version of your system.

$ rpm -ivh http://mirrors.opencas.cn/epel/7/x86_64/e/epel-release-7-5.noarch.rpm
Copy after login

Modified on 2016-10-22:

The source posted above recently cannot be used. Please find the corresponding version here

http://dl.fedoraproject.org/pub/

If you can’t pass the wall, please use the domestic mirror


http://mirrors.sohu.com/fedora-epel/7/x86_64/e/epel-release-7-8.noarch.rpm

remi source contains the latest php related information, Such as: php7, mysql, etc. Therefore, in order to easily obtain the latest information of php7, you also need to install this source.

$ rpm -ivh http://rpms.famillecollet.com/enterprise/remi-release-7.rpm
Copy after login

iptables firewall

Because I often use iptables before, I am not familiar with the firewalld firewall that comes with centos7, so I will turn off the firewalld that comes with centos7 and enable it myself. Be familiar with iptables.

First, turn off the built-in firewalld firewall

$ systemctl stop firewalld.service $ systemctl disable firewalld.service #防止开机启动
Copy after login

Install iptables

$ yum install iptables-services
Copy after login

The installation process is as shown in the figure below

How to build a php7 environment with vagrant

Start iptables firewall

systemctl start iptables.service systemctl enable iptables.service #开机自动启动
Copy after login

Edit firewall configuration file

In order for us to have smooth access on our own host, we need to open the following ports,

vim /etc/sysconfig/iptables

Edit the firewall, set 80 (nginx) 3306 (mysql/mariadb) 6379 (redis) port, accessible from the external network

How to build a php7 environment with vagrant

Installation of PHP7.0

View the installable php information in the remi source

$ yum list --enablerepo=remi --enablerepo=remi-php70 | grep php70
Copy after login

The list will list all the php that can be installed Module information, from which you can install the modules you need. Installing the modules below is my own module selection. Some of them are required and some are optional. For example, php-fpm is necessary if you are using nginx.

$ yum install --enablerepo=remi --enablerepo=remi-php70 php php-opcache php-pecl-apcu php-devel php-mbstring php-mcrypt php-mysqlnd php-pecl-xdebug php-pdo php-pear php-fpm php-cli php-xml php-bcmath php-process php-gd php-common php-json php-imap php-pecl-redis php-pecl-memcached php-pecl-mongodb
Copy after login

After the installation is complete, enter php -v to view the currently installed php version information.

How to build a php7 environment with vagrant

Start php-fpm, because nginx needs it to parse the php program

$ systemctl start php-fpm $ systemctl enable php-fpm #设置开机自启动
Copy after login

Configure nginx to access php

Enter the nginx file configuration center,

$ cd /etc/nginx/conf.d/ # 复制默认的配置文件 $ cp default.conf php.conf
Copy after login

First edit the default file through vim. Change the listening port to 8080, because our own php.conf will use port 80 later.

How to build a php7 environment with vagrant

Now let’s edit the copied php.conf file. You can directly copy the following content. As for the meaning of configuration, I will open an article to explain it separately later.

server { listen 80; server_name localhost; charset utf-8; root /vagrant/www;# 自己的项目目录,也就是php项目所在目录 location / { # 请注意,一定要加index.php这项 index index.php index.html index.htm; } error_page 500 502 503 504 /50x.html; location = /50x.html { root /usr/share/nginx/html; } location ~ \.php$ { fastcgi_pass 127.0.0.1:9000; fastcgi_index index.php; # 注意此处变量的不同 fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name; include fastcgi_params; } }
Copy after login

After modifying the file, nginx must be restarted for the current configuration to take effect.

$ systemctl reload nginx
Copy after login

Test access

Create a new file index.php under /vagrant/www


        
Copy after login

Open it in the browser and access the corresponding ip , you can see the output php information

How to build a php7 environment with vagrant

Note: If there are newly added php modules during use, you need to restart php-fpm

systemctl reload php-fpm
Copy after login

Mariadb的安装

这里很多同学可能第一次听说mariadb,他呢是mysql的一个重要分子,或者可以理解为mysql的替代品,自从mysql被控制后,更新速度已经慢太多了。两者的用法基本没有区别,实际中有哪些坑,大家可以自己去踩一踩。哈哈,别说我不负责任。

# 安装 $ yum install mariadb-server # 启动服务 $ systemctl start mariadb # 开机启动 $ systemctl enable mariadb
Copy after login

MariaDB的安全配置

MariaDB默认root密码为空,我们需要设置一下,执行脚本:

$ sudo mysql_secure_installation
Copy after login

这个脚本会经过一些列的交互问答来进行MariaDB的安全设置。

首先提示输入当前的root密码:

Enter current password for root (enter for none):

初始root密码为空,我们直接敲回车进行下一步。

Set root password? [Y/n]

设置root密码,默认选项为Yes,我们直接回车,提示输入密码,在这里设置您的MariaDB的root账户密码。

Remove anonymous users? [Y/n]

是否移除匿名用户,默认选项为Yes,建议按默认设置,回车继续。

Disallow root login remotely? [Y/n]

是否禁止root用户远程登录?如果您只在本机内访问MariaDB,建议按默认设置,回车继续。 如果您还有其他云主机需要使用root账号访问该数据库,则需要选择n。

Remove test database and access to it? [Y/n]

是否删除测试用的数据库和权限? 建议按照默认设置,回车继续。

Reload privilege tables now? [Y/n]

是否重新加载权限表?因为我们上面更新了root的密码,这里需要重新加载,回车。

完成后你会看到Success!的提示,MariaDB的安全设置已经完成。我们可以使用以下命令登录MariaDB:

$ mysql -uroot -p
Copy after login

按提示输入root密码,就会进入MariaDB的交互界面,说明已经安装成功。

How to build a php7 environment with vagrant

最后我们将MariaDB设置为开机启动。

$ sudo systemctl enable mariadb
Copy after login

让外网可以进行链接

mysql> grant all on *.* to 'root'@'%' identified by 'root'; mysql> flush privileges;
Copy after login

安装composer

composer的大名,我就不想介绍了,如果你是一个phper,没用过,我也就不怪你,毕竟但是他现在才刚过1.0版,但是如果听都没听过,请面壁去……

安装说明

$ php -r “readfile(‘https://getcomposer.org/installer‘);” > composer-setup.php $ php composer-setup.php $ php -r “unlink(‘composer-setup.php’);”
Copy after login

上述 3 条命令的作用依次是:

  • 下载安装脚本(composer-setup.php)到当前目录。

  • 执行安装过程。

  • 删除安装脚本 – composer-setup.php 。

全局安装composer

全局安装是将 Composer 安装到系统环境变量 PATH 所包含的路径下面,然后就能够在命令行窗口中直接执行 composer 命令了。

Mac 或 Linux 系统:打开命令行窗口并执行如下命令将前面下载的 composer.phar 文件移动到 /usr/local/bin/ 目录下面:

$ sudo mv composer.phar /usr/local/bin/composer
Copy after login

然后执行:

composer -v
Copy after login

How to build a php7 environment with vagrant

由于composer的包都在国外,这里设置一下composer的配置,让其每次运行时,都使用国内的包

$ composer config -g repo.packagist composer https://packagist.phpcomposer.com
Copy after login

查看composer的配置文件

vim /root/.composer/config.json

How to build a php7 environment with vagrant

看到以上内容,表示配置成功!

推荐学习:php视频教程

The above is the detailed content of How to build a php7 environment with vagrant. For more information, please follow other related articles on the PHP Chinese website!

Related labels:
source:csdn.net
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template
About us Disclaimer Sitemap
php.cn:Public welfare online PHP training,Help PHP learners grow quickly!