详解如何在云服务器上部署Laravel


Posted in PHP onJune 30, 2017

学习PHP和Laravel已经有一段时间了,但是所有的代码都是跑在本地的虚拟主机上的,于是去腾讯云申请了一个月的免费云主机,想把项目部署到云服务器上。

不得不说这里面的坑实在是有点多,让我这个初次接触服务器的小白摸不清头脑。在配置好服务器之后,部署一个Laravel项目更是费劲心思,于是乎想记录下部署Laravel项目的过程。

PS: Linux真是越用越有感觉的系统,回家在台式机上也要装个Linux敲代码用。

环境简介

在操作系统的选择上,我选用了Linux ubuntu16.04的系统,使用的是LNMP的环境,即 Linux + Nginx + Mysql + PHP的环境。

删除Apache

sudo service apache2 stop
update-rc.d -f apache2 remove
sudo apt-get remove apache2

先用这三条命令来删除Apaceh 之后更新一下包列表

sudo apt-get update

1.安装Nginx

sudo apt-get install nginx

在安装完Nginx之后,要重启nginx

sudo service nginx start

执行完之后,在浏览器输入云服务器分配给你的公网ip,就可以看到welcome to nginx的界面了

2. 安装Mysql

sudo apt-get install mysql-server mysql-client

过程中会提示你设置Mysql的密码,就跟平时的密码设置一样,一次输入,一次确认。密码确认完毕后基本等一会就安装好了。尝试

mysql -u root -p

如果登录成功,那Mysql就正确安装了。

3.安装PHP

sudo apt-get install php5-fpm php5-cli php5-mcrypt

只有通过php5-fpm,PHP在Nginx下才能正常运行,遂,安装之。

至于php5-mcrypt,有些PHP框架会依赖于这个,比如Laravel就是,所以也把它装上了。

题外话,这里的php5我自己在部署时安装了php7 如果想尝试的也可以试试。

4.配置PHP

sudo vim /etc/php5/fpm/php.ini

打开PHP配置文件,找到cgi.fix_pathinfo选项,去掉它前面的注释分号;,然后将它的值设置为0,如下

cgi.fix_pathinfo=0

5. 启用php5-mcrypt:

sudo php5enmod mcrypt

6.重启php5-fpm:

sudo service php5-fpm restart

在搭建完LEMP环境之后,首先要明确两个重要目录

Nginx的默认root文件夹

/usr/share/nginx/html

Nginx的服务器配置文件所在目录

/etc/nginx/sites-available/

上面两个目录记住就好,很常用,先摆出来

下面一步一步在云服务器上部署Laravel

1.创建网站的根目录

sudo mkdir -p /var/www

2.配置nginx服务器

sudo vim /etc/nginx/sites-available/default

打开nginx的配置文件之后,找到server这一块,大概是长这个样子的

server {
  listen 80 default_server;
  listen [::]:80 default_server ipv6only=on;

  root /usr/share/nginx/html;
  index index.html index.htm;

  server_name localhost;

  location / {
    try_files $uri $uri/ =404;
  }
}

其中root,index ,server_name和location这几行需要稍微修改一下

root修改

root /var/www/laravel/public;

这里就是将nginx服务器的根目录指向Laravel的public文件夹下,后续的Laravel项目的代码我们会放在我们之前创建的/var/www/laravel目录下

index修改

index index.php index.html index.htm;

这里需要注意的是,将index.php排在最前面

server_name修改

server_name server_domain_or_IP;

将server_domain_or_IP修改为你的公网IP

location修改

location / {
  try_files $uri $uri/ /index.php?$query_string;
}

修改完是这样的:

server {
 listen 80 default_server;
 listen [::]:80 default_server ipv6only=on;

 root /var/www/laravel/public;
 index index.php index.html index.htm;

 server_name server_domain_or_IP;

 location / {
   try_files $uri $uri/ /index.php?$query_string;
 }
}

最后我们还需要配置一下Nginx,让其执行PHP文件。同样是在这个文件里,在location下方添加下面的配置:

server {
 listen 80 default_server;
 listen [::]:80 default_server ipv6only=on;

 root /var/www/laravel/public;
 index index.php index.html index.htm;

 server_name server_domain_or_IP;

 location / {
  try_files $uri $uri/ /index.php?$query_string;
 }

 location ~ \.php$ {
  try_files $uri /index.php =404;
  fastcgi_split_path_info ^(.+\.php)(/.+)$;
  fastcgi_pass unix:/var/run/php5-fpm.sock;
  fastcgi_index index.php;
  fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
  include fastcgi_params;
 }
}

注意,最下面的location ~ \.php$是自己加上去的:

配置完之后重启Nginx,使上面的配置项生效。

sudo service nginx restart

3.创建Laravel项目

在配置完nginx后,怎么获取Laravel的项目代码呢?有以下几种方法:

(1).直接composer安装

直接通过composer来安装,你可以在服务器上通过执行

cd ~
curl -sS https://getcomposer.org/installer | php

上面命令会安装composer

composer全局使用:

sudo mv composer.phar /usr/local/bin/composer

然后在/var/www目录下直接执行

sudo composer create-project laravel/laravel laravel

因为我们之前创建/var/www目录,你可以直接cd /var/www然后执行上面的命令。然后坐等安装完成。

