2016年12月

PHP项目开发实践总结内部分享大纲

项目部署相关

  • 项目命名: 域名中 . 替换为 _,如: app.domain.com 项目名为 app_domain_com。关于分支,deploy分支用于部署到正式环境,如有测试环境的需要可以添加test分支,如果测试环境对稳定性有需求的话可以开develop分支,如果是多人协作的项目中有周期较长的功能模块需要开发则可以单独新开分支。
  • 所有在上线时需要忽略的文件都写到.gitignore里,这样运维在配置发布系统时也比较方便
  • 如果开启了 opcache,则每次新代码上线之后都需要清空 opcache 缓存(service php-fpm reload 或者通过调用cgi的opcache),否则上线后没有效果。
  • 如果在composer.json中添加了自定义的自动加载项,如使用了git subtree的情况下,每次上线后可能都需要重新 composer dump-autoload 一遍。该问题可复现,但具体出现原因不明
  • 服务器若仅有内网,外网是通过proxy进行访问的情况下需注意代码的行为可能会和预期的不一致(主要curl等操作)
  • 服务器在使用了内网namedserver的情况下,如果 nginx 使用unix socket的方式调用php-fpm的话,可能不生效

性能优化相关

  • php7(php 各版本新特性的分享中提到过 php7 的性能对照)
  • opcache(开启了 opcache 的 php7 才能展现出真正的高性能)
  • composer dump-autoload -o (能一定程度上提升第三方库的加载效率,尤其是在未开启 opcache 的情况下)
  • 项目配置(如主要提供 api 的项目可以关闭 session 以提升性能)
  • redis/memcache缓存(尤其适用于查询接口较多的项目,性能提升明显)

静态资源部署

  • protocol relative url(方便地切换 http 和 https)
  • 版本号(日期时间序列或hash)
  • 静态资源域名采用特定的静态资源域名,防止 cookie 过大对加载时间造成影响
  • 浏览器对相同域名的并发连接数限制,一般浏览器是6个,http2是一个服务器一个连接而不是一个资源一个连接所以对于复杂页面性能提升很大,http2的硬性要求是https

编码风格相关

  • php-cs-fixer用法,已分享
  • phpstorm自带代码风格检查设置,Settings > Editor > Code Style > PHP > Set from...,快捷键(windows Ctrl + Alt + L)

数据库设计相关

  • 数据一致性要求不严格的场景下不要使用外键、unique等,在代码中进行逻辑控制,这一点在快速迭代的项目中尤其适用
  • 联合索引的第一列如果不能将范围缩至六分之一(具体数字记不得了)以内则会全表扫描
  • 数据库字符集utf8mb4加索引时需注意varchar类型的长度,mysql索引长度最多1000字节,varchar类型默认长度255,utf8mb4的情况下最多占用1020字节超出限制,migration运行会报错
  • collate中unicode_ci和general_ci的注意点,查询时的相等判定(1AÀ
  • 表名和字段名无特殊含义或专有名词的情况下建议使用单数形式,如:user、game
  • 所有资源类的数据表都可能会需要如下字段:
    created_at、created_by、updated_at、updated_by,这些字段在yii2的model中可以通过
    TimestampBehavior、BlameableBehavior进行自动控制。
    status字段表示软删除,引用SoftDeleteTrait即可

  • 表示与其他表id字段进行关联的字段建议命名为:表名_id,如:user_id、category_id,代码中对id的命名也建议采用如:\$user_id,$userId 之类的方式避免产生混淆

  • 需要与其他表进行关联的字段添加索引时,两表中的对应字段类型应保持一致

composer相关

  • 使用国内镜像进行加速,http://pkg.phpcomposer.com/
  • composer根目录路径不要有中文(windows环境上),否则会出现一些问题。修改composer默认根目录可以通过设置COMPOSER_HOME实现
  • composer.json中常见配置字段含义和作用讲解,composer.lock文件的作用讲解(minimum-stability、require版本通配符、require-dev、autoload、scripts、extra)

yii2框架相关

  • 何时采用basic模板何时采用advanced模板,在session分离并且数据互通的情况下应采用多应用端的advanced模板结构,若session互通则使用basic模板分模块进行开发
  • Model中rules、behaviors、scenarios作用和相互之间的联系
  • Model中的relations使用
  • Components的编写和使用(https://github.com/takashiki/yii2-ide-helper
  • Controller中responseFormat的使用
  • ActiveQuery中使用->limit(1)->one()来提升性能

设计模式相关

  • 工厂模式,在有完善的依赖注入框架的情况下使用场景较少
  • 单列模式,维护配置文件、数据字典等仍会经常用到
  • 策略模式(框架的缓存实现)
  • 适配器模式(不同游戏的进入游戏加币等)

学习相关

最快的提升方式就是去看别人的优质代码:

https://github.com/trending
https://github.com/ziadoz/awesome-php
http://www.phptherightway.com/
https://github.com/domnikl/DesignPatternsPHP
http://www.digpage.com/
https://github.com/samdark/yii2-cookbook
https://github.com/forecho/awesome-yii2
http://www.yiichina.com/
https://getyii.com/
http://laravelacademy.org/
https://laravel-china.org/
http://www.laruence.com/

PHP基础的提升则要多看官方手册:
http://php.net/

建议多看英文文档,英文文档在即时性、准确性和详细程度上一般都有优势,PHP官方文档也是如此,比如:
http://php.net/manual/en/function.serialize.php
http://php.net/manual/zh/function.serialize.php

目前个人使用的科学上网方案整理,不定期更新

加速器(荐)

地址:http://www.qidian789.com/union/share/?fn=37001

PC下载:http://www.qidian789.com/downfile/?sys=0&fn=37001

安卓下载:http://www.qidian789.com/downfile/?sys=1&fn=37001

有各个平台的客户端,线路也比较丰富,使用比较方便,速度还算快,新用户可免费试用15分钟。


SocketPro(荐)

地址:https://www.socketpro.link/aff/15068

目前也比较推荐这个,使用挺方便的,支持 Windows、安卓、iOS、Mac 等系统,服务器位置也比较丰富,韩国、日本、台湾、香港、新加坡这些都比较快,官网看着也比较舒服,稳定运营两年多了也算比较放心。


MiaoSS

地址:http://miaoaff.com/reg.php?id=9770

目前免费300M流量,每天签到可领流量,速度不错但流量较少,可以备用。也可购买付费服务,也比较便宜。由于其官网经常会被墙,获取最新地址可以向miaowuget@gmail.com发送一封邮件,内容任意。


Lantern

官网地址:http://getlantern.org/

下载地址: https://github.com/getlantern/forum

使用方便而且速度不错,不过好像不一定支持所有的被墙网站,使用的时候要注意需禁用其他的代理插件,如SwitchyProxySharp(SwitchyOmega)等。现在提供付费专业版,邀请好友可增加使用时长,使用邀请码YMSQP3 购买可增加时长。


一枝红杏

地址:http://order.yizhihongxing2017.com/aff.php?aff=1506

由于服务器原因更换了域名,并没有跑路,不过也并不是十分推荐。主要出售 ss 账号,目前官网也都切成了英文,相对来说需要一定基础才会使用,略麻烦些。使用优惠码 `qxmugen` 可以有 8 折优惠。


GreenSS

地址:https://en.greenss.biz/users/aff.php?aff=1616

从前的 GreenVPN 旗下的出售 SS 账号的子站,虽然首页是英文,不过随便点个按钮就会跳转到中文页面。