Skip to content

Latest commit

 

History

History
188 lines (128 loc) · 6.39 KB

README-zh_CN.md

File metadata and controls

188 lines (128 loc) · 6.39 KB

如何在共享主机上部署Laravel应用程序

API Documentation API Documentation API Documentation API Documentation

本简要指南介绍如何在共享主机上部署Laravel和Lumen应用程序。

本指南有一个更加简明的版本(也许你已经读过),阅读该指南请移步"在共享主机上部署Laravel 5应用程序的简单指南(英文)"

系统要求

尝试在共享主机上部署Laravel应用程序之前,需要确保主机服务提供适合Laravel要求的环境。 例如,Laravel 5.2的基本要求如下:

  • PHP >= 5.5.9
  • OpenSSL PHP 扩展
  • PDO PHP 扩展
  • Mbstring PHP 扩展
  • Tokenizer PHP 扩展

总之,具体取决于你想安装的Laravel版本,请检查相应版本的Laravel文档的服务器要求页面

接下来,你必须拥有虚拟主机的SSH访问权限。否则下面的内容都可以忽略。

除了PHP和上述必备扩展,下列实用程序可以使部署更加容易。

有了这些就好办了。接下来,请参阅以下内容,详细了解部署Laravel应用程序的更多信息。

部署说明

首先,让我们来了解如何组织Laravel应用程序文件结构。 一开始,您的虚拟主机用户文件夹下,会有类似下列目录和文件:

.bash_history
.bash_logout
.bash_profile
.bashrc
.cache
.cpanel
.htpasswds
logs
mail
public_ftp
public_html
.ssh
tmp
etc
www -> public_html
...

对于与主域名绑定的主账户,前端代码应该保存在“public_html”或“www”目录中。 我们当然不想将 Laravel文件 (如.env 等...)暴露给全世界,所以我们要把它们放在其他目录中。

创建一个与“public_html”或“www”平行的目录,将它命名为projects或其他适合的名字。

$ mkdir projects
$ cd projects

好了,接下来我们可以利用git命令来获取代码。

$ git clone http://[GIT_SERVER]/awesome-app.git
$ cd awesome-app

下一步是要将awesome-app/public目录映射到www目录。这个时候符号连接(symbolic link)非常有用。不过,首先我们需要备份public文件夹。

$ mv public public_bak
$ ln -s ~/www public
$ cp -a public_bak/* public/
$ cp public_bak/.htaccess public/

因为我们把www目录映射成项目的虚拟public目录,所以,我们需要编辑~/www/index.php,更新文件路径:

- require __DIR__.’/../bootstrap/autoload.php’;
+ require __DIR__.'/../projects/awesome-app/bootstrap/autoload.php';

- $app = require_once __DIR__.’/../bootstrap/app.php’;
+ $app = require_once __DIR__.'/../projects/awesome-app/bootstrap/app.php';

更新后的文件应该是这样:

require __DIR__.'/../projects/awesome-app/bootstrap/autoload.php';

$app = require_once __DIR__.'/../projects/awesome-app/bootstrap/app.php';

好了,麻烦的部分到此结束。接下来就似乎一些基本的Laravel设置了。首先,确保storage目录可写:

$ chmod -R o+w storage

然后,编辑.env文件,确保配置正确。这步不要忘记!

最后,使用composer来安装或更新必要的依赖包,并添加必要的缓存文件:

$ php composer install
$ php composer dumpautoload -o
$ php artisan config:cache
$ php artisan route:cache

恭喜!到此,你已成功在共享虚拟主机上设置Laravel应用程序。

常见问题

1. 如何获取我的帐户的SSH访问权限?

请联系您的主机客服,确认您的身份后,您将立即可以获得SSH访问权限。

2. git在哪里? 我怎么找不到。

在CPanel主机服务中,git一般安装在/usr/local/cpanel/3rdparty/bin/git。所以,如果想要使用git命令,则要提供git的完整路径。 当然,也可以创建别名以方便使用:

alias git="/usr/local/cpanel/3rdparty/bin/git"

3. 如何安装composer?

可以使用FTP或SCP命令来上传将下载好的composer.phar上传到虚拟主机。也可以直接使用wgetcurl在主机上直接下载:

$ wget https://getcomposer.org/composer.phar

或者

$ curl -sS https://getcomposer.org/installer | php — –filename=composer

4. 这个指南可以用于Lumen吗?

Laravel和Lumen就像一对双胞胎,所以Lumen也适用。

5. 我尝试使用composer命令,但什么也没显示。发生了什么?

运行composer需要提供php环境信息。也就是说,在某些虚拟主机上不能直接运行composer。要运行composer,需要使用如下命令:

$ php -c php.ini composer [命令]

6. 怎么找到composer需要加载的php.ini文件?

你可以将默认php.ini文件复制过来。这个文件一般保存在/usr/local/lib/php.ini。当然也可以用这个命令来查找:

$ php -i | grep "php.ini"

测试可用的提供商

经测试,以下共享主机服务提供商100%可部署Laravel应用。

GeekStorage的共享服务上也可用,不过要通过.htaccessAddHandler application/x-httpd-php56.php来启用 PHP 5.6。

如果确定其他提供商可用,欢迎添加到此列表。

仍有问题?

如果采用上述步骤还没有解决安装问题,请提出你的详细问题,我会来帮你。

如何贡献

欢迎fork这个项目,也欢迎提交pull request.