首页
学习
活动
专区
圈层
工具
发布
社区首页 >专栏 >Laravel 使用笔记

Laravel 使用笔记

作者头像
云游君
发布2021-05-21 10:28:07
发布2021-05-21 10:28:07
1.3K0
举报
文章被收录于专栏:云游的小教程云游的小教程

Laravel 框架使用过程中的一些笔记。

线上部署

相关过程

  1. LNMP 一键安装包
  2. 记 LNMP 一键安装后 Laravel 线上部署的坑

关键步骤

安装 composer
git 部署
  • 安装 git,$ sudo apt install git
  • 创建 ssh-key,$ ssh-keygen -t rsa -C "邮箱",一路回车。
  • $ cat ~/.ssh/id_rsa.pub 复制公钥到 github 上。添加 ssh key。
  • $ cd /home/wwwroot 到放置项目代码的文件夹
  • $ git clone git@github.com:用户名/项目名.git,从 github 获取线上代码。
  • $ cp .env.example .env 对.env 文件并进行配置。(app_key,database,mail 等)
  • $ composer install 安装相关包
  • $ php artisan migrate 安装数据库迁移

FAQ

数据库字符长度过长

参见 Laravel 5.4 migrate 时报错: Specified key was too long error

代码语言:javascript
复制
1071 Specified key was too long; max key length is 767 bytes

MySql 支持的 utf8 编码最大字符长度为 3 字节,如果遇到 4 字节的宽字符就会出现插入异常。三个字节 UTF-8 最大能编码的 Unicode 字符是 0xffff ,即 Unicode 中的基本多文种平面(BMP)。因而包括 Emoji 表情(Emoji 是一种特殊的 Unicode 编码)在内的非基本多文种平面的 Unicode 字符都无法使用 MySql 的 utf8 字符集存储。

这也应该就是 Laravel 5.4 改用 4 字节长度的 utf8mb4 字符编码的原因之一。不过要注意的是,只有 MySql 5.5.3 版本以后才开始支持 utf8mb4 字符编码(查看版本:selection version();)。如果 MySql 版本过低,需要进行版本更新。

解决方案(二选一)
  1. 升级 MySql 版本到 5.5.3 以上。
  2. 手动配置迁移命令 migrate 生成的默认字符串长度,在 app\Providers\AppServiceProders 中调用 Schema::defaultStringLength 方法来实现配置:
代码语言:javascript
复制
use Illuminate\Support\Facades\Schema;

/**
* Bootstrap any application services.
*
* @return void
*/
public function boot()
{
   Schema::defaultStringLength(191);
}

停止维护时间戳

代码语言:javascript
复制
class Xxx extends Model {
  public $timestamps= false;
}

模版插件

Laravel-admin

To Be Continued.

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2017-08-21,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 线上部署
    • 相关过程
    • 关键步骤
      • 安装 composer
      • git 部署
  • FAQ
    • 数据库字符长度过长
      • 解决方案(二选一)
    • 停止维护时间戳
  • 模版插件
    • Laravel-admin
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档