(2).直接上传代码

使用下面命令上传

scp -r laravel root@your_IP:

然后在服务器上将laravel移动到/var/www目录下

sudo mv laravel/ /var/www

(3).使用Git和Coding平台

个人比较喜欢使用git来上传代码,可以很方便的更新代码和进行回滚,一旦版本更新出Bug我可以借助Git的强大版本管理能力来修复Bug。流程大概是这样:

本地代码---->Github---->云服务器

既然要使用git,那么先在云服务器上安装git:

sudo apt-get install git

安装完成就可以使用git了,然后在Github上创建一个私有项目laravel,里面包含所有该Laravel项目所需代码。

一旦本地代码都推送到Coding,然后在/var/www目录下直接使用

git clone your-project-git-link

your-project-git-link替换为你Github上的laravel项目地址

5.BINGO

在浏览器输入:http://server_domain_or_IP

至此,你可以在服务器上随意地用Laravel了,keep coding!

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

PHP 相关文章推荐
BBS(php & mysql)完整版(二)
Oct 09 PHP
php中目录,文件操作详谈
Mar 19 PHP
php+MySQL判断update语句是否执行成功的方法
Aug 28 PHP
php单例模式实现方法分析
Mar 14 PHP
PHP滚动日志的代码实现
Jun 10 PHP
php中__toString()方法用法示例
Dec 07 PHP
php+mysql+ajax实现单表多字段多关键词查询的方法
Apr 15 PHP
php生出随机字符串
Jul 06 PHP
php使用filter_var函数判断邮箱,url,ip格式示例
Jul 06 PHP
Laravel框架Eloquent ORM简介、模型建立及查询数据操作详解
Dec 04 PHP
使用PHP+Redis实现延迟任务,实现自动取消订单功能
Nov 21 PHP
phpstudy2020搭建站点的实现示例
Oct 30 PHP
[企业公众号]升级到[企业微信]之后发送消息失败的解决方法
Jun 30 #PHP
ThinkPHP实现登录退出功能
Jun 29 #PHP
PHP实现微信图片上传到服务器的方法示例
Jun 29 #PHP
PHP微信模板消息操作示例
Jun 29 #PHP
PHP开发的微信现金红包功能示例
Jun 29 #PHP
PHP实现微信模拟登陆并给用户发送消息的方法【文字,图片,图文】
Jun 29 #PHP
php实现微信模拟登陆、获取用户列表及群发消息功能示例
Jun 28 #PHP
You might like
解析PHP工厂模式的好处
2013/06/18 PHP
PHP读取CURL模拟登录时生成Cookie文件的方法
2014/11/04 PHP
php中序列化与反序列化详解
2017/02/13 PHP
PHP实现Session入库/存入redis的方法
2017/05/04 PHP
window.location.hash 属性使用说明
2010/03/20 Javascript
javascript利用控件对windows的操作实现原理与应用
2012/12/23 Javascript
jquery焦点图片切换(数字标注/手动/自动播放/横向滚动)
2013/01/24 Javascript
JavaScript动态插入script的基本思路及实现函数
2013/11/11 Javascript
JS使用replace()方法和正则表达式进行字符串的搜索与替换实例
2014/04/10 Javascript
jQuery实现鼠标可拖动调整表格列宽度
2014/05/26 Javascript
jQuery里filter()函数与find()函数用法分析
2015/06/24 Javascript
js编写贪吃蛇的小游戏
2020/08/24 Javascript
去除html代码里面的script正则方法
2016/05/19 Javascript
jQuery中弹出iframe内嵌页面元素到父页面并全屏化的实例代码
2016/12/27 Javascript
Angular实现跨域(搜索框的下拉列表)
2017/02/16 Javascript
Vue filter介绍及其使用详解
2017/10/21 Javascript
webpack打包js文件及部署的实现方法
2017/12/18 Javascript
微信小程序wx:for和wx:for-item的用法详解
2018/04/01 Javascript
微信小程序中添加客服按钮contact-button功能
2018/04/27 Javascript
vue单页应用在页面刷新时保留状态数据的方法
2018/09/21 Javascript
NUXT SSR初级入门笔记(小结)
2019/12/16 Javascript
[01:44]剑指西雅图 展望TI之CIS战队专访
2014/06/25 DOTA
Python实现生成简单的Makefile文件代码示例
2015/03/10 Python
基于并发服务器几种实现方法(总结)
2017/12/29 Python
Python类的继承用法示例
2019/01/31 Python
django-crontab实现服务端的定时任务的示例代码
2020/02/17 Python
GAP欧盟网上商店:GAP EU
2016/09/13 全球购物
澳大利亚礼品卡商店:Gift Card Store
2019/06/24 全球购物
高中运动会入场词
2014/02/14 职场文书
计算机专业求职信
2014/06/02 职场文书
九一八事变演讲稿范文
2014/09/14 职场文书
2014年群众路线党员自我评议
2014/09/24 职场文书
格列夫游记读书笔记
2015/07/01 职场文书
使用pandas模块实现数据的标准化操作
2021/05/14 Python
python 常用的异步框架汇总整理
2021/06/18 Python
Vue vee-validate插件的简单使用
2021/06/22 Vue.